1 // Copyright (C) 2007-2012 CEA/DEN, EDF R&D, OPEN CASCADE
3 // This library is free software; you can redistribute it and/or
4 // modify it under the terms of the GNU Lesser General Public
5 // License as published by the Free Software Foundation; either
6 // version 2.1 of the License.
8 // This library is distributed in the hope that it will be useful,
9 // but WITHOUT ANY WARRANTY; without even the implied warranty of
10 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 // Lesser General Public License for more details.
13 // You should have received a copy of the GNU Lesser General Public
14 // License along with this library; if not, write to the Free Software
15 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
19 // GEOM GEOMGUI : GUI for Geometry component
20 // File : EntityGUI_3DSketcherDlg.h
23 #ifndef ENTITYGUI_3DSKETCHERDLG_H
24 #define ENTITYGUI_3DSKETCHERDLG_H
26 #include <GEOMBase_Skeleton.h>
30 class EntityGUI_3Spin;
32 class EntityGUI_Angles;
33 class EntityGUI_Controls;
37 #include <AIS_ListOfInteractive.hxx>
38 #include <AIS_AngleDimension.hxx>
39 #include <AIS_LengthDimension.hxx>
42 # define COORD_MIN -1e+15
43 # define COORD_MAX +1e+15
44 # define MAX_NUMBER 100000
45 # define DBL_DIGITS_DISPLAY 16
48 //=================================================================================
49 // class : EntityGUI_Dlg
51 //=================================================================================
52 class EntityGUI_3DSketcherDlg : public GEOMBase_Skeleton
58 XYZ() { x = y = z = 0.0; command = params = ""; L=A=0; }
59 double x, y, z; // for preview only
60 int L, A; // for preview only
72 typedef QList<XYZ> XYZList;
75 EntityGUI_3DSketcherDlg (GeometryGUI*, QWidget* = 0, bool = false, Qt::WindowFlags = 0, const double = 2.);
76 ~EntityGUI_3DSketcherDlg();
80 // redefined from GEOMBase_Helper
81 virtual GEOM::GEOM_IOperations_ptr createOperation();
82 virtual bool isValid( QString& );
83 virtual bool execute( ObjectList& );
87 void enterEvent( QEvent* );
89 virtual void displayPreview( GEOM::GEOM_Object_ptr,
97 Handle(AIS_LengthDimension) createAISLengthDimension(double theLength,
102 Handle(AIS_AngleDimension) createAISAngleDimension(double theAngle,
107 void displayAngle(double theAngle,
113 void displayLength(gp_Pnt P1,
118 void displayTrihedron( int );
120 void displayDimensions(bool store = false);
122 bool createShapes( GEOM::GEOM_Object_ptr,
126 XYZ getLastPoint() const;
127 XYZ getPenultimatePoint() const;
128 XYZ getCurrentPoint() const;
130 gp_Dir getPresentationPlane() const;
132 std::string doubleToString( double );
134 void removeLastIOFromPrs();
135 void restoreLastIOToPrs();
138 XYZList myPointsList;
140 AIS_ListOfInteractive myLengthIORedoList;
141 AIS_ListOfInteractive myAngleIORedoList;
144 EntityGUI_3Spin* Group3Spin;
145 EntityGUI_Angles* GroupAngles;
146 EntityGUI_Controls* GroupControls;
147 EntityGUI_Type* GroupType;
148 QButtonGroup* myTypeGroup1;
149 QButtonGroup* myTypeGroup2;
155 bool isLengthVisible;
159 GeometryGUI* myGeometryGUI;
160 SOCC_Prs* myAnglePrs;
161 SOCC_Prs* myLengthPrs;
165 void ClickOnAddPoint();
167 // bool isSameAsPrevious();
168 void UpdateButtonsState();
169 void UpdatePointCoordinates();
174 void SelectionIntoArgument();
175 void DeactivateActiveDialog();
176 void ActivateThisDialog();
177 void TypeClicked( int );
178 void ValueChangedInSpinBox( double );
179 void ButtonClicked( bool );
180 void BoxChecked ( bool );
181 void SetDoubleSpinBoxStep( double );
184 #endif // ENTITYGUI_SKETCHERDLG_H