IvfVec3d.h

00001 //
00002 // Copyright 1999-2006 by Structural Mechanics, Lund University.
00003 //
00004 // This library is free software; you can redistribute it and/or
00005 // modify it under the terms of the GNU Library General Public
00006 // License as published by the Free Software Foundation; either
00007 // version 2 of the License, or (at your option) any later version.
00008 //
00009 // This library is distributed in the hope that it will be useful,
00010 // but WITHOUT ANY WARRANTY; without even the implied warranty of
00011 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00012 // Library General Public License for more details.
00013 //
00014 // You should have received a copy of the GNU Library General Public
00015 // License along with this library; if not, write to the Free Software
00016 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
00017 // USA.
00018 //
00019 // Please report all bugs and problems to "ivf@byggmek.lth.se".
00020 //
00021 //
00022 // Written by Jonas Lindemann
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         //CIvfVec3d& operator=(CIvfVec3d& a);
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 

Generated on Fri Sep 1 15:36:47 2006 for Interactive Visualisation Framework - Ivf++ by  doxygen 1.4.6-NO