UltraTrakModule.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 
00069 #ifndef _ULTRATRAKMODULE_H
00070 #define _ULTRATRAKMODULE_H
00071 
00072 #include "../OpenTracker.h"
00073 #include "UltraTrakSource.h"
00074 
00075 #include <ace/SOCK_Dgram.h>
00076 
00077 #include <vector>
00078 
00079 
00080 #ifndef OT_NO_ULTRATRACK_SUPPORT
00081 
00082 
00083 namespace ot {
00084 
00086     struct Station
00087     {
00088         int number;    
00089         Event event;
00090         int modified;
00091         UltraTrakSource * source;
00092 
00093         Station( const int number_, UltraTrakSource * source_ ) :
00094             number( number_ ), modified( 0 ), source( source_ )
00095         {};
00096     };
00097 
00098 
00099     typedef std::vector<Station *> StationVector;
00100 
00102     const int ultraTrakMaxUnits = 16;
00103 
00105     struct UltraTrakStationData
00106     {
00107         char dummy1;
00108         char boardNumber;
00109         char updateFlag;
00110         char stationNumber;
00111 #ifdef ERRORCODE
00112         char errorCode;
00113 #endif
00114         char dummy2;
00115         char position[3][4];
00116         char orientation[4][4];
00117     };
00118         
00120     struct UltraTrakFrameData
00121     {
00122         char header[56];
00123         UltraTrakStationData stationData[ultraTrakMaxUnits];
00124     };
00125 
00126 
00127      
00136     class OPENTRACKER_API UltraTrakModule : public ThreadModule, public NodeFactory
00137     {
00138         // members
00139     protected:    
00140     
00142         StationVector stations;
00144         UltraTrakFrameData buffer;
00146         int port;
00147         int stop;
00148 
00149         int positionMapping[3];
00150         int invertPosition[3];
00151         int orientationMapping[3];
00152         int invertOrientation[3];
00153     
00154         // methods
00155     protected:
00161         static void convertFloatsNToHl(float* floats, float* result, int num);
00164         void run();
00165         int parseVector(const std::string & line, int * val);
00166         void initMappping(int *mapping);
00167         void initInversion(int *inversion);
00168         void calcInversion(int *inversion);
00169         void correctData(std::vector<float> &d, int *mapping, int *inversion);
00170 
00171     public:    
00173         UltraTrakModule();
00174 
00176         virtual ~UltraTrakModule();
00182         virtual void init(StringTable& attributes, ConfigNode * localTree);
00190         virtual Node * createNode( const std::string& name,  StringTable& attributes);        
00194         virtual void start();
00198         virtual void close();    
00204         virtual void pushEvent();             
00205     };
00206         OT_MODULE(UltraTrakModule);
00207 
00208 } // namespace ot
00209 
00210 
00211 #endif // OT_NO_ULTRATRACK_SUPPORT
00212 
00213 
00214 #endif
00215 
00216 /* 
00217  * ------------------------------------------------------------
00218  *   End of UltraTrakModule.h
00219  * ------------------------------------------------------------
00220  *   Automatic Emacs configuration follows.
00221  *   Local Variables:
00222  *   mode:c++
00223  *   c-basic-offset: 4
00224  *   eval: (c-set-offset 'substatement-open 0)
00225  *   eval: (c-set-offset 'case-label '+)
00226  *   eval: (c-set-offset 'statement 'c-lineup-runin-statements)
00227  *   eval: (setq indent-tabs-mode nil)
00228  *   End:
00229  * ------------------------------------------------------------ 
00230  */

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