Salome HOME
0016756: EDF 545 GEOM : Extrusion, give the coordinates of the vector as input
[modules/geom.git] / src / PrimitiveGUI / PrimitiveGUI_TorusDlg.h
1 // GEOM GEOMGUI : GUI for Geometry component
2 //
3 // Copyright (C) 2003  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS 
5 // 
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. 
10 // 
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. 
15 // 
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 
19 // 
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 // File   : PrimitiveGUI_TorusDlg.h
23 // Author : Lucien PIGNOLONI, Open CASCADE S.A.S.
24 //
25
26 #ifndef PRIMITIVEGUI_TORUSDLG_H
27 #define PRIMITIVEGUI_TORUSDLG_H
28
29 #include <GEOMBase_Skeleton.h>
30
31 class DlgRef_2Sel2Spin;
32 class DlgRef_2Spin;
33
34 //=================================================================================
35 // class    : PrimitiveGUI_TorusDlg
36 // purpose  :
37 //=================================================================================
38 class PrimitiveGUI_TorusDlg : public GEOMBase_Skeleton
39
40   Q_OBJECT
41
42 public:
43   PrimitiveGUI_TorusDlg( GeometryGUI*, QWidget* = 0, bool = false, Qt::WindowFlags = 0 );
44   ~PrimitiveGUI_TorusDlg();
45   
46 protected:
47   // redefined from GEOMBase_Helper
48   virtual GEOM::GEOM_IOperations_ptr createOperation();
49   virtual bool                       isValid( QString& );
50   virtual bool                       execute( ObjectList& );
51   virtual void                       addSubshapesToStudy();
52
53 private:
54   void                               Init();
55   void                               enterEvent( QEvent* );
56   double                             getRadius1() const;
57   double                             getRadius2() const;
58   
59   GEOM::GEOM_Object_var              myPoint, myDir;
60   
61   DlgRef_2Sel2Spin*                  GroupPoints;
62   DlgRef_2Spin*                      GroupDimensions;
63   
64 private slots:
65   void                               ClickOnOk();
66   bool                               ClickOnApply();
67   void                               ActivateThisDialog();
68   void                               LineEditReturnPressed();
69   void                               SelectionIntoArgument();
70   void                               SetEditCurrentArgument();
71   void                               ConstructorsClicked( int );
72   void                               ValueChangedInSpinBox();
73   void                               SetDoubleSpinBoxStep( double );
74 };
75
76 #endif // PRIMITIVEGUI_TORUSDLG_H