1 // GEOM GEOMGUI : GUI for Geometry 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.com
22 // File : OperationGUI_PartitionDlg.cxx
23 // Author : Lucien PIGNOLONI, Open CASCADE S.A.S.
26 #include "OperationGUI_PartitionDlg.h"
29 #include <GeometryGUI.h>
32 #include <GEOMImpl_Types.hxx>
34 #include <SUIT_Desktop.h>
35 #include <SUIT_Session.h>
36 #include <SUIT_ResourceMgr.h>
37 #include <SalomeApp_Application.h>
38 #include <LightApp_SelectionMgr.h>
40 //=================================================================================
41 // class : OperationGUI_PartitionDlg()
42 // purpose : Constructs a OperationGUI_PartitionDlg which is a child of 'parent', with the
43 // name 'name' and widget flags set to 'f'.
44 // The dialog will by default be modeless, unless you set 'modal' to
45 // TRUE to construct a modal dialog.
46 //=================================================================================
47 OperationGUI_PartitionDlg::OperationGUI_PartitionDlg( GeometryGUI* theGeometryGUI, QWidget* parent )
48 : GEOMBase_Skeleton( theGeometryGUI, parent, false )
50 SUIT_ResourceMgr* aResMgr = myGeomGUI->getApp()->resourceMgr();
51 QPixmap image0( aResMgr->loadPixmap( "GEOM", tr( "ICON_DLG_PARTITION" ) ) );
52 QPixmap image1( aResMgr->loadPixmap( "GEOM", tr( "ICON_DLG_PARTITION_PLANE" ) ) );
53 QPixmap image2( aResMgr->loadPixmap( "GEOM", tr( "ICON_SELECT" ) ) );
55 setWindowTitle( tr( "GEOM_PARTITION_TITLE" ) );
57 /***************************************************************/
58 mainFrame()->GroupConstructors->setTitle( tr( "GEOM_PARTITION" ) );
59 mainFrame()->RadioButton1->setIcon( image0 );
60 mainFrame()->RadioButton2->setIcon( image1 );
61 mainFrame()->RadioButton3->setAttribute( Qt::WA_DeleteOnClose );
62 mainFrame()->RadioButton3->close();
64 // Full partition (contains half-space partition)
65 GroupPoints = new DlgRef_2Sel1List1Check( centralWidget() );
66 GroupPoints->GroupBox1->setTitle( tr( "GEOM_PARTITION" ) );
67 GroupPoints->TextLabel1->setText( tr( "GEOM_OBJECTS" ) );
68 GroupPoints->TextLabel2->setText( tr( "GEOM_TOOL_OBJECT" ) );
69 GroupPoints->TextLabel3->setText( tr( "GEOM_RECONSTRUCTION_LIMIT" ) );
70 GroupPoints->PushButton1->setIcon( image2 );
71 GroupPoints->PushButton2->setIcon( image2 );
72 GroupPoints->LineEdit1->setReadOnly( true );
73 GroupPoints->LineEdit2->setReadOnly( true );
74 GroupPoints->CheckButton1->setText( tr( "GEOM_KEEP_NONLIMIT_SHAPES" ) );
76 QVBoxLayout* layout = new QVBoxLayout( centralWidget() );
77 layout->setMargin( 0 ); layout->setSpacing( 6 );
78 layout->addWidget( GroupPoints );
80 /***************************************************************/
82 setHelpFileName( "partition_page.html" );
88 //=================================================================================
89 // function : ~OperationGUI_PartitionDlg()
90 // purpose : Destroys the object and frees any allocated resources
91 //=================================================================================
92 OperationGUI_PartitionDlg::~OperationGUI_PartitionDlg()
94 // no need to delete child widgets, Qt does it all for us
97 void OperationGUI_PartitionDlg::SetListMaterials( GEOM::ListOfLong ListMaterials )
99 myListMaterials = ListMaterials;
102 GEOM::ListOfLong OperationGUI_PartitionDlg::GetListMaterials()
104 return myListMaterials;
107 //=================================================================================
110 //=================================================================================
111 void OperationGUI_PartitionDlg::Init()
113 /* type for sub shape selection */
114 GroupPoints->ComboBox1->addItem( tr( "GEOM_RECONSTRUCTION_LIMIT_SOLID" ) );
115 GroupPoints->ComboBox1->addItem( tr( "GEOM_RECONSTRUCTION_LIMIT_SHELL" ) );
116 GroupPoints->ComboBox1->addItem( tr( "GEOM_RECONSTRUCTION_LIMIT_FACE" ) );
117 GroupPoints->ComboBox1->addItem( tr( "GEOM_RECONSTRUCTION_LIMIT_WIRE" ) );
118 GroupPoints->ComboBox1->addItem( tr( "GEOM_RECONSTRUCTION_LIMIT_EDGE" ) );
119 GroupPoints->ComboBox1->addItem( tr( "GEOM_RECONSTRUCTION_LIMIT_VERTEX" ) );
120 GroupPoints->CheckButton1->setChecked( false );
122 /* signals and slots connections */
123 connect( buttonOk(), SIGNAL( clicked() ), this, SLOT( ClickOnOk() ) );
124 connect( buttonApply(), SIGNAL( clicked() ), this, SLOT( ClickOnApply() ) );
126 connect( this, SIGNAL( constructorsClicked( int ) ), this, SLOT( ConstructorsClicked( int ) ) );
128 connect( GroupPoints->PushButton1, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
129 connect( GroupPoints->PushButton2, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
131 connect( GroupPoints->LineEdit1, SIGNAL( returnPressed() ), this, SLOT( LineEditReturnPressed() ) );
132 connect( GroupPoints->LineEdit2, SIGNAL( returnPressed() ), this, SLOT( LineEditReturnPressed() ) );
134 connect( GroupPoints->ComboBox1, SIGNAL( activated( int ) ), this, SLOT( ComboTextChanged() ) );
136 connect( GroupPoints->CheckButton1, SIGNAL( stateChanged( int ) ), this, SLOT( ReverseSense( int ) ) );
138 connect( myGeomGUI->getApp()->selectionMgr(),
139 SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
141 initName( tr( "GEOM_PARTITION" ) );
143 ConstructorsClicked( 0 );
147 //=================================================================================
148 // function : ConstructorsClicked()
149 // purpose : Radio button management
150 //=================================================================================
151 void OperationGUI_PartitionDlg::ConstructorsClicked( int constructorId )
153 disconnect( myGeomGUI->getApp()->selectionMgr(), 0, this, 0 );
156 myListShapes.length( 0 );
157 myListTools.length( 0 );
158 myListKeepInside.length( 0 );
159 myListRemoveInside.length( 0 );
160 myListMaterials.length( 0 );
162 switch ( constructorId ) {
163 case 0: /*Full partition */
164 GroupPoints->GroupBox1->setTitle( tr( "GEOM_PARTITION" ) );
165 GroupPoints->TextLabel2->setText( tr( "GEOM_TOOL_OBJECT" ) );
166 GroupPoints->TextLabel3->show();
167 GroupPoints->ComboBox1->show();
168 GroupPoints->ComboBox1->setCurrentIndex( 0 );
169 GroupPoints->CheckButton1->show();
171 case 1: /*Half-space partition */
172 GroupPoints->GroupBox1->setTitle( tr( "GEOM_PARTITION_HALFSPACE" ) );
173 GroupPoints->TextLabel3->hide();
174 GroupPoints->ComboBox1->hide();
175 GroupPoints->TextLabel2->setText( tr( "GEOM_PLANE" ) );
176 GroupPoints->CheckButton1->hide();
180 myEditCurrentArgument = GroupPoints->LineEdit1;
181 GroupPoints->LineEdit1->clear();
182 GroupPoints->LineEdit2->clear();
184 qApp->processEvents();
186 resize( minimumSize() );
188 myEditCurrentArgument->setFocus();
189 connect( myGeomGUI->getApp()->selectionMgr(),
190 SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
194 //=================================================================================
195 // function : ClickOnOk()
197 //=================================================================================
198 void OperationGUI_PartitionDlg::ClickOnOk()
200 if ( ClickOnApply() )
205 //=================================================================================
206 // function : ClickOnApply()
208 //=================================================================================
209 bool OperationGUI_PartitionDlg::ClickOnApply()
215 ConstructorsClicked( getConstructorId() );
220 //=================================================================================
221 // function : SelectionIntoArgument()
222 // purpose : Called when selection as changed or other case
223 //=================================================================================
224 void OperationGUI_PartitionDlg::SelectionIntoArgument()
226 myEditCurrentArgument->setText( "" );
227 QString aString = "";
229 int nbSel = GEOMBase::GetNameOfSelectedIObjects( selectedIO(), aString, true );
232 if ( myEditCurrentArgument == GroupPoints->LineEdit1 ) {
233 myListShapes.length( 0 );
234 myListMaterials.length( 0 );
236 else if ( myEditCurrentArgument == GroupPoints->LineEdit2 )
237 myListTools.length( 0 );
240 // One and only one plane can be selected
242 if ( getConstructorId() == 1 &&
243 myEditCurrentArgument == GroupPoints->LineEdit2 &&
245 myListTools.length( 0 );
249 if ( myEditCurrentArgument == GroupPoints->LineEdit1 ) {
250 GEOMBase::ConvertListOfIOInListOfGO( selectedIO(), myListShapes, true );
251 myListMaterials.length( 0 );
252 if ( !myListShapes.length() )
255 else if ( myEditCurrentArgument == GroupPoints->LineEdit2 ) {
256 GEOMBase::ConvertListOfIOInListOfGO( selectedIO(), myListTools, true );
257 if ( !myListTools.length() )
261 myEditCurrentArgument->setText( aString );
265 //=================================================================================
266 // function : SetEditCurrentArgument()
268 //=================================================================================
269 void OperationGUI_PartitionDlg::SetEditCurrentArgument()
271 QPushButton* send = (QPushButton*)sender();
273 if ( send == GroupPoints->PushButton1 )
274 myEditCurrentArgument = GroupPoints->LineEdit1;
275 else if ( send == GroupPoints->PushButton2 ) {
276 myEditCurrentArgument = GroupPoints->LineEdit2;
277 if ( getConstructorId() == 1 )
278 globalSelection( GEOM_PLANE );
281 globalSelection( GEOM_ALLSHAPES );
283 myEditCurrentArgument->setFocus();
284 SelectionIntoArgument();
288 //=================================================================================
289 // function : LineEditReturnPressed()
291 //=================================================================================
292 void OperationGUI_PartitionDlg::LineEditReturnPressed()
294 QLineEdit* send = (QLineEdit*)sender();
296 if ( send == GroupPoints->LineEdit1 ||
297 send == GroupPoints->LineEdit2 ) {
298 myEditCurrentArgument = send;
299 GEOMBase_Skeleton::LineEditReturnPressed();
304 //=================================================================================
305 // function : ActivateThisDialog()
307 //=================================================================================
308 void OperationGUI_PartitionDlg::ActivateThisDialog()
310 GEOMBase_Skeleton::ActivateThisDialog();
311 connect( myGeomGUI->getApp()->selectionMgr(),
312 SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
314 ConstructorsClicked( getConstructorId() );
318 //=================================================================================
319 // function : enterEvent()
321 //=================================================================================
322 void OperationGUI_PartitionDlg::enterEvent( QEvent* )
324 if ( !mainFrame()->GroupConstructors->isEnabled() )
325 this->ActivateThisDialog();
329 //=================================================================================
330 // function : createOperation
332 //=================================================================================
333 GEOM::GEOM_IOperations_ptr OperationGUI_PartitionDlg::createOperation()
335 return getGeomEngine()->GetIBooleanOperations( getStudyId() );
339 //=================================================================================
340 // function : isValid
342 //=================================================================================
343 bool OperationGUI_PartitionDlg::isValid( QString& )
345 return ( myListShapes.length() || myListTools.length() ||
346 myListKeepInside.length() || myListRemoveInside.length() );
350 //=================================================================================
351 // function : execute
353 //=================================================================================
354 bool OperationGUI_PartitionDlg::execute( ObjectList& objects )
358 GEOM::GEOM_Object_var anObj;
361 int aLimit = GetLimit();
362 int aConstructorId = getConstructorId();
363 int aKeepNonlimitShapes = 0;
365 if ( aConstructorId == 1 ) {
366 aLimit = GEOM::SHAPE;
369 if ( GroupPoints->CheckButton1->isChecked() ) {
370 aKeepNonlimitShapes = 1;
373 aKeepNonlimitShapes = 0;
377 if ( isValid( msg ) ) {
378 anObj = GEOM::GEOM_IBooleanOperations::_narrow( getOperation() )->
379 MakePartition( myListShapes, myListTools,
380 myListKeepInside, myListRemoveInside,
381 aLimit, false, myListMaterials, aKeepNonlimitShapes );
385 if ( !anObj->_is_nil() )
386 objects.push_back( anObj._retn() );
392 //=======================================================================
393 //function : ComboTextChanged
395 //=======================================================================
396 void OperationGUI_PartitionDlg::ComboTextChanged()
398 //bool IsEnabled = GroupPoints->ComboBox1->currentItem() < 3;
399 //GroupPoints->LineEdit3->setEnabled(IsEnabled);
400 //GroupPoints->LineEdit4->setEnabled(IsEnabled);
401 //GroupPoints->TextLabel4->setEnabled(IsEnabled);
402 //GroupPoints->TextLabel5->setEnabled(IsEnabled);
403 //GroupPoints->PushButton3->setEnabled(IsEnabled);
404 //GroupPoints->PushButton4->setEnabled(IsEnabled);
408 //=================================================================================
409 // function : GetLimit()
411 //=================================================================================
412 int OperationGUI_PartitionDlg::GetLimit() const
414 int aLimit = GroupPoints->ComboBox1->currentIndex();
417 case 0: aLimit = GEOM::SOLID ; break;
418 case 1: aLimit = GEOM::SHELL ; break;
419 case 2: aLimit = GEOM::FACE ; break;
420 case 3: aLimit = GEOM::WIRE ; break;
421 case 4: aLimit = GEOM::EDGE ; break;
422 case 5: aLimit = GEOM::VERTEX; break;
423 default: aLimit = GEOM::SHAPE ;