22#include "ITKQuadEdgeMeshExport.h"
30#define itkQEDebugMacro(x) \
32 std::ostringstream itkmsg; \
33 itkmsg << "Debug: In " __FILE__ ", line " << __LINE__ << '\n' << " (" << this << "): " x << "\n\n"; \
34 OutputWindowDisplayDebugText(itkmsg.str().c_str()); \
36 ITK_MACROEND_NOOP_STATEMENT
37#define itkQEWarningMacro(x) \
39 std::ostringstream itkmsg; \
40 itkmsg << "WARNING: In " __FILE__ ", line " << __LINE__ << '\n' << " (" << this << "): " x << "\n\n"; \
41 OutputWindowDisplayWarningText(itkmsg.str().c_str()); \
43 ITK_MACROEND_NOOP_STATEMENT
56#define itkQEAccessorsMacro(st, pt, dt) \
57 pt * GetOnext() { return (dynamic_cast<pt *>(this->st::GetOnext())); } \
59 dt * GetRot() { return (dynamic_cast<dt *>(this->st::GetRot())); } \
61 pt * GetSym() { return (dynamic_cast<pt *>(this->st::GetSym())); } \
63 pt * GetLnext() { return (dynamic_cast<pt *>(this->st::GetLnext())); } \
65 pt * GetRnext() { return (dynamic_cast<pt *>(this->st::GetRnext())); } \
67 pt * GetDnext() { return (dynamic_cast<pt *>(this->st::GetDnext())); } \
69 pt * GetOprev() { return (dynamic_cast<pt *>(this->st::GetOprev())); } \
71 pt * GetLprev() { return (dynamic_cast<pt *>(this->st::GetLprev())); } \
73 pt * GetRprev() { return (dynamic_cast<pt *>(this->st::GetRprev())); } \
75 pt * GetDprev() { return (dynamic_cast<pt *>(this->st::GetDprev())); } \
77 dt * GetInvRot() { return (dynamic_cast<dt *>(this->st::GetInvRot())); } \
79 pt * GetInvOnext() { return (dynamic_cast<pt *>(this->st::GetInvOnext())); } \
81 pt * GetInvLnext() { return (dynamic_cast<pt *>(this->st::GetInvLnext())); } \
83 pt * GetInvRnext() { return (dynamic_cast<pt *>(this->st::GetInvRnext())); } \
85 pt * GetInvDnext() { return (dynamic_cast<pt *>(this->st::GetInvDnext())); } \
86 const pt * GetOnext() const { return (dynamic_cast<const pt *>(this->st::GetOnext())); } \
88 const dt * GetRot() const { return (dynamic_cast<const dt *>(this->st::GetRot())); } \
90 const pt * GetSym() const { return (dynamic_cast<const pt *>(this->st::GetSym())); } \
92 const pt * GetLnext() const { return (dynamic_cast<const pt *>(this->st::GetLnext())); } \
94 const pt * GetRnext() const { return (dynamic_cast<const pt *>(this->st::GetRnext())); } \
96 const pt * GetDnext() const { return (dynamic_cast<const pt *>(this->st::GetDnext())); } \
98 const pt * GetOprev() const { return (dynamic_cast<const pt *>(this->st::GetOprev())); } \
100 const pt * GetLprev() const { return (dynamic_cast<const pt *>(this->st::GetLprev())); } \
102 const pt * GetRprev() const { return (dynamic_cast<const pt *>(this->st::GetRprev())); } \
104 const pt * GetDprev() const { return (dynamic_cast<const pt *>(this->st::GetDprev())); } \
106 const dt * GetInvRot() const { return (dynamic_cast<const dt *>(this->st::GetInvRot())); } \
108 const pt * GetInvOnext() const { return (dynamic_cast<const pt *>(this->st::GetInvOnext())); } \
110 const pt * GetInvLnext() const { return (dynamic_cast<const pt *>(this->st::GetInvLnext())); } \
112 const pt * GetInvRnext() const { return (dynamic_cast<const pt *>(this->st::GetInvRnext())); } \
114 const pt * GetInvDnext() const { return (dynamic_cast<const pt *>(this->st::GetInvDnext())); } \
116 ITK_MACROEND_NOOP_STATEMENT
259 return (this->
m_Rot->m_Rot);
269 return (this->
m_Rot->m_Rot);
Const iterator for QuadEdgeMesh.
Non const iterator for QuadMesh.
const Self * GetOnext() const
const Self * GetRnext() const
QuadEdge(QuadEdge &&)=default
QuadEdgeMeshIterator< Self > Iterator
void SetOnext(Self *onext)
void Splice(Self *b)
Basic quad-edge topological method.
const Self * GetRot() const
const Self * GetLnext() const
const Self * GetRprev() const
unsigned int GetOrder() const
const Self * GetDprev() const
const Self * GetInvRot() const
const Self * GetInvLnext() const
itkQEDefineIteratorMethodsMacro(Onext)
const Self * GetOprev() const
const Self * GetSym() const
const Self * GetLprev() const
bool IsEdgeInOnextRing(Self *testEdge) const
QuadEdge(const QuadEdge &)=default
QuadEdge & operator=(QuadEdge &&)=default
const Self * GetInvOnext() const
QuadEdge & operator=(const QuadEdge &)=default
const Self * GetDnext() const
const Self * GetInvDnext() const
const Self * GetInvRnext() const
QuadEdgeMeshConstIterator< Self > ConstIterator
bool IsLnextGivenSizeCyclic(const int size) const
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....