Fence slice extractor for hexahedron Ijk meshes More...
#include <MeshVizXLM/extractors/MiFenceSliceExtractHexahedronIjk.h>
Public Member Functions | |
virtual | ~MiFenceSliceExtractHexahedronIjk () |
virtual const MeXScalardSetI & | extractScalarSet (const MiScalardSetI &inputSet)=0 |
virtual const MeXScalardSetI & | extractScalarSet (const MiScalardSetIjk &inputSet)=0 |
virtual const MeXVec3dSetI & | extractVec3Set (const MiVec3dSetI &inputSet)=0 |
virtual const MeXVec3dSetI & | extractVec3Set (const MiVec3dSetIjk &inputSet)=0 |
Static Public Member Functions | |
static MiFenceSliceExtractHexahedronIjk * | getNewInstance (const MiVolumeMeshHexahedronIjk &mesh, bool parallel=true, MiTessellator *tessellator=NULL) |
A fence slice is an unstructured surface mesh defined by the intersection of several arbitrary planes (the fences) with a volume mesh. These fences are defined by a polyline and a direction. Each segment of the polyline is extruded along the direction to form a clipped plane slice. Thus, each fence goes through a segment of the polyline. Each plane slice is clipped by the extrusion of the 2 endpoints of each segment in the direction. The extracted fence slice is an unstructured surface.
MoMeshFenceSlice, MiFenceSliceExtractIjk, MiFenceSliceExtractUnstructured
virtual MiFenceSliceExtractHexahedronIjk::~MiFenceSliceExtractHexahedronIjk | ( | ) | [inline, virtual] |
virtual const MeXScalardSetI& MiFenceSliceExtractHexahedronIjk::extractScalarSet | ( | const MiScalardSetIjk & | inputSet | ) | [pure virtual] |
Computes a PER_CELL scalar set on the extracted fences.
Note : The argument i,j,k of the method MiScalardSetIjk::get(i,j,k) refers to the cell (i,j,k). Thus the binding of the inputSet must be PER_CELL. An exception is thrown otherwise.
inputSet | the input scalar set defined on the volume mesh |
Implements MiFenceSliceExtractIjk.
virtual const MeXScalardSetI& MiFenceSliceExtractHexahedronIjk::extractScalarSet | ( | const MiScalardSetI & | inputSet | ) | [pure virtual] |
Computes a PER_NODE scalar set on the extracted fences.
Note : The argument i of the method MiScalardSetI::get(i) refers to the i-th node of the mesh. Thus the binding of the inputSet must be PER_NODE. An exception is thrown otherwise.
inputSet | the input scalar set defined on the volume mesh |
virtual const MeXVec3dSetI& MiFenceSliceExtractHexahedronIjk::extractVec3Set | ( | const MiVec3dSetIjk & | inputSet | ) | [pure virtual] |
Computes a vector set on the extracted fences.
Note : The argument i,j,k of the method MiVec3dSetIjk::get(i,j,k) refers to the cell (i,j,k). Thus the binding of the inputSet must be PER_CELL. An exception is thrown otherwise.
inputSet | the input vec3 set defined on the volume mesh |
Implements MiFenceSliceExtractIjk.
virtual const MeXVec3dSetI& MiFenceSliceExtractHexahedronIjk::extractVec3Set | ( | const MiVec3dSetI & | inputSet | ) | [pure virtual] |
Computes a vector set on the extracted fences.
Note : The argument i of the method MiVec3dSetI::get(i) refers to the i-th node of the mesh. Thus the binding of the inputSet must be PER_NODE. An exception is thrown otherwise.
inputSet | the input vec3 set defined on the volume mesh |
static MiFenceSliceExtractHexahedronIjk* MiFenceSliceExtractHexahedronIjk::getNewInstance | ( | const MiVolumeMeshHexahedronIjk & | mesh, | |
bool | parallel = true , |
|||
MiTessellator * | tessellator = NULL | |||
) | [static] |
Factory method returning a new instance of a class implementing this interface.
mesh | The input mesh | |
parallel | When true, tries to create an extract module using a parallel algorithm to speed up the extraction. | |
tessellator | The tessellator object used for tessellating non linear cells (quadratic,...). |