-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSmootherRemesher.hh
executable file
·96 lines (82 loc) · 3.28 KB
/
SmootherRemesher.hh
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
/*
Written by Onur Paça, PhD student at Istanbul Technical University in 2017
for the first homework of Advanced Mesh Processing Class instructued by
Asst. Prof. Dr. Erkan Günpınar
paca[at]itu.edu.tr
onurpaca[at]gmail.com
opaca[at]rotorbit.com
*/
#ifndef SMOOTHREMESH_HH
#define SMOOTHREMESH_HH
#include <algorithm>
#include <vector>
#include <iostream>
#include <QObject>
#include <OpenFlipper/BasePlugin/BaseInterface.hh>
#include <OpenFlipper/BasePlugin/ToolboxInterface.hh>
#include <OpenFlipper/BasePlugin/LoggingInterface.hh>
#include <OpenFlipper/common/Types.hh>
#include <ObjectTypes/TriangleMesh/TriangleMesh.hh>
#include <OpenFlipper/common/Types.hh>
#include <ObjectTypes/PolyMesh/PolyMesh.hh>
#include <OpenFlipper/BasePlugin/PluginFunctions.hh>
#include <OpenMesh/Core/Mesh/Attributes.hh>
#include <OpenMesh/Core/Utils/GenProg.hh>
#include <OpenMesh/Core/Utils/vector_traits.hh>
#include <OpenMesh/Core/Mesh/PolyConnectivity.hh>
#include <libs_required/OpenMesh/src/OpenMesh/Core/Mesh/PolyConnectivity.hh>
#include <OpenMesh/Core/Mesh/TriMesh_ArrayKernelT.hh>
#include <MeshTools/MeshNavigationT.hh>
#include <OpenMesh/Core/Geometry/MathDefs.hh>
#include <OpenFlipper/BasePlugin/BaseInterface.hh>
#include <OpenFlipper/BasePlugin/KeyInterface.hh>
#include <OpenFlipper/BasePlugin/MouseInterface.hh>
#include <OpenFlipper/BasePlugin/LoggingInterface.hh>
#include <OpenFlipper/BasePlugin/ToolboxInterface.hh>
#include <OpenFlipper/BasePlugin/ToolbarInterface.hh>
#include <OpenFlipper/BasePlugin/LoadSaveInterface.hh>
#include <OpenFlipper/BasePlugin/BackupInterface.hh>
#include <OpenFlipper/BasePlugin/INIInterface.hh>
#include <OpenFlipper/BasePlugin/ScriptInterface.hh>
#include <OpenFlipper/BasePlugin/SelectionInterface.hh>
#include <OpenFlipper/common/Types.hh>
#include <OpenFlipper/BasePlugin/PluginFunctions.hh>
#include <OpenFlipper/INIFile/INIFile.hh>
#include <ObjectTypes/PolyMesh/PolyMesh.hh>
#include <ObjectTypes/TriangleMesh/TriangleMesh.hh>
#include <ObjectTypes/PolyMesh/PolyMesh.hh>
#include <ObjectTypes/TriangleMesh/TriangleMesh.hh>
#include "OpenFlipper/BasePlugin/PluginFunctions.hh"
class SmootherRemesherPlugin : public QObject, BaseInterface, ToolboxInterface, LoggingInterface
{
Q_OBJECT
Q_INTERFACES(BaseInterface)
Q_INTERFACES(ToolboxInterface)
Q_INTERFACES(LoggingInterface)
signals:
void updateView();
void updatedObject(int _identifier, const UpdateType& _type);
void log(Logtype _type, QString _message);
void log(QString _message);
void addToolbox( QString _name, QWidget* _widget );
public:
SmootherRemesherPlugin();
QString name() { return (QString("Smoother & Remesher")); };
QString description( ) { return (QString("Smooths and Remeshes a Mesh")); };
private:
QSpinBox* iternoSpinbox_;
QDoubleSpinBox* targetEdgeLengthSpinbox_;
private slots:
void initializePlugin();
void smooth();
void remesh();
void splitLongEdges(double high, TriMesh* &mesh);
void collapseShortEdges(double high, double low, TriMesh* &mesh);
void equalizeValences(TriMesh* &mesh);
void smooth(int nIter, TriMesh* &mesh);
bool checkLongEdges(double high, TriMesh* &mesh);
bool checkShortEdges(double low, TriMesh* &mesh);
public slots:
QString version() { return QString("1.0"); };
};
#endif