RayGeom.hh
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027 #ifndef RAYGEOM_HH
00028 #define RAYGEOM_HH
00029
00030 #include "Geom.hh"
00031
00032 namespace gazebo
00033 {
00034 class OgreDynamicLines;
00035
00038
00043
00044
00045
00046
00048 class RayGeom : public Geom
00049 {
00052 public: RayGeom( Body *body );
00053
00055 public: virtual ~RayGeom();
00056
00060 public: void SetPoints(const Vector3 &posStart, const Vector3 &posEnd);
00061
00065 public: void GetRelativePoints(Vector3 &posA, Vector3 &posB);
00066
00070 public: void GetGlobalPoints(Vector3 &posA, Vector3 &posB);
00071
00074 public: void SetLength( double len );
00075
00077 public: double GetLength() const;
00078
00080 public: void Update();
00081
00083 public: void SetRetro( float retro );
00084
00086 public: float GetRetro() const;
00087
00089 public: void SetFiducial( int fid );
00090
00092 public: int GetFiducial() const;
00093
00095 protected: virtual void LoadChild(XMLConfigNode *node);
00096
00099 private: double contactLen;
00100 private: double contactRetro;
00101 private: int contactFiducial;
00102
00103 private: OgreDynamicLines *line;
00104
00106 private: Vector3 relativeStartPos;
00107 private: Vector3 relativeEndPos;
00108
00110 private: Vector3 globalStartPos;
00111 private: Vector3 globalEndPos;
00112
00113
00114 };
00115
00117 }
00118
00119 #endif