1 // SMESH SMESHGUI : GUI for SMESH 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.org
24 // File : SMESHGUI_GroupDlg.cxx
25 // Author : Natalia KOPNOVA
29 #include "SMESHGUI_GroupDlg.h"
30 #include "SMESHGUI_FilterDlg.h"
31 #include "SMESHGUI_Filter.h"
34 #include "SMESHGUI_Utils.h"
35 #include "SMESHGUI_VTKUtils.h"
36 #include "SMESHGUI_MeshUtils.h"
37 #include "SMESHGUI_GroupUtils.h"
38 #include "SMESHGUI_FilterUtils.h"
39 #include "SMESHGUI_GEOMGenUtils.h"
41 #include "SALOMEGUI_QtCatchCorbaException.hxx"
42 #include "SALOME_ListIteratorOfListIO.hxx"
43 #include "VTKViewer_ViewFrame.h"
44 #include "QAD_Application.h"
45 #include "QAD_Desktop.h"
46 #include "QAD_MessageBox.h"
47 #include "QAD_RightFrame.h"
48 #include "utilities.h"
50 #include "SMESH_Actor.h"
55 #include <qbuttongroup.h>
56 #include <qgroupbox.h>
59 #include <qlineedit.h>
60 #include <qpushbutton.h>
61 #include <qradiobutton.h>
62 #include <qcheckbox.h>
67 #include <qmemarray.h>
68 #include <qwidgetstack.h>
76 //=================================================================================
77 // class : SMESHGUI_GroupDlg()
79 //=================================================================================
80 SMESHGUI_GroupDlg::SMESHGUI_GroupDlg( QWidget* parent, const char* name, SALOME_Selection* theSel,
81 SMESH::SMESH_Mesh_ptr theMesh, bool modal, WFlags fl )
82 : QDialog( parent, name, modal, WStyle_Customize | WStyle_NormalBorder | WStyle_Title | WStyle_SysMenu | WDestructiveClose )
84 if ( !name ) setName( "SMESHGUI_GroupDlg" );
85 initDialog(theSel, true);
86 if (!theMesh->_is_nil())
89 mySelectSubMesh->setEnabled(false);
90 mySelectGroup->setEnabled(false);
91 myGeomGroupBtn->setEnabled(false);
92 myGeomGroupLine->setEnabled(false);
95 /* Move widget on the botton right corner of main widget */
97 mySMESHGUI->DefineDlgPosition(this, x, y);
101 SMESHGUI_GroupDlg::SMESHGUI_GroupDlg( QWidget* parent, const char* name, SALOME_Selection* theSel,
102 SMESH::SMESH_Group_ptr theGroup, bool modal, WFlags fl )
103 : QDialog( parent, name, modal, WStyle_Customize | WStyle_NormalBorder | WStyle_Title | WStyle_SysMenu | WDestructiveClose )
105 if ( !name ) setName( "SMESHGUI_GroupDlg" );
106 initDialog(theSel, false);
107 if (!theGroup->_is_nil())
110 mySelectSubMesh->setEnabled(false);
111 mySelectGroup->setEnabled(false);
114 /* Move widget on the botton right corner of main widget */
116 mySMESHGUI->DefineDlgPosition(this, x, y);
120 void SMESHGUI_GroupDlg::initDialog(SALOME_Selection* theSel, bool create)
124 myCurrentLineEdit = 0;
126 QPixmap image0(QAD_Desktop::getResourceManager()->loadPixmap( "SMESH",tr("ICON_SELECT")));
129 setCaption( tr( "SMESH_CREATE_GROUP_TITLE" ) );
131 setCaption( tr( "SMESH_EDIT_GROUP_TITLE" ) );
133 setSizeGripEnabled( TRUE );
135 QGridLayout* aMainLayout = new QGridLayout(this, 7, 3, 11, 6);
137 /***************************************************************/
138 QLabel* meshGroupLab = new QLabel(this, "mesh/group label");
140 meshGroupLab->setText(tr("SMESH_MESH"));
142 meshGroupLab->setText(tr("SMESH_GROUP"));
143 myMeshGroupBtn = new QPushButton(this, "mesh/group button");
144 myMeshGroupBtn->setPixmap(image0);
145 myMeshGroupLine = new QLineEdit(this, "mesh/group line");
146 myMeshGroupLine->setReadOnly(true);
148 /***************************************************************/
149 myTypeGroup = new QButtonGroup(1, Qt::Vertical, this, "Group types");
150 myTypeGroup->setTitle(tr("SMESH_ELEMENTS_TYPE"));
151 myTypeGroup->setExclusive(true);
154 types.append(tr("MESH_NODE"));
155 types.append(tr("SMESH_EDGE"));
156 types.append(tr("SMESH_FACE"));
157 types.append(tr("SMESH_VOLUME"));
159 for (int i = 0; i < types.count(); i++) {
160 rb = new QRadioButton(types[i], myTypeGroup);
162 myTypeGroup->setEnabled(create);
165 /***************************************************************/
166 QLabel* aName = new QLabel(this, "name label");
167 aName->setText(tr("SMESH_NAME"));
168 aName->setMinimumSize(50,0);
169 myName = new QLineEdit(this, "name");
171 /***************************************************************/
172 myGrpTypeGroup = new QButtonGroup(1, Qt::Vertical, this, "Type of group");
173 myGrpTypeGroup->setTitle(tr("SMESH_GROUP_TYPE"));
174 myGrpTypeGroup->setExclusive(true);
175 QRadioButton* rb1 = new QRadioButton( tr("SMESH_GROUP_STANDALONE"), myGrpTypeGroup);
176 QRadioButton* rb2 = new QRadioButton( tr("SMESH_GROUP_GEOMETRY"), myGrpTypeGroup);
177 myGrpTypeGroup->setEnabled(create);
180 /***************************************************************/
181 myWGStack = new QWidgetStack( this, "widget stack");
182 QWidget* wg1 = new QFrame( myWGStack, "first widget" );
183 QWidget* wg2 = new QFrame( myWGStack, "second widget" );
185 /***************************************************************/
186 QGroupBox* aContentBox = new QGroupBox(1, Qt::Horizontal, wg1, "content box");
187 aContentBox->setTitle(tr("SMESH_CONTENT"));
188 QFrame* aContent = new QFrame(aContentBox, "content");
189 QGridLayout* aLayout = new QGridLayout(aContent, 7, 4);
190 aLayout->setSpacing(6);
191 aLayout->setAutoAdd(false);
193 QLabel* aLabel = new QLabel(aContent, "elements label");
194 aLabel->setText(tr("SMESH_ID_ELEMENTS"));
195 myElements = new QListBox(aContent, "elements list");
196 myElements->setSelectionMode(QListBox::Extended);
198 myFilter = new QPushButton(aContent, "filter");
199 myFilter->setText(tr("SMESH_BUT_FILTER"));
200 QPushButton* aAddBtn = new QPushButton(aContent, "add");
201 aAddBtn->setText(tr("SMESH_BUT_ADD"));
202 QPushButton* aRemoveBtn = new QPushButton(aContent, "remove");
203 aRemoveBtn->setText(tr("SMESH_BUT_REMOVE"));
204 QPushButton* aSortBtn = new QPushButton(aContent, "sort");
205 aSortBtn->setText(tr("SMESH_BUT_SORT"));
207 aLayout->addWidget(aLabel, 0, 0);
208 aLayout->addMultiCellWidget(myElements, 1, 6, 0, 0);
209 aLayout->addWidget(myFilter, 1, 2);
210 aLayout->addWidget(aAddBtn, 3, 2);
211 aLayout->addWidget(aRemoveBtn, 4, 2);
212 aLayout->addWidget(aSortBtn, 6, 2);
214 aLayout->setColStretch(0, 1);
215 aLayout->addColSpacing(1, 20);
216 aLayout->addColSpacing(3, 20);
217 aLayout->setRowStretch(2, 1);
218 aLayout->setRowStretch(5, 1);
220 /***************************************************************/
221 QGroupBox* aSelectBox = new QGroupBox(3, Qt::Horizontal, wg1, "select box");
222 aSelectBox->setTitle(tr("SMESH_SELECT_FROM"));
224 mySelectSubMesh = new QCheckBox(aSelectBox, "submesh checkbox");
225 mySelectSubMesh->setText(tr("SMESH_SUBMESH"));
226 mySelectSubMesh->setMinimumSize(50, 0);
227 mySubMeshBtn = new QPushButton(aSelectBox, "submesh button");
228 mySubMeshBtn->setText("");
229 mySubMeshBtn->setPixmap(image0);
230 mySubMeshLine = new QLineEdit(aSelectBox, "submesh line");
231 mySubMeshLine->setReadOnly(true);
232 onSelectSubMesh(false);
234 mySelectGroup = new QCheckBox(aSelectBox, "group checkbox");
235 mySelectGroup->setText(tr("SMESH_GROUP"));
236 mySelectGroup->setMinimumSize(50, 0);
237 myGroupBtn = new QPushButton(aSelectBox, "group button");
238 myGroupBtn->setText("");
239 myGroupBtn->setPixmap(image0);
240 myGroupLine = new QLineEdit(aSelectBox, "group line");
241 myGroupLine->setReadOnly(true);
242 onSelectGroup(false);
244 /***************************************************************/
245 QGridLayout* wg1Layout = new QGridLayout( wg1, 3, 1, 0, 6 );
246 wg1Layout->addWidget(aContentBox, 0, 0);
247 wg1Layout->addWidget(aSelectBox, 1, 0);
248 wg1Layout->setRowStretch(2, 5);
250 /***************************************************************/
251 QLabel* geomObject = new QLabel(wg2, "geometry object label");
252 geomObject->setText(tr("SMESH_OBJECT_GEOM"));
253 myGeomGroupBtn = new QPushButton(wg2, "geometry group button");
254 myGeomGroupBtn->setText("");
255 myGeomGroupBtn->setPixmap(image0);
256 myGeomGroupLine = new QLineEdit(wg2, "geometry group line");
257 myGeomGroupLine->setReadOnly(true); //VSR ???
258 onSelectGeomGroup(false);
260 /***************************************************************/
261 QGridLayout* wg2Layout = new QGridLayout( wg2, 2, 3, 0, 6 );
262 wg2Layout->addWidget(geomObject, 0, 0);
263 wg2Layout->addWidget(myGeomGroupBtn, 0, 1);
264 wg2Layout->addWidget(myGeomGroupLine,0, 2);
265 wg2Layout->setRowStretch(1, 5);
267 /***************************************************************/
268 QVBoxLayout* dumb = new QVBoxLayout(myWGStack);
269 dumb->addWidget(wg1);
270 dumb->addWidget(wg2);
271 myWGStack->addWidget( wg1, myGrpTypeGroup->id(rb1) );
272 myWGStack->addWidget( wg2, myGrpTypeGroup->id(rb2) );
274 /***************************************************************/
275 QFrame* aButtons = new QFrame(this, "button box");
276 aButtons->setFrameStyle(QFrame::Box | QFrame::Sunken);
277 QHBoxLayout* aBtnLayout = new QHBoxLayout(aButtons, 11, 6);
278 aBtnLayout->setAutoAdd(false);
280 QPushButton* aOKBtn = new QPushButton(aButtons, "ok");
281 aOKBtn->setText(tr("SMESH_BUT_OK"));
282 aOKBtn->setAutoDefault(true);
283 aOKBtn->setDefault(true);
284 QPushButton* aApplyBtn = new QPushButton(aButtons, "apply");
285 aApplyBtn->setText(tr("SMESH_BUT_APPLY"));
286 aApplyBtn->setAutoDefault(true);
287 QPushButton* aCloseBtn = new QPushButton(aButtons, "close");
288 aCloseBtn->setText(tr("SMESH_BUT_CLOSE"));
289 aCloseBtn->setAutoDefault(true);
291 aBtnLayout->addWidget(aOKBtn);
292 aBtnLayout->addWidget(aApplyBtn);
293 aBtnLayout->addStretch();
294 aBtnLayout->addWidget(aCloseBtn);
296 /***************************************************************/
297 aMainLayout->addWidget(meshGroupLab, 0, 0);
298 aMainLayout->addWidget(myMeshGroupBtn, 0, 1);
299 aMainLayout->addWidget(myMeshGroupLine, 0, 2);
300 aMainLayout->addMultiCellWidget(myTypeGroup, 1, 1, 0, 2);
301 aMainLayout->addWidget(aName, 2, 0);
302 aMainLayout->addWidget(myName, 2, 2);
303 aMainLayout->addMultiCellWidget(myGrpTypeGroup, 3, 3, 0, 2);
304 aMainLayout->addMultiCellWidget(myWGStack, 4, 4, 0, 2);
305 aMainLayout->setRowStretch( 5, 5 );
306 aMainLayout->addMultiCellWidget(aButtons, 6, 6, 0, 2);
308 /* signals and slots connections */
309 connect(myMeshGroupBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
311 connect(myGrpTypeGroup, SIGNAL(clicked(int)), this, SLOT(onGrpTypeChanged(int)));
313 connect(myTypeGroup, SIGNAL(clicked(int)), this, SLOT(onTypeChanged(int)));
315 connect(myName, SIGNAL(textChanged(const QString&)), this, SLOT(onNameChanged(const QString&)));
316 connect(myElements, SIGNAL(selectionChanged()), this, SLOT(onListSelectionChanged()));
318 connect(myFilter, SIGNAL(clicked()), this, SLOT(setFilters()));
319 connect(aAddBtn, SIGNAL(clicked()), this, SLOT(onAdd()));
320 connect(aRemoveBtn, SIGNAL(clicked()), this, SLOT(onRemove()));
321 connect(aSortBtn, SIGNAL(clicked()), this, SLOT(onSort()));
323 connect(mySelectSubMesh, SIGNAL(toggled(bool)), this, SLOT(onSelectSubMesh(bool)));
324 connect(mySelectGroup, SIGNAL(toggled(bool)), this, SLOT(onSelectGroup(bool)));
325 connect(mySubMeshBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
326 connect(myGroupBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
327 connect(myGeomGroupBtn, SIGNAL(clicked()), this, SLOT(setCurrentSelection()));
329 connect(aOKBtn, SIGNAL(clicked()), this, SLOT(onOK()));
330 connect(aApplyBtn, SIGNAL(clicked()), this, SLOT(onApply()));
331 connect(aCloseBtn, SIGNAL(clicked()), this, SLOT(onClose()));
334 mySelection = theSel;
335 mySMESHGUI = SMESHGUI::GetSMESHGUI();
336 mySMESHGUI->SetActiveDialogBox(this);
337 mySMESHGUI->SetState(800);
339 mySelectionMode = -1;
340 myMeshFilter = new SMESH_TypeFilter(MESH);
341 mySubMeshFilter = new SMESH_TypeFilter(SUBMESH);
342 myGroupFilter = new SMESH_TypeFilter(GROUP);
344 connect(mySMESHGUI, SIGNAL(SignalDeactivateActiveDialog()), this, SLOT(onDeactivate()));
345 connect(mySMESHGUI, SIGNAL(SignalCloseAllDialogs()), this, SLOT(onClose()));
346 connect(mySelection, SIGNAL(currentSelectionChanged()), this, SLOT(onObjectSelectionChanged()));
348 myGrpTypeGroup->setButton(myGrpTypeGroup->id(rb1)); // VSR !!!
349 onGrpTypeChanged(myGrpTypeGroup->id(rb1)); // VSR!!!
351 if (myMesh->_is_nil() )
352 myTypeGroup->setButton(0);
357 //=================================================================================
358 // function : ~SMESHGUI_GroupDlg()
359 // purpose : Destroys the object and frees any allocated resources
360 //=================================================================================
361 SMESHGUI_GroupDlg::~SMESHGUI_GroupDlg()
363 // no need to delete child widgets, Qt does it all for us
364 if ( myFilterDlg != 0 )
366 myFilterDlg->reparent( 0, QPoint() );
372 //=================================================================================
375 //=================================================================================
376 void SMESHGUI_GroupDlg::init(SMESH::SMESH_Mesh_ptr theMesh)
378 /* init data from current selection */
379 myMesh = SMESH::SMESH_Mesh::_duplicate(theMesh);
380 myGroup = SMESH::SMESH_Group::_nil();
382 myActor = SMESH::FindActorByObject(myMesh);
383 SMESH::SetPickable(myActor);
385 QString aName = mySelection->firstIObject()->getName();
386 myMeshGroupLine->setText(aName) ;
387 myMeshGroupLine->home( false );
389 myCurrentLineEdit = 0;
391 myTypeGroup->setButton(0);
395 //=================================================================================
398 //=================================================================================
399 void SMESHGUI_GroupDlg::init(SMESH::SMESH_Group_ptr theGroup)
401 myMesh = theGroup->GetMesh();
402 myGroup = SMESH::SMESH_Group::_duplicate(theGroup);
404 myActor = SMESH::FindActorByObject(myMesh);
406 myActor = SMESH::FindActorByObject(myGroup);
407 SMESH::SetPickable(myActor);
410 switch(theGroup->GetType()) {
411 case SMESH::NODE: aType= 0; break;
412 case SMESH::EDGE: aType = 1; break;
413 case SMESH::FACE: aType = 2; break;
414 case SMESH::VOLUME: aType = 3; break;
417 myName->setText(myGroup->GetName());
419 myMeshGroupLine->setText(myGroup->GetName());
421 myCurrentLineEdit = 0;
422 myTypeGroup->setButton(aType);
424 setSelectionMode(aType);
428 if (!theGroup->IsEmpty()) {
429 SMESH::long_array_var anElements = myGroup->GetListOfID();
430 int k = anElements->length();
431 for (int i = 0; i < k; i++) {
432 myIdList.append(anElements[i]);
433 myElements->insertItem(QString::number(anElements[i]));
435 myElements->selectAll(true);
440 //=================================================================================
441 // function : updateButtons()
443 //=================================================================================
444 void SMESHGUI_GroupDlg::updateButtons()
448 if (myGrpTypeId == 0)
449 enable = !myName->text().stripWhiteSpace().isEmpty() && myElements->count() > 0;
450 else if (myGrpTypeId == 1)
451 enable = !myName->text().stripWhiteSpace().isEmpty() && !CORBA::is_nil( myGeomGroup );
453 aBtn = (QPushButton*) child("ok", "QPushButton");
454 if (aBtn) aBtn->setEnabled(enable);
455 aBtn = (QPushButton*) child("apply", "QPushButton");
456 if (aBtn) aBtn->setEnabled(enable);
459 //=================================================================================
460 // function : onNameChanged()
462 //=================================================================================
463 void SMESHGUI_GroupDlg::onNameChanged(const QString& text)
468 //=================================================================================
469 // function : onTypeChanged()
470 // purpose : Group elements type radio button management
471 //=================================================================================
472 void SMESHGUI_GroupDlg::onTypeChanged(int id)
474 if (myTypeId != id) {
476 if (myCurrentLineEdit == 0)
477 setSelectionMode(id);
482 //=================================================================================
483 // function : onGrpTypeChanged()
484 // purpose : Group type radio button management
485 //=================================================================================
486 void SMESHGUI_GroupDlg::onGrpTypeChanged(int id)
488 if (myGrpTypeId != id) {
489 myWGStack->raiseWidget( id );
490 onSelectGeomGroup(id == 1);
495 //=================================================================================
496 // function : setSelectionMode()
497 // purpose : Radio button management
498 //=================================================================================
499 void SMESHGUI_GroupDlg::setSelectionMode(int theMode)
502 if (myMesh->_is_nil())
505 if (mySelectionMode != theMode) {
506 mySelection->ClearIObjects();
507 mySelection->ClearFilters();
508 SMESH::SetPointRepresentation(false);
513 myActor->SetPointRepresentation(true);
515 SMESH::SetPointRepresentation(true);
516 QAD_Application::getDesktop()->SetSelectionMode(NodeSelection, true);
519 QAD_Application::getDesktop()->SetSelectionMode(EdgeSelection, true);
522 QAD_Application::getDesktop()->SetSelectionMode(FaceSelection, true);
525 QAD_Application::getDesktop()->SetSelectionMode(VolumeSelection, true);
529 QAD_Application::getDesktop()->SetSelectionMode(ActorSelection, true);
531 mySelection->AddFilter(mySubMeshFilter);
532 else if (theMode == 5)
533 mySelection->AddFilter(myGroupFilter);
534 else if (theMode == 6)
535 mySelection->AddFilter(myMeshFilter);
537 mySelectionMode = theMode;
541 //=================================================================================
542 // function : onApply()
544 //=================================================================================
545 bool SMESHGUI_GroupDlg::onApply()
547 if (mySMESHGUI->ActiveStudyLocked())
550 if ( myGrpTypeId == 0 && !myName->text().stripWhiteSpace().isEmpty() && myElements->count() > 0) {
551 mySelection->ClearIObjects();
552 if (myGroup->_is_nil()) {
553 SMESH::ElementType aType = SMESH::ALL;
555 case 0: aType = SMESH::NODE; break;
556 case 1: aType = SMESH::EDGE; break;
557 case 2: aType = SMESH::FACE; break;
558 case 3: aType = SMESH::VOLUME; break;
560 SMESH::long_array_var anIdList = new SMESH::long_array;
561 int i, k = myElements->count();
563 QListBoxItem* anItem;
564 for (i = 0, anItem = myElements->firstItem(); anItem != 0; i++, anItem = anItem->next()) {
565 anIdList[i] = anItem->text().toInt();
568 myGroup = SMESH::AddGroup(myMesh, aType, myName->text());
569 myGroup->Add(anIdList.inout());
571 /* init for next operation */
574 myGroup = SMESH::SMESH_Group::_nil();
577 myGroup->SetName(myName->text());
579 QValueList<int> aAddList;
580 QValueList<int>::iterator anIt;
581 QListBoxItem* anItem;
583 for (anItem = myElements->firstItem(); anItem != 0; anItem = anItem->next()) {
584 int anId = anItem->text().toInt();
585 if ((anIt = myIdList.find(anId)) == myIdList.end())
586 aAddList.append(anId);
588 myIdList.remove(anIt);
590 if (!aAddList.empty()) {
591 SMESH::long_array_var anIdList = new SMESH::long_array;
592 anIdList->length(aAddList.count());
594 for (i = 0, anIt = aAddList.begin(); anIt != aAddList.end(); anIt++, i++)
596 myGroup->Add(anIdList.inout());
598 if (!myIdList.empty()) {
599 SMESH::long_array_var anIdList = new SMESH::long_array;
600 anIdList->length(myIdList.count());
602 for (i = 0, anIt = myIdList.begin(); anIt != myIdList.end(); anIt++, i++)
604 myGroup->Remove(anIdList.inout());
606 /* init for next operation */
608 for (anItem = myElements->firstItem(); anItem != 0; anItem = anItem->next())
609 myIdList.append(anItem->text().toInt());
612 mySMESHGUI->GetActiveStudy()->updateObjBrowser(true);
613 SMESH::UpdateView(); // asv: fix of BUG PAL5515
614 mySelection->ClearIObjects();
617 else if (myGrpTypeId == 1 && !myName->text().stripWhiteSpace().isEmpty() && !CORBA::is_nil( myGeomGroup ))
619 SMESH::ElementType aType = SMESH::ALL;
621 case 0: aType = SMESH::NODE; break;
622 case 1: aType = SMESH::EDGE; break;
623 case 2: aType = SMESH::FACE; break;
624 case 3: aType = SMESH::VOLUME; break;
627 SALOMEDS::Study_var aStudy = SMESH::GetActiveStudyDocument();
628 GEOM::GEOM_IGroupOperations_var aGroupOp = SMESH::GetGEOMGen()->GetIGroupOperations(aStudy->StudyId());
630 SMESH::SMESH_GroupOnGeom_var aGroupOnGeom = myMesh->CreateGroupFromGEOM(aType, myName->text(),myGeomGroup);
632 mySMESHGUI->GetActiveStudy()->updateObjBrowser(true);
633 mySelection->ClearIObjects();
634 /* init for next operation */
642 //=================================================================================
645 //=================================================================================
646 void SMESHGUI_GroupDlg::onOK()
652 static bool busy = false;
653 //=================================================================================
654 // function : onListSelectionChanged()
655 // purpose : Called when selection in element list is changed
656 //=================================================================================
657 void SMESHGUI_GroupDlg::onListSelectionChanged()
659 // MESSAGE("SMESHGUI_GroupDlg::onListSelectionChanged(); myActor = " << myActor);
660 if (busy || !myActor) return;
663 if (myCurrentLineEdit == 0) {
664 mySelection->ClearIObjects();
665 TColStd_MapOfInteger aIndexes;
666 QListBoxItem* anItem;
667 for (anItem = myElements->firstItem(); anItem != 0; anItem = anItem->next()) {
668 if (anItem->isSelected()) {
669 int anId = anItem->text().toInt();
673 mySelection->AddOrRemoveIndex(myActor->getIO(), aIndexes, false, false);
674 mySelection->AddIObject(myActor->getIO());
679 //=================================================================================
680 // function : onObjectSelectionChanged()
681 // purpose : Called when selection in 3D view or ObjectBrowser is changed
682 //=================================================================================
683 void SMESHGUI_GroupDlg::onObjectSelectionChanged()
685 if (busy || !isEnabled()) return;
688 int aNbSel = mySelection->IObjectCount();
689 myElements->clearSelection();
691 if (myCurrentLineEdit) {
692 myCurrentLineEdit->setText("") ;
693 QString aString = "";
695 if (myCurrentLineEdit == myMeshGroupLine)
697 mySelectSubMesh->setEnabled(false);
698 mySelectGroup->setEnabled(false);
699 myGroupLine->setText("");
700 mySubMeshLine->setText("");
702 myGeomGroupBtn->setEnabled(false);
703 myGeomGroupLine->setEnabled(false);
704 myGeomGroupLine->setText("");
712 myGroup = SMESH::SMESH_Group::_nil();
713 myMesh = SMESH::SMESH_Mesh::_nil();
717 Handle(SALOME_InteractiveObject) IO = mySelection->firstIObject();
721 myMesh = SMESH::IObjectToInterface<SMESH::SMESH_Mesh>(IO);
722 if(myMesh->_is_nil())
727 myGroup = SMESH::SMESH_Group::_nil();
729 myActor = SMESH::FindActorByObject(myMesh);
730 SMESH::SetPickable(myActor);
732 aString = mySelection->firstIObject()->getName();
733 myMeshGroupLine->setText(aString) ;
734 myMeshGroupLine->home( false );
736 mySelectSubMesh->setEnabled(true);
737 mySelectGroup->setEnabled(true);
738 myGeomGroupBtn->setEnabled(true);
739 myGeomGroupLine->setEnabled(true);
744 SMESH::SMESH_Group_var aGroup = SMESH::IObjectToInterface<SMESH::SMESH_Group>(IO);
745 if(aGroup->_is_nil())
751 myCurrentLineEdit = 0;
754 mySelectSubMesh->setEnabled(true);
755 mySelectGroup->setEnabled(true);
756 myGeomGroupBtn->setEnabled(true);
757 myGeomGroupLine->setEnabled(true);
759 myCurrentLineEdit = 0;
769 setSelectionMode(myTypeId);
774 else if (myCurrentLineEdit == myGeomGroupLine)
779 myGeomGroup = GEOM::GEOM_Object::_nil();
784 Standard_Boolean testResult = Standard_False;
785 myGeomGroup = GEOMBase::ConvertIOinGEOMObject(mySelection->firstIObject(), testResult );
787 // Check if the object is a geometry group
788 if(!testResult || CORBA::is_nil( myGeomGroup ))
790 myGeomGroup = GEOM::GEOM_Object::_nil();
794 // Check if group constructed on the same shape as a mesh or on its child
795 SALOMEDS::Study_var aStudy = SMESH::GetActiveStudyDocument();
796 GEOM::GEOM_IGroupOperations_var anOp = SMESH::GetGEOMGen()->GetIGroupOperations(aStudy->StudyId());
797 // The main shape of the group
798 GEOM::GEOM_Object_var aGroupMainShape;
799 if( myGeomGroup->GetType() == 37 )
800 aGroupMainShape = anOp->GetMainShape( myGeomGroup );
802 aGroupMainShape = GEOM::GEOM_Object::_duplicate(myGeomGroup);
803 SALOMEDS::SObject_var aGroupMainShapeSO = aStudy->FindObjectIOR( aStudy->ConvertObjectToIOR(aGroupMainShape) );
805 SALOMEDS::SObject_var aMeshSO = aStudy->FindObjectIOR( aStudy->ConvertObjectToIOR(myMesh) );
806 if ( aMeshSO->_is_nil() ) {
807 myGeomGroup = GEOM::GEOM_Object::_nil();
811 SALOMEDS::SObject_var anObj, aRef;
812 bool isRefOrSubShape = false;
813 if ( aMeshSO->FindSubObject( 1, anObj ) && anObj->ReferencedObject( aRef )) {
814 if ( strcmp( aRef->GetID(), aGroupMainShapeSO->GetID() ) == 0 )
815 isRefOrSubShape = true;
818 SALOMEDS::SObject_var aFather = aGroupMainShapeSO->GetFather();
819 SALOMEDS::SComponent_var aComponent = aGroupMainShapeSO->GetFatherComponent();
820 while ( !isRefOrSubShape && strcmp( aFather->GetID(), aComponent->GetID() ) != 0 )
822 if (strcmp( aRef->GetID(), aFather->GetID() ) == 0)
823 isRefOrSubShape = true;
825 aFather = aFather->GetFather();
829 if ( !isRefOrSubShape )
831 myGeomGroup = GEOM::GEOM_Object::_nil();
839 if (myCurrentLineEdit == mySubMeshLine)
840 aString = tr("SMESH_SUBMESH_SELECTED").arg(aNbSel);
841 else if (myCurrentLineEdit == myGroupLine || myCurrentLineEdit == myGeomGroupLine)
842 aString = tr("SMESH_GROUP_SELECTED").arg(aNbSel);
845 aString = mySelection->firstIObject()->getName();
849 myCurrentLineEdit->setText(aString) ;
850 myCurrentLineEdit->home( false );
856 QString aListStr = "";
859 aNbItems = SMESH::GetNameOfSelectedNodes(mySelection, aListStr);
862 aNbItems = SMESH::GetNameOfSelectedElements(mySelection, aListStr);
865 QStringList anElements = QStringList::split(" ", aListStr);
866 QListBoxItem* anItem = 0;
867 for (QStringList::iterator it = anElements.begin(); it != anElements.end(); ++it) {
868 anItem = myElements->findItem(*it, Qt::ExactMatch);
869 if (anItem) myElements->setSelected(anItem, true);
876 if ( !myGroup->_is_nil() )
877 myActor = SMESH::FindActorByObject(myGroup);
879 myActor = SMESH::FindActorByObject(myMesh);
886 //=================================================================================
887 // function : onSelectSubMesh()
888 // purpose : Called when selection in 3D view or ObjectBrowser is changed
889 //=================================================================================
890 void SMESHGUI_GroupDlg::onSelectSubMesh(bool on)
893 if (mySelectGroup->isChecked()) {
894 mySelectGroup->setChecked(false);
896 //VSR: else if (mySelectGeomGroup->isChecked()) {
897 //VSR: mySelectGeomGroup->setChecked(false);
899 myCurrentLineEdit = mySubMeshLine;
903 mySubMeshLine->setText("");
904 myCurrentLineEdit = 0;
906 setSelectionMode(myTypeId);
908 mySubMeshBtn->setEnabled(on);
909 mySubMeshLine->setEnabled(on);
913 //=================================================================================
914 // function : (onSelectGroup)
915 // purpose : Called when selection in 3D view or ObjectBrowser is changed
916 //=================================================================================
917 void SMESHGUI_GroupDlg::onSelectGroup(bool on)
920 if (mySelectSubMesh->isChecked()) {
921 mySelectSubMesh->setChecked(false);
923 myCurrentLineEdit = myGroupLine;
927 myGroupLine->setText("");
928 myCurrentLineEdit = 0;
930 setSelectionMode(myTypeId);
932 myGroupBtn->setEnabled(on);
933 myGroupLine->setEnabled(on);
937 //=================================================================================
938 // function : (onSelectGeomGroup)
939 // purpose : Called when selection in 3D view or ObjectBrowser is changed
940 //=================================================================================
941 void SMESHGUI_GroupDlg::onSelectGeomGroup(bool on)
944 if (mySelectSubMesh->isChecked()) {
945 mySelectSubMesh->setChecked(false);
947 else if (mySelectGroup->isChecked()) {
948 mySelectGroup->setChecked(false);
950 myCurrentLineEdit = myGeomGroupLine;
954 myGeomGroupLine->setText("");
955 myCurrentLineEdit = 0;
957 setSelectionMode(myTypeId);
962 //=================================================================================
963 // function : setCurrentSelection()
965 //=================================================================================
966 void SMESHGUI_GroupDlg::setCurrentSelection()
968 QPushButton* send = (QPushButton*)sender();
969 myCurrentLineEdit = 0;
970 if (send == myMeshGroupBtn) {
971 myCurrentLineEdit = myMeshGroupLine;
976 onObjectSelectionChanged();
978 else if (send == mySubMeshBtn) {
979 myCurrentLineEdit = mySubMeshLine;
980 onObjectSelectionChanged();
982 else if (send == myGroupBtn) {
983 myCurrentLineEdit = myGroupLine;
984 onObjectSelectionChanged();
986 else if (send == myGeomGroupBtn) {
987 myCurrentLineEdit = myGeomGroupLine;
989 onObjectSelectionChanged();
994 //=================================================================================
995 // function : setFilters()
996 // purpose : SLOT. Called when "Filter" button pressed.
997 //=================================================================================
998 void SMESHGUI_GroupDlg::setFilters()
1000 SMESH::ElementType aType = SMESH::ALL;
1003 case 0 : aType = SMESH::NODE; break;
1004 case 1 : aType = SMESH::EDGE; break;
1005 case 2 : aType = SMESH::FACE; break;
1006 case 3 : aType = SMESH::VOLUME; break;
1010 if ( myFilterDlg == 0 )
1012 myFilterDlg = new SMESHGUI_FilterDlg( (QWidget*)parent(), aType );
1013 connect( myFilterDlg, SIGNAL( Accepted() ), SLOT( onFilterAccepted() ) );
1016 myFilterDlg->Init( aType );
1018 myFilterDlg->SetSelection( mySelection );
1019 myFilterDlg->SetMesh( myMesh );
1020 myFilterDlg->SetSourceWg( myElements );
1022 myFilterDlg->show();
1025 //=================================================================================
1026 // function : onFilterAccepted()
1027 // purpose : SLOT. Called when Filter dlg closed with OK button.
1028 // Uncheck "Select submesh" and "Select group" checkboxes
1029 //=================================================================================
1030 void SMESHGUI_GroupDlg::onFilterAccepted()
1032 if ( mySelectSubMesh->isChecked() || mySelectGroup->isChecked() )
1034 mySelectionMode = myTypeId;
1035 mySelectSubMesh->setChecked( false );
1036 mySelectGroup->setChecked( false );
1040 //=================================================================================
1041 // function : onAdd()
1043 //=================================================================================
1044 void SMESHGUI_GroupDlg::onAdd()
1046 int aNbSel = mySelection->IObjectCount();
1047 if (aNbSel == 0 || !myActor || myMesh->_is_nil()) return;
1051 SMESH::ElementType aType = SMESH::ALL;
1053 case 0: aType = SMESH::NODE; break;
1054 case 1: aType = SMESH::EDGE; break;
1055 case 2: aType = SMESH::FACE; break;
1056 case 3: aType = SMESH::VOLUME; break;
1059 if (myCurrentLineEdit == 0) {
1060 //if (aNbSel != 1) { busy = false; return; }
1061 QString aListStr = "";
1063 if (myTypeId == 0) {
1064 aNbItems = SMESH::GetNameOfSelectedNodes(mySelection, myActor->getIO(), aListStr);
1067 aNbItems = SMESH::GetNameOfSelectedElements(mySelection, myActor->getIO(), aListStr);
1070 QStringList anElements = QStringList::split(" ", aListStr);
1071 QListBoxItem* anItem = 0;
1072 for (QStringList::iterator it = anElements.begin(); it != anElements.end(); ++it) {
1073 anItem = myElements->findItem(*it, Qt::ExactMatch);
1075 anItem = new QListBoxText(*it);
1076 myElements->insertItem(anItem);
1078 myElements->setSelected(anItem, true);
1082 else if (myCurrentLineEdit == mySubMeshLine) {
1083 SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1084 for (; anIt.More(); anIt.Next()) {
1085 SMESH::SMESH_subMesh_var aSubMesh = SMESH::IObjectToInterface<SMESH::SMESH_subMesh>(anIt.Value());
1086 if (!aSubMesh->_is_nil()) {
1087 // check if mesh is the same
1088 if (aSubMesh->GetFather()->GetId() == myMesh->GetId()) {
1090 SMESH::long_array_var anElements = aSubMesh->GetElementsByType ( aType );
1091 int k = anElements->length();
1092 QListBoxItem* anItem = 0;
1093 for (int i = 0; i < k; i++) {
1094 QString aText = QString::number(anElements[i]);
1095 anItem = myElements->findItem(aText, Qt::ExactMatch);
1097 anItem = new QListBoxText(aText);
1098 myElements->insertItem(anItem);
1100 myElements->setSelected(anItem, true);
1103 catch (const SALOME::SALOME_Exception& ex) {
1104 QtCatchCorbaException(ex);
1109 mySelectSubMesh->setChecked(false);
1111 onListSelectionChanged();
1113 else if (myCurrentLineEdit == myGroupLine) {
1114 SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1115 for (; anIt.More(); anIt.Next()) {
1116 SMESH::SMESH_Group_var aGroup = SMESH::IObjectToInterface<SMESH::SMESH_Group>(anIt.Value());
1117 if (!aGroup->_is_nil()) {
1118 // check if mesh is the same
1119 if (aGroup->GetType() == aType && aGroup->GetMesh()->GetId() == myMesh->GetId()) {
1120 SMESH::long_array_var anElements = aGroup->GetListOfID();
1121 int k = anElements->length();
1122 QListBoxItem* anItem = 0;
1123 for (int i = 0; i < k; i++) {
1124 QString aText = QString::number(anElements[i]);
1125 anItem = myElements->findItem(aText, Qt::ExactMatch);
1127 anItem = new QListBoxText(aText);
1128 myElements->insertItem(anItem);
1130 myElements->setSelected(anItem, true);
1135 mySelectGroup->setChecked(false);
1137 onListSelectionChanged();
1139 else if (myCurrentLineEdit == myGeomGroupLine && !CORBA::is_nil(myGeomGroup)) {
1141 SALOMEDS::Study_var aStudy = SMESH::GetActiveStudyDocument();
1142 GEOM::GEOM_IGroupOperations_var aGroupOp = SMESH::GetGEOMGen()->GetIGroupOperations(aStudy->StudyId());
1144 SMESH::ElementType aGroupType = SMESH::ALL;
1145 switch(aGroupOp->GetType(myGeomGroup)) {
1146 case 7: aGroupType = SMESH::NODE; break;
1147 case 6: aGroupType = SMESH::EDGE; break;
1148 case 4: aGroupType = SMESH::FACE; break;
1149 case 2: aGroupType = SMESH::VOLUME; break;
1153 if (aGroupType == aType) {
1154 SALOMEDS::SObject_var aGroupSO = aStudy->FindObjectIOR( aStudy->ConvertObjectToIOR(myGeomGroup) );
1156 SMESH::FilterManager_var aFilterMgr = SMESH::GetFilterManager();
1157 SMESH::Filter_var aFilter = aFilterMgr->CreateFilter();
1158 SMESH::BelongToGeom_var aBelongToGeom = aFilterMgr->CreateBelongToGeom();;
1159 aBelongToGeom->SetGeom(myGeomGroup);
1160 aBelongToGeom->SetShapeName(aGroupSO->GetName());
1161 aBelongToGeom->SetElementType(aType);
1162 aFilter->SetPredicate( aBelongToGeom );
1164 SMESH::long_array_var anElements = aFilter->GetElementsId( myMesh );
1166 int k = anElements->length();
1167 QListBoxItem* anItem = 0;
1168 for (int i = 0; i < k; i++) {
1169 QString aText = QString::number(anElements[i]);
1170 anItem = myElements->findItem(aText, Qt::ExactMatch);
1172 anItem = new QListBoxText(aText);
1173 myElements->insertItem(anItem);
1175 myElements->setSelected(anItem, true);
1179 //VSR: mySelectGeomGroup->setChecked(false);
1181 onListSelectionChanged();
1184 // mySelection->ClearIObjects();
1188 //=================================================================================
1189 // function : onRemove()
1191 //=================================================================================
1192 void SMESHGUI_GroupDlg::onRemove()
1195 if (myCurrentLineEdit == 0) {
1196 for (int i = myElements->count(); i > 0; i--) {
1197 if (myElements->isSelected(i-1)) {
1198 myElements->removeItem(i-1);
1203 int aNbSel = mySelection->IObjectCount();
1204 if (aNbSel == 0) { busy = false; return; }
1206 SMESH::ElementType aType = SMESH::ALL;
1208 case 0: aType = SMESH::NODE; break;
1209 case 1: aType = SMESH::EDGE; break;
1210 case 2: aType = SMESH::FACE; break;
1211 case 3: aType = SMESH::VOLUME; break;
1214 if (myCurrentLineEdit == mySubMeshLine) {
1215 SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1216 for (; anIt.More(); anIt.Next()) {
1217 SMESH::SMESH_subMesh_var aSubMesh = SMESH::IObjectToInterface<SMESH::SMESH_subMesh>(anIt.Value());
1218 if (!aSubMesh->_is_nil()) {
1219 // check if mesh is the same
1220 if (aSubMesh->GetFather()->GetId() == myMesh->GetId()) {
1221 if (aType == SMESH::NODE) {
1223 SMESH::long_array_var anElements = aSubMesh->GetNodesId();
1224 int k = anElements->length();
1225 QListBoxItem* anItem = 0;
1226 for (int i = 0; i < k; i++) {
1227 anItem = myElements->findItem(QString::number(anElements[i]), Qt::ExactMatch);
1228 if (anItem) delete anItem;
1231 catch (const SALOME::SALOME_Exception& ex) {
1232 QtCatchCorbaException(ex);
1237 SMESH::long_array_var anElements = aSubMesh->GetElementsId();
1238 int k = anElements->length();
1239 QListBoxItem* anItem = 0;
1240 for (int i = 0; i < k; i++) {
1241 anItem = myElements->findItem(QString::number(anElements[i]), Qt::ExactMatch);
1242 if (anItem) delete anItem;
1245 catch (const SALOME::SALOME_Exception& ex) {
1246 QtCatchCorbaException(ex);
1253 else if (myCurrentLineEdit == myGroupLine) {
1254 Standard_Boolean aRes;
1255 SALOME_ListIteratorOfListIO anIt(mySelection->StoredIObjects());
1256 for (; anIt.More(); anIt.Next()) {
1257 SMESH::SMESH_Group_var aGroup = SMESH::IObjectToInterface<SMESH::SMESH_Group>(anIt.Value());
1258 if (aRes && !aGroup->_is_nil()) {
1259 // check if mesh is the same
1260 if (aGroup->GetType() == aType && aGroup->GetMesh()->GetId() == myMesh->GetId()) {
1261 SMESH::long_array_var anElements = aGroup->GetListOfID();
1262 int k = anElements->length();
1263 QListBoxItem* anItem = 0;
1264 for (int i = 0; i < k; i++) {
1265 anItem = myElements->findItem(QString::number(anElements[i]), Qt::ExactMatch);
1266 if (anItem) delete anItem;
1277 //=================================================================================
1278 // function : onSort()
1280 //=================================================================================
1281 void SMESHGUI_GroupDlg::onSort()
1283 // PAL5412: sorts items in ascending by "string" value
1284 // myElements->sort(true);
1285 // myElements->update();
1286 int i, k = myElements->count();
1289 QStringList aSelected;
1290 std::vector<int> anArray(k);
1291 // QMemArray<int> anArray(k);
1292 QListBoxItem* anItem;
1294 for (anItem = myElements->firstItem(), i = 0; anItem != 0; anItem = anItem->next(), i++) {
1295 anArray[i] = anItem->text().toInt();
1296 if (anItem->isSelected())
1297 aSelected.append(anItem->text());
1299 // sort & update list
1300 std::sort(anArray.begin(), anArray.end());
1302 myElements->clear();
1303 for (i = 0; i < k; i++) {
1304 myElements->insertItem(QString::number(anArray[i]));
1306 for (QStringList::iterator it = aSelected.begin(); it != aSelected.end(); ++it) {
1307 anItem = myElements->findItem(*it, Qt::ExactMatch);
1308 if (anItem) myElements->setSelected(anItem, true);
1314 //=================================================================================
1315 // function : closeEvent()
1317 //=================================================================================
1318 void SMESHGUI_GroupDlg::closeEvent( QCloseEvent* e )
1323 //=======================================================================
1324 // name : SMESHGUI_GroupDlg::onClose
1325 // Purpose : SLOT called when "Close" button pressed. Close dialog
1326 //=======================================================================
1327 void SMESHGUI_GroupDlg::onClose()
1329 QAD_StudyFrame* aStudyFrame = mySMESHGUI->GetActiveStudy()->getActiveStudyFrame();
1330 if (aStudyFrame->getTypeView() == VIEW_VTK) {
1331 SMESH::RemoveFilters(); // PAL6938 -- clean all mesh entity filters
1332 SMESH::SetPointRepresentation(false);
1333 SMESH::SetPickable();
1336 mySelection->ClearIObjects();
1337 QAD_Application::getDesktop()->SetSelectionMode(ActorSelection);
1338 mySelection->ClearFilters();
1339 mySMESHGUI->ResetState();
1344 //=======================================================================
1345 // name : SMESHGUI_GroupDlg::onDeactivate
1346 // Purpose : SLOT called when dialog must be deativated
1347 //=======================================================================
1348 void SMESHGUI_GroupDlg::onDeactivate()
1350 mySMESHGUI->ResetState();
1351 setEnabled( false );
1354 //=======================================================================
1355 // name : SMESHGUI_GroupDlg::enterEvent
1356 // Purpose : Event filter
1357 //=======================================================================
1358 void SMESHGUI_GroupDlg::enterEvent( QEvent* )
1360 if ( !isEnabled() ) {
1361 SMESHGUI::GetSMESHGUI()->EmitSignalDeactivateDialog();
1363 mySelectionMode = -1;
1364 setSelectionMode( myTypeId );
1365 mySMESHGUI->SetActiveDialogBox( (QDialog*)this ) ;
1366 mySMESHGUI->SetState(800);
1370 //=======================================================================
1371 //function : hideEvent
1372 //purpose : caused by ESC key
1373 //=======================================================================
1375 void SMESHGUI_GroupDlg::hideEvent ( QHideEvent * e )
1377 if ( !isMinimized() )