VTK  9.4.20251007
vtkCell.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
27
28#ifndef vtkCell_h
29#define vtkCell_h
30
31#define VTK_CELL_SIZE 512
32#define VTK_TOL 1.e-05 // Tolerance for geometric calculation
33
34#include "vtkCommonDataModelModule.h" // For export macro
35#include "vtkObject.h"
36
37#include "vtkBoundingBox.h" // Needed for IntersectWithCell
38#include "vtkCellType.h" // Needed to define cell types
39#include "vtkDeprecation.h" // For VTK_DEPRECATED_IN_9_4_0
40#include "vtkIdList.h" // Needed for inline methods
41
42VTK_ABI_NAMESPACE_BEGIN
43class vtkCellArray;
44class vtkCellData;
45class vtkDataArray;
46class vtkPointData;
48class vtkPoints;
49
50class VTKCOMMONDATAMODEL_EXPORT vtkCell : public vtkObject
51{
52public:
53 vtkTypeMacro(vtkCell, vtkObject);
54 void PrintSelf(ostream& os, vtkIndent indent) override;
55
60 void Initialize(int npts, const vtkIdType* pts, vtkPoints* p);
61
68 void Initialize(int npts, vtkPoints* p);
69
75 virtual void ShallowCopy(vtkCell* c);
76
81 virtual void DeepCopy(vtkCell* c);
82
86 virtual int GetCellType() = 0;
87
91 virtual int GetCellDimension() = 0;
92
98 virtual int IsLinear() { return 1; }
99
104 virtual int RequiresInitialization() { return 0; }
105 virtual void Initialize() {}
106
112 virtual int IsExplicitCell() { return 0; }
113
119 virtual int RequiresExplicitFaceRepresentation() { return 0; }
120
121 VTK_DEPRECATED_IN_9_4_0("Use SetCellFaces() after casting the cell to vtkPolyhedron.")
122 virtual void SetFaces(vtkIdType* vtkNotUsed(faces)) {}
123 VTK_DEPRECATED_IN_9_4_0("Use GetCellFaces() after casting the cell to vtkPolyhedron.")
124 virtual vtkIdType* GetFaces() { return nullptr; }
125
129 vtkPoints* GetPoints() { return this->Points; }
130
134 vtkIdType GetNumberOfPoints() const { return this->PointIds->GetNumberOfIds(); }
135
139 virtual int GetNumberOfEdges() = 0;
140
144 virtual int GetNumberOfFaces() = 0;
145
149 vtkIdList* GetPointIds() { return this->PointIds; }
150
154 vtkIdType GetPointId(int ptId) VTK_EXPECTS(0 <= ptId && ptId < GetPointIds()->GetNumberOfIds())
155 {
156 return this->PointIds->GetId(ptId);
157 }
158
162 virtual vtkCell* GetEdge(int edgeId) = 0;
163
175 virtual vtkCell* GetFace(int faceId) = 0;
176
184 virtual int CellBoundary(int subId, const double pcoords[3], vtkIdList* pts) = 0;
185
203 virtual int EvaluatePosition(const double x[3], double closestPoint[3], int& subId,
204 double pcoords[3], double& dist2, double weights[]) = 0;
205
211 virtual void EvaluateLocation(
212 int& subId, const double pcoords[3], double x[3], double* weights) = 0;
213
227 virtual void Contour(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
228 vtkCellArray* verts, vtkCellArray* lines, vtkCellArray* polys, vtkPointData* inPd,
229 vtkPointData* outPd, vtkCellData* inCd, vtkIdType cellId, vtkCellData* outCd) = 0;
230
243 virtual void Clip(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
244 vtkCellArray* connectivity, vtkPointData* inPd, vtkPointData* outPd, vtkCellData* inCd,
245 vtkIdType cellId, vtkCellData* outCd, int insideOut) = 0;
246
260 virtual int Inflate(double dist);
261
270 virtual double ComputeBoundingSphere(double center[3]) const;
271
280 virtual int IntersectWithLine(const double p1[3], const double p2[3], double tol, double& t,
281 double x[3], double pcoords[3], int& subId) = 0;
282
284
291 virtual int IntersectWithCell(vtkCell* other, double tol = 0.0);
292 virtual int IntersectWithCell(vtkCell* other, const vtkBoundingBox& boudingBox,
293 const vtkBoundingBox& otherBoundingBox, double tol = 0.0);
295
306 virtual int Triangulate(int index, vtkIdList* ptIds, vtkPoints* pts);
307
318 virtual int TriangulateIds(int index, vtkIdList* ptIds);
319
331 virtual int TriangulateLocalIds(int index, vtkIdList* ptIds) = 0;
332
347 virtual void Derivatives(
348 int subId, const double pcoords[3], const double* values, int dim, double* derivs) = 0;
349
354 void GetBounds(double bounds[6]);
355
361
365 double GetLength2();
366
373 virtual int GetParametricCenter(double pcoords[3]);
374
382 virtual double GetParametricDistance(const double pcoords[3]);
383
391 virtual int IsPrimaryCell() { return 1; }
392
403
409 virtual void InterpolateFunctions(const double vtkNotUsed(pcoords)[3], double* vtkNotUsed(weight))
410 {
411 }
412 virtual void InterpolateDerivs(const double vtkNotUsed(pcoords)[3], double* vtkNotUsed(derivs)) {}
413
414 // left public for quick computational access
417
418protected:
420 ~vtkCell() override;
421
422 double Bounds[6];
423
424private:
425 vtkCell(const vtkCell&) = delete;
426 void operator=(const vtkCell&) = delete;
427};
428
429VTK_ABI_NAMESPACE_END
430#endif
Fast, simple class for representing and operating on 3D bounds.
object to represent cell connectivity
represent and manipulate cell attribute data
Definition vtkCellData.h:32
virtual void SetFaces(vtkIdType *vtkNotUsed(faces))
Definition vtkCell.h:122
virtual int GetNumberOfEdges()=0
Return the number of edges in the cell.
virtual void Derivatives(int subId, const double pcoords[3], const double *values, int dim, double *derivs)=0
Compute derivatives given cell subId and parametric coordinates.
virtual int EvaluatePosition(const double x[3], double closestPoint[3], int &subId, double pcoords[3], double &dist2, double weights[])=0
Given a point x[3] return inside(=1), outside(=0) cell, or (-1) computational problem encountered; ev...
double Bounds[6]
Definition vtkCell.h:422
vtkIdType GetPointId(int ptId)
For cell point i, return the actual point id.
Definition vtkCell.h:154
virtual void Clip(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *connectivity, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd, int insideOut)=0
Cut (or clip) the cell based on the input cellScalars and the specified value.
double GetLength2()
Compute Length squared of cell (i.e., bounding box diagonal squared).
virtual int CellBoundary(int subId, const double pcoords[3], vtkIdList *pts)=0
Given parametric coordinates of a point, return the closest cell boundary, and whether the point is i...
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
virtual void InterpolateFunctions(const double vtkNotUsed(pcoords)[3], double *vtkNotUsed(weight))
Compute the interpolation functions/derivatives (aka shape functions/derivatives) No-ops at this leve...
Definition vtkCell.h:409
virtual int Inflate(double dist)
Inflates the cell.
vtkIdList * GetPointIds()
Return the list of point ids defining the cell.
Definition vtkCell.h:149
virtual int GetCellDimension()=0
Return the topological dimensional of the cell (0,1,2, or 3).
virtual void Contour(double value, vtkDataArray *cellScalars, vtkIncrementalPointLocator *locator, vtkCellArray *verts, vtkCellArray *lines, vtkCellArray *polys, vtkPointData *inPd, vtkPointData *outPd, vtkCellData *inCd, vtkIdType cellId, vtkCellData *outCd)=0
Generate contouring primitives.
virtual int GetNumberOfFaces()=0
Return the number of faces in the cell.
virtual void EvaluateLocation(int &subId, const double pcoords[3], double x[3], double *weights)=0
Determine global coordinate (x[3]) from subId and parametric coordinates.
void GetBounds(double bounds[6])
Compute cell bounding box (xmin,xmax,ymin,ymax,zmin,zmax).
virtual void ShallowCopy(vtkCell *c)
Copy this cell by reference counting the internal data structures.
virtual vtkCell * GetEdge(int edgeId)=0
Return the edge cell from the edgeId of the cell.
virtual int Triangulate(int index, vtkIdList *ptIds, vtkPoints *pts)
Generate simplices of proper dimension.
virtual int IntersectWithLine(const double p1[3], const double p2[3], double tol, double &t, double x[3], double pcoords[3], int &subId)=0
Intersect with a ray.
virtual double ComputeBoundingSphere(double center[3]) const
Computes the bounding sphere of the cell.
virtual int GetCellType()=0
Return the type of cell.
virtual void DeepCopy(vtkCell *c)
Copy this cell by completely copying internal data structures.
virtual int RequiresExplicitFaceRepresentation()
Determine whether the cell requires explicit face representation, and methods for setting and getting...
Definition vtkCell.h:119
virtual vtkIdType * GetFaces()
Definition vtkCell.h:124
virtual int IsPrimaryCell()
Return whether this cell type has a fixed topology or whether the topology varies depending on the da...
Definition vtkCell.h:391
virtual void Initialize()
Definition vtkCell.h:105
virtual int TriangulateLocalIds(int index, vtkIdList *ptIds)=0
Generate simplices of proper dimension.
void Initialize(int npts, vtkPoints *p)
Initialize the cell with point coordinates specified.
virtual int TriangulateIds(int index, vtkIdList *ptIds)
Generate simplices of proper dimension.
virtual double GetParametricDistance(const double pcoords[3])
Return the distance of the parametric coordinate provided to the cell.
virtual int IntersectWithCell(vtkCell *other, const vtkBoundingBox &boudingBox, const vtkBoundingBox &otherBoundingBox, double tol=0.0)
Intersects with an other cell.
vtkPoints * GetPoints()
Get the point coordinates for the cell.
Definition vtkCell.h:129
double * GetBounds()
Compute cell bounding box (xmin,xmax,ymin,ymax,zmin,zmax).
~vtkCell() override
virtual vtkCell * GetFace(int faceId)=0
Return the face cell from the faceId of the cell.
virtual int RequiresInitialization()
Some cells require initialization prior to access.
Definition vtkCell.h:104
vtkPoints * Points
Definition vtkCell.h:415
virtual int IsLinear()
Non-linear cells require special treatment beyond the usual cell type and connectivity list informati...
Definition vtkCell.h:98
void Initialize(int npts, const vtkIdType *pts, vtkPoints *p)
Initialize cell from outside with point ids and point coordinates specified.
vtkIdList * PointIds
Definition vtkCell.h:416
virtual int IntersectWithCell(vtkCell *other, double tol=0.0)
Intersects with an other cell.
virtual int GetParametricCenter(double pcoords[3])
Return center of the cell in parametric coordinates.
virtual double * GetParametricCoords()
Return a contiguous array of parametric coordinates of the points defining this cell.
vtkIdType GetNumberOfPoints() const
Return the number of points in the cell.
Definition vtkCell.h:134
virtual int IsExplicitCell()
Explicit cells require additional representational information beyond the usual cell type and connect...
Definition vtkCell.h:112
virtual void InterpolateDerivs(const double vtkNotUsed(pcoords)[3], double *vtkNotUsed(derivs))
Definition vtkCell.h:412
list of point or cell ids
Definition vtkIdList.h:24
Abstract class in support of both point location and point insertion.
a simple class to control print indentation
Definition vtkIndent.h:29
represent and manipulate point attribute data
represent and manipulate 3D points
Definition vtkPoints.h:30
#define vtkDataArray
#define VTK_DEPRECATED_IN_9_4_0(reason)
int vtkIdType
Definition vtkType.h:315
#define VTK_SIZEHINT(...)
#define VTK_EXPECTS(x)