VTK  9.6.20260408
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
106
107#ifndef vtkCell_h
108#define vtkCell_h
109
110#define VTK_CELL_SIZE 512
111#define VTK_TOL 1.e-05 // Tolerance for geometric calculation
112
113#include "vtkCommonDataModelModule.h" // For export macro
114#include "vtkObject.h"
115
116#include "vtkBoundingBox.h" // Needed for IntersectWithCell
117#include "vtkCellType.h" // Needed to define cell types
118#include "vtkIdList.h" // Needed for inline methods
119#include "vtkSmartPointer.h" // Needed for vtkSmartPointer
120
121VTK_ABI_NAMESPACE_BEGIN
122class vtkCellArray;
123class vtkCellData;
124class vtkDataArray;
125class vtkPointData;
127class vtkPoints;
128
129class VTKCOMMONDATAMODEL_EXPORT vtkCell : public vtkObject
130{
131public:
132 vtkTypeMacro(vtkCell, vtkObject);
133 void PrintSelf(ostream& os, vtkIndent indent) override;
134
139 void Initialize(int npts, const vtkIdType* pts, vtkPoints* p);
140
147 void Initialize(int npts, vtkPoints* p);
148
154 virtual void ShallowCopy(vtkCell* c);
155
160 virtual void DeepCopy(vtkCell* c);
161
165 virtual int GetCellType() = 0;
166
170 virtual int GetCellDimension() = 0;
171
177 virtual int IsLinear() VTK_FUTURE_CONST { return 1; }
178
183 virtual int RequiresInitialization() { return 0; }
184 virtual void Initialize() {}
185
191 virtual int IsExplicitCell() VTK_FUTURE_CONST { return 0; }
192
198 virtual int RequiresExplicitFaceRepresentation() VTK_FUTURE_CONST { return 0; }
199
203 vtkPoints* GetPoints() { return this->Points; }
204
208 vtkIdType GetNumberOfPoints() const { return this->PointIds->GetNumberOfIds(); }
209
213 virtual int GetNumberOfEdges() = 0;
214
218 virtual int GetNumberOfFaces() = 0;
219
223 vtkIdList* GetPointIds() { return this->PointIds; }
224
228 vtkIdType GetPointId(int ptId) VTK_EXPECTS(0 <= ptId && ptId < GetPointIds()->GetNumberOfIds())
229 {
230 return this->PointIds->GetId(ptId);
231 }
232
236 virtual vtkCell* GetEdge(int edgeId) = 0;
237
249 virtual vtkCell* GetFace(int faceId) = 0;
250
258 virtual int CellBoundary(int subId, const double pcoords[3], vtkIdList* pts) = 0;
259
277 virtual int EvaluatePosition(const double x[3], double closestPoint[3], int& subId,
278 double pcoords[3], double& dist2, double weights[]) = 0;
279
285 virtual void EvaluateLocation(
286 int& subId, const double pcoords[3], double x[3], double* weights) = 0;
287
301 virtual void Contour(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
302 vtkCellArray* verts, vtkCellArray* lines, vtkCellArray* polys, vtkPointData* inPd,
303 vtkPointData* outPd, vtkCellData* inCd, vtkIdType cellId, vtkCellData* outCd) = 0;
304
317 virtual void Clip(double value, vtkDataArray* cellScalars, vtkIncrementalPointLocator* locator,
318 vtkCellArray* connectivity, vtkPointData* inPd, vtkPointData* outPd, vtkCellData* inCd,
319 vtkIdType cellId, vtkCellData* outCd, int insideOut) = 0;
320
334 virtual int Inflate(double dist);
335
344 virtual double ComputeBoundingSphere(double center[3]) const;
345
354 virtual int IntersectWithLine(const double p1[3], const double p2[3], double tol, double& t,
355 double x[3], double pcoords[3], int& subId) = 0;
356
358
365 virtual int IntersectWithCell(vtkCell* other, double tol = 0.0);
366 virtual int IntersectWithCell(vtkCell* other, const vtkBoundingBox& boudingBox,
367 const vtkBoundingBox& otherBoundingBox, double tol = 0.0);
369
380 virtual int Triangulate(int index, vtkIdList* ptIds, vtkPoints* pts);
381
392 virtual int TriangulateIds(int index, vtkIdList* ptIds);
393
405 virtual int TriangulateLocalIds(int index, vtkIdList* ptIds) = 0;
406
421 virtual void Derivatives(
422 int subId, const double pcoords[3], const double* values, int dim, double* derivs) = 0;
423
428 void GetBounds(double bounds[6]);
429
435
439 double GetLength2();
440
447 virtual int GetParametricCenter(double pcoords[3]);
448
456 virtual double GetParametricDistance(const double pcoords[3]);
457
465 virtual int IsPrimaryCell() VTK_FUTURE_CONST { return 1; }
466
477
483 virtual void InterpolateFunctions(const double vtkNotUsed(pcoords)[3], double* vtkNotUsed(weight))
484 {
485 }
486 virtual void InterpolateDerivs(const double vtkNotUsed(pcoords)[3], double* vtkNotUsed(derivs)) {}
487
488 // left public for quick computational access
491
492protected:
494 ~vtkCell() override;
495
496 double Bounds[6];
497
498private:
499 vtkCell(const vtkCell&) = delete;
500 void operator=(const vtkCell&) = delete;
501};
502
503VTK_ABI_NAMESPACE_END
504#endif
Fast, simple class for representing and operating on 3D bounds.
object to represent cell connectivity
represent and manipulate cell attribute data
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:496
vtkIdType GetPointId(int ptId)
For cell point i, return the actual point id.
Definition vtkCell.h:228
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 int Inflate(double dist)
Inflates the cell.
virtual void InterpolateFunctions(const double pcoords[3], double *weight)
Compute the interpolation functions/derivatives (aka shape functions/derivatives) No-ops at this leve...
Definition vtkCell.h:483
virtual int RequiresExplicitFaceRepresentation() VTK_FUTURE_CONST
Determine whether the cell requires explicit face representation, and methods for setting and getting...
Definition vtkCell.h:198
vtkIdList * GetPointIds()
Return the list of point ids defining the cell.
Definition vtkCell.h:223
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 int IsExplicitCell() VTK_FUTURE_CONST
Explicit cells require additional representational information beyond the usual cell type and connect...
Definition vtkCell.h:191
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 InterpolateDerivs(const double pcoords[3], double *derivs)
Definition vtkCell.h:486
virtual void DeepCopy(vtkCell *c)
Copy this cell by completely copying internal data structures.
virtual int IsPrimaryCell() VTK_FUTURE_CONST
Return whether this cell type has a fixed topology or whether the topology varies depending on the da...
Definition vtkCell.h:465
virtual void Initialize()
Definition vtkCell.h:184
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:203
double * GetBounds()
Compute cell bounding box (xmin,xmax,ymin,ymax,zmin,zmax).
~vtkCell() override
virtual int IsLinear() VTK_FUTURE_CONST
Non-linear cells require special treatment beyond the usual cell type and connectivity list informati...
Definition vtkCell.h:177
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:183
vtkPoints * Points
Definition vtkCell.h:489
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:490
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:208
list of point or cell ids
Definition vtkIdList.h:135
Abstract class in support of both point location and point insertion.
a simple class to control print indentation
Definition vtkIndent.h:108
represent and manipulate point attribute data
represent and manipulate 3D points
Definition vtkPoints.h:140
#define vtkDataArray
int vtkIdType
Definition vtkType.h:363
#define VTK_SIZEHINT(...)
#define VTK_EXPECTS(x)