ITK 6.0.0
Insight Toolkit
 
Loading...
Searching...
No Matches
itkGeometricalQuadEdge.h
Go to the documentation of this file.
1/*=========================================================================
2 *
3 * Copyright NumFOCUS
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * https://www.apache.org/licenses/LICENSE-2.0.txt
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 *=========================================================================*/
18#ifndef itkGeometricalQuadEdge_h
19#define itkGeometricalQuadEdge_h
20
21#include "itkQuadEdge.h"
22
23namespace itk
24{
60template <typename TVRef, typename TFRef, typename TPrimalData, typename TDualData, bool PrimalDual = true>
61class ITK_TEMPLATE_EXPORT GeometricalQuadEdge : public QuadEdge
62{
63public:
67 using RawPointer = Self *;
68
75
77 using OriginRefType = TVRef;
78 using DualOriginRefType = TFRef;
79 using PrimalDataType = TPrimalData;
80 using DualDataType = TDualData;
81 // Line Cell Id in Mesh Cell Container
82 // used to go up to LineCell level
83 using LineCellIdentifier = TFRef;
84
85public:
89
108
109public:
114 operator=(const GeometricalQuadEdge &) = default;
117 ~GeometricalQuadEdge() override = default;
118
120 inline void
122 {
123 m_Origin = v;
124 }
125
126 inline void
128 {
129 this->GetSym()->SetOrigin(v);
130 }
131
132 inline void
134 {
135 this->GetRot()->SetOrigin(v);
136 }
137
138 inline void
140 {
141 this->GetInvRot()->SetOrigin(v);
142 }
143
151 bool
152 SetLnextRingWithSameLeftFace(const DualOriginRefType faceGeom, int maxSize = 100);
153
154 inline void
156 {
158 }
159 inline void
161 {
162 this->GetSym()->UnsetOrigin();
163 }
164 inline void
166 {
167 this->GetRot()->UnsetOrigin();
168 }
169 inline void
171 {
172 this->GetInvRot()->UnsetOrigin();
173 }
174
177 // ORIENTATION_NOTE: this definition of GetLeft (or GetRight)
178 // implicitly assumes that the Onext order is counter-clockwise !
179 inline const OriginRefType
180 GetOrigin() const
181 {
182 return (m_Origin);
183 }
184 inline const OriginRefType
186 {
187 return (GetSym()->GetOrigin());
188 }
189 inline const DualOriginRefType
190 GetRight() const
191 {
192 return (GetRot()->GetOrigin());
193 }
194 inline const DualOriginRefType
195 GetLeft() const
196 {
197 return (GetInvRot()->GetOrigin());
198 }
199
201 bool
202 IsOriginSet() const;
203
204 bool
206
207 bool
208 IsRightSet() const;
209
210 bool
211 IsLeftSet() const;
212
215 inline void
217 {
218 m_Data = data;
219 this->SetPrimalData();
220 }
221 inline void
223 {
224 this->GetRot()->SetPrimalData(data);
225 }
226
227 inline void
229 {
230 m_DataSet = true;
231 }
232 inline void
234 {
235 this->GetRot()->SetPrimalData();
236 }
237
238 inline void
240 {
241 m_Data = false;
242 }
243 inline void
245 {
246 this->GetRot()->UnsetPrimalData();
247 }
248
251 inline PrimalDataType
253 {
254 return (m_Data);
255 }
256 inline DualDataType
258 {
259 return (this->GetRot()->GetPrimalData());
260 }
261
264 inline bool
266 {
267 return (m_DataSet);
268 }
269 inline bool
271 {
272 return (this->GetRot()->IsPrimalDataSet());
273 }
274
279 inline bool
281 {
282 return (!(this->IsLeftSet()) && !(this->IsRightSet()));
283 }
284
290 inline bool
292 {
293 return ((this->IsLeftSet() && !this->IsRightSet()) || (!this->IsLeftSet() && this->IsRightSet()));
294 }
295
300 inline bool
302 {
303 return (this->IsLeftSet() && this->IsRightSet());
304 }
305
306 bool
308
309 bool
310 IsLnextSharingSameFace(int maxSize = 100);
311
312 bool
314
315 bool
317
318 bool
320
321 Self *
323
324 bool
326
327 bool
329
332 inline bool
334 {
335 return (this == this->GetOnext());
336 }
337 inline bool
339 {
340 return (this->GetSym()->IsOriginDisconnected());
341 }
342 inline bool
344 {
345 return (this->IsOriginDisconnected() && this->IsDestinationDisconnected());
346 }
347
348 void
350
351 inline void
352 SetIdent(const LineCellIdentifier & User_Value)
353 {
354 this->m_LineCellIdent = User_Value;
355 }
356 inline LineCellIdentifier
358 {
359 return (this->m_LineCellIdent);
360 }
361
362public:
363 // Reserved OriginRefType designated to represent the absence of Origin
365
366protected:
367 OriginRefType m_Origin{}; // Geometrical information
368 PrimalDataType m_Data{}; // User data associated to this edge.
369 bool m_DataSet{ false }; // Indicates if the data is set.
371};
372} // namespace itk
373
374#ifndef ITK_MANUAL_INSTANTIATION
375# include "itkGeometricalQuadEdge.hxx"
376#endif
377
378#endif
const OriginRefType GetOrigin() const
bool IsOriginInternal() const
bool IsInLnextRing(Self *)
Self * GetNextBorderEdgeWithUnsetLeft(Self *edgeTest=nullptr)
void SetRight(const DualOriginRefType v)
itkQEDefineIteratorGeomMethodsMacro(InvRnext)
itkQEDefineIteratorGeomMethodsMacro(InvDnext)
itkQEDefineIteratorGeomMethodsMacro(Rprev)
itkQEDefineIteratorGeomMethodsMacro(Lprev)
itkQEDefineIteratorGeomMethodsMacro(InvOnext)
~GeometricalQuadEdge() override=default
itkQEDefineIteratorGeomMethodsMacro(Lnext)
itkQEDefineIteratorGeomMethodsMacro(Rnext)
void SetDualData(const DualDataType data)
itkQEDefineIteratorGeomMethodsMacro(Onext)
itkQEDefineIteratorGeomMethodsMacro(InvLnext)
const OriginRefType GetDestination() const
bool IsDestinationSet() const
itkQEDefineIteratorGeomMethodsMacro(Dnext)
void SetPrimalData(const PrimalDataType data)
GeometricalQuadEdge(GeometricalQuadEdge &&)=default
void SetDestination(const OriginRefType v)
itkQEDefineIteratorGeomMethodsMacro(Dprev)
bool InsertAfterNextBorderEdgeWithUnsetLeft(Self *isol, Self *hint=nullptr)
bool SetLnextRingWithSameLeftFace(const DualOriginRefType faceGeom, int maxSize=100)
itkQEDefineIteratorGeomMethodsMacro(Oprev)
GeometricalQuadEdge & operator=(GeometricalQuadEdge &&)=default
const DualOriginRefType GetRight() const
bool IsLnextSharingSameFace(int maxSize=100)
bool ReorderOnextRingBeforeAddFace(Self *second)
void SetLeft(const DualOriginRefType v)
const DualOriginRefType GetLeft() const
GeometricalQuadEdge & operator=(const GeometricalQuadEdge &)=default
itkQEAccessorsMacro(Superclass, Self, DualType)
GeometricalQuadEdge(const GeometricalQuadEdge &)=default
void SetIdent(const LineCellIdentifier &User_Value)
void SetOrigin(const OriginRefType v)
GeometricalQuadEdge< TFRef, TVRef, TDualData, TPrimalData, !PrimalDual > DualType
bool IsInOnextRing(Self *)
Non const geometrical iterator.
Self * GetSym()
Self * GetInvRot()
Self * GetRot()
Self * GetOnext()
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....