|  
 
 | General purpose float triple for use as vertices, vectors and normals. 
 
Public Fields
![[more]](icon1.gif) float _v[3] 
Public Methods
![[more]](icon1.gif) Vec3() 
![[more]](icon1.gif) Vec3(float x, float y, float z) 
![[more]](icon1.gif) inline   bool operator == (const Vec3& v) const 
![[more]](icon1.gif) inline   bool operator != (const Vec3& v) const 
![[more]](icon1.gif) inline   bool operator <  (const Vec3& v) const 
![[more]](icon1.gif) inline   float* ptr() 
![[more]](icon1.gif) inline   const float* ptr() const 
![[more]](icon1.gif) inline   void set( float x, float y, float z) 
![[more]](icon1.gif) inline   float& operator [] (int i) 
![[more]](icon1.gif) inline   float operator [] (int i) const 
![[more]](icon1.gif) inline   float& x() 
![[more]](icon1.gif) inline   float& y() 
![[more]](icon1.gif) inline   float& z() 
![[more]](icon1.gif) inline   float x() const 
![[more]](icon1.gif) inline   float y() const 
![[more]](icon1.gif) inline   float z() const 
![[more]](icon1.gif) inline   bool valid() const 
![[more]](icon1.gif) inline   bool isNaN() const 
![[more]](icon1.gif) inline   float operator * (const Vec3& rhs) constdot product
![[more]](icon1.gif) inline   const Vec3 operator ^ (const Vec3& rhs) constcross product
![[more]](icon1.gif) inline   const Vec3 operator * (float rhs) constmultiply by scalar
![[more]](icon1.gif) inline   Vec3& operator *= (float rhs)unary multiply by scalar
![[more]](icon1.gif) inline   const Vec3 operator / (float rhs) constdivide by scalar
![[more]](icon1.gif) inline   Vec3& operator /= (float rhs)unary divide by scalar
![[more]](icon1.gif) inline   const Vec3 operator + (const Vec3& rhs) constbinary vector add
![[more]](icon1.gif) inline   Vec3& operator += (const Vec3& rhs)unary vector add.
![[more]](icon1.gif) inline   const Vec3 operator - (const Vec3& rhs) constbinary vector subtract
![[more]](icon1.gif) inline   Vec3& operator -= (const Vec3& rhs)unary vector subtract
![[more]](icon1.gif) inline   const Vec3 operator - () constnegation operator.
![[more]](icon1.gif) inline   float length() constLength of the vector = sqrt( vec .
![[more]](icon1.gif) inline   float length2() constLength squared of the vector = vec .
![[more]](icon1.gif) inline   float normalize()normalize the vector so that it has length unity returns the previous length of the vector
 
 DocumentationGeneral purpose float triple for use as vertices, vectors and normals.
Provides general maths operations from addition through to cross products.
No support yet added for float * Vec3 - is it necessary?
Need to define a non-member non-friend operator*  etc.
Vec3 * float is okay 
 Vec3()
 
  Vec3(float x, float y, float z)
 
  float _v[3]
 
  inline   bool operator == (const Vec3& v) const
 
  inline   bool operator != (const Vec3& v) const
 
  inline   bool operator <  (const Vec3& v) const
 
  inline   float* ptr()
 
  inline   const float* ptr() const
 
  inline   void set( float x, float y, float z)
 
  inline   float& operator [] (int i)
 
  inline   float operator [] (int i) const
 
  inline   float& x()
 
  inline   float& y()
 
  inline   float& z()
 
  inline   float x() const
 
  inline   float y() const
 
  inline   float z() const
 
  inline   bool valid() const
 
  inline   bool isNaN() const
 
  inline   float operator * (const Vec3& rhs) constdot product
 
 inline   const Vec3 operator ^ (const Vec3& rhs) constcross product
 
 inline   const Vec3 operator * (float rhs) constmultiply by scalar
 
 inline   Vec3& operator *= (float rhs)unary multiply by scalar
 
 inline   const Vec3 operator / (float rhs) constdivide by scalar
 
 inline   Vec3& operator /= (float rhs)unary divide by scalar
 
 inline   const Vec3 operator + (const Vec3& rhs) constbinary vector add
 
 inline   Vec3& operator += (const Vec3& rhs)unary vector add.  Slightly more efficient because no temporary
intermediate object
 
 inline   const Vec3 operator - (const Vec3& rhs) constbinary vector subtract
 
 inline   Vec3& operator -= (const Vec3& rhs)unary vector subtract
 
 inline   const Vec3 operator - () constnegation operator.  Returns the negative of the Vec3
 
 inline   float length() constLength of the vector = sqrt( vec . vec )
 
 inline   float length2() constLength squared of the vector = vec . vec
 
 inline   float normalize()normalize the vector so that it has length unity
returns the previous length of the vector
 
 This class has no child classes.
 Friends:  inline std::ostream& operator << (std::ostream& output, const Vec3& vec)
 Alphabetic index HTML hierarchy of classes or Java 
 This page was generated with the help of DOC++.
 |