30 #ifndef vtkConvexPointSet_h
31 #define vtkConvexPointSet_h
34 #include "vtkCommonDataModelModule.h"
61 vtkWarningMacro(<<
"vtkConvexPointSet::GetEdgePoints Not Implemented");
64 VTK_LEGACY(
void GetEdgePoints(
int vtkNotUsed(edgeId),
int*& vtkNotUsed(pts))
override {
65 vtkWarningMacro(<<
"vtkConvexPointSet::GetEdgePoints Not Implemented. "
66 <<
"Also note that this signature is deprecated. "
67 <<
"Please use GetEdgePoints(vtkIdType, const vtkIdType*& instead");
71 vtkWarningMacro(<<
"vtkConvexPointSet::GetFacePoints Not Implemented");
75 VTK_LEGACY(
void GetFacePoints(
int vtkNotUsed(faceId),
int*& vtkNotUsed(pts))
override {
76 vtkWarningMacro(<<
"vtkConvexPointSet::GetFacePoints Not Implemented. "
77 <<
"Also note that this signature is deprecated. "
78 <<
"Please use GetFacePoints(vtkIdType, const vtkIdType*& instead");
83 vtkWarningMacro(<<
"vtkConvexPointSet::GetEdgeToAdjacentFaces Not Implemented");
88 vtkWarningMacro(<<
"vtkConvexPointSet::GetFaceToAdjacentFaces Not Implemented");
94 vtkWarningMacro(<<
"vtkConvexPointSet::GetPointToIncidentEdges Not Implemented");
100 vtkWarningMacro(<<
"vtkConvexPointSet::GetPointToIncidentFaces Not Implemented");
106 vtkWarningMacro(<<
"vtkConvexPointSet::GetPointToOneRingPoints Not Implemented");
111 vtkWarningMacro(<<
"vtkConvexPointSet::GetCentroid Not Implemented");
171 int EvaluatePosition(
const double x[3],
double closestPoint[3],
int& subId,
double pcoords[3],
172 double& dist2,
double weights[])
override;
177 void EvaluateLocation(
int& subId,
const double pcoords[3],
double x[3],
double* weights)
override;
183 int IntersectWithLine(
const double p1[3],
const double p2[3],
double tol,
double& t,
double x[3],
184 double pcoords[3],
int& subId)
override;
196 int subId,
const double pcoords[3],
const double* values,
int dim,
double* derivs)
override;
246 pcoords[0] = pcoords[1] = pcoords[2] = 0.5;
abstract class to specify 3D cell interface
virtual vtkIdType GetFacePoints(vtkIdType faceId, const vtkIdType *&pts)=0
Get the list of vertices that define a face.
virtual void GetEdgePoints(vtkIdType edgeId, const vtkIdType *&pts)=0
Get the pair of vertices that define an edge.
object to represent cell connectivity
represent and manipulate cell attribute data
abstract class to specify cell behavior
virtual int GetParametricCenter(double pcoords[3])
Return center of the cell in parametric coordinates.
a 3D cell defined by a set of convex points
int Triangulate(int index, vtkIdList *ptIds, vtkPoints *pts) override
Triangulate using methods of vtkOrderedTriangulator.
vtkDoubleArray * ParametricCoords
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
bool GetCentroid(double vtkNotUsed(centroid)[3]) const override
int GetNumberOfEdges() override
A convex point set has no explicit cell edge or faces; however implicitly (after triangulation) it do...
int RequiresInitialization() override
This cell requires that it be initialized prior to access.
vtkDoubleArray * TetraScalars
void Contour(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *verts, vtkCellArray *lines, vtkCellArray *polys, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd) override
Satisfy the vtkCell API.
int CellBoundary(int subId, const double pcoords[3], vtkIdList *pts) override
Returns the set of points forming a face of the triangulation of these points that are on the boundar...
void Clip(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *connectivity, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd, int insideOut) override
Satisfy the vtkCell API.
vtkIdType GetPointToIncidentEdges(vtkIdType vtkNotUsed(pointId), const vtkIdType *&vtkNotUsed(edgeIds)) override
vtkIdType GetFacePoints(vtkIdType vtkNotUsed(faceId), const vtkIdType *&vtkNotUsed(pts)) override
~vtkConvexPointSet() override
void GetEdgePoints(vtkIdType vtkNotUsed(edgeId), const vtkIdType *&vtkNotUsed(pts)) override
See vtkCell3D API for description of these methods.
void Initialize() override
int IntersectWithLine(const double p1[3], const double p2[3], double tol, double &t, double x[3], double pcoords[3], int &subId) override
Triangulates the cells and then intersects them to determine the intersection point.
vtkCell * GetFace(int faceId) override
Return the face cell from the faceId of the cell.
double * GetParametricCoords() override
See vtkCell3D API for description of this method.
void InterpolateDerivs(const double pcoords[3], double *derivs) override
vtkCellArray * BoundaryTris
int EvaluatePosition(const double x[3], double closestPoint[3], int &subId, double pcoords[3], double &dist2, double weights[]) override
Satisfy the vtkCell API.
int GetParametricCenter(double pcoords[3]) override
Return the center of the cell in parametric coordinates.
vtkIdType GetFaceToAdjacentFaces(vtkIdType vtkNotUsed(faceId), const vtkIdType *&vtkNotUsed(faceIds)) override
static vtkConvexPointSet * New()
void GetEdgeToAdjacentFaces(vtkIdType vtkNotUsed(edgeId), const vtkIdType *&vtkNotUsed(pts)) override
int IsPrimaryCell() override
A convex point set is triangulated prior to any operations on it so it is not a primary cell,...
int GetCellType() override
See the vtkCell API for descriptions of these methods.
int GetNumberOfFaces() override
Return the number of faces in the cell.
void Derivatives(int subId, const double pcoords[3], const double *values, int dim, double *derivs) override
Computes derivatives by triangulating and from subId and pcoords, evaluating derivatives on the resul...
void InterpolateFunctions(const double pcoords[3], double *sf) override
Compute the interpolation functions/derivatives (aka shape functions/derivatives)
vtkIdType GetPointToIncidentFaces(vtkIdType vtkNotUsed(pointId), const vtkIdType *&vtkNotUsed(faceIds)) override
void EvaluateLocation(int &subId, const double pcoords[3], double x[3], double *weights) override
The inverse of EvaluatePosition.
virtual int HasFixedTopology()
See vtkCell3D API for description of this method.
vtkCell * GetEdge(int) override
Return the edge cell from the edgeId of the cell.
vtkIdType GetPointToOneRingPoints(vtkIdType vtkNotUsed(pointId), const vtkIdType *&vtkNotUsed(pts)) override
abstract superclass for arrays of numeric data
dynamic, self-adjusting array of double
list of point or cell ids
Abstract class in support of both point location and point insertion.
a simple class to control print indentation
represent and manipulate point attribute data
represent and manipulate 3D points
a 3D cell that represents a tetrahedron
a cell that represents a triangle
dataset represents arbitrary combinations of all possible cell types