Open Inventor Release 2024.2.2
 
Loading...
Searching...
No Matches
MiFenceSliceExtractIjk Class Referenceabstract

MeshViz Fence slice extractor for structured volume meshes More...

#include <MeshVizXLM/extractors/MiFenceSliceExtractIjk.h>

+ Inheritance diagram for MiFenceSliceExtractIjk:

Public Member Functions

virtual ~MiFenceSliceExtractIjk ()
 
virtual const MeXSurfaceMeshUnstructuredextract (const MbVec3d &direction, const std::vector< MbVec3d > &polyline, const MiCellFilterIjk *cellFilter=NULL)=0
 Builds the topology and geometry of a fence slice intersecting the volume mesh.
 
virtual const MeXScalardSetIextractScalarSet (const MiScalardSetIjk &inputSet)=0
 Extracts a scalar set from the volume mesh.
 
virtual const MeXVec3dSetIextractVec3Set (const MiVec3dSetIjk &inputSet)=0
 Extracts a vector set from the volume mesh.
 
virtual const MeXSurfaceMeshUnstructuredgetExtract () const =0
 Returns the result of the extraction as a mesh.
 
- Public Member Functions inherited from MiBaseExtractor
virtual ~MiBaseExtractor ()
 
virtual void setExtractorCallback (MiExtractorCallback *extractorCallback)=0
 Set the user defined extractor callback which will be called before each extraction, during each extraction and after each extraction.
 
virtual SoDEPRECATED void setExtractorCallback (MiExtractorCallback &extractorCallback)
 

Static Public Member Functions

static MiFenceSliceExtractIjkgetNewInstance (const MiVolumeMeshRegular &mesh, bool parallel=true, MiTessellator *tessellator=NULL)
 Factory method returning a new instance of a class implementing this interface.
 
static MiFenceSliceExtractIjkgetNewInstance (const MiVolumeMeshRectilinear &mesh, bool parallel=true, MiTessellator *tessellator=NULL)
 
static MiFenceSliceExtractIjkgetNewInstance (const MiVolumeMeshCurvilinear &mesh, bool parallel=true, MiTessellator *tessellator=NULL)
 
static MiFenceSliceExtractIjkgetNewInstance (const MiVolumeMeshVertexHexahedronIjk &mesh, bool parallel=true, MiTessellator *tessellator=NULL)
 

Detailed Description

MeshViz Fence slice extractor for structured volume meshes

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.

SEE ALSO

MoMeshFenceSlice, MiFenceSliceExtractUnstructured, MiFenceSliceExtractHexahedronIjk

Definition at line 53 of file MiFenceSliceExtractIjk.h.

Constructor & Destructor Documentation

◆ ~MiFenceSliceExtractIjk()

virtual MiFenceSliceExtractIjk::~MiFenceSliceExtractIjk ( )
inlinevirtual

Definition at line 56 of file MiFenceSliceExtractIjk.h.

Member Function Documentation

◆ extract()

virtual const MeXSurfaceMeshUnstructured & MiFenceSliceExtractIjk::extract ( const MbVec3d direction,
const std::vector< MbVec3d > &  polyline,
const MiCellFilterIjk cellFilter = NULL 
)
pure virtual

Builds the topology and geometry of a fence slice intersecting the volume mesh.

Returns
the fence slice extracted as an unstructured surface mesh.
Parameters
directionvector defining the direction of the fences
polylineset of points defining the position of the fences
cellFilterThe cell filter object.
Returns
An unstructured surface mesh representing the fence slice

◆ extractScalarSet()

virtual const MeXScalardSetI & MiFenceSliceExtractIjk::extractScalarSet ( const MiScalardSetIjk inputSet)
pure virtual

Extracts a scalar set from the volume mesh.

The scalars are mapped onto the current extracted fence slice.

Parameters
inputSetthe input scalar set defined on the volume mesh
Returns
the output scalar set defined on the latest extracted mesh

Implemented in MiFenceSliceExtractHexahedronIjk.

◆ extractVec3Set()

virtual const MeXVec3dSetI & MiFenceSliceExtractIjk::extractVec3Set ( const MiVec3dSetIjk inputSet)
pure virtual

Extracts a vector set from the volume mesh.

The vectors are mapped onto the current extracted fence slice.

Parameters
inputSetthe input vector set defined on the volume mesh
Returns
the output vector set defined on the latest extracted mesh

Implemented in MiFenceSliceExtractHexahedronIjk.

◆ getExtract()

virtual const MeXSurfaceMeshUnstructured & MiFenceSliceExtractIjk::getExtract ( ) const
pure virtual

Returns the result of the extraction as a mesh.

◆ getNewInstance() [1/4]

static MiFenceSliceExtractIjk * MiFenceSliceExtractIjk::getNewInstance ( const MiVolumeMeshCurvilinear mesh,
bool  parallel = true,
MiTessellator tessellator = NULL 
)
static

◆ getNewInstance() [2/4]

static MiFenceSliceExtractIjk * MiFenceSliceExtractIjk::getNewInstance ( const MiVolumeMeshRectilinear mesh,
bool  parallel = true,
MiTessellator tessellator = NULL 
)
static

◆ getNewInstance() [3/4]

static MiFenceSliceExtractIjk * MiFenceSliceExtractIjk::getNewInstance ( const MiVolumeMeshRegular mesh,
bool  parallel = true,
MiTessellator tessellator = NULL 
)
static

Factory method returning a new instance of a class implementing this interface.

Parameters
meshThe input mesh
parallelWhen true, tries to create an extract module using a parallel algorithm to speed up the extraction.
tessellatorThe tessellator object used for tessellating non linear cells (quadratic,...).
Note
Only some of the extraction algorithms have a parallel implementation.

◆ getNewInstance() [4/4]

static MiFenceSliceExtractIjk * MiFenceSliceExtractIjk::getNewInstance ( const MiVolumeMeshVertexHexahedronIjk mesh,
bool  parallel = true,
MiTessellator tessellator = NULL 
)
static

The documentation for this class was generated from the following file: