]> SALOME platform Git repositories - modules/geom.git/blob - src/PrimitiveGUI/PrimitiveGUI_BoxDlg.cxx
Salome HOME
NPAL 18378
[modules/geom.git] / src / PrimitiveGUI / PrimitiveGUI_BoxDlg.cxx
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 //
23 //
24 //  File   : PrimitiveGUI_BoxDlg.cxx
25 //  Author : Lucien PIGNOLONI
26 //  Module : GEOM
27 //  $Header$
28
29 #include "PrimitiveGUI_BoxDlg.h"
30
31 #include "SUIT_Desktop.h"
32 #include "SUIT_Session.h"
33 #include "SalomeApp_Application.h"
34 #include "LightApp_SelectionMgr.h"
35
36 #include <TopoDS_Shape.hxx>
37 #include <TopoDS.hxx>
38 #include <TopExp.hxx>
39 #include <TColStd_IndexedMapOfInteger.hxx>
40 #include <TopTools_IndexedMapOfShape.hxx>
41
42 #include <qlabel.h>
43
44 #include "GEOMImpl_Types.hxx"
45
46 #include "utilities.h"
47
48 using namespace std;
49
50
51 //=================================================================================
52 // class    : PrimitiveGUI_BoxDlg()
53 // purpose  : Constructs a PrimitiveGUI_BoxDlg which is a child of 'parent', with the 
54 //            name 'name' and widget flags set to 'f'.
55 //            The dialog will by default be modeless, unless you set 'modal' to
56 //            TRUE to construct a modal dialog.
57 //=================================================================================
58 PrimitiveGUI_BoxDlg::PrimitiveGUI_BoxDlg(GeometryGUI* theGeometryGUI, QWidget* parent,
59                                          const char* name, bool modal, WFlags fl)
60   :GEOMBase_Skeleton(theGeometryGUI, parent, name, modal, WStyle_Customize |
61                      WStyle_NormalBorder | WStyle_Title | WStyle_SysMenu)
62 {
63   QPixmap image0(SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_DLG_BOX_2P")));
64   QPixmap image1(SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_DLG_BOX_DXYZ")));
65   QPixmap image2(SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_SELECT")));
66
67   setCaption(tr("GEOM_BOX_TITLE"));
68
69   /***************************************************************/
70   GroupConstructors->setTitle(tr("GEOM_BOX"));
71   RadioButton1->setPixmap(image0);
72   RadioButton2->setPixmap(image1);
73   RadioButton3->close(TRUE);
74
75   GroupPoints = new DlgRef_2Sel_QTD(this, "GroupPoints");
76   GroupPoints->GroupBox1->setTitle(tr("GEOM_DIAGONAL_POINTS"));
77   GroupPoints->TextLabel1->setText(tr("GEOM_POINT_I").arg("1"));
78   GroupPoints->TextLabel2->setText(tr("GEOM_POINT_I").arg("2"));
79   GroupPoints->PushButton1->setPixmap(image2);
80   GroupPoints->PushButton2->setPixmap(image2);
81
82   GroupDimensions = new DlgRef_3Spin(this, "GroupDimensions");
83   GroupDimensions->GroupBox1->setTitle(tr("GEOM_BOX_OBJ"));
84   GroupDimensions->TextLabel1->setText(tr("GEOM_DX"));
85   GroupDimensions->TextLabel2->setText(tr("GEOM_DY"));
86   GroupDimensions->TextLabel3->setText(tr("GEOM_DZ"));
87
88   Layout1->addWidget(GroupPoints, 2, 0);
89   Layout1->addWidget(GroupDimensions, 2, 0);
90   /***************************************************************/
91
92   setHelpFileName("box.htm");
93   
94   Init();
95 }
96
97
98 //=================================================================================
99 // function : ~DialogBox_Box()
100 // purpose  : Destroys the object and frees any allocated resources
101 //=================================================================================
102 PrimitiveGUI_BoxDlg::~PrimitiveGUI_BoxDlg()
103 {
104   // no need to delete child widgets, Qt does it all for us
105 }
106
107
108 //=================================================================================
109 // function : Init()
110 // purpose  :
111 //=================================================================================
112 void PrimitiveGUI_BoxDlg::Init()
113 {
114   /* init variables */
115   myEditCurrentArgument = GroupPoints->LineEdit1;
116   GroupPoints->LineEdit1->setReadOnly( true );
117   GroupPoints->LineEdit2->setReadOnly( true );
118   
119   myPoint1 = myPoint2 = GEOM::GEOM_Object::_nil();
120     
121   /* Get setting of step value from file configuration */
122   SUIT_ResourceMgr* resMgr = SUIT_Session::session()->resourceMgr();
123   double step = resMgr->doubleValue( "Geometry", "SettingsGeomStep", 100);
124   
125   /* min, max, step and decimals for spin boxes */
126   GroupDimensions->SpinBox_DX->RangeStepAndValidator(COORD_MIN, COORD_MAX, step, DBL_DIGITS_DISPLAY);
127   GroupDimensions->SpinBox_DY->RangeStepAndValidator(COORD_MIN, COORD_MAX, step, DBL_DIGITS_DISPLAY);
128   GroupDimensions->SpinBox_DZ->RangeStepAndValidator(COORD_MIN, COORD_MAX, step, DBL_DIGITS_DISPLAY);
129
130   double initValue = 200.0;
131   GroupDimensions->SpinBox_DX->SetValue(initValue);
132   GroupDimensions->SpinBox_DY->SetValue(initValue);
133   GroupDimensions->SpinBox_DZ->SetValue(initValue);
134
135   /* signals and slots connections */
136   connect(buttonOk, SIGNAL(clicked()), this, SLOT(ClickOnOk()));
137   connect(buttonApply, SIGNAL(clicked()), this, SLOT(ClickOnApply()));
138
139   connect(GroupConstructors, SIGNAL(clicked(int)), this, SLOT(ConstructorsClicked(int)));
140
141   connect(GroupPoints->PushButton1, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
142   connect(GroupPoints->PushButton2, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
143
144   connect(GroupPoints->LineEdit1, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed()));
145   connect(GroupPoints->LineEdit2, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed()));
146
147   connect(GroupDimensions->SpinBox_DX, SIGNAL(valueChanged(double)), this, SLOT(ValueChangedInSpinBox()));
148   connect(GroupDimensions->SpinBox_DY, SIGNAL(valueChanged(double)), this, SLOT(ValueChangedInSpinBox()));
149   connect(GroupDimensions->SpinBox_DZ, SIGNAL(valueChanged(double)), this, SLOT(ValueChangedInSpinBox()));
150   
151   connect(myGeomGUI, SIGNAL(SignalDefaultStepValueChanged(double)), GroupDimensions->SpinBox_DX, SLOT(SetStep(double)));
152   connect(myGeomGUI, SIGNAL(SignalDefaultStepValueChanged(double)), GroupDimensions->SpinBox_DY, SLOT(SetStep(double)));
153   connect(myGeomGUI, SIGNAL(SignalDefaultStepValueChanged(double)), GroupDimensions->SpinBox_DZ, SLOT(SetStep(double)));
154
155   connect(myGeomGUI->getApp()->selectionMgr(), 
156           SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument()));
157
158   initName( tr( "GEOM_BOX" ) );
159   ConstructorsClicked(0);
160 }
161
162 //=================================================================================
163 // function : ConstructorsClicked()
164 // purpose  : Radio button management
165 //=================================================================================
166 void PrimitiveGUI_BoxDlg::ConstructorsClicked(int constructorId)
167 {
168   disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0);
169
170   switch (constructorId)
171     {
172     case 0:
173       {
174         //      globalSelection( GEOM_POINT );
175         globalSelection(); // close local contexts, if any
176         localSelection( GEOM::GEOM_Object::_nil(), TopAbs_VERTEX );
177
178         GroupDimensions->hide();
179         resize(0, 0);
180         GroupPoints->show();
181
182         myEditCurrentArgument = GroupPoints->LineEdit1;
183         GroupPoints->LineEdit1->setText("");
184         GroupPoints->LineEdit2->setText("");
185         myPoint1 = myPoint2 = GEOM::GEOM_Object::_nil();
186         
187         connect(myGeomGUI->getApp()->selectionMgr(), 
188                 SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument()));
189         break;
190       }
191     case 1:
192       {
193         GroupPoints->hide();
194         resize(0, 0);
195         GroupDimensions->show();
196         
197         break;
198       }
199     }
200   displayPreview();
201 }
202
203 //=================================================================================
204 // function : ClickOnOk()
205 // purpose  :
206 //=================================================================================
207 void PrimitiveGUI_BoxDlg::ClickOnOk()
208 {
209   if ( ClickOnApply() )
210     ClickOnCancel();
211 }
212
213 //=================================================================================
214 // function : ClickOnApply()
215 // purpose  :
216 //=================================================================================
217 bool PrimitiveGUI_BoxDlg::ClickOnApply()
218 {
219   if ( !onAccept() )
220     return false;
221   
222   initName();
223   ConstructorsClicked( getConstructorId() );
224   return true;
225 }
226
227 //=================================================================================
228 // function : SelectionIntoArgument()
229 // purpose  : Called when selection as changed
230 //=================================================================================
231 void PrimitiveGUI_BoxDlg::SelectionIntoArgument()
232 {
233   if (getConstructorId() != 0)
234     return;
235
236   myEditCurrentArgument->setText("");
237
238   if (IObjectCount() != 1) 
239   {
240     if (myEditCurrentArgument == GroupPoints->LineEdit1)
241       myPoint1 = GEOM::GEOM_Object::_nil();
242     else if (myEditCurrentArgument == GroupPoints->LineEdit2)
243       myPoint2 = GEOM::GEOM_Object::_nil();
244     return;
245   }
246
247   // nbSel == 1
248   Standard_Boolean testResult = Standard_False;
249   GEOM::GEOM_Object_var aSelectedObject = GEOMBase::ConvertIOinGEOMObject(firstIObject(), testResult);
250
251   if (!testResult || CORBA::is_nil(aSelectedObject))
252     return;
253
254   TopoDS_Shape aShape;
255   QString aName = GEOMBase::GetName(aSelectedObject);
256   if (GEOMBase::GetShape(aSelectedObject, aShape, TopAbs_SHAPE) && !aShape.IsNull())
257   {
258     LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
259     TColStd_IndexedMapOfInteger aMap;
260     aSelMgr->GetIndexes(firstIObject(), aMap);
261     if (aMap.Extent() == 1) // Local Selection
262     {
263       int anIndex = aMap( 1 );
264       aName.append( ":vertex_" + QString::number( anIndex ) );    
265
266       //Find SubShape Object in Father
267       GEOM::GEOM_Object_var aFindedObject = GEOMBase_Helper::findObjectInFather(aSelectedObject, aName);
268       
269       if ( aFindedObject == GEOM::GEOM_Object::_nil() ) { // Object not found in study
270         GEOM::GEOM_IShapesOperations_var aShapesOp =
271           getGeomEngine()->GetIShapesOperations( getStudyId() );
272         aSelectedObject = aShapesOp->GetSubShape(aSelectedObject, anIndex);
273       }
274       else
275         aSelectedObject = aFindedObject; // get Object from study       
276     }
277     else // Global Selection
278     {
279       if (aShape.ShapeType() != TopAbs_VERTEX) {
280         aSelectedObject = GEOM::GEOM_Object::_nil();
281         aName = "";
282       }
283     }
284   }
285
286   myEditCurrentArgument->setText(aName);
287
288   if (myEditCurrentArgument == GroupPoints->LineEdit1)
289     myPoint1 = aSelectedObject;
290   else if (myEditCurrentArgument == GroupPoints->LineEdit2)
291     myPoint2 = aSelectedObject;
292
293   displayPreview();
294 }
295
296 //=================================================================================
297 // function : SetEditCurrentArgument()
298 // purpose  :
299 //=================================================================================
300 void PrimitiveGUI_BoxDlg::SetEditCurrentArgument()
301 {
302   QPushButton* send = (QPushButton*)sender();
303
304   if(send == GroupPoints->PushButton1)
305     myEditCurrentArgument = GroupPoints->LineEdit1;
306   else if(send == GroupPoints->PushButton2)
307     myEditCurrentArgument = GroupPoints->LineEdit2;
308
309   //  globalSelection( GEOM_POINT );
310   globalSelection(); // close local contexts, if any
311   localSelection( GEOM::GEOM_Object::_nil(), TopAbs_VERTEX );
312
313   myEditCurrentArgument->setFocus();
314   SelectionIntoArgument();
315 }
316
317 //=================================================================================
318 // function : LineEditReturnPressed()
319 // purpose  :
320 //=================================================================================
321 void PrimitiveGUI_BoxDlg::LineEditReturnPressed()
322 {
323   QLineEdit* send = (QLineEdit*)sender();
324   if(send == GroupPoints->LineEdit1 || send == GroupPoints->LineEdit2)
325     {
326       myEditCurrentArgument = send;
327       GEOMBase_Skeleton::LineEditReturnPressed();
328     }
329 }
330
331
332 //=================================================================================
333 // function : ActivateThisDialog()
334 // purpose  :
335 //=================================================================================
336 void PrimitiveGUI_BoxDlg::ActivateThisDialog()
337 {
338   GEOMBase_Skeleton::ActivateThisDialog();
339   connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()),
340           this, SLOT(SelectionIntoArgument()));
341
342   ConstructorsClicked( getConstructorId() );
343 }
344
345
346 //=================================================================================
347 // function : enterEvent [REDEFINED]
348 // purpose  :
349 //=================================================================================
350 void PrimitiveGUI_BoxDlg::enterEvent(QEvent* e)
351 {
352   if ( !GroupConstructors->isEnabled() )
353     ActivateThisDialog();
354 }
355
356
357 //=================================================================================
358 // function : ValueChangedInSpinBox()
359 // purpose  :
360 //=================================================================================
361 void PrimitiveGUI_BoxDlg::ValueChangedInSpinBox()
362 {
363   displayPreview();
364 }
365
366
367 //=================================================================================
368 // function : createOperation
369 // purpose  :
370 //=================================================================================
371 GEOM::GEOM_IOperations_ptr PrimitiveGUI_BoxDlg::createOperation()
372 {
373   return getGeomEngine()->GetI3DPrimOperations( getStudyId() );
374 }
375
376
377 //=================================================================================
378 // function : isValid
379 // purpose  :
380 //=================================================================================
381 bool PrimitiveGUI_BoxDlg::isValid( QString& msg )
382 {
383   return getConstructorId() == 0 ? !(myPoint1->_is_nil() || myPoint2->_is_nil()) : true;
384 }
385
386
387 //=================================================================================
388 // function : execute
389 // purpose  :
390 //=================================================================================
391 bool PrimitiveGUI_BoxDlg::execute( ObjectList& objects )
392 {
393   bool res = false;
394   
395   GEOM::GEOM_Object_var anObj;
396   
397   switch ( getConstructorId() ) 
398   {
399   case 0 :
400     { 
401       if ( !CORBA::is_nil( myPoint1 ) &&  !CORBA::is_nil( myPoint2 ) ) {
402         anObj = GEOM::GEOM_I3DPrimOperations::_narrow( getOperation() )->MakeBoxTwoPnt( myPoint1, myPoint2 );
403         res = true;
404       }
405       
406       break;
407     }
408   case 1 :
409     {
410       double x = GroupDimensions->SpinBox_DX->GetValue();
411       double y = GroupDimensions->SpinBox_DY->GetValue();
412       double z = GroupDimensions->SpinBox_DZ->GetValue();
413       
414       anObj = GEOM::GEOM_I3DPrimOperations::_narrow( getOperation() )->MakeBoxDXDYDZ( x, y, z );
415       res = true;
416       break;
417     }
418   }
419   
420   if ( !anObj->_is_nil() )
421   objects.push_back( anObj._retn() );
422   
423   return res;
424 }
425
426 //=================================================================================
427 // function : closeEvent
428 // purpose  :
429 //=================================================================================
430 void  PrimitiveGUI_BoxDlg::closeEvent( QCloseEvent* e )
431 {
432   GEOMBase_Skeleton::closeEvent( e );
433 }
434
435 //=================================================================================
436 // function : addSubshapeToStudy
437 // purpose  : virtual method to add new SubObjects if local selection
438 //=================================================================================
439 void PrimitiveGUI_BoxDlg::addSubshapesToStudy()
440 {
441   QMap<QString, GEOM::GEOM_Object_var> objMap;
442   if ( getConstructorId() == 0 ) 
443   {
444     objMap[GroupPoints->LineEdit1->text()] = myPoint1;
445     objMap[GroupPoints->LineEdit2->text()] = myPoint2;
446     addSubshapesToFather( objMap );
447   }
448 }