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 _SO_MF_VEC3D_
00026 #define _SO_MF_VEC3D_
00027
00028 #include <Inventor/fields/SoSubField.h>
00029 #include <Inventor/SbLinear.h>
00030
00032
00033
00034
00036
00067 class SoMFVec3d : public SoMField {
00068
00069 SO_MFIELD_HEADER(SoMFVec3d, SbVec3d, const SbVec3d &);
00070
00071 SO_MFIELD_SETVALUESPOINTER_HEADER(double);
00072 SO_MFIELD_SETVALUESPOINTER_HEADER(SbVec3d);
00073 SO_FIELD_SUPPORT_MEMOBJ();
00074
00075 public:
00076
00077
00078
00079
00092 void setValues(int start, int num, const double xyz[][3]);
00093 #ifdef _WIN32
00094
00098 void setValues(int start, int num, double xyz[][3]);
00099 #endif
00100
00107 void set1Value(int index, double x, double y, double z);
00108
00115 void set1Value(int index, const double xyz[3]);
00116
00122 void setValue(double x, double y, double z);
00123
00129 void setValue(const double xyz[3]);
00130
00131 private:
00132 static void initClass();
00133 static void exitClass();
00134 virtual void writeBinaryValues(SoOutput*, int , int ) const;
00135 virtual SbBool readBinaryValues( SoInput*, int, int );
00136
00137 private:
00138
00139 virtual void writeBinaryValues(SoOutput *out) const;
00140 virtual SbBool readBinaryValues(SoInput *in, int numToRead);
00141
00142 };
00143
00144 #endif
00145
00146