53class PoMesh3D :
public PoMesh {
55 SO_KIT_HEADER(PoMesh3D) ;
74 static void initClass() ;
75 static void exitClass() ;
77 void indexedMeshLevelSurfShapeIndices(
PbIndexedMesh3D *mesh,
int surfOrientation=1,
78 const float *per_cell_value=NULL);
80 const float *per_cell_value=NULL) ;
81 void hexahedronMeshLevelSurfShapeIndices(
PbHexahedronMesh3D *mesh,
int surfOrientation=1,
82 const float *percell_value=NULL) ;
83 virtual void addOptQuadrangle(
int num_quad,
int *quad_nodes,
int cell_index);
85 virtual const float *getIsosurfDataSet() {
return NULL; }
86 virtual float getIsosurfValue()
const {
return 0; }
87 virtual int getSurfOrientation() {
return 1; }
89 int addSurfPoint (
int nod_ind1,
int nod_ind2, int32_t &point_index);
90 void computeCrossPointCoord(
int index,
const float *x,
const float *y,
const float *z,
const float *v,
91 int n0,
int n1,
float d0,
float d1);
96 virtual size_t getMemorySize();
97 size_t getHashTableMemorySize();
102 int getNumIsoCells() {
103 return m_numIsoCells;
109 void clearIsoCells() {
117 virtual ~PoMesh3D() ;
120 virtual void basicObjectChange(PbBase *basicObj);
121 virtual void preRebuild();
123 void crossPlaneAndQuadrangle(
const float *x,
const float *y,
const float *z,
const float *v,
124 const int32_t *quad_nodes,
const int32_t *quad_ind,
float xn,
float yn,
float zn,
125 float dist_plane_orig,
SbBool &intersect,int32_t *point_ind);
126 void getParalCartGrid3DCrossContour(PbParalCartesianGrid3D *mesh,
const float *nod_values,
127 float xn,
float yn,
float zn,
float dist_to_origin,
128 SoIndexedLineSet *indexed_line_set, SoCoordinate3 *coordinate);
129 void getRegularGrid3DCrossContour(PbRegularCartesianGrid3D *mesh,
const float *nod_values,
130 float xn,
float yn,
float zn,
float dist_to_origin,
131 SoIndexedLineSet *indexed_line_set, SoCoordinate3 *coordinate);
133 virtual void initOptQuadrangleList();
134 virtual void addLevelSurfOptQuadrangle();
137 void makeCrossContour(
float dist_to_origin,
float xn,
float yn,
float zn,
138 const float *x,
const float *y,
const float *z,
const float *nod_values,
139 SoGroup *local_group);
140 void initSurfPointList();
143 void updateSurfaceShapeBindings(
SbBool strip_set_used=FALSE);
145 void meshLevelSurf(
const PbMesh3D *mesh);
147 void updateLevelSurfTopology(
const float *values,
float &isovalue);
148 void updateLevelSurfCoord(
const float *values,
float isovalue);
149 void updateLevelSurfColors(
const float *values,
float isovalue);
150 void updateLevelSurfTextures();
151 void updateLevelSurfContouring();
152 void updateLevelSurfPointValues(std::vector< float > &point_values);
154 virtual int getIsosurfDataSetId()
const {
return -1; }
155 virtual int getIsosurfDataSetIndex()
const {
return -1; }
156 virtual SbVec3f getOverallNormal()
const {
return SbVec3f(0,0,0); }
158 const PbMesh3D *m_mesh3D;
160 mutable PiMeshSkin *m_skin;
164 mutable int m_numIsoCells;
168 SbBoolVector *m_nodeSign;
170 PbMesh3D *m_mesh3DSet;
171 void checkOrientation(SoMFVec3f *coords, SoMFInt32 *coordIndex, SbVec3f *normal);
185 Tedge_interpol *TTabEdgeInterpol;
186 int TAllocEdgeInterpol;
187 int TNumEdgeInterpol;