00001 /* ======================================================================== 00002 * Copyright (c) 2006, 00003 * Institute for Computer Graphics and Vision 00004 * Graz University of Technology 00005 * All rights reserved. 00006 * 00007 * Redistribution and use in source and binary forms, with or without 00008 * modification, are permitted provided that the following conditions are 00009 * met: 00010 * 00011 * Redistributions of source code must retain the above copyright notice, 00012 * this list of conditions and the following disclaimer. 00013 * 00014 * Redistributions in binary form must reproduce the above copyright 00015 * notice, this list of conditions and the following disclaimer in the 00016 * documentation and/or other materials provided with the distribution. 00017 * 00018 * Neither the name of the Graz University of Technology nor the names of 00019 * its contributors may be used to endorse or promote products derived from 00020 * this software without specific prior written permission. 00021 * 00022 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS 00023 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 00024 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A 00025 * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER 00026 * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 00027 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 00028 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 00029 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 00030 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING 00031 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 00032 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 00033 * ======================================================================== 00034 * PROJECT: OpenTracker 00035 * ======================================================================== */ 00042 /* ======================================================================= */ 00043 00059 #ifndef _GPSDIRECTIONSOURCE_H 00060 #define _GPSDIRECTIONSOURCE_H 00061 00062 #include "../OpenTracker.h" 00063 #include "GPSDriver.h" 00064 00065 00066 #ifndef OT_NO_GPS_SUPPORT 00067 00068 00075 namespace ot { 00076 00077 class OPENTRACKER_API GPSDirectionSource : public Node, public GPSListener 00078 { 00079 public: 00080 00082 Event event; 00084 Event buffer; 00085 00089 virtual int isEventGenerator() 00090 { 00091 return 1; 00092 } 00093 00094 virtual void newData( const GPResult * point, const char * line, void * userData ); 00095 00096 protected: 00098 GPSDirectionSource() {}; 00099 00100 friend class GPSModule; 00101 }; 00102 00103 inline void GPSDirectionSource::newData( const GPResult * res, const char * line, void * userData ) 00104 { 00105 ACE_ASSERT( userData != NULL ); 00106 if( res->type == GPResult::GPVTG){ 00107 GPVTG * point = (GPVTG *) res; 00108 GPSModule * module = (GPSModule *)userData; 00109 if( !module->driver->hasFix() ) 00110 return; 00111 module->lock(); 00112 buffer.timeStamp(); 00113 // klm/h = 3.6 * m/s, 1/3.6 = 0.27777777777777777777777777777778 00114 buffer.getPosition()[0] = (float)(point->speedKlm * 0.27777777777777777777777777777778); 00115 float temp[4]; 00116 temp[0] = 0; 00117 temp[1] = 1; 00118 temp[2] = 0; 00119 temp[3] = (float)(point->trueCourse * MathUtils::GradToRad); 00120 MathUtils::axisAngleToQuaternion( copyA2V(temp, 4), buffer.getOrientation() ); 00121 buffer.getConfidence() = (float)(1 / module->driver->getHdop()); 00122 module->unlock(); 00123 } 00124 } 00125 00126 } // namespace ot 00127 00128 00129 #endif // OT_NO_GPS_SUPPORT 00130 00131 00132 #endif // !defined(_GPSDIRECTIONSOURCE_H) 00133 00134 /* 00135 * ------------------------------------------------------------ 00136 * End of GPSDirectionSource.h 00137 * ------------------------------------------------------------ 00138 * Automatic Emacs configuration follows. 00139 * Local Variables: 00140 * mode:c++ 00141 * c-basic-offset: 4 00142 * eval: (c-set-offset 'substatement-open 0) 00143 * eval: (c-set-offset 'case-label '+) 00144 * eval: (c-set-offset 'statement 'c-lineup-runin-statements) 00145 * eval: (setq indent-tabs-mode nil) 00146 * End: 00147 * ------------------------------------------------------------ 00148 */
1.4.6