VTK  9.2.6
vtkGenericCell.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkGenericCell.h
5
6 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7 All rights reserved.
8 See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9
10 This software is distributed WITHOUT ANY WARRANTY; without even
11 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12 PURPOSE. See the above copyright notice for more information.
13
14=========================================================================*/
33#ifndef vtkGenericCell_h
34#define vtkGenericCell_h
35
36#include "vtkCell.h"
37#include "vtkCommonDataModelModule.h" // For export macro
38
39class VTKCOMMONDATAMODEL_EXPORT vtkGenericCell : public vtkCell
40{
41public:
46
47 vtkTypeMacro(vtkGenericCell, vtkCell);
48 void PrintSelf(ostream& os, vtkIndent indent) override;
49
54 void SetPoints(vtkPoints* points);
55
60 void SetPointIds(vtkIdList* pointIds);
61
63
66 void ShallowCopy(vtkCell* c) override;
67 void DeepCopy(vtkCell* c) override;
68 int GetCellType() override;
69 int GetCellDimension() override;
70 int IsLinear() override;
71 int RequiresInitialization() override;
72 void Initialize() override;
74 void SetFaces(vtkIdType* faces) override;
75 vtkIdType* GetFaces() override;
76 int GetNumberOfEdges() override;
77 int GetNumberOfFaces() override;
78 vtkCell* GetEdge(int edgeId) override;
79 vtkCell* GetFace(int faceId) override;
80 int CellBoundary(int subId, const double pcoords[3], vtkIdList* pts) override;
81 int EvaluatePosition(const double x[3], double closestPoint[3], int& subId, double pcoords[3],
82 double& dist2, double weights[]) override;
83 void EvaluateLocation(int& subId, const double pcoords[3], double x[3], double* weights) override;
84 void Contour(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
85 vtkCellArray* verts, vtkCellArray* lines, vtkCellArray* polys, vtkPointData* inPd,
86 vtkPointData* outPd, vtkCellData* inCd, vtkIdType cellId, vtkCellData* outCd) override;
87 void Clip(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
88 vtkCellArray* connectivity, vtkPointData* inPd, vtkPointData* outPd, vtkCellData* inCd,
89 vtkIdType cellId, vtkCellData* outCd, int insideOut) override;
90 int IntersectWithLine(const double p1[3], const double p2[3], double tol, double& t, double x[3],
91 double pcoords[3], int& subId) override;
92 int Triangulate(int index, vtkIdList* ptIds, vtkPoints* pts) override;
94 int subId, const double pcoords[3], const double* values, int dim, double* derivs) override;
95 int GetParametricCenter(double pcoords[3]) override;
96 double* GetParametricCoords() override;
97 int IsPrimaryCell() override;
99
101
105 void InterpolateFunctions(const double pcoords[3], double* weights) override;
106 void InterpolateDerivs(const double pcoords[3], double* derivs) override;
108
116 void SetCellType(int cellType);
117 void SetCellTypeToEmptyCell() { this->SetCellType(VTK_EMPTY_CELL); }
118 void SetCellTypeToVertex() { this->SetCellType(VTK_VERTEX); }
119 void SetCellTypeToPolyVertex() { this->SetCellType(VTK_POLY_VERTEX); }
120 void SetCellTypeToLine() { this->SetCellType(VTK_LINE); }
121 void SetCellTypeToPolyLine() { this->SetCellType(VTK_POLY_LINE); }
122 void SetCellTypeToTriangle() { this->SetCellType(VTK_TRIANGLE); }
123 void SetCellTypeToTriangleStrip() { this->SetCellType(VTK_TRIANGLE_STRIP); }
124 void SetCellTypeToPolygon() { this->SetCellType(VTK_POLYGON); }
125 void SetCellTypeToPixel() { this->SetCellType(VTK_PIXEL); }
126 void SetCellTypeToQuad() { this->SetCellType(VTK_QUAD); }
127 void SetCellTypeToTetra() { this->SetCellType(VTK_TETRA); }
128 void SetCellTypeToVoxel() { this->SetCellType(VTK_VOXEL); }
129 void SetCellTypeToHexahedron() { this->SetCellType(VTK_HEXAHEDRON); }
130 void SetCellTypeToWedge() { this->SetCellType(VTK_WEDGE); }
131 void SetCellTypeToPyramid() { this->SetCellType(VTK_PYRAMID); }
134 void SetCellTypeToPolyhedron() { this->SetCellType(VTK_POLYHEDRON); }
136 void SetCellTypeToQuadraticEdge() { this->SetCellType(VTK_QUADRATIC_EDGE); }
137 void SetCellTypeToCubicLine() { this->SetCellType(VTK_CUBIC_LINE); }
140 void SetCellTypeToQuadraticQuad() { this->SetCellType(VTK_QUADRATIC_QUAD); }
150 {
151 this->SetCellType(VTK_BIQUADRATIC_QUADRATIC_WEDGE);
152 }
156 {
157 this->SetCellType(VTK_BIQUADRATIC_QUADRATIC_HEXAHEDRON);
158 }
161 void SetCellTypeToLagrangeCurve() { this->SetCellType(VTK_LAGRANGE_CURVE); }
164 void SetCellTypeToLagrangeWedge() { this->SetCellType(VTK_LAGRANGE_WEDGE); }
165
168 void SetCellTypeToBezierCurve() { this->SetCellType(VTK_BEZIER_CURVE); }
171 void SetCellTypeToBezierWedge() { this->SetCellType(VTK_BEZIER_WEDGE); }
175 static vtkCell* InstantiateCell(int cellType);
176
177 vtkCell* GetRepresentativeCell() { return this->Cell; }
178
179protected:
181 ~vtkGenericCell() override;
182
185
186private:
187 vtkGenericCell(const vtkGenericCell&) = delete;
188 void operator=(const vtkGenericCell&) = delete;
189};
190
191#endif
object to represent cell connectivity
represent and manipulate cell attribute data
Definition vtkCellData.h:42
abstract class to specify cell behavior
Definition vtkCell.h:61
abstract superclass for arrays of numeric data
provides thread-safe access to cells
void SetCellTypeToLagrangeCurve()
void SetCellTypeToHexahedron()
vtkIdType * GetFaces() override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToQuadraticLinearWedge()
static vtkCell * InstantiateCell(int cellType)
Instantiate a new vtkCell based on it's cell type value.
void EvaluateLocation(int &subId, const double pcoords[3], double x[3], double *weights) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToLagrangeWedge()
void Initialize() override
See the vtkCell API for descriptions of these methods.
vtkCell * GetFace(int faceId) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToQuadraticWedge()
void SetCellTypeToQuadraticPolygon()
int CellBoundary(int subId, const double pcoords[3], vtkIdList *pts) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToPyramid()
void SetCellTypeToQuadraticTetra()
void SetCellTypeToTriangleStrip()
void SetCellTypeToPixel()
int RequiresInitialization() override
See the vtkCell API for descriptions of these methods.
vtkCell * GetRepresentativeCell()
int EvaluatePosition(const double x[3], double closestPoint[3], int &subId, double pcoords[3], double &dist2, double weights[]) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToQuadraticQuad()
void SetCellTypeToQuadraticLinearQuad()
int GetParametricCenter(double pcoords[3]) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToBezierWedge()
void SetCellTypeToTetra()
~vtkGenericCell() override
void Clip(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *connectivity, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd, int insideOut) override
See the vtkCell API for descriptions of these methods.
static vtkGenericCell * New()
Create handle to any type of cell; by default a vtkEmptyCell.
void SetCellTypeToLagrangeTetra()
void Derivatives(int subId, const double pcoords[3], const double *values, int dim, double *derivs) override
See the vtkCell API for descriptions of these methods.
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
See the vtkCell API for descriptions of these methods.
void SetCellTypeToPolyhedron()
void InterpolateDerivs(const double pcoords[3], double *derivs) override
Compute the interpolation functions/derivatives (aka shape functions/derivatives)
void SetCellTypeToBezierTetra()
int IsPrimaryCell() override
See the vtkCell API for descriptions of these methods.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
int IsLinear() override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToQuadraticHexahedron()
void SetCellTypeToVoxel()
void SetPoints(vtkPoints *points)
Set the points object to use for this cell.
void SetFaces(vtkIdType *faces) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToTriQuadraticHexahedron()
int IntersectWithLine(const double p1[3], const double p2[3], double tol, double &t, double x[3], double pcoords[3], int &subId) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToBiQuadraticQuadraticHexahedron()
void SetCellTypeToBiQuadraticQuad()
void SetCellTypeToCubicLine()
int RequiresExplicitFaceRepresentation() override
See the vtkCell API for descriptions of these methods.
double * GetParametricCoords() override
See the vtkCell API for descriptions of these methods.
int GetNumberOfEdges() override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToConvexPointSet()
int GetCellDimension() override
See the vtkCell API for descriptions of these methods.
void DeepCopy(vtkCell *c) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToVertex()
void SetCellTypeToBezierCurve()
int GetNumberOfFaces() override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToLagrangeTriangle()
void SetCellTypeToWedge()
void SetCellType(int cellType)
This method is used to support the vtkDataSet::GetCell(vtkGenericCell *) method.
int Triangulate(int index, vtkIdList *ptIds, vtkPoints *pts) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToTriangle()
void SetCellTypeToQuadraticPyramid()
void SetCellTypeToQuadraticEdge()
int GetCellType() override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToBiQuadraticQuadraticWedge()
void SetCellTypeToBiQuadraticTriangle()
void SetCellTypeToPolyLine()
void SetCellTypeToPentagonalPrism()
void SetCellTypeToPolygon()
void SetCellTypeToBezierQuadrilateral()
void SetCellTypeToLagrangeQuadrilateral()
void SetCellTypeToBezierTriangle()
void InterpolateFunctions(const double pcoords[3], double *weights) override
Compute the interpolation functions/derivatives (aka shape functions/derivatives)
vtkCell * GetEdge(int edgeId) override
See the vtkCell API for descriptions of these methods.
void SetCellTypeToHexagonalPrism()
void SetCellTypeToBezierHexahedron()
void SetCellTypeToEmptyCell()
void SetCellTypeToLagrangeHexahedron()
void SetCellTypeToPolyVertex()
void ShallowCopy(vtkCell *c) override
See the vtkCell API for descriptions of these methods.
void SetPointIds(vtkIdList *pointIds)
Set the point ids to use for this cell.
void SetCellTypeToTriQuadraticPyramid()
void SetCellTypeToQuadraticTriangle()
list of point or cell ids
Definition vtkIdList.h:34
Abstract class in support of both point location and point insertion.
a simple class to control print indentation
Definition vtkIndent.h:40
represent and manipulate point attribute data
represent and manipulate 3D points
Definition vtkPoints.h:40
@ VTK_VOXEL
Definition vtkCellType.h:57
@ VTK_QUADRATIC_HEXAHEDRON
Definition vtkCellType.h:70
@ VTK_TRIANGLE_STRIP
Definition vtkCellType.h:52
@ VTK_BIQUADRATIC_QUADRATIC_HEXAHEDRON
Definition vtkCellType.h:79
@ VTK_NUMBER_OF_CELL_TYPES
@ VTK_LAGRANGE_CURVE
@ VTK_PYRAMID
Definition vtkCellType.h:60
@ VTK_PIXEL
Definition vtkCellType.h:54
@ VTK_QUADRATIC_WEDGE
Definition vtkCellType.h:71
@ VTK_BEZIER_WEDGE
@ VTK_BIQUADRATIC_QUAD
Definition vtkCellType.h:73
@ VTK_LAGRANGE_QUADRILATERAL
@ VTK_POLY_LINE
Definition vtkCellType.h:50
@ VTK_TRIQUADRATIC_PYRAMID
Definition vtkCellType.h:75
@ VTK_TRIANGLE
Definition vtkCellType.h:51
@ VTK_BEZIER_TRIANGLE
@ VTK_POLYGON
Definition vtkCellType.h:53
@ VTK_EMPTY_CELL
Definition vtkCellType.h:46
@ VTK_QUADRATIC_PYRAMID
Definition vtkCellType.h:72
@ VTK_POLYHEDRON
Definition vtkCellType.h:89
@ VTK_TRIQUADRATIC_HEXAHEDRON
Definition vtkCellType.h:74
@ VTK_TETRA
Definition vtkCellType.h:56
@ VTK_LINE
Definition vtkCellType.h:49
@ VTK_CONVEX_POINT_SET
Definition vtkCellType.h:86
@ VTK_BEZIER_HEXAHEDRON
@ VTK_LAGRANGE_WEDGE
@ VTK_LAGRANGE_HEXAHEDRON
@ VTK_PENTAGONAL_PRISM
Definition vtkCellType.h:61
@ VTK_QUADRATIC_QUAD
Definition vtkCellType.h:67
@ VTK_WEDGE
Definition vtkCellType.h:59
@ VTK_LAGRANGE_TETRAHEDRON
@ VTK_BEZIER_CURVE
@ VTK_HEXAGONAL_PRISM
Definition vtkCellType.h:62
@ VTK_BEZIER_QUADRILATERAL
@ VTK_QUADRATIC_LINEAR_WEDGE
Definition vtkCellType.h:77
@ VTK_HEXAHEDRON
Definition vtkCellType.h:58
@ VTK_CUBIC_LINE
Definition vtkCellType.h:83
@ VTK_LAGRANGE_TRIANGLE
@ VTK_QUADRATIC_POLYGON
Definition vtkCellType.h:68
@ VTK_QUAD
Definition vtkCellType.h:55
@ VTK_QUADRATIC_TRIANGLE
Definition vtkCellType.h:66
@ VTK_QUADRATIC_EDGE
Definition vtkCellType.h:65
@ VTK_QUADRATIC_TETRA
Definition vtkCellType.h:69
@ VTK_BEZIER_TETRAHEDRON
@ VTK_VERTEX
Definition vtkCellType.h:47
@ VTK_POLY_VERTEX
Definition vtkCellType.h:48
@ VTK_QUADRATIC_LINEAR_QUAD
Definition vtkCellType.h:76
@ VTK_BIQUADRATIC_QUADRATIC_WEDGE
Definition vtkCellType.h:78
@ VTK_BIQUADRATIC_TRIANGLE
Definition vtkCellType.h:80
int vtkIdType
Definition vtkType.h:332