MeshRepairPlugin.hh 7.82 KB
Newer Older
Jan Möbius's avatar
 
Jan Möbius 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 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
/*===========================================================================*\
*                                                                            *
*                              OpenFlipper                                   *
*      Copyright (C) 2001-2011 by Computer Graphics Group, RWTH Aachen       *
*                           www.openflipper.org                              *
*                                                                            *
*--------------------------------------------------------------------------- *
*  This file is part of OpenFlipper.                                         *
*                                                                            *
*  OpenFlipper 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.                         *
*                                                                            *
*  OpenFlipper 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 OpenFlipper. If not,                                   *
*  see <http://www.gnu.org/licenses/>.                                       *
*                                                                            *
\*===========================================================================*/

/*===========================================================================*\
*                                                                            *
*   $Revision$                                                       *
*   $LastChangedBy$                                                *
*   $Date$                     *
*                                                                            *
\*===========================================================================*/

#ifndef MESHREPAIRPLUGIN_HH
#define MESHREPAIRPLUGIN_HH

#include <QObject>
#include <QMenuBar>

#include <OpenFlipper/BasePlugin/BaseInterface.hh>
#include <OpenFlipper/BasePlugin/LoggingInterface.hh>
#include <OpenFlipper/BasePlugin/ToolboxInterface.hh>
#include <OpenFlipper/BasePlugin/BackupInterface.hh>
53 54
#include <OpenFlipper/BasePlugin/ScriptInterface.hh>
#include <OpenFlipper/BasePlugin/RPCInterface.hh>
Jan Möbius's avatar
 
Jan Möbius committed
55 56 57 58 59 60
#include <OpenFlipper/common/Types.hh>
#include <ObjectTypes/PolyMesh/PolyMesh.hh>
#include <ObjectTypes/TriangleMesh/TriangleMesh.hh>

#include "MeshRepairToolbar.hh"

61
class MeshRepairPlugin : public QObject, BaseInterface , ToolboxInterface, BackupInterface, LoggingInterface, ScriptInterface, RPCInterface
Jan Möbius's avatar
 
Jan Möbius committed
62 63 64 65 66 67
{
    Q_OBJECT
    Q_INTERFACES(BaseInterface)
    Q_INTERFACES(ToolboxInterface)
    Q_INTERFACES(BackupInterface)
    Q_INTERFACES(LoggingInterface)
68 69
    Q_INTERFACES(ScriptInterface)
    Q_INTERFACES(RPCInterface)
Jan Möbius's avatar
 
Jan Möbius committed
70 71 72 73 74 75 76

signals:

    void updateView();

    // Base Interface
    void updatedObject(int _identifier, const UpdateType _type);
77 78
    void setSlotDescription(QString     _slotName,   QString     _slotDescription,
                            QStringList _parameters, QStringList _descriptions);
Jan Möbius's avatar
 
Jan Möbius committed
79

80
    // Logging interface
Jan Möbius's avatar
 
Jan Möbius committed
81 82 83 84 85 86 87
    void log(Logtype _type, QString _message);
    void log(QString _message);

    // ToolboxInterface
    void addToolbox( QString _name  , QWidget* _widget, QIcon* _icon );

    // Backup Interface
Dirk Wilden's avatar
Dirk Wilden committed
88
    void createBackup( int _objectid, QString _name, UpdateType _type = UPDATE_ALL);
Jan Möbius's avatar
 
Jan Möbius committed
89

90 91 92 93 94 95 96
    // RPC Interface
    void pluginExists( QString _pluginName , bool& _exists  ) ;
    void functionExists( QString _pluginName , QString _functionName , bool& _exists  );

    // ScriptInterface
    void scriptInfo( QString _functionName );

Jan Möbius's avatar
 
Jan Möbius committed
97 98 99
private slots:

    void initializePlugin();
100
    void pluginsInitialized();
Jan Möbius's avatar
 
Jan Möbius committed
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
    void slotActiveObjectChanged() {};

public :

    ~MeshRepairPlugin() {};

    QString name() {
        return (QString("Mesh Repair"));
    };
    QString description( ) {
        return (QString("Functionality to repair meshes"));
    };

private :

    /// Widget for Toolbox
    MeshRepairToolbarWidget* tool_;
    QIcon* toolIcon_;

private slots:

    /// Button slot
    void slotRemoveSelectedVal3Vertices();

    /// Button slot
    void slotRemoveSelectedEdges();

    /// Button slot
129
    void slotDetectSkinnyTriangleByAngle();
Jan Möbius's avatar
 
Jan Möbius committed
130 131

    /// Button slot
132
    void slotRemoveSkinnyTriangleByAngle();
Jan Möbius's avatar
 
Jan Möbius committed
133 134 135 136 137 138 139

    /// Button slot
    void slotDetectFoldover();

    /// Button slot
    void slotDetectTriangleAspect();

140 141 142 143 144 145 146 147 148 149 150 151 152
    /// Button slot
    void slotFlipOrientation();

    /// Button slot
    void slotUpdateVertexNormals();

    /// Button slot
    void slotUpdateFaceNormals();

    /// Button slot
    void slotUpdateNormals();

    /// Button Slot
153
    void slotDetectEdgesLonger();
154

155 156
    /// Button Slot
    void slotDetectEdgesShorter();
157

158 159
    /// Button slot
    void slotDetectFlatValence3Vertices();
160 161 162

    //Scripting functions:
public slots:
Jan Möbius's avatar
 
Jan Möbius committed
163

164 165 166
    /// Remove all selected valence 3 vertices
    void removeSelectedVal3Vertices(int _objectId);

Jan Möbius's avatar
 
Jan Möbius committed
167 168 169
    /// Removes all selected edges
    void removeSelectedEdges(int _objectId);

Jan Möbius's avatar
Jan Möbius committed
170
    /// Detect/Remove edges where neighboring faces form angle > _angle degrees
171
    void detectSkinnyTriangleByAngle(int _objectId, double _angle, bool _remove);
172

173 174
    /// Detect folded-over configurations
    void detectFoldover(int _objectId, float _angle);
175

176 177
    /// Detect triangle with aspect of _aspect and select candidates
    void detectTriangleAspect(int _objectId, float _aspect);
178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196

    /// Recomputes the face normals of an object
    void updateFaceNormals(int _objectId);

    /// Recomputes the vertex normals of an object
    void updateVertexNormals(int _objectId);

    /// Recomputes the face and vertex normals of an object
    void updateNormals(int _objectId);

    /// Flips the normals of all faces by changing the vertex order
    void flipOrientation(int _objectId);

    /// Selects all edges of an object which are shorter than the given length
    void selectEdgesShorterThan(int _objectId,double _length);

    /// Selects all edges of an object which are larger than the given length
    void selectEdgesLongerThan(int _objectId,double _length);

Jan Möbius's avatar
Jan Möbius committed
197 198 199
    /// Detect valence 3 vertices with faces that lie in the plane of their adjacent triangles
    void detectFlatValence3Vertices(int _objectId, double _angle);

Jan Möbius's avatar
 
Jan Möbius committed
200 201 202 203 204 205 206 207 208 209 210 211
private:
    /** \brief select edges based on length
    *
    * Selects edges if they are larger or shorter than a given length,
    * @param _objectId Id of the object to select
    * @param _length Length
    * @param _larger true : select larger edges, false select smaller edges
    */
    void selectionEdgeLength(int _objectId, double _length, bool _larger);

public slots:
    QString version() {
212
        return QString("1.2");
Jan Möbius's avatar
 
Jan Möbius committed
213 214 215 216
    };
};

#endif //MESHREPAIRPLUGIN_HH