Developer Documentation
NormalAttribT_impl.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 #define NORMALATTRIBT_CC
36 
37 #include <set>
38 
39 #include "NormalAttrib.hh"
40 
41 #include "../Core/GeometryKernel.hh"
42 
43 namespace OpenVolumeMesh {
44 
45 template <class GeomKernelT>
46 NormalAttrib<GeomKernelT>::NormalAttrib(GeomKernelT& _kernel) :
47 kernel_(_kernel),
48 v_normals_(_kernel.template request_vertex_property<typename GeomKernelT::PointT>("vertex_normals", typename GeomKernelT::PointT(0.0))),
49 f_normals_(_kernel.template request_face_property<typename GeomKernelT::PointT>("face_normals", typename GeomKernelT::PointT(0.0)))
50 {
51 
52 }
53 
54 template <class GeomKernelT>
55 NormalAttrib<GeomKernelT>::~NormalAttrib() {
56 
57 }
58 
59 template <class GeomKernelT>
61 
62  if(!kernel_.has_face_bottom_up_incidences()) {
63  std::cerr << "Error: update_vertex_normals() needs bottom-up incidences!" << std::endl;
64  return;
65  }
66 
67  // Compute face normals
69 
70  for(const auto &_vh: kernel_.vertices())
71  {
72  compute_vertex_normal(_vh);
73  }
74 }
75 
76 template <class GeomKernelT>
78 
79  if(!kernel_.has_face_bottom_up_incidences()) {
80  std::cerr << "Error: update_normals() needs bottom-up incidences!" << std::endl;
81  return;
82  }
83 
84  for (const auto &_fh: kernel_.faces()) {
85  f_normals_[_fh] = kernel_.normal(kernel_.halfface_handle(_fh, 0));
86  }
87 }
88 
89 template <class GeomKernelT>
91 
92  std::set<HalfFaceHandle> halffaces;
93  for(VertexOHalfEdgeIter voh_it = kernel_.voh_iter(_vh);
94  voh_it.valid(); ++voh_it) {
95 
96  for(HalfEdgeHalfFaceIter hehf_it = kernel_.hehf_iter(*voh_it);
97  hehf_it.valid(); ++hehf_it) {
98  if(kernel_.is_boundary(*hehf_it)) {
99  halffaces.insert(*hehf_it);
100  }
101  }
102  }
103  typename GeomKernelT::PointT normal = typename GeomKernelT::PointT(0.0);
104  for(std::set<HalfFaceHandle>::const_iterator hf_it = halffaces.begin();
105  hf_it != halffaces.end(); ++hf_it) {
106  normal += (*this)[*hf_it];
107  }
108 
109  normal.normalize();
110 
111 }
112 
113 } // Namespace OpenVolumeMesh
void update_vertex_normals()
A simple heuristic to estimate the vertex normals.
void update_face_normals()
Compute face normals.