// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen // SPDX-License-Identifier: BSD-3-Clause /** * @class vtkBezierTriangle * @brief A 2D cell that represents an arbitrary order Bezier triangle * * vtkBezierTriangle is a concrete implementation of vtkCell to represent a * 2D triangle using Bezier shape functions of user specified order. * * The number of points in a Bezier cell determines the order over which they * are iterated relative to the parametric coordinate system of the cell. The * first points that are reported are vertices. They appear in the same order in * which they would appear in linear cells. Mid-edge points are reported next. * They are reported in sequence. For two- and three-dimensional (3D) cells, the * following set of points to be reported are face points. Finally, 3D cells * report points interior to their volume. */ #ifndef vtkBezierTriangle_h #define vtkBezierTriangle_h #include "vtkCommonDataModelModule.h" // For export macro #include "vtkHigherOrderTriangle.h" VTK_ABI_NAMESPACE_BEGIN class vtkDoubleArray; class vtkBezierCurve; class vtkTriangle; class vtkDataSet; class VTKCOMMONDATAMODEL_EXPORT vtkBezierTriangle : public vtkHigherOrderTriangle { public: static vtkBezierTriangle* New(); vtkTypeMacro(vtkBezierTriangle, vtkHigherOrderTriangle); void PrintSelf(ostream& os, vtkIndent indent) override; int GetCellType() override { return VTK_BEZIER_TRIANGLE; } vtkCell* GetEdge(int edgeId) override; void SetRationalWeightsFromPointData(vtkPointData* point_data, vtkIdType numPts); void InterpolateFunctions(const double pcoords[3], double* weights) override; void InterpolateDerivs(const double pcoords[3], double* derivs) override; vtkHigherOrderCurve* GetEdgeCell() override; vtkDoubleArray* GetRationalWeights(); protected: vtkBezierTriangle(); ~vtkBezierTriangle() override; vtkNew EdgeCell; vtkNew RationalWeights; private: vtkBezierTriangle(const vtkBezierTriangle&) = delete; void operator=(const vtkBezierTriangle&) = delete; }; VTK_ABI_NAMESPACE_END #endif