53 #ifndef OPENMESH_DECIMATER_MODNORMALFLIPPING_HH
54 #define OPENMESH_DECIMATER_MODNORMALFLIPPING_HH
77 template <
typename MeshT>
116 Base::mesh().set_point(_ci.
v0, _ci.
p1);
119 typename Mesh::ConstVertexFaceIter vf_it(Base::mesh(), _ci.
v0);
120 typename Mesh::FaceHandle fh;
121 typename Mesh::Scalar c(1.0);
123 for (; vf_it.is_valid(); ++vf_it)
126 if (fh != _ci.
fl && fh != _ci.
fr)
129 typename Mesh::Normal n2 = Base::mesh().calc_face_normal(fh);
139 Base::mesh().set_point(_ci.
v0, _ci.
p0);
141 return float( (c < min_cos_) ? Base::ILLEGAL_COLLAPSE : Base::LEGAL_COLLAPSE );
146 if (_factor >= 0.0 && _factor <= 1.0) {
150 double max_normal_deviation = (max_deviation_ * 180.0/M_PI) * _factor / this->error_tolerance_factor_;
152 this->error_tolerance_factor_ = _factor;
168 max_deviation_ = _d / 180.0 * M_PI;
169 min_cos_ = cos(max_deviation_);
175 void set_binary(
bool _b) {}
180 double max_deviation_, min_cos_;
188 #endif // OPENACG_MODNORMALFLIPPING_HH defined
Base class for all decimation modules.
Stores information about a halfedge collapse.
Definition: CollapseInfoT.hh:73
void set_max_normal_deviation(double _d)
Set normal deviation.
Definition: ModNormalFlippingT.hh:167
Decimating module to avoid flipping of faces.
Definition: ModNormalFlippingT.hh:78
Base class for all decimation modules.
Definition: ModBaseT.hh:190
double max_normal_deviation() const
get normal deviation
Definition: ModNormalFlippingT.hh:160
Mesh::Point p0
Position of removed vertex.
Definition: CollapseInfoT.hh:92
Add normals to mesh item (vertices/faces)
Definition: Attributes.hh:80
ModNormalFlippingT(MeshT &_mesh)
Constructor.
Definition: ModNormalFlippingT.hh:87
osg::Vec3f::ValueType dot(const osg::Vec3f &_v1, const osg::Vec3f &_v2)
Adapter for osg vector member computing a scalar product.
Definition: VectorAdapter.hh:174
Mesh::VertexHandle v0
Vertex to be removed.
Definition: CollapseInfoT.hh:90
Mesh::Point p1
Positions of remaining vertex.
Definition: CollapseInfoT.hh:93
void set_error_tolerance_factor(double _factor)
set the percentage of maximum normal deviation
Definition: ModNormalFlippingT.hh:145
Mesh::FaceHandle fl
Left face.
Definition: CollapseInfoT.hh:94
float collapse_priority(const CollapseInfo &_ci)
Compute collapse priority due to angular deviation of face normals before and after a collapse...
Definition: ModNormalFlippingT.hh:113
Mesh::FaceHandle fr
Right face.
Definition: CollapseInfoT.hh:95
#define DECIMATING_MODULE(Classname, MeshT, Name)
Convenience macro, to be used in derived modules The macro defines the types.
Definition: ModBaseT.hh:147