The concept HalfedgeDSFace defines the requirements for the local Face type in the HalfedgeDS concept. It is also required in the Face_wrapper<Refs,Traits> member class template of an items class, see the HalfedgeDSItems concept.
A face optionally stores a reference to an incident halfedge that points to the face. A type tag indicates whether the related member functions are supported. Figure 24.3 depicts the relationship between a halfedge and its incident halfedges, vertices, and faces.
For the protection of the integrity of the data structure classes such as CGAL::Polyhedron_3 are allowed to redefine the modifying member functions to be private. In order to make them accessible for the halfedge data structure they must be derived from a base class Base where the modifying member functions are still public. (The protection can be bypassed by the user, but not by accident.)
| |
instantiated HalfedgeDS ( ≡ Refs).
| |
| |
base class that allows modifications.
| |
| |
model of HalfedgeDSVertex.
| |
| |
model of HalfedgeDSHalfedge.
| |
| |
handle to vertex.
| |
| |
handle to halfedge.
| |
| |
handle to face.
| |
| |
| |
| |
| |
CGAL::Tag_true or
CGAL::Tag_false.
|
| |
default constructor.
|
|
|
|
|
| incident halfedge that points to f. |
|
| |
sets incident halfedge to h. |
CGAL::HalfedgeDS_face_base<Refs>
CGAL::HalfedgeDS_face_min_base<Refs>
HalfedgeDS<Traits,Items,Alloc>
HalfedgeDSItems
HalfedgeDSVertex
HalfedgeDSHalfedge