1 // GEOM GEOMGUI : GUI for Geometry component
3 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 // File : RepairGUI_ShapeProcessDlg.h
23 // Author : Lucien PIGNOLONI, Open CASCADE S.A.S.
26 #ifndef REPAIRGUI_SHAPEPROCESSDLG_H
27 #define REPAIRGUI_SHAPEPROCESSDLG_H
29 #include <GEOMBase_Skeleton.h>
40 //=================================================================================
41 // class : RepairGUI_ShapeProcessDlg
43 //=================================================================================
44 class RepairGUI_ShapeProcessDlg : public GEOMBase_Skeleton
49 RepairGUI_ShapeProcessDlg( GeometryGUI*, QWidget* = 0, bool = false );
50 ~RepairGUI_ShapeProcessDlg();
53 // redefined from GEOMBase_Helper
54 virtual GEOM::GEOM_IOperations_ptr createOperation();
55 virtual bool isValid( QString& );
56 virtual bool execute( ObjectList& );
61 void loadDefaults(); // initialize all controls with default values (from resource file)
63 GEOM::string_array* getActiveOperators();
64 GEOM::string_array* getParameters( const GEOM::string_array& );
65 GEOM::string_array* getValues( const GEOM::string_array& );
67 void enterEvent( QEvent* );
69 QWidget* getControl( const QString& );
70 void setValue( QWidget*, const QString& ); // initialize the given control in the proper way
71 // (analize its class and convert the value string)
72 QString getValue( QWidget* ) const; // retrieve value of the control in the proper way
74 //QDict<QString,QWidget*> myCtrlMap; // map of controls (values) of parameters
75 void initParamsValues(); // initialize the data structures
79 QStringList myOpLst; // list of available Shape Healing Operators
80 QMap<QString,QStringList> myValMap; // map of parameters of operators
82 GEOM::ListOfGO_var myObjects; // selected objects
84 DlgRef_1Sel* mySelectWdgt;
85 QListWidget* myOpList;
87 QDoubleSpinBox* myFixShapeTol3D;
88 QDoubleSpinBox* myFixShapeMaxTol3D;
90 QDoubleSpinBox* myFixFaceSizeTol;
92 QDoubleSpinBox* myDropSmallEdgesTol3D;
94 QDoubleSpinBox* mySplitAngleAngle;
95 QDoubleSpinBox* mySplitAngleMaxTol;
97 QSpinBox* mySplitClosedFacesNum;
99 QDoubleSpinBox* mySplitContTol3D;
100 QComboBox* mySplitContSurfCont;
101 QComboBox* mySplitContCurvCont;
103 QCheckBox* myBSplineSurfModeChk;
104 QCheckBox* myBSpline3DCurveChk;
105 QCheckBox* myBSpline2DCurveChk;
106 QDoubleSpinBox* myBSplineTol3D;
107 QDoubleSpinBox* myBSplineTol2D;
108 QSpinBox* myBSplineDegree;
109 QSpinBox* myBSplineSegments;
110 QComboBox* myBSpline2DCont;
111 QComboBox* myBSpline3DCont;
113 QCheckBox* myToBezierSurfModeChk;
114 QCheckBox* myToBezier3DCurveChk;
115 QCheckBox* myToBezier2DCurveChk;
116 QDoubleSpinBox* myToBezierMaxTol;
118 QDoubleSpinBox* mySameParameterTol3D;
126 void lineEditReturnPressed();
127 void selectionChanged();
128 void selectClicked();
129 void advOptionToggled( bool );
132 #endif // REPAIRGUI_SHAPEPROCESSDLG_H