]> SALOME platform Git repositories - modules/smesh.git/blob - src/SMESHGUI/SMESHGUI_BuildCompoundDlg.cxx
Salome HOME
Redesign SALOME documentation
[modules/smesh.git] / src / SMESHGUI / SMESHGUI_BuildCompoundDlg.cxx
1 // Copyright (C) 2007-2016  CEA/DEN, EDF R&D, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007  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, or (at your option) any later version.
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   : SMESHGUI_BuildCompoundDlg.cxx
23 //  Author : Alexander KOVALEV, Open CASCADE S.A.S.
24 //  SMESH includes
25
26 #include "SMESHGUI_BuildCompoundDlg.h"
27
28 #include "SMESHGUI.h"
29 #include "SMESHGUI_Utils.h"
30 #include "SMESHGUI_SpinBox.h"
31 #include "SMESHGUI_VTKUtils.h"
32
33 #include <SMESH_TypeFilter.hxx>
34
35 // SALOME GUI includes
36 #include <SUIT_Desktop.h>
37 #include <SUIT_Session.h>
38 #include <SUIT_MessageBox.h>
39 #include <SUIT_ResourceMgr.h>
40 #include <SalomeApp_Study.h>
41 #include <SUIT_OverrideCursor.h>
42
43 #include <LightApp_Application.h>
44 #include <LightApp_SelectionMgr.h>
45 #include <SALOME_ListIO.hxx>
46
47 // Qt includes
48 #include <QApplication>
49 #include <QGroupBox>
50 #include <QLabel>
51 #include <QLineEdit>
52 #include <QPushButton>
53 #include <QRadioButton>
54 #include <QHBoxLayout>
55 #include <QVBoxLayout>
56 #include <QGridLayout>
57 #include <QCheckBox>
58 #include <QComboBox>
59 #include <QKeyEvent>
60 #include <QButtonGroup>
61
62 // STL includes
63 #include <set>
64
65 #define SPACING 6
66 #define MARGIN  11
67
68 //=================================================================================
69 // name    : SMESHGUI_BuildCompoundDlg
70 // Purpose :
71 //=================================================================================
72 SMESHGUI_BuildCompoundDlg::SMESHGUI_BuildCompoundDlg( SMESHGUI* theModule )
73   : QDialog(SMESH::GetDesktop(theModule)),
74     mySMESHGUI(theModule),
75     mySelectionMgr(SMESH::GetSelectionMgr(theModule)),
76     myIsApplyAndClose( false )
77 {
78   setModal(false);
79   setAttribute(Qt::WA_DeleteOnClose, true);
80   setWindowTitle(tr("SMESH_BUILD_COMPOUND_TITLE"));
81
82   SUIT_ResourceMgr* aResMgr = SUIT_Session::session()->resourceMgr();
83   QPixmap image0 (aResMgr->loadPixmap("SMESH", tr("ICON_DLG_BUILD_COMPOUND_MESH")));
84   QPixmap image1 (aResMgr->loadPixmap("SMESH", tr("ICON_SELECT")));
85
86   setSizeGripEnabled(true);
87
88   QVBoxLayout* aTopLayout = new QVBoxLayout(this);
89   aTopLayout->setSpacing(SPACING);
90   aTopLayout->setMargin(MARGIN);
91
92   /***************************************************************/
93   GroupConstructors = new QGroupBox(tr("COMPOUND"), this);
94   QButtonGroup* ButtonGroup = new QButtonGroup(this);
95   QHBoxLayout* GroupConstructorsLayout = new QHBoxLayout(GroupConstructors);
96   GroupConstructorsLayout->setSpacing(SPACING);
97   GroupConstructorsLayout->setMargin(MARGIN);
98
99   Constructor1 = new QRadioButton(GroupConstructors);
100   Constructor1->setIcon(image0);
101   Constructor1->setChecked(true);
102   GroupConstructorsLayout->addWidget(Constructor1);
103   ButtonGroup->addButton(Constructor1, 0);
104
105   /***************************************************************/
106   GroupName = new QGroupBox(tr("RESULT_NAME"), this);
107   QHBoxLayout* GroupNameLayout = new QHBoxLayout(GroupName);
108   GroupNameLayout->setSpacing(SPACING);
109   GroupNameLayout->setMargin(MARGIN);
110
111   TextLabelName = new QLabel(tr("SMESH_NAME"), GroupName);
112   LineEditName = new QLineEdit(GroupName);
113
114   GroupNameLayout->addWidget(TextLabelName);
115   GroupNameLayout->addWidget(LineEditName);
116
117   /***************************************************************/
118   GroupArgs = new QGroupBox(tr("SMESH_ARGUMENTS"), this);
119   QGridLayout* GroupArgsLayout = new QGridLayout(GroupArgs);
120   GroupArgsLayout->setSpacing(SPACING);
121   GroupArgsLayout->setMargin(MARGIN);
122
123   TextLabelMeshes = new QLabel(tr("MESHES"), GroupArgs);
124   SelectButton = new QPushButton(GroupArgs);
125   SelectButton->setIcon(image1);
126   SelectButton->setSizePolicy(QSizePolicy(QSizePolicy::Fixed, QSizePolicy::Fixed));
127   LineEditMeshes = new QLineEdit(GroupArgs);
128   LineEditMeshes->setReadOnly(true);
129
130   TextLabelUnion = new QLabel(tr("PROCESSING_IDENTICAL_GROUPS"), GroupArgs);
131   ComboBoxUnion = new QComboBox(GroupArgs);
132
133   CheckBoxCommon = new QCheckBox(tr("CREATE_COMMON_GROUPS"), GroupArgs);
134
135   CheckBoxMerge = new QCheckBox(tr("MERGE_NODES_AND_ELEMENTS"), GroupArgs);
136
137   TextLabelTol = new QLabel(tr("SMESH_TOLERANCE"), GroupArgs);
138   //TextLabelTol->setAlignment(Qt::AlignCenter);
139   SpinBoxTol = new SMESHGUI_SpinBox(GroupArgs);
140   SpinBoxTol->RangeStepAndValidator(0.0, COORD_MAX, 0.00001, "len_tol_precision" );
141
142   GroupArgsLayout->addWidget(TextLabelMeshes, 0, 0);
143   GroupArgsLayout->addWidget(SelectButton,    0, 1);
144   GroupArgsLayout->addWidget(LineEditMeshes,  0, 2, 1, 2);
145   GroupArgsLayout->addWidget(TextLabelUnion,  1, 0, 1, 3);
146   GroupArgsLayout->addWidget(ComboBoxUnion,   1, 3);
147   GroupArgsLayout->addWidget(CheckBoxCommon,  2, 0, 1, 4);
148   GroupArgsLayout->addWidget(CheckBoxMerge,   3, 0, 1, 4);
149   GroupArgsLayout->addWidget(TextLabelTol,    4, 0);
150   GroupArgsLayout->addWidget(SpinBoxTol,      4, 1, 1, 3);
151
152   /***************************************************************/
153   GroupButtons = new QGroupBox(this);
154   QHBoxLayout* GroupButtonsLayout = new QHBoxLayout(GroupButtons);
155   GroupButtonsLayout->setSpacing(SPACING);
156   GroupButtonsLayout->setMargin(MARGIN);
157
158   buttonOk = new QPushButton(tr("SMESH_BUT_APPLY_AND_CLOSE"), GroupButtons);
159   buttonOk->setAutoDefault(true);
160   buttonOk->setDefault(true);
161   buttonApply = new QPushButton(tr("SMESH_BUT_APPLY"), GroupButtons);
162   buttonApply->setAutoDefault(true);
163   buttonCancel = new QPushButton(tr("SMESH_BUT_CLOSE"), GroupButtons);
164   buttonCancel->setAutoDefault(true);
165   buttonHelp = new QPushButton(tr("SMESH_BUT_HELP"), GroupButtons);
166   buttonHelp->setAutoDefault(true);
167
168   GroupButtonsLayout->addWidget(buttonOk);
169   GroupButtonsLayout->addSpacing(10);
170   GroupButtonsLayout->addWidget(buttonApply);
171   GroupButtonsLayout->addSpacing(10);
172   GroupButtonsLayout->addStretch();
173   GroupButtonsLayout->addWidget(buttonCancel);
174   GroupButtonsLayout->addWidget(buttonHelp);
175
176   /***************************************************************/
177   aTopLayout->addWidget(GroupConstructors);
178   aTopLayout->addWidget(GroupName);
179   aTopLayout->addWidget(GroupArgs);
180   aTopLayout->addWidget(GroupButtons);
181
182   myHelpFileName = "building_compounds.html";
183
184   Init(); // Initialisations
185 }
186
187 //=================================================================================
188 // function : ~SMESHGUI_BuildCompoundDlg()
189 // purpose  : Destroys the object and frees any allocated resources
190 //=================================================================================
191 SMESHGUI_BuildCompoundDlg::~SMESHGUI_BuildCompoundDlg()
192 {
193 }
194
195 //=================================================================================
196 // function : Init()
197 // purpose  :
198 //=================================================================================
199 void SMESHGUI_BuildCompoundDlg::Init()
200 {
201   mySMESHGUI->SetActiveDialogBox((QDialog*)this);
202
203   myMesh = SMESH::SMESH_IDSource::_nil();
204
205   myMeshFilter = new SMESH_TypeFilter (SMESH::IDSOURCE);
206
207   myMeshArray = new SMESH::ListOfIDSources();
208
209   // signals and slots connections
210   connect(buttonOk,     SIGNAL(clicked()), this, SLOT(ClickOnOk()));
211   connect(buttonCancel, SIGNAL(clicked()), this, SLOT(reject()));
212   connect(buttonApply,  SIGNAL(clicked()), this, SLOT(ClickOnApply()));
213   connect(buttonHelp,   SIGNAL(clicked()), this, SLOT(ClickOnHelp()));
214
215   connect(SelectButton, SIGNAL(clicked()), this, SLOT(SelectionIntoArgument()));
216
217   connect(CheckBoxMerge, SIGNAL(toggled(bool)), this, SLOT(onSelectMerge(bool)));
218
219   connect(mySelectionMgr, SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument()));
220
221   connect(mySMESHGUI, SIGNAL(SignalDeactivateActiveDialog()), this, SLOT(DeactivateActiveDialog()));
222   connect(mySMESHGUI, SIGNAL(SignalCloseAllDialogs()),        this, SLOT(reject()));
223
224   LineEditName->setText(GetDefaultName(tr("COMPOUND_MESH")));
225   LineEditMeshes->setFocus();
226
227   ComboBoxUnion->addItem(tr("UNITE"));
228   ComboBoxUnion->addItem(tr("RENAME"));
229   ComboBoxUnion->setCurrentIndex(0);
230
231   CheckBoxMerge->setChecked(true);
232
233   TextLabelTol->setEnabled(CheckBoxMerge->isChecked());
234   SpinBoxTol->SetValue(1e-05);
235
236   SpinBoxTol->setEnabled(CheckBoxMerge->isChecked());
237
238   mySelectionMgr->clearFilters();
239   mySelectionMgr->installFilter(myMeshFilter);
240
241   SelectionIntoArgument();
242 }
243
244 //=================================================================================
245 // function : GetDefaultName()
246 // purpose  :
247 //=================================================================================
248 QString SMESHGUI_BuildCompoundDlg::GetDefaultName(const QString& theOperation)
249 {
250   QString aName = "";
251
252   // collect all object names of SMESH component
253   SalomeApp_Study* appStudy =
254     dynamic_cast<SalomeApp_Study*>( SUIT_Session::session()->activeApplication()->activeStudy() );
255   if ( !appStudy ) return aName;
256   _PTR(Study) aStudy = appStudy->studyDS();
257
258   std::set<std::string> aSet;
259   _PTR(SComponent) aMeshCompo (aStudy->FindComponent("SMESH"));
260   if (aMeshCompo) {
261     _PTR(ChildIterator) it (aStudy->NewChildIterator(aMeshCompo));
262     _PTR(SObject) obj;
263     for (it->InitEx(true); it->More(); it->Next()) {
264       obj = it->Value();
265       aSet.insert(obj->GetName());
266     }
267   }
268
269   // build a unique name
270   int aNumber = 0;
271   bool isUnique = false;
272   while (!isUnique) {
273     aName = theOperation + "_" + QString::number(++aNumber);
274     isUnique = (aSet.count(aName.toLatin1().data()) == 0);
275   }
276
277   return aName;
278 }
279
280 //=================================================================================
281 // function : ClickOnApply()
282 // purpose  :
283 //=================================================================================
284 bool SMESHGUI_BuildCompoundDlg::ClickOnApply()
285 {
286   if (mySMESHGUI->isActiveStudyLocked())
287     return false;
288
289   if (!isValid())
290     return false;
291
292   SUIT_OverrideCursor aWaitCursor;
293
294   SMESH::SMESH_Mesh_var aMesh;
295
296   if (!myMesh->_is_nil())
297   {
298     QStringList aParameters;
299     aParameters << (CheckBoxMerge->isChecked() ? SpinBoxTol->text() : QString(" "));
300
301     QStringList anEntryList;
302     try {
303
304       aMesh = myMeshArray[0]->GetMesh();
305       aMesh->SetParameters( aParameters.join(":").toLatin1().constData() );
306
307       SMESH::SMESH_Gen_var aSMESHGen = SMESHGUI::GetSMESHGen();
308       // concatenate meshes
309       if(CheckBoxCommon->isChecked())
310         aMesh = aSMESHGen->ConcatenateWithGroups(myMeshArray,
311                                                  !(ComboBoxUnion->currentIndex()),
312                                                  CheckBoxMerge->isChecked(),
313                                                  SpinBoxTol->GetValue());
314       else
315         aMesh = aSMESHGen->Concatenate(myMeshArray,
316                                        !(ComboBoxUnion->currentIndex()),
317                                        CheckBoxMerge->isChecked(),
318                                        SpinBoxTol->GetValue());
319
320       _PTR(SObject) aSO = SMESH::FindSObject( aMesh );
321       if( aSO ) {
322         SMESH::SetName( aSO, LineEditName->text() );
323         anEntryList.append( aSO->GetID().c_str() );
324       }
325       mySMESHGUI->updateObjBrowser();
326     } catch(...) {
327       return false;
328     }
329
330     LineEditName->setText(GetDefaultName(tr("COMPOUND_MESH")));
331
332     // IPAL21468 Compound is hidden after creation.
333     if ( SMESHGUI::automaticUpdate() ) {
334       mySelectionMgr->clearSelected();
335       SMESH::UpdateView();
336
337       _PTR(SObject) aSO = SMESH::FindSObject(aMesh.in());
338       if ( SMESH_Actor* anActor = SMESH::CreateActor(aSO->GetStudy(), aSO->GetID().c_str()) ) {
339         SMESH::DisplayActor(SMESH::GetActiveWindow(), anActor);
340         SMESH::UpdateView();
341       }
342     }// end IPAL21468
343
344     if( LightApp_Application* anApp =
345         dynamic_cast<LightApp_Application*>( SUIT_Session::session()->activeApplication() ) )
346       anApp->browseObjects( anEntryList, isApplyAndClose() );
347
348     SMESHGUI::Modified();
349
350     return true;
351   }
352   return false;
353 }
354
355 //=================================================================================
356 // function : ClickOnOk()
357 // purpose  :
358 //=================================================================================
359 void SMESHGUI_BuildCompoundDlg::ClickOnOk()
360 {
361   setIsApplyAndClose( true );
362   if (ClickOnApply())
363     reject();
364 }
365
366 //=================================================================================
367 // function : reject()
368 // purpose  :
369 //=================================================================================
370 void SMESHGUI_BuildCompoundDlg::reject()
371 {
372   //mySelectionMgr->clearSelected();
373   mySelectionMgr->clearFilters();
374   disconnect(mySelectionMgr, 0, this, 0);
375   mySMESHGUI->ResetState();
376   QDialog::reject();
377 }
378
379 //=================================================================================
380 // function : ClickOnHelp()
381 // purpose  :
382 //=================================================================================
383 void SMESHGUI_BuildCompoundDlg::ClickOnHelp()
384 {
385   LightApp_Application* app = (LightApp_Application*)(SUIT_Session::session()->activeApplication());
386   if (app)
387     app->onHelpContextModule(mySMESHGUI ? app->moduleName(mySMESHGUI->moduleName()) : QString(""), myHelpFileName);
388   else {
389     SUIT_MessageBox::warning(this, tr("WRN_WARNING"),
390                              tr("EXTERNAL_BROWSER_CANNOT_SHOW_PAGE").
391                              arg(app->resourceMgr()->stringValue("ExternalBrowser",
392                                                                  "application")).
393                              arg(myHelpFileName));
394   }
395 }
396
397 //=================================================================================
398 // function : SelectionIntoArgument()
399 // purpose  : Called when selection as changed or other case
400 //=================================================================================
401 void SMESHGUI_BuildCompoundDlg::SelectionIntoArgument()
402 {
403   if (!GroupButtons->isEnabled()) // inactive
404     return;
405
406   QString aString = "";
407
408   SALOME_ListIO aList;
409   mySelectionMgr->selectedObjects(aList);
410   int nbSel = SMESH::GetNameOfSelectedIObjects(mySelectionMgr, aString);
411
412   if (nbSel != 0) {
413     myMeshArray->length(nbSel);
414     for (int i = 0; nbSel != 0; i++, nbSel--) {
415       Handle(SALOME_InteractiveObject) IO = aList.First();
416       aList.RemoveFirst();
417       myMesh = SMESH::IObjectToInterface<SMESH::SMESH_IDSource>(IO);
418       myMeshArray[i] = myMesh;
419     }
420   }
421   else {
422     myMesh = SMESH::SMESH_IDSource::_nil();
423     aString = "";
424   }
425
426   LineEditMeshes->setText(aString);
427
428   bool isEnabled = (!myMesh->_is_nil());
429   buttonOk->setEnabled(isEnabled);
430   buttonApply->setEnabled(isEnabled);
431 }
432
433 //=================================================================================
434 // function : DeactivateActiveDialog()
435 // purpose  :
436 //=================================================================================
437 void SMESHGUI_BuildCompoundDlg::DeactivateActiveDialog()
438 {
439   if (GroupConstructors->isEnabled()) {
440     GroupConstructors->setEnabled(false);
441     GroupName->setEnabled(false);
442     GroupArgs->setEnabled(false);
443     GroupButtons->setEnabled(false);
444     mySMESHGUI->ResetState();
445     mySMESHGUI->SetActiveDialogBox(0);
446   }
447 }
448
449 //=================================================================================
450 // function : ActivateThisDialog()
451 // purpose  :
452 //=================================================================================
453 void SMESHGUI_BuildCompoundDlg::ActivateThisDialog()
454 {
455   /* Emit a signal to deactivate the active dialog */
456   mySMESHGUI->EmitSignalDeactivateDialog();
457   GroupConstructors->setEnabled(true);
458   GroupName->setEnabled(true);
459   GroupArgs->setEnabled(true);
460   GroupButtons->setEnabled(true);
461
462   mySMESHGUI->SetActiveDialogBox((QDialog*)this);
463   SelectionIntoArgument();
464 }
465
466 //=================================================================================
467 // function : enterEvent()
468 // purpose  :
469 //=================================================================================
470 void SMESHGUI_BuildCompoundDlg::enterEvent( QEvent* )
471 {
472   if (GroupConstructors->isEnabled())
473     return;
474   ActivateThisDialog();
475 }
476
477 //=================================================================================
478 // function : keyPressEvent()
479 // purpose  :
480 //=================================================================================
481 void SMESHGUI_BuildCompoundDlg::keyPressEvent( QKeyEvent* e )
482 {
483   QDialog::keyPressEvent( e );
484   if ( e->isAccepted() )
485     return;
486
487   if ( e->key() == Qt::Key_F1 ) {
488     e->accept();
489     ClickOnHelp();
490   }
491 }
492
493
494 //=================================================================================
495 // function : onSelectMerge()
496 // purpose  :
497 //=================================================================================
498 void SMESHGUI_BuildCompoundDlg::onSelectMerge(bool toMerge)
499 {
500   TextLabelTol->setEnabled(toMerge);
501   SpinBoxTol->setEnabled(toMerge);
502   if(!toMerge)
503     SpinBoxTol->SetValue(1e-05);
504 }
505
506 //=================================================================================
507 // function : isValid
508 // purpose  :
509 //=================================================================================
510 bool SMESHGUI_BuildCompoundDlg::isValid()
511 {
512   QString msg;
513   bool ok=true;
514   if(CheckBoxMerge->isChecked())
515     ok = SpinBoxTol->isValid( msg, true );
516
517   if( !ok ) {
518     QString str( tr( "SMESH_INCORRECT_INPUT" ) );
519     if ( !msg.isEmpty() )
520       str += "\n" + msg;
521     SUIT_MessageBox::critical( this, tr( "SMESH_ERROR" ), str );
522     return false;
523   }
524   return true;
525 }
526
527 //================================================================
528 // function : setIsApplyAndClose
529 // Purpose  : Set value of the flag indicating that the dialog is
530 //            accepted by Apply & Close button
531 //================================================================
532 void SMESHGUI_BuildCompoundDlg::setIsApplyAndClose( const bool theFlag )
533 {
534   myIsApplyAndClose = theFlag;
535 }
536
537 //================================================================
538 // function : isApplyAndClose
539 // Purpose  : Get value of the flag indicating that the dialog is
540 //            accepted by Apply & Close button
541 //================================================================
542 bool SMESHGUI_BuildCompoundDlg::isApplyAndClose() const
543 {
544   return myIsApplyAndClose;
545 }