18 #ifndef itkQuadEdgeMeshPolygonCell_h
19 #define itkQuadEdgeMeshPolygonCell_h
38 template <
typename TCellInterface>
54 using typename Superclass::PixelType;
55 using CellType =
typename Superclass::CellType;
56 using typename Superclass::CellAutoPointer;
57 using typename Superclass::CellConstAutoPointer;
58 using typename Superclass::CellRawPointer;
59 using typename Superclass::CellConstRawPointer;
61 using typename Superclass::CoordinateType;
62 using typename Superclass::InterpolationWeightType;
63 using typename Superclass::PointIdentifier;
64 using typename Superclass::CellIdentifier;
65 using typename Superclass::CellFeatureIdentifier;
68 using typename Superclass::PointsContainer;
69 using typename Superclass::UsingCellsContainer;
70 using typename Superclass::ParametricCoordArrayType;
71 using typename Superclass::ShapeFunctionsArrayType;
72 static constexpr
unsigned int PointDimension = Superclass::PointDimension;
73 static constexpr
unsigned int CellDimension = 2;
93 using QEDual =
typename QuadEdgeType::DualType;
122 return (m_EdgeRingEntry);
127 m_EdgeRingEntry = entry;
137 Accept(CellIdentifier cellId, MultiVisitor * mv)
override;
155 return (Self::CellDimension);
159 GetNumberOfPoints()
const override;
162 GetNumberOfBoundaryFeatures(
int dimension)
const override;
165 GetBoundaryFeature(
int dimension, CellFeatureIdentifier cellId, CellAutoPointer & cell)
override;
171 const PointIdentifier numberOfPoints = this->GetNumberOfPoints();
172 auto * newPolygonCell =
new Self(numberOfPoints);
175 cell.TakeOwnership(newPolygonCell);
178 PointIdentifier i = 0;
185 newPolygonCell->SetPointId(i, it.Value()->GetOrigin());
194 SetPointIds(PointIdConstIterator first)
override;
197 SetPointIds(PointIdConstIterator first, PointIdConstIterator last)
override;
200 SetPointId(
int localId, PointIdentifier pId)
override;
202 virtual PointIdentifier
203 GetPointId(
int localId)
const;
210 if (m_PointIds.empty())
212 return (static_cast<PointIdIterator>(
nullptr));
215 return &m_PointIds.front();
222 if (m_PointIds.empty())
224 return (static_cast<PointIdIterator>(
nullptr));
227 return &m_PointIds.back() + 1;
235 if (m_PointIds.empty())
237 return (static_cast<PointIdIterator>(
nullptr));
240 return &m_PointIds.front();
247 if (m_PointIds.empty())
249 return (static_cast<PointIdIterator>(
nullptr));
252 return &m_PointIds.back() + 1;
257 InternalSetPointIds(PointIdInternalConstIterator first);
260 InternalSetPointIds(PointIdInternalConstIterator first, PointIdInternalConstIterator last);
262 virtual PointIdInternalIterator
263 InternalPointIdsBegin();
265 virtual PointIdInternalIterator
266 InternalPointIdsEnd();
268 virtual PointIdInternalConstIterator
269 InternalGetPointIds()
const;
271 virtual PointIdInternalConstIterator
272 InternalPointIdsBegin()
const;
274 virtual PointIdInternalConstIterator
275 InternalPointIdsEnd()
const;
292 m_PointIds.push_back(it.Value()->GetOrigin());
300 CellIdentifier m_Ident{};
314 #ifndef ITK_MANUAL_INSTANTIATION
315 # include "itkQuadEdgeMeshPolygonCell.hxx"