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 #ifndef _CIvfVec3d_h_
00026 #define _CIvfVec3d_h_
00027
00028 #include <ivf/ivfconfig.h>
00029 #include <ivfmath/IvfMathBase.h>
00030
00031 IvfSmartPointer(CIvfVec3d);
00032
00041 class IVFMATH_API CIvfVec3d : public CIvfMathBase {
00042 private:
00043 double m_vector[3];
00044 public:
00046 CIvfVec3d();
00047
00049 CIvfVec3d(double vx, double vy, double vz);
00050
00052 CIvfVec3d(CIvfVec3d& v);
00053
00055 virtual ~CIvfVec3d();
00056
00057 IvfClassInfo("CIvfVec3d",CIvfMathBase);
00058
00060 void rotate(CIvfVec3d& axis, double angle);
00061
00063 void normalize();
00064
00066 double length();
00067
00069 void negate();
00070
00071 #ifdef IVF_HAVE_IOSTREAM
00072
00073 void print(std::ostream &out);
00074 #else
00075
00076 void print(ostream &out);
00077 #endif
00078
00080 void setFromPoints(CIvfVec3d& pos, CIvfVec3d& target);
00081
00083 void add(double dx, double dy, double dz);
00084
00086 void getEulerAngles(double &pitch, double &heading);
00087
00089 void setComponents(double vx, double vy, double vz);
00090
00092 void getComponents(double &vx, double &vy, double &vz);
00093
00095 void setComponents(const double *v);
00096
00098 void getComponents(double* v);
00099
00101 double* getComponents();
00102
00104 void setZ(double value);
00105
00107 void setY(double value);
00108
00110 void setX(double value);
00111
00112 CIvfVec3d& operator+=(CIvfVec3d& a);
00113 CIvfVec3d& operator-=(CIvfVec3d& a);
00114
00115 CIvfVec3d& operator=(CIvfVec3d& a);
00116 double operator[](const int idx);
00117
00118 bool operator==(CIvfVec3d& a);
00119 bool operator!=(CIvfVec3d& a);
00120
00121 };
00122
00123 IVFMATH_API CIvfVec3d& operator*(CIvfVec3d& a, CIvfVec3d& b);
00124 IVFMATH_API CIvfVec3d& operator*(CIvfVec3d& a, double b);
00125 IVFMATH_API CIvfVec3d& operator*(double a, CIvfVec3d& b);
00126 IVFMATH_API CIvfVec3d& operator+(CIvfVec3d& a, CIvfVec3d& b);
00127 IVFMATH_API CIvfVec3d& operator-(CIvfVec3d& a, CIvfVec3d& b);
00128
00129 IVFMATH_API CIvfVec3d& ivfGetTempVec3d();
00130
00135 #endif