Salome HOME
*** empty log message ***
[modules/geom.git] / src / RepairGUI / RepairGUI_RemoveIntWiresDlg.cxx
1 // GEOM GEOMGUI : GUI for Geometry component
2 //
3 // Copyright (C) 2003  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS 
5 // 
6 // This library is free software; you can redistribute it and/or 
7 // modify it under the terms of the GNU Lesser General Public 
8 // License as published by the Free Software Foundation; either 
9 // version 2.1 of the License. 
10 // 
11 // This library is distributed in the hope that it will be useful, 
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of 
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU 
14 // Lesser General Public License for more details. 
15 // 
16 // You should have received a copy of the GNU Lesser General Public 
17 // License along with this library; if not, write to the Free Software 
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA 
19 // 
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 // File   : RepairGUI_RemoveIntWiresDlg.cxx
23 // Author : Lucien PIGNOLONI, Open CASCADE S.A.S.
24 //
25
26 #include "RepairGUI_RemoveIntWiresDlg.h"
27
28 #include <DlgRef.h>
29 #include <GeometryGUI.h>
30 #include <GEOMBase.h>
31
32 #include <SalomeApp_Application.h>
33 #include <LightApp_SelectionMgr.h>
34 #include <SUIT_Session.h>
35 #include <SUIT_ResourceMgr.h>
36
37 #include <GEOMImpl_Types.hxx>
38
39 #include <TopAbs.hxx>
40 #include <TColStd_MapOfInteger.hxx>
41 #include <TColStd_IndexedMapOfInteger.hxx>
42
43 //=================================================================================
44 // class    : RepairGUI_RemoveIntWiresDlg()
45 // purpose  : Constructs a RepairGUI_RemoveIntWiresDlg  which is a child of 'parent', with the
46 //            name 'name' and widget flags set to 'f'.
47 //            The dialog will by default be modeless, unless you set 'modal' to
48 //            TRUE to construct a modal dialog.
49 //=================================================================================
50 RepairGUI_RemoveIntWiresDlg::RepairGUI_RemoveIntWiresDlg( GeometryGUI* theGeometryGUI, QWidget* parent,
51                                                           bool modal )
52   : GEOMBase_Skeleton( theGeometryGUI, parent, modal )
53 {
54   QPixmap image0( myGeomGUI->getApp()->resourceMgr()->loadPixmap( "GEOM", tr( "ICON_DLG_SUPPRESS_INT_WIRES" ) ) );
55   QPixmap image1( myGeomGUI->getApp()->resourceMgr()->loadPixmap( "GEOM", tr( "ICON_SELECT" ) ) );
56
57   setWindowTitle( tr( "GEOM_REMOVE_INTERNAL_WIRES_TITLE" ) );
58
59   /***************************************************************/
60   mainFrame()->GroupConstructors->setTitle( tr( "GEOM_REMOVE_INTERNAL_WIRES_TITLE" ) );
61   mainFrame()->RadioButton1->setIcon( image0 );
62   mainFrame()->RadioButton2->setAttribute( Qt::WA_DeleteOnClose );
63   mainFrame()->RadioButton2->close();
64   mainFrame()->RadioButton3->setAttribute( Qt::WA_DeleteOnClose );
65   mainFrame()->RadioButton3->close();
66
67   GroupPoints = new DlgRef_1Sel1Check1Sel( centralWidget() );
68   GroupPoints->GroupBox1->setTitle( tr( "GEOM_INTERNAL_WIRES" ) );
69   GroupPoints->TextLabel1->setText( tr( "GEOM_SELECTED_FACE" ) );
70   GroupPoints->PushButton1->setIcon( image1 );
71   GroupPoints->LineEdit1->setReadOnly( true );
72   GroupPoints->CheckButton1->setText( tr( "GEOM_REMOVE_ALL_INT_WIRES" ) );
73   GroupPoints->TextLabel2->setText( tr( "GEOM_WIRES_TO_REMOVE" ) );
74   GroupPoints->PushButton2->setIcon( image1 );
75   GroupPoints->LineEdit2->setReadOnly( true );
76
77   QVBoxLayout* layout = new QVBoxLayout( centralWidget() );
78   layout->setMargin( 0 ); layout->setSpacing( 6 );
79   layout->addWidget( GroupPoints );
80
81   /***************************************************************/
82
83   setHelpFileName( "suppress_internal_wires.htm" );
84
85   Init();
86 }
87
88
89 //=================================================================================
90 // function : ~RepairGUI_RemoveIntWiresDlg()
91 // purpose  : Destroys the object and frees any allocated resources
92 //=================================================================================
93 RepairGUI_RemoveIntWiresDlg::~RepairGUI_RemoveIntWiresDlg()
94 {
95 }
96
97
98 //=================================================================================
99 // function : Init()
100 // purpose  :
101 //=================================================================================
102 void RepairGUI_RemoveIntWiresDlg::Init()
103 {
104   /* init variables */
105   myEditCurrentArgument = GroupPoints->LineEdit1;
106
107   myObject = GEOM::GEOM_Object::_nil();
108   myWiresInd = new GEOM::short_array();
109   myWiresInd->length( 0 );
110
111   //myGeomGUI->SetState( 0 );
112   initSelection(); 
113
114   /* signals and slots connections */
115   connect( buttonOk(),    SIGNAL( clicked() ), this, SLOT( ClickOnOk() ) );
116   connect( buttonApply(), SIGNAL( clicked() ), this, SLOT( ClickOnApply() ) );
117
118   connect( GroupPoints->PushButton1, SIGNAL( clicked() ),       this, SLOT( SetEditCurrentArgument() ) );
119   connect( GroupPoints->PushButton2, SIGNAL( clicked() ),       this, SLOT( SetEditCurrentArgument() ) );
120   connect( GroupPoints->LineEdit1,   SIGNAL( returnPressed() ), this, SLOT( LineEditReturnPressed() ) );
121   connect( GroupPoints->LineEdit2,   SIGNAL( returnPressed() ), this, SLOT( LineEditReturnPressed() ) );
122
123   connect( ( (SalomeApp_Application*)( SUIT_Session::session()->activeApplication() ) )->selectionMgr(), 
124            SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
125
126   connect( GroupPoints->CheckButton1, SIGNAL( clicked() ), this, SLOT( onRemoveAllClicked() ) );
127
128   initName( tr( "REMOVE_INT_WIRES_NEW_OBJ_NAME" ) );
129 }
130
131
132 //=================================================================================
133 // function : ClickOnOk()
134 // purpose  : Same than click on apply but close this dialog.
135 //=================================================================================
136 void RepairGUI_RemoveIntWiresDlg::ClickOnOk()
137 {
138   if ( ClickOnApply() )
139     ClickOnCancel();
140 }
141
142 //=================================================================================
143 // function : ClickOnApply()
144 // purpose  :
145 //=================================================================================
146 bool RepairGUI_RemoveIntWiresDlg::ClickOnApply()
147 {
148   if ( !onAccept() )
149     return false;
150
151   initName();
152
153   myEditCurrentArgument = GroupPoints->LineEdit1;
154   myEditCurrentArgument->setText( "" );
155   GroupPoints->LineEdit2->setText( "" );
156   myObject = GEOM::GEOM_Object::_nil();
157   myWiresInd->length( 0 );
158   
159   initSelection();
160   
161   return true;
162 }
163
164
165 //=================================================================================
166 // function : SelectionIntoArgument()
167 // purpose  : Called when selection
168 //=================================================================================
169 void RepairGUI_RemoveIntWiresDlg::SelectionIntoArgument()
170 {
171   myEditCurrentArgument->setText( "" );
172   if ( myEditCurrentArgument == GroupPoints->LineEdit1 ) myObject = GEOM::GEOM_Object::_nil();
173   else if ( myEditCurrentArgument == GroupPoints->LineEdit2 ) myWiresInd->length( 0 );
174
175   if ( IObjectCount() == 1 ) {
176     Handle(SALOME_InteractiveObject) anIO = firstIObject();
177     
178     if ( myEditCurrentArgument == GroupPoints->LineEdit1 ) {    // face selection
179       Standard_Boolean aRes;
180       myObject = GEOMBase::ConvertIOinGEOMObject( anIO, aRes );
181       if ( aRes && GEOMBase::IsShape( myObject ) )
182         myEditCurrentArgument->setText( GEOMBase::GetName( myObject ) );
183       else
184         myObject = GEOM::GEOM_Object::_nil();
185     }
186     else if ( myEditCurrentArgument == GroupPoints->LineEdit2 && 
187               !GroupPoints->CheckButton1->isChecked() ) {
188       TColStd_IndexedMapOfInteger aMap;
189       ( (SalomeApp_Application*)( SUIT_Session::session()->activeApplication() ) )->selectionMgr()->GetIndexes( anIO, aMap );
190       const int n = aMap.Extent();
191       myWiresInd->length( n );
192       for ( int i = 1; i <= n; i++ )
193         myWiresInd[i-1] = aMap( i );
194       if ( n )
195         myEditCurrentArgument->setText( QString::number( n ) + "_" + tr( "GEOM_WIRE" ) + tr( "_S_" ) );
196     }
197   }
198 }
199
200 //=================================================================================
201 // function : SetEditCurrentArgument()
202 // purpose  :
203 //=================================================================================
204 void RepairGUI_RemoveIntWiresDlg::SetEditCurrentArgument()
205 {
206   const QObject* send = sender();
207   if ( send == GroupPoints->PushButton1 )
208     myEditCurrentArgument = GroupPoints->LineEdit1;
209   else if ( send == GroupPoints->PushButton2 && !myObject->_is_nil() )
210     myEditCurrentArgument = GroupPoints->LineEdit2;
211
212   if ( myEditCurrentArgument ) {
213     initSelection();
214     myEditCurrentArgument->setFocus();
215     SelectionIntoArgument();
216   }
217 }
218
219
220 //=================================================================================
221 // function : LineEditReturnPressed()
222 // purpose  :
223 //=================================================================================
224 void RepairGUI_RemoveIntWiresDlg::LineEditReturnPressed()
225 {
226   const QObject* send = sender();
227   if ( send == GroupPoints->LineEdit1 || send == GroupPoints->LineEdit2 ) {
228     myEditCurrentArgument = (QLineEdit*)send;
229     GEOMBase_Skeleton::LineEditReturnPressed();
230   }
231 }
232
233
234 //=================================================================================
235 // function : ActivateThisDialog()
236 // purpose  :
237 //=================================================================================
238 void RepairGUI_RemoveIntWiresDlg::ActivateThisDialog()
239 {
240   GEOMBase_Skeleton::ActivateThisDialog();
241   connect( ( (SalomeApp_Application*)( SUIT_Session::session()->activeApplication() ) )->selectionMgr(),
242            SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
243
244   myEditCurrentArgument = GroupPoints->LineEdit1;
245   myEditCurrentArgument->setText( "" );
246   GroupPoints->LineEdit2->setText( "" );
247   myObject = GEOM::GEOM_Object::_nil();
248   myWiresInd->length( 0 );
249
250   //myGeomGUI->SetState( 0 );
251   initSelection();
252 }
253
254 //=================================================================================
255 // function : enterEvent()
256 // purpose  : Mouse enter onto the dialog to activate it
257 //=================================================================================
258 void RepairGUI_RemoveIntWiresDlg::enterEvent( QEvent* )
259 {
260   if ( !mainFrame()->GroupConstructors->isEnabled() )
261     ActivateThisDialog();
262 }
263
264 //=================================================================================
265 // function : closeEvent()
266 // purpose  :
267 //=================================================================================
268 void RepairGUI_RemoveIntWiresDlg::closeEvent( QCloseEvent* e )
269 {
270   //myGeomGUI->SetState( -1 );
271   GEOMBase_Skeleton::closeEvent( e );
272 }
273
274 //=================================================================================
275 // function : createOperation
276 // purpose  :
277 //=================================================================================
278 GEOM::GEOM_IOperations_ptr RepairGUI_RemoveIntWiresDlg::createOperation()
279 {
280   return getGeomEngine()->GetIHealingOperations( getStudyId() );
281 }
282
283 //=================================================================================
284 // function : isValid
285 // purpose  :
286 //=================================================================================
287 bool RepairGUI_RemoveIntWiresDlg::isValid( QString& )
288 {
289   return !myObject->_is_nil() && ( GroupPoints->CheckButton1->isChecked() || myWiresInd->length() );
290 }
291
292 //=================================================================================
293 // function : execute
294 // purpose  :
295 //=================================================================================
296 bool RepairGUI_RemoveIntWiresDlg::execute( ObjectList& objects )
297 {
298   GEOM::GEOM_Object_var anObj = GEOM::GEOM_IHealingOperations::_narrow( getOperation() )->
299     RemoveIntWires( myObject, myWiresInd );
300   bool aResult = !anObj->_is_nil();
301   if ( aResult )
302     objects.push_back( anObj._retn() );
303
304   return aResult;
305 }
306
307 //=================================================================================
308 // function : onRemoveAllClicked
309 // purpose  :
310 //=================================================================================
311 void RepairGUI_RemoveIntWiresDlg::onRemoveAllClicked()
312 {
313   bool b = GroupPoints->CheckButton1->isChecked();
314   GroupPoints->TextLabel2->setEnabled( !b );
315   GroupPoints->PushButton2->setEnabled( !b );
316   GroupPoints->LineEdit2->setEnabled( !b );
317   if ( b ) {
318     GroupPoints->LineEdit2->setText( "" );
319     myWiresInd->length( 0 );
320   }
321 }
322
323 //=================================================================================
324 // function : initSelection
325 // purpose  :
326 //=================================================================================
327 void RepairGUI_RemoveIntWiresDlg::initSelection()
328 {
329   if ( myEditCurrentArgument == GroupPoints->LineEdit1 ) {
330     TColStd_MapOfInteger aTypes;
331     aTypes.Add( GEOM_COMPOUND );
332     aTypes.Add( GEOM_SOLID );
333     aTypes.Add( GEOM_SHELL );
334     aTypes.Add( GEOM_FACE );
335     
336     globalSelection( aTypes );
337   }
338   else if ( myEditCurrentArgument == GroupPoints->LineEdit2 ) {
339     //localSelection( myObject, TopAbs_EDGE );
340     localSelection( myObject, TopAbs_WIRE );
341   }
342 }