1 // Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 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
23 // GEOM GEOMGUI : GUI for Geometry component
24 // File : BlocksGUI_TrsfDlg.cxx
25 // Author : Julia DOROVSKIKH, Open CASCADE S.A.S. (julia.dorovskikh@opencascade.com)
27 #include "BlocksGUI_TrsfDlg.h"
30 #include <GeometryGUI.h>
33 #include <SUIT_Session.h>
34 #include <SUIT_Desktop.h>
35 #include <SUIT_ResourceMgr.h>
36 #include <SUIT_ViewWindow.h>
37 #include <SUIT_ViewManager.h>
38 #include <SalomeApp_Application.h>
39 #include <LightApp_SelectionMgr.h>
40 #include <OCCViewer_ViewModel.h>
43 #include <TColStd_IndexedMapOfInteger.hxx>
45 //=================================================================================
46 // class : BlocksGUI_TrsfDlg()
47 // purpose : Constructs a BlocksGUI_TrsfDlg which is a child of 'parent'.
48 //=================================================================================
49 BlocksGUI_TrsfDlg::BlocksGUI_TrsfDlg (GeometryGUI* theGeometryGUI, QWidget* parent)
50 : GEOMBase_Skeleton(theGeometryGUI, parent),
53 SUIT_ResourceMgr* aResMgr = myGeomGUI->getApp()->resourceMgr();
54 QPixmap image1 (aResMgr->loadPixmap("GEOM", tr("ICON_DLG_BLOCK_MULTITRSF_SIMPLE")));
55 QPixmap image2 (aResMgr->loadPixmap("GEOM", tr("ICON_DLG_BLOCK_MULTITRSF_DOUBLE")));
56 QPixmap imageS (aResMgr->loadPixmap("GEOM", tr("ICON_SELECT")));
58 setWindowTitle(tr("GEOM_BLOCK_MULTITRSF_TITLE"));
60 /***************************************************************/
61 mainFrame()->GroupConstructors->setTitle(tr("GEOM_BLOCK_MULTITRSF"));
63 mainFrame()->RadioButton1->setIcon(image1);
64 mainFrame()->RadioButton2->setIcon(image2);
65 mainFrame()->RadioButton3->setAttribute(Qt::WA_DeleteOnClose);
66 mainFrame()->RadioButton3->close();
69 myGrp1 = new QGroupBox(tr("GEOM_BLOCK_MULTITRSF_SIMPLE"), centralWidget());
71 createSelWg(tr("GEOM_MAIN_OBJECT"), imageS, myGrp1, MainObj1);
72 createSelWg(tr("FACE_1"), imageS, myGrp1, Face1);
73 createSelWg(tr("FACE_2"), imageS, myGrp1, Face2);
74 createSpinWg(tr("GEOM_NB_TIMES"), myGrp1, SpinBox1);
76 // Create second group
77 myGrp2 = new QGroupBox(tr("GEOM_BLOCK_MULTITRSF_DOUBLE"), centralWidget());
79 createSelWg(tr("GEOM_MAIN_OBJECT"), imageS, myGrp2, MainObj2);
80 createSelWg(tr("FACE_1U"), imageS, myGrp2, Face1U);
81 createSelWg(tr("FACE_2U"), imageS, myGrp2, Face2U);
82 createSpinWg(tr("GEOM_NB_TIMES_U"), myGrp2, SpinBox2U);
83 createSelWg(tr("FACE_1V"), imageS, myGrp2, Face1V);
84 createSelWg(tr("FACE_2V"), imageS, myGrp2, Face2V);
85 createSpinWg(tr("GEOM_NB_TIMES_V"), myGrp2, SpinBox2V);
87 // Add groups to layout
88 QVBoxLayout* layout = new QVBoxLayout(centralWidget());
89 layout->setMargin(0); layout->setSpacing(6);
90 layout->addWidget(myGrp1);
91 layout->addWidget(myGrp2);
92 /***************************************************************/
94 setHelpFileName("multi_transformation_operation_page.html");
99 //=================================================================================
100 // function : ~BlocksGUI_TrsfDlg()
101 // purpose : Destroys the object and frees any allocated resources
102 //=================================================================================
103 BlocksGUI_TrsfDlg::~BlocksGUI_TrsfDlg()
105 // no need to delete child widgets, Qt does it all for us
108 //=================================================================================
111 //=================================================================================
112 void BlocksGUI_TrsfDlg::Init()
114 // Set range of spinboxes
115 int SpecificStep = 1;
116 QMap<int, SalomeApp_IntSpinBox*>::iterator anIter;
117 for (anIter = mySpinBox.begin(); anIter != mySpinBox.end(); ++anIter) {
118 initSpinBox(anIter.value(), 1, 999, SpecificStep);
121 // signals and slots connections
122 connect(buttonOk(), SIGNAL(clicked()), this, SLOT(ClickOnOk()));
123 connect(buttonApply(), SIGNAL(clicked()), this, SLOT(ClickOnApply()));
125 connect(this, SIGNAL(constructorsClicked(int)), this, SLOT(ConstructorsClicked(int)));
127 QMap<int, QPushButton*>::iterator anIterBtn;
128 for (anIterBtn = mySelBtn.begin(); anIterBtn != mySelBtn.end(); ++anIterBtn)
129 connect(anIterBtn.value(), SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
131 QMap<int, SalomeApp_IntSpinBox*>::iterator anIterSpin;
132 for (anIterSpin = mySpinBox.begin(); anIterSpin != mySpinBox.end(); ++anIterSpin)
133 connect(anIterSpin.value(), SIGNAL(valueChanged(int)), this, SLOT(ValueChangedInSpinBox(int)));
135 // init controls and fields
136 initName(tr("GEOM_BLOCK_MULTITRSF"));
138 myConstructorId = -1;
139 ConstructorsClicked(0);
142 //=================================================================================
143 // function : ConstructorsClicked()
144 // purpose : Radio button management
145 //=================================================================================
146 void BlocksGUI_TrsfDlg::ConstructorsClicked (int constructorId)
148 if (myConstructorId == constructorId)
151 myConstructorId = constructorId;
154 myShape = GEOM::GEOM_Object::_nil();
155 myFaces[Face1] = myFaces[Face2] = -1;
156 myFaces[Face1U] = myFaces[Face2U] = -1;
157 myFaces[Face1V] = myFaces[Face2V] = -1;
160 QMap<int, QLineEdit*>::iterator anIterLE;
161 for (anIterLE = mySelName.begin(); anIterLE != mySelName.end(); ++anIterLE)
162 anIterLE.value()->setText("");
164 switch (constructorId) {
168 mySpinBox[SpinBox1]->setValue(2);
169 mySelBtn[MainObj1]->click();
174 mySpinBox[SpinBox2U]->setValue(2);
175 mySpinBox[SpinBox2V]->setValue(2);
176 mySelBtn[MainObj2]->click();
182 qApp->processEvents();
184 resize(minimumSizeHint());
186 // on dialog initialization we init the first field with a selected object (if any)
187 SelectionIntoArgument();
190 //=================================================================================
191 // function : ClickOnOk()
193 //=================================================================================
194 void BlocksGUI_TrsfDlg::ClickOnOk()
200 //=================================================================================
201 // function : ClickOnApply()
203 //=================================================================================
204 bool BlocksGUI_TrsfDlg::ClickOnApply()
213 //=================================================================================
214 // function : SelectionIntoArgument()
215 // purpose : Called when selection is changed or on dialog initialization or activation
216 //=================================================================================
217 void BlocksGUI_TrsfDlg::SelectionIntoArgument()
220 myEditCurrentArgument->setText("");
222 // Get index of current selection focus
224 QMap<int, QLineEdit*>::iterator anIter;
225 for (anIter = mySelName.begin(); anIter != mySelName.end(); ++anIter) {
226 if (myEditCurrentArgument == anIter.value()) {
227 aCurrFocus = anIter.key();
232 LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
233 SALOME_ListIO aSelList;
234 aSelMgr->selectedObjects(aSelList);
237 GEOM::GEOM_Object_var anObj = GEOM::GEOM_Object::_nil();
239 if (aCurrFocus == MainObj1 || aCurrFocus == MainObj2)
241 // If selection of main object is activated
242 if (aSelList.Extent() == 1) {
243 anObj = GEOMBase::ConvertIOinGEOMObject( aSelList.First() );
245 if ( GEOMBase::IsShape(anObj) ) {
246 aName = GEOMBase::GetName(anObj);
249 myEditCurrentArgument->setText(aName);
253 else if (aCurrFocus == Face1 || aCurrFocus == Face2 ||
254 aCurrFocus == Face1U || aCurrFocus == Face2U ||
255 aCurrFocus == Face1V || aCurrFocus == Face2V) {
256 // If face selection is activated
258 if (aSelList.Extent() == 1) {
259 anObj = GEOMBase::ConvertIOinGEOMObject( aSelList.First() );
260 if ( GEOMBase::IsShape(anObj) ) {
261 aName = GEOMBase::GetName(anObj);
262 TColStd_IndexedMapOfInteger anIndexes;
263 aSelMgr->GetIndexes(aSelList.First(), anIndexes);
265 if (anIndexes.Extent() == 1) {
266 anIndex = anIndexes(1);
267 aName += QString(":face_%1").arg(anIndex);
271 myEditCurrentArgument->setText(aName);
272 myFaces[aCurrFocus] = anIndex;
276 switch (aCurrFocus) {
279 if (!myShape->_is_nil() && myFaces[Face1] == -1)
280 mySelBtn[Face1]->click();
283 if (myFaces[Face1] != -1 && myFaces[Face2] == -1)
284 mySelBtn[Face2]->click();
287 if (myFaces[Face2] != -1 && myShape->_is_nil())
288 mySelBtn[MainObj1]->click();
293 if (!myShape->_is_nil() && myFaces[Face1U] == -1)
294 mySelBtn[Face1U]->click();
297 if (myFaces[Face1U] != -1 && myFaces[Face2U] == -1)
298 mySelBtn[Face2U]->click();
301 if (myFaces[Face2U] != -1 && myFaces[Face1V] == -1)
302 mySelBtn[Face1V]->click();
305 if (myFaces[Face1V] != -1 && myFaces[Face2V] == -1)
306 mySelBtn[Face2V]->click();
309 if (myFaces[Face2V] != -1 && myShape->_is_nil())
310 mySelBtn[MainObj1]->click();
318 //=================================================================================
319 // function : SetEditCurrentArgument()
321 //=================================================================================
322 void BlocksGUI_TrsfDlg::SetEditCurrentArgument()
324 QPushButton* aSender = (QPushButton*)sender();
327 disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0);
331 myGeomGUI->getApp()->selectionMgr()->clearSelected();
334 switch (myConstructorId) {
336 mySelBtn[MainObj1]->setDown(false);
337 mySelBtn[Face1]->setDown(false);
338 mySelBtn[Face2]->setDown(false);
340 mySelName[MainObj1]->setEnabled(false);
341 mySelName[Face1]->setEnabled(false);
342 mySelName[Face2]->setEnabled(false);
345 mySelBtn[MainObj2]->setDown(false);
346 mySelBtn[Face1U]->setDown(false);
347 mySelBtn[Face2U]->setDown(false);
348 mySelBtn[Face1V]->setDown(false);
349 mySelBtn[Face2V]->setDown(false);
351 mySelName[MainObj2]->setEnabled(false);
352 mySelName[Face1U]->setEnabled(false);
353 mySelName[Face2U]->setEnabled(false);
354 mySelName[Face1V]->setEnabled(false);
355 mySelName[Face2V]->setEnabled(false);
361 // set line edit as current argument
362 QMap<int, QPushButton*>::iterator anIter;
363 for (anIter = mySelBtn.begin(); anIter != mySelBtn.end(); ++anIter) {
364 if (anIter.value() == aSender) {
365 myEditCurrentArgument = mySelName[anIter.key()];
371 myEditCurrentArgument->setEnabled(true);
372 myEditCurrentArgument->setFocus();
374 // enable push button
375 // after setFocus(), because it will be setDown(false) when loses focus
376 aSender->setDown(true);
381 //=================================================================================
382 // function : ActivateThisDialog()
384 //=================================================================================
385 void BlocksGUI_TrsfDlg::ActivateThisDialog()
387 GEOMBase_Skeleton::ActivateThisDialog();
394 //=================================================================================
395 // function : enterEvent()
397 //=================================================================================
398 void BlocksGUI_TrsfDlg::enterEvent (QEvent*)
400 if (!mainFrame()->GroupConstructors->isEnabled())
401 ActivateThisDialog();
404 //=================================================================================
405 // function : ValueChangedInSpinBox()
407 //=================================================================================
408 void BlocksGUI_TrsfDlg::ValueChangedInSpinBox(int)
413 //=================================================================================
414 // function : createSelWg()
416 //=================================================================================
417 void BlocksGUI_TrsfDlg::createSelWg (const QString& theLbl,
422 QLabel* lab = new QLabel(theLbl, theParent);
423 mySelBtn[theId] = new QPushButton(theParent);
424 mySelBtn[theId]->setIcon(thePix);
425 mySelBtn[theId]->setSizePolicy(QSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed));
426 mySelName[theId] = new QLineEdit(theParent);
427 mySelName[theId]->setReadOnly(true);
429 if (!theParent->layout()) {
430 l = new QGridLayout(theParent);
431 l->setMargin(9); l->setSpacing(6);
434 l = qobject_cast<QGridLayout*>(theParent->layout());
436 int row = l->rowCount();
437 l->addWidget(lab, row, 0);
438 l->addWidget(mySelBtn[theId], row, 1);
439 l->addWidget(mySelName[theId], row, 2);
442 //=================================================================================
443 // function : createSpinWg()
445 //=================================================================================
446 void BlocksGUI_TrsfDlg::createSpinWg (const QString& theLbl,
450 QLabel* lab = new QLabel(theLbl, theParent);
451 mySpinBox[theId] = new SalomeApp_IntSpinBox(theParent);
453 if (!theParent->layout()) {
454 l = new QGridLayout(theParent);
455 l->setMargin(9); l->setSpacing(6);
458 l = qobject_cast<QGridLayout*>(theParent->layout());
460 int row = l->rowCount();
461 l->addWidget(lab, row, 0);
462 l->addWidget(mySpinBox[theId], row, 2);
465 //=================================================================================
466 // function : activateSelection
467 // purpose : Activate selection in accordance with myEditCurrentArgument
468 //=================================================================================
469 void BlocksGUI_TrsfDlg::activateSelection()
471 globalSelection(GEOM_ALLSHAPES);
472 if (!myShape->_is_nil() &&
473 (myEditCurrentArgument == mySelName[Face1 ] ||
474 myEditCurrentArgument == mySelName[Face2 ] ||
475 myEditCurrentArgument == mySelName[Face1U] ||
476 myEditCurrentArgument == mySelName[Face2U] ||
477 myEditCurrentArgument == mySelName[Face1V] ||
478 myEditCurrentArgument == mySelName[Face2V]))
480 // Local selection is available only in the OCC Viewer
481 if (getDesktop()->activeWindow()->getViewManager()->getType() == OCCViewer_Viewer::Type()) {
482 localSelection(myShape, TopAbs_FACE);
485 connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()),
486 this, SLOT(SelectionIntoArgument()));
489 //=================================================================================
490 // function : enableWidgets
491 // purpose : Enable widgets of faces in accordance with value of main object
492 //=================================================================================
493 void BlocksGUI_TrsfDlg::enableWidgets()
495 int anId = getConstructorId();
497 bool toEnable = !myShape->_is_nil();
500 //mySelName[Face1]->setEnabled(toEnable);
501 //mySelName[Face2]->setEnabled(toEnable);
502 //mySelBtn[Face1]->setEnabled(toEnable);
503 //mySelBtn[Face2]->setEnabled(toEnable);
506 mySelName[Face1]->setText("");
507 mySelName[Face2]->setText("");
512 else if (anId == 1) {
513 //mySelName[Face1U]->setEnabled(toEnable);
514 //mySelName[Face2U]->setEnabled(toEnable);
515 //mySelName[Face1V]->setEnabled(toEnable);
516 //mySelName[Face2V]->setEnabled(toEnable);
517 //mySelBtn[Face1U]->setEnabled(toEnable);
518 //mySelBtn[Face2U]->setEnabled(toEnable);
519 //mySelBtn[Face1V]->setEnabled(toEnable);
520 //mySelBtn[Face2V]->setEnabled(toEnable);
523 mySelName[Face1U]->setText("");
524 mySelName[Face2U]->setText("");
525 mySelName[Face1V]->setText("");
526 mySelName[Face2V]->setText("");
527 myFaces[Face1U] = -1;
528 myFaces[Face2U] = -1;
529 myFaces[Face1V] = -1;
530 myFaces[Face2V] = -1;
535 //=================================================================================
536 // function : createOperation
538 //=================================================================================
539 GEOM::GEOM_IOperations_ptr BlocksGUI_TrsfDlg::createOperation()
541 return getGeomEngine()->GetIBlocksOperations(getStudyId());
544 //=================================================================================
545 // function : isValid
546 // purpose : Verify validity of input data
547 //=================================================================================
548 bool BlocksGUI_TrsfDlg::isValid (QString& msg)
550 bool ok = false, okSP = true;
551 switch (getConstructorId()) {
553 ok = !myShape->_is_nil() && myFaces[Face1] > 0;
554 okSP = mySpinBox[SpinBox1]->isValid( msg, !IsPreview() );
557 ok = !myShape->_is_nil() && myFaces[Face1U] > 0 && myFaces[Face1V] > 0;
558 okSP = mySpinBox[SpinBox2U]->isValid( msg, !IsPreview() ) && okSP;
559 okSP = mySpinBox[SpinBox2V]->isValid( msg, !IsPreview() ) && okSP;
567 //=================================================================================
568 // function : execute
570 //=================================================================================
571 bool BlocksGUI_TrsfDlg::execute (ObjectList& objects)
575 GEOM::GEOM_Object_var anObj;
577 GEOM::GEOM_IBlocksOperations_var anOper = GEOM::GEOM_IBlocksOperations::_narrow(getOperation());
579 switch (getConstructorId()) {
581 anObj = anOper->MakeMultiTransformation1D(myShape,
582 myFaces[Face1], myFaces[Face2],
583 mySpinBox[SpinBox1]->value());
584 if (!anObj->_is_nil() && !IsPreview())
586 QStringList aParameters;
587 aParameters << "" << "";
588 aParameters << mySpinBox[SpinBox1]->text();
589 anObj->SetParameters(aParameters.join(":").toLatin1().constData());
594 anObj = anOper->MakeMultiTransformation2D (myShape,
595 myFaces[Face1U], myFaces[Face2U],
596 mySpinBox[SpinBox2U]->value(),
597 myFaces[Face1V], myFaces[Face2V],
598 mySpinBox[SpinBox2V]->value());
599 if (!anObj->_is_nil() && !IsPreview())
601 QStringList aParameters;
602 aParameters << "" << "";
603 aParameters << mySpinBox[SpinBox2U]->text();
604 aParameters << "" << "";
605 aParameters << mySpinBox[SpinBox2V]->text();
606 anObj->SetParameters(aParameters.join(":").toLatin1().constData());
614 if (!anObj->_is_nil())
615 objects.push_back(anObj._retn());