ModEdgeLengthT.hh 5.3 KB
Newer Older
Jan Möbius's avatar
Jan Möbius committed
1
2
3
/*===========================================================================*\
 *                                                                           *
 *                               OpenMesh                                    *
Jan Möbius's avatar
Jan Möbius committed
4
 *      Copyright (C) 2001-2012 by Computer Graphics Group, RWTH Aachen      *
Jan Möbius's avatar
Jan Möbius committed
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
 *                           www.openmesh.org                                *
 *                                                                           *
 *---------------------------------------------------------------------------*
 *  This file is part of OpenMesh.                                           *
 *                                                                           *
 *  OpenMesh is free software: you can redistribute it and/or modify         *
 *  it under the terms of the GNU Lesser General Public License as           *
 *  published by the Free Software Foundation, either version 3 of           *
 *  the License, or (at your option) any later version with the              *
 *  following exceptions:                                                    *
 *                                                                           *
 *  If other files instantiate templates or use macros                       *
 *  or inline functions from this file, or you compile this file and         *
 *  link it with other files to produce an executable, this file does        *
 *  not by itself cause the resulting executable to be covered by the        *
 *  GNU Lesser General Public License. This exception does not however       *
 *  invalidate any other reasons why the executable file might be            *
 *  covered by the GNU Lesser General Public License.                        *
 *                                                                           *
 *  OpenMesh is distributed in the hope that it will be useful,              *
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of           *
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the            *
 *  GNU Lesser General Public License for more details.                      *
 *                                                                           *
 *  You should have received a copy of the GNU LesserGeneral Public          *
 *  License along with OpenMesh.  If not,                                    *
 *  see <http://www.gnu.org/licenses/>.                                      *
 *                                                                           *
33
 \*===========================================================================*/
Jan Möbius's avatar
Jan Möbius committed
34
35
36

/*===========================================================================*\
 *                                                                           *
Jan Möbius's avatar
Jan Möbius committed
37
38
 *   $Revision$                                                        *
 *   $Date$                   *
Jan Möbius's avatar
Jan Möbius committed
39
 *                                                                           *
40
 \*===========================================================================*/
Jan Möbius's avatar
Jan Möbius committed
41
42
43
44
45
46
47
48
49

/** \file ModEdgeLengthT.hh
 */

//=============================================================================
//
//  CLASS ModEdgeLengthT
//
//=============================================================================
50
51
#ifndef OPENMESH_DECIMATER_MODEDGELENGTHT_HH
#define OPENMESH_DECIMATER_MODEDGELENGTHT_HH
Jan Möbius's avatar
Jan Möbius committed
52
53
54
55
56
57
58
59

//== INCLUDES =================================================================

#include <OpenMesh/Tools/Decimater/ModBaseT.hh>
#include <float.h>

//== NAMESPACES ===============================================================

60
namespace OpenMesh {
Jan Möbius's avatar
Jan Möbius committed
61
62
63
64
namespace Decimater {

//== CLASS DEFINITION =========================================================

65
66
67
68
69
70
71
72
/** \brief Use edge length to control decimation
 *
 * This module computes the edge length.
 *
 * In binary and continuous mode, the collapse is legal if:
 *  - The length after the collapse is lower than the given tolerance
 *
 */
73
74
template<class MeshT>
class ModEdgeLengthT: public ModBaseT<MeshT> {
75
76
  public:

77
    DECIMATING_MODULE( ModEdgeLengthT, MeshT, EdgeLength )
78
79
80
    ;

    /// Constructor
81
    ModEdgeLengthT(MeshT& _mesh, float _edge_length = FLT_MAX,
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
        bool _is_binary = true);

    /// get edge_length
    float edge_length() const {
      return edge_length_;
    }

    /// set edge_length
    void set_edge_length(float _f) {
      edge_length_ = _f;
      sqr_edge_length_ = _f * _f;
    }

    /** Compute priority:
     Binary mode: Don't collapse edges longer then edge_length_
     Cont. mode:  Collapse smallest edge first, but
     don't collapse edges longer as edge_length_
     */
    float collapse_priority(const CollapseInfo& _ci);

102
103
104
    /// set the percentage of edge length
    void set_error_tolerance_factor(double _factor);

105
106
107
108
  private:

    Mesh& mesh_;
    typename Mesh::Scalar edge_length_, sqr_edge_length_;
Jan Möbius's avatar
Jan Möbius committed
109
110
111
};

//=============================================================================
112
}// END_NS_DECIMATER
Jan Möbius's avatar
Jan Möbius committed
113
114
} // END_NS_OPENMESH
//=============================================================================
115
#if defined(OM_INCLUDE_TEMPLATES) && !defined(OPENMESH_DECIMATER_MODEDGELENGTHT_C)
116
#define MODEDGELENGTHT_TEMPLATES
Jan Möbius's avatar
Jan Möbius committed
117
118
119
#include "ModEdgeLengthT.cc"
#endif
//=============================================================================
120
#endif // OPENMESH_DECIMATER_MODEDGELENGTHT_HH defined
Jan Möbius's avatar
Jan Möbius committed
121
122
//=============================================================================