Files
create/src/Mod/Mesh/Gui/ViewProviderDefects.h
2013-02-17 08:28:01 +01:00

221 lines
7.1 KiB
C++

/***************************************************************************
* Copyright (c) 2006 Werner Mayer <wmayer[at]users.sourceforge.net> *
* *
* This file is part of the FreeCAD CAx development system. *
* *
* This library is free software; you can redistribute it and/or *
* modify it under the terms of the GNU Library General Public *
* License as published by the Free Software Foundation; either *
* version 2 of the License, or (at your option) any later version. *
* *
* This library 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 Library General Public License for more details. *
* *
* You should have received a copy of the GNU Library General Public *
* License along with this library; see the file COPYING.LIB. If not, *
* write to the Free Software Foundation, Inc., 59 Temple Place, *
* Suite 330, Boston, MA 02111-1307, USA *
* *
***************************************************************************/
#ifndef MESHGUI_VIEWPROVIDER_MESH_DEFECTS_H
#define MESHGUI_VIEWPROVIDER_MESH_DEFECTS_H
#include "ViewProvider.h"
class SoCoordinate3;
class SoPointSet;
class SoLineSet;
class SoFaceSet;
namespace MeshGui {
/** The ViewProviderMeshDefects class is used to display the most known types of defects of a polymesh.
* In subclasses defects like non-manifolds, wrong oriented facets, degenerated facets, duplicates, .... are displayed.
* @author Werner Mayer
*/
class MeshGuiExport ViewProviderMeshDefects : public Gui::ViewProviderDocumentObject
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshDefects);
public:
ViewProviderMeshDefects();
virtual ~ViewProviderMeshDefects();
// Display properties
App::PropertyFloat LineWidth;
// Build up the initial Inventor node
virtual void attach(App::DocumentObject* pcFeature) = 0;
/// Fill up the Inventor node with data
virtual void showDefects(const std::vector<unsigned long>&) = 0;
protected:
/// get called by the container whenever a property has been changed
void onChanged(const App::Property* prop);
SoCoordinate3 * pcCoords;
SoDrawStyle * pcDrawStyle;
};
/** The ViewProviderMeshOrientation class displays wrong oriented facets (i.e. flipped normals) in orange.
* @author Werner Mayer
*/
class MeshGuiExport ViewProviderMeshOrientation : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshOrientation);
public:
ViewProviderMeshOrientation();
virtual ~ViewProviderMeshOrientation();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoFaceSet* pcFaces;
};
/** The ViewProviderMeshNonManifolds class displays edges with more than two faces attached in red.
* @author Werner Mayer
*/
class MeshGuiExport ViewProviderMeshNonManifolds : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshNonManifolds);
public:
ViewProviderMeshNonManifolds();
virtual ~ViewProviderMeshNonManifolds();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoLineSet* pcLines;
};
/** The ViewProviderMeshNonManifoldPoints class displays non-manifold vertexes in red.
* @author Werner Mayer
*/
class MeshGuiExport ViewProviderMeshNonManifoldPoints : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshNonManifoldPoints);
public:
ViewProviderMeshNonManifoldPoints();
virtual ~ViewProviderMeshNonManifoldPoints();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoPointSet* pcPoints;
};
/** The ViewProviderMeshDuplicatedFaces class displays duplicated faces in red.
* @author Werner Mayer
*/
class MeshGuiExport ViewProviderMeshDuplicatedFaces : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshDuplicatedFaces);
public:
ViewProviderMeshDuplicatedFaces();
virtual ~ViewProviderMeshDuplicatedFaces();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoFaceSet* pcFaces;
};
/** The ViewProviderMeshDegenerations class displays degenerated faces to a line or even a point in orange.
* @author Werner Mayer
*/
class MeshGuiExport ViewProviderMeshDegenerations : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshDegenerations);
public:
ViewProviderMeshDegenerations();
virtual ~ViewProviderMeshDegenerations();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoLineSet* pcLines;
};
class MeshGuiExport ViewProviderMeshDuplicatedPoints : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshDuplicatedPoints);
public:
ViewProviderMeshDuplicatedPoints();
virtual ~ViewProviderMeshDuplicatedPoints();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoPointSet* pcPoints;
};
class MeshGuiExport ViewProviderMeshIndices : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshIndices);
public:
ViewProviderMeshIndices();
virtual ~ViewProviderMeshIndices();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoFaceSet* pcFaces;
};
/** The ViewProviderMeshSelfIntersections class displays lines of self-intersections.
* @author Werner Mayer
*/
class MeshGuiExport ViewProviderMeshSelfIntersections : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshSelfIntersections);
public:
ViewProviderMeshSelfIntersections();
virtual ~ViewProviderMeshSelfIntersections();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoLineSet* pcLines;
};
class MeshGuiExport ViewProviderMeshFolds : public ViewProviderMeshDefects
{
PROPERTY_HEADER(MeshGui::ViewProviderMeshFolds);
public:
ViewProviderMeshFolds();
virtual ~ViewProviderMeshFolds();
void attach(App::DocumentObject* pcFeature);
void showDefects(const std::vector<unsigned long>&);
protected:
SoFaceSet* pcFaces;
};
} // namespace MeshGui
#endif // MESHGUI_VIEWPROVIDER_MESH_DEFECTS_H