ModAspectRatioT.hh 6.02 KB
Newer Older
Isaak Lim's avatar
Isaak Lim committed
1
2
3
4
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
/*===========================================================================*\
 *                                                                           *
 *                               OpenMesh                                    *
 *      Copyright (C) 2001-2011 by Computer Graphics Group, RWTH Aachen      *
 *                           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
 \*===========================================================================*/
Isaak Lim's avatar
Isaak Lim committed
34
35
36
37
38
39

/*===========================================================================*\
 *                                                                           *
 *   $Revision: 448 $                                                        *
 *   $Date: 2011-11-04 13:59:37 +0100 (Fri, 04 Nov 2011) $                   *
 *                                                                           *
40
 \*===========================================================================*/
Isaak Lim's avatar
Isaak Lim committed
41
42
43
44
45
46
47
48
49
50

/** \file ModAspectRatioT.hh
 */

//=============================================================================
//
//  CLASS ModAspectRatioT
//
//=============================================================================

51
52
#ifndef OPENMESH_DECIMATER_MODASPECTRATIOT_HH
#define OPENMESH_DECIMATER_MODASPECTRATIOT_HH
Isaak Lim's avatar
Isaak Lim committed
53
54
55
56
57
58
59
60

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

#include <OpenMesh/Tools/Decimater/ModBaseT.hh>
#include <OpenMesh/Core/Utils/Property.hh>

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

61
namespace OpenMesh {
Isaak Lim's avatar
Isaak Lim committed
62
63
64
65
namespace Decimater {

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

66
67
68
69
70
71
72
73
74
75
76
77
78
/** \brief Use aspect ratio to control decimation
 *
 * This module computes the aspect ratio.
 *
 * In binary mode, the collapse is legal if:
 *  - The aspect ratio after the collapse is greater
 *  - The aspect ratio after the collapse is greater than the given minimum
 *
 * In continuous mode the collapse is illegal if:
 *  - The aspect ratio after the collapse is smaller than the given minimum
 *
 *
 */
79
80
template<class MeshT>
class ModAspectRatioT: public ModBaseT<MeshT> {
81
  public:
Isaak Lim's avatar
Isaak Lim committed
82

83
    DECIMATING_MODULE( ModAspectRatioT, MeshT, Roundness )
84
85
86
87
88
89
    ;

    typedef typename Mesh::Scalar Scalar;
    typedef typename Mesh::Point Point;

    /// constructor
90
    ModAspectRatioT(MeshT& _mesh, float _min_aspect = 5.0, bool _is_binary =
91
        true) :
92
        Base(_mesh, _is_binary), mesh_(Base::mesh()), min_aspect_(
93
94
95
96
97
98
99
100
            1.0 / _min_aspect) {
      mesh_.add_property(aspect_);
    }

    /// destructor
    ~ModAspectRatioT() {
      mesh_.remove_property(aspect_);
    }
Isaak Lim's avatar
Isaak Lim committed
101

102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
    /// get aspect ratio
    float aspect_ratio() const {
      return 1.0 / min_aspect_;
    }

    /// set aspect ratio
    void set_aspect_ratio(float _f) {
      min_aspect_ = 1.0 / _f;
    }

    /// precompute face aspect ratio
    void initialize();

    /// Returns the collapse priority
    float collapse_priority(const CollapseInfo& _ci);

    /// update aspect ratio of one-ring
    void preprocess_collapse(const CollapseInfo& _ci);

121
122
123
    /// set percentage of aspect ratio
    void set_error_tolerance_factor(double _factor);

124
125
126
127
128
129
130
131
132
133
134
135
136
  private:

    /** \brief return aspect ratio (length/height) of triangle
     *
     */
    Scalar aspectRatio(const Point& _v0, const Point& _v1, const Point& _v2);

  private:

    Mesh& mesh_;
    float min_aspect_;
    FPropHandleT<float> aspect_;
};
Isaak Lim's avatar
Isaak Lim committed
137
138

//=============================================================================
139
}// END_NS_DECIMATER
Isaak Lim's avatar
Isaak Lim committed
140
141
} // END_NS_OPENMESH
//=============================================================================
142
#if defined(OM_INCLUDE_TEMPLATES) && !defined(OPENMESH_DECIMATER_MODASPECTRATIOT_C)
143
#define OPENMESH_DECIMATER_MODASPECTRATIOT_TEMPLATES
Isaak Lim's avatar
Isaak Lim committed
144
145
146
#include "ModAspectRatioT.cc"
#endif
//=============================================================================
147
#endif // OPENMESH_DECIMATER_MODASPECTRATIOT_HH defined
Isaak Lim's avatar
Isaak Lim committed
148
149
//=============================================================================