Developer Documentation
BaseEntities.hh
1 /*===========================================================================*\
2  * *
3  * OpenVolumeMesh *
4  * Copyright (C) 2011 by Computer Graphics Group, RWTH Aachen *
5  * www.openvolumemesh.org *
6  * *
7  *---------------------------------------------------------------------------*
8  * This file is part of OpenVolumeMesh. *
9  * *
10  * OpenVolumeMesh is free software: you can redistribute it and/or modify *
11  * it under the terms of the GNU Lesser General Public License as *
12  * published by the Free Software Foundation, either version 3 of *
13  * the License, or (at your option) any later version with the *
14  * following exceptions: *
15  * *
16  * If other files instantiate templates or use macros *
17  * or inline functions from this file, or you compile this file and *
18  * link it with other files to produce an executable, this file does *
19  * not by itself cause the resulting executable to be covered by the *
20  * GNU Lesser General Public License. This exception does not however *
21  * invalidate any other reasons why the executable file might be *
22  * covered by the GNU Lesser General Public License. *
23  * *
24  * OpenVolumeMesh is distributed in the hope that it will be useful, *
25  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
26  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
27  * GNU Lesser General Public License for more details. *
28  * *
29  * You should have received a copy of the GNU LesserGeneral Public *
30  * License along with OpenVolumeMesh. If not, *
31  * see <http://www.gnu.org/licenses/>. *
32  * *
33 \*===========================================================================*/
34 
35 /*===========================================================================*\
36  * *
37  * $Revision$ *
38  * $Date$ *
39  * $LastChangedBy$ *
40  * *
41 \*===========================================================================*/
42 
43 #ifndef BASEENTITIES_HH_
44 #define BASEENTITIES_HH_
45 
46 #include <vector>
47 
48 #include "OpenVolumeMesh/Config/Export.hh"
49 #include "OpenVolumeMeshHandle.hh"
50 
51 namespace OpenVolumeMesh {
52 
53 class OVM_EXPORT OpenVolumeMeshEdge {
54 friend class TopologyKernel;
55 public:
56  OpenVolumeMeshEdge(const VertexHandle& _fromVertex,
57  const VertexHandle& _toVertex) :
58  fromVertex_(_fromVertex),
59  toVertex_(_toVertex) {
60  }
61 
62  const VertexHandle from_vertex() const {
63  return fromVertex_;
64  }
65  const VertexHandle to_vertex() const {
66  return toVertex_;
67  }
68 
69 protected:
70 
71  void set_from_vertex(const VertexHandle& _vertex) {
72  fromVertex_ = _vertex;
73  }
74  void set_to_vertex(const VertexHandle& _vertex) {
75  toVertex_ = _vertex;
76  }
77 
78 private:
79  VertexHandle fromVertex_;
80  VertexHandle toVertex_;
81 };
82 
83 // Stream operator for edges
84 std::ostream& operator<<(std::ostream& _os, const OpenVolumeMeshEdge& _edge);
85 
86 //***************************************************************************
87 
88 class OVM_EXPORT OpenVolumeMeshFace {
89 friend class TopologyKernel;
90 public:
91  explicit OpenVolumeMeshFace(const std::vector<HalfEdgeHandle>& _halfedges) :
92  halfedges_(_halfedges) {
93  }
94 
95  const std::vector<HalfEdgeHandle>& halfedges() const & {
96  return halfedges_;
97  }
98 
99  const std::vector<HalfEdgeHandle>& halfedges() const && = delete;
100  std::vector<HalfEdgeHandle> halfedges() && {
101  return std::move(halfedges_);
102  }
103 
104 protected:
105 
106  void set_halfedges(const std::vector<HalfEdgeHandle>& _halfedges) {
107  halfedges_ = _halfedges;
108  }
109 
110 private:
111  std::vector<HalfEdgeHandle> halfedges_;
112 };
113 
114 // Stream operator for faces
115 std::ostream& operator<<(std::ostream& _os, const OpenVolumeMeshFace& _face);
116 
117 //***************************************************************************
118 
119 class OVM_EXPORT OpenVolumeMeshCell {
120 friend class TopologyKernel;
121 public:
122  explicit OpenVolumeMeshCell(const std::vector<HalfFaceHandle>& _halffaces) :
123  halffaces_(_halffaces) {
124  }
125 
126  const std::vector<HalfFaceHandle>& halffaces() const & {
127  return halffaces_;
128  }
129 
130  const std::vector<HalfFaceHandle>& halffaces() const && = delete;
131  std::vector<HalfFaceHandle> halffaces() && {
132  return std::move(halffaces_);
133  }
134 
135 protected:
136 
137  void set_halffaces(const std::vector<HalfFaceHandle>& _halffaces) {
138  halffaces_ = _halffaces;
139  }
140 
141 private:
142  std::vector<HalfFaceHandle> halffaces_;
143 };
144 
145 // Stream operator for cells
146 std::ostream& operator<<(std::ostream& _os, const OpenVolumeMeshCell& _cell);
147 
148 } // Namespace OpenVolumeMesh
149 
150 #endif /* BASEENTITIES_HH_ */