GPSDirectionSource.h

Go to the documentation of this file.
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  */

Generated on Wed Feb 28 15:18:49 2007 for NaviTrack by  doxygen 1.4.6