51#define OPENMESH_DECIMATER_MODEDGELENGTHT_C
67 Base(_mesh, _is_binary), mesh_(Base::mesh()) {
75 typename Mesh::Scalar sqr_length = sqrnorm(_ci.p0 - _ci.p1);
77 return ( (sqr_length <= sqr_edge_length_) ? sqr_length : float(Base::ILLEGAL_COLLAPSE));
84 if (_factor >= 0.0 && _factor <= 1.0) {
88 typename Mesh::Scalar new_edge_length = edge_length_ *
static_cast<typename
Mesh::Scalar>(_factor / this->error_tolerance_factor_);
89 set_edge_length(new_edge_length);
90 this->error_tolerance_factor_ = _factor;
Contains all the mesh ingredients like the polygonal mesh, the triangle mesh, different mesh kernels ...
Definition MeshItems.hh:59
Kernel::Scalar Scalar
Scalar type.
Definition PolyMeshT.hh:110
void set_error_tolerance_factor(double _factor) override
set the percentage of edge length
Definition ModEdgeLengthT_impl.hh:83
void set_edge_length(typename Mesh::Scalar _f)
set edge_length
Definition ModEdgeLengthT.hh:91
ModEdgeLengthT(MeshT &_mesh, float _edge_length=FLT_MAX, bool _is_binary=true)
Constructor.
Definition ModEdgeLengthT_impl.hh:65
float collapse_priority(const CollapseInfo &_ci) override
Compute priority: Binary mode: Don't collapse edges longer then edge_length_ Cont.
Definition ModEdgeLengthT_impl.hh:74