]> SALOME platform Git repositories - modules/geom.git/commitdiff
Salome HOME
Bugs 16640, 19050: Improve selection mechanism in GEOM dialog boxes.
authorjfa <jfa@opencascade.com>
Mon, 15 Sep 2008 08:10:33 +0000 (08:10 +0000)
committerjfa <jfa@opencascade.com>
Mon, 15 Sep 2008 08:10:33 +0000 (08:10 +0000)
src/BlocksGUI/BlocksGUI_BlockDlg.cxx
src/BlocksGUI/BlocksGUI_BlockDlg.h

index dc0749389631fd0a2351dda68fe9902f99d11d74..b1f94656462ba4ac6af158e49bb49c4899f8c032 100644 (file)
 
 #include <GEOMImpl_Types.hxx>
 
+// OCCT Includes
+#include <TColStd_IndexedMapOfInteger.hxx>
+
 //=================================================================================
 // class    : BlocksGUI_BlockDlg()
 // purpose  : Constructs a BlocksGUI_BlockDlg which is a child of 'parent'.
 //=================================================================================
-BlocksGUI_BlockDlg::BlocksGUI_BlockDlg( GeometryGUI* theGeometryGUI, QWidget* parent )
-  : GEOMBase_Skeleton( theGeometryGUI, parent )
+BlocksGUI_BlockDlg::BlocksGUI_BlockDlg (GeometryGUI* theGeometryGUI, QWidget* parent)
+  : GEOMBase_Skeleton(theGeometryGUI, parent),
+    myInitial(true)
 {
-  QPixmap image0( SUIT_Session::session()->resourceMgr()->loadPixmap( "GEOM", tr( "ICON_DLG_BLOCK_2F" ) ) );
-  QPixmap image1( SUIT_Session::session()->resourceMgr()->loadPixmap( "GEOM", tr( "ICON_DLG_BLOCK_6F" ) ) );
-  QPixmap imageS( SUIT_Session::session()->resourceMgr()->loadPixmap( "GEOM", tr( "ICON_SELECT" ) ) );
+  QPixmap image0 (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_DLG_BLOCK_2F")));
+  QPixmap image1 (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_DLG_BLOCK_6F")));
+  QPixmap imageS (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_SELECT")));
 
-  setWindowTitle( tr( "GEOM_BLOCK_TITLE" ) );
+  setWindowTitle(tr("GEOM_BLOCK_TITLE"));
 
   /***************************************************************/
-  mainFrame()->GroupConstructors->setTitle( tr( "GEOM_BLOCK" ) );
+  mainFrame()->GroupConstructors->setTitle(tr("GEOM_BLOCK"));
 
-  mainFrame()->RadioButton1->setIcon( image0 );
-  mainFrame()->RadioButton2->setIcon( image1 );
-  mainFrame()->RadioButton3->setAttribute( Qt::WA_DeleteOnClose );
+  mainFrame()->RadioButton1->setIcon(image0);
+  mainFrame()->RadioButton2->setIcon(image1);
+  mainFrame()->RadioButton3->setAttribute(Qt::WA_DeleteOnClose);
   mainFrame()->RadioButton3->close();
 
   // Create first group
-  Group2F = new DlgRef_2Sel( centralWidget() );
-  Group2F->GroupBox1->setTitle( tr( "GEOM_ARGUMENTS" ) );
-  Group2F->TextLabel1->setText( tr( "FACE_1" ) );
-  Group2F->TextLabel2->setText( tr( "FACE_2" ) );
-  Group2F->PushButton1->setIcon( imageS );
-  Group2F->PushButton2->setIcon( imageS );
+  Group2F = new DlgRef_2Sel (centralWidget());
+  Group2F->GroupBox1->setTitle(tr("GEOM_ARGUMENTS"));
+  Group2F->TextLabel1->setText(tr("FACE_1"));
+  Group2F->TextLabel2->setText(tr("FACE_2"));
+  Group2F->PushButton1->setIcon(imageS);
+  Group2F->PushButton2->setIcon(imageS);
 
   // Create second group
-  Group6F = new DlgRef_6Sel( centralWidget() );
-  Group6F->GroupBox1->setTitle( tr( "GEOM_ARGUMENTS" ) );
-  Group6F->TextLabel1->setText( tr( "FACE_1" ) );
-  Group6F->TextLabel2->setText( tr( "FACE_2" ) );
-  Group6F->TextLabel3->setText( tr( "FACE_3" ) );
-  Group6F->TextLabel4->setText( tr( "FACE_4" ) );
-  Group6F->TextLabel5->setText( tr( "FACE_5" ) );
-  Group6F->TextLabel6->setText( tr( "FACE_6" ) );
-  Group6F->PushButton1->setIcon( imageS );
-  Group6F->PushButton2->setIcon( imageS );
-  Group6F->PushButton3->setIcon( imageS );
-  Group6F->PushButton4->setIcon( imageS );
-  Group6F->PushButton5->setIcon( imageS );
-  Group6F->PushButton6->setIcon( imageS );
+  Group6F = new DlgRef_6Sel (centralWidget());
+  Group6F->GroupBox1->setTitle(tr("GEOM_ARGUMENTS"));
+  Group6F->TextLabel1->setText(tr("FACE_1"));
+  Group6F->TextLabel2->setText(tr("FACE_2"));
+  Group6F->TextLabel3->setText(tr("FACE_3"));
+  Group6F->TextLabel4->setText(tr("FACE_4"));
+  Group6F->TextLabel5->setText(tr("FACE_5"));
+  Group6F->TextLabel6->setText(tr("FACE_6"));
+  Group6F->PushButton1->setIcon(imageS);
+  Group6F->PushButton2->setIcon(imageS);
+  Group6F->PushButton3->setIcon(imageS);
+  Group6F->PushButton4->setIcon(imageS);
+  Group6F->PushButton5->setIcon(imageS);
+  Group6F->PushButton6->setIcon(imageS);
 
   // Add groups to layout
-  QVBoxLayout* layout = new QVBoxLayout( centralWidget() );
-  layout->setMargin( 0 ); layout->setSpacing( 6 );
-  layout->addWidget( Group2F );
-  layout->addWidget( Group6F );
+  QVBoxLayout* layout = new QVBoxLayout (centralWidget());
+  layout->setMargin(0);
+  layout->setSpacing(6);
+  layout->addWidget(Group2F);
+  layout->addWidget(Group6F);
   /***************************************************************/
 
-  setHelpFileName( "build_by_blocks_page.html#hexa_solid_anchor" );
+  setHelpFileName("build_by_blocks_page.html#hexa_solid_anchor");
 
   Init();
 }
@@ -108,91 +113,87 @@ BlocksGUI_BlockDlg::~BlocksGUI_BlockDlg()
 void BlocksGUI_BlockDlg::Init()
 {
   // init variables
-  Group2F->LineEdit1->setReadOnly( true );
-  Group2F->LineEdit2->setReadOnly( true );
+  Group2F->LineEdit1->setReadOnly(true);
+  Group2F->LineEdit2->setReadOnly(true);
 
-  Group6F->LineEdit1->setReadOnly( true );
-  Group6F->LineEdit2->setReadOnly( true );
-  Group6F->LineEdit3->setReadOnly( true );
-  Group6F->LineEdit4->setReadOnly( true );
-  Group6F->LineEdit5->setReadOnly( true );
-  Group6F->LineEdit6->setReadOnly( true );
+  Group6F->LineEdit1->setReadOnly(true);
+  Group6F->LineEdit2->setReadOnly(true);
+  Group6F->LineEdit3->setReadOnly(true);
+  Group6F->LineEdit4->setReadOnly(true);
+  Group6F->LineEdit5->setReadOnly(true);
+  Group6F->LineEdit6->setReadOnly(true);
 
   // signals and slots connections
-  connect( buttonOk(),    SIGNAL( clicked() ), this, SLOT( ClickOnOk() ) );
-  connect( buttonApply(), SIGNAL( clicked() ), this, SLOT( ClickOnApply() ) );
-
-  connect( this, SIGNAL( constructorsClicked( int ) ), 
-          this, SLOT( ConstructorsClicked( int ) ) );
+  connect(buttonOk(),    SIGNAL(clicked()), this, SLOT(ClickOnOk()));
+  connect(buttonApply(), SIGNAL(clicked()), this, SLOT(ClickOnApply()));
 
-  connect( Group2F->PushButton1, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
-  connect( Group2F->PushButton2, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
+  connect(this, SIGNAL(constructorsClicked(int)), this, SLOT(ConstructorsClicked(int)));
 
-  connect( Group6F->PushButton1, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
-  connect( Group6F->PushButton2, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
-  connect( Group6F->PushButton3, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
-  connect( Group6F->PushButton4, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
-  connect( Group6F->PushButton5, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
-  connect( Group6F->PushButton6, SIGNAL( clicked() ), this, SLOT( SetEditCurrentArgument() ) );
+  connect(Group2F->PushButton1, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
+  connect(Group2F->PushButton2, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
 
-  connect( ( (SalomeApp_Application*)( SUIT_Session::session()->activeApplication() ) )->selectionMgr(),
-          SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
+  connect(Group6F->PushButton1, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
+  connect(Group6F->PushButton2, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
+  connect(Group6F->PushButton3, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
+  connect(Group6F->PushButton4, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
+  connect(Group6F->PushButton5, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
+  connect(Group6F->PushButton6, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
 
   // init controls and fields
-  initName( tr( "GEOM_BLOCK" ) );
+  initName(tr("GEOM_BLOCK"));
 
   myConstructorId = -1;
-  ConstructorsClicked( 0 );
+  ConstructorsClicked(0);
 }
 
 //=================================================================================
 // function : ConstructorsClicked()
 // purpose  : Radio button management
 //=================================================================================
-void BlocksGUI_BlockDlg::ConstructorsClicked( int constructorId )
+void BlocksGUI_BlockDlg::ConstructorsClicked (int constructorId)
 {
-  if ( myConstructorId == constructorId )
+  if (myConstructorId == constructorId)
     return;
 
   myConstructorId = constructorId;
 
-  switch ( constructorId ) {
+  // init fields
+  myFace1 = myFace2 = GEOM::GEOM_Object::_nil();
+  myFace3 = myFace4 = myFace5 = myFace6 = myFace1;
+
+  switch (constructorId) {
   case 0:
     Group6F->hide();
     Group2F->show();
 
-    myEditCurrentArgument = Group2F->LineEdit1;
-    Group2F->LineEdit1->setText( tr( "" ) );
-    Group2F->LineEdit2->setText( tr( "" ) );
+    Group2F->LineEdit1->setText(tr(""));
+    Group2F->LineEdit2->setText(tr(""));
+
+    Group2F->PushButton1->click();
     break;
   case 1:
     Group2F->hide();
     Group6F->show();
 
-    myEditCurrentArgument = Group6F->LineEdit1;
-    Group6F->LineEdit1->setText( tr( "" ) );
-    Group6F->LineEdit2->setText( tr( "" ) );
-    Group6F->LineEdit3->setText( tr( "" ) );
-    Group6F->LineEdit4->setText( tr( "" ) );
-    Group6F->LineEdit5->setText( tr( "" ) );
-    Group6F->LineEdit6->setText( tr( "" ) );
+    Group6F->LineEdit1->setText(tr(""));
+    Group6F->LineEdit2->setText(tr(""));
+    Group6F->LineEdit3->setText(tr(""));
+    Group6F->LineEdit4->setText(tr(""));
+    Group6F->LineEdit5->setText(tr(""));
+    Group6F->LineEdit6->setText(tr(""));
+
+    Group6F->PushButton1->click();
     break;
   default:
     break;
   }
 
-  // init fields
-  myFace1 = myFace2 = GEOM::GEOM_Object::_nil();
-  myFace3 = myFace4 = myFace5 = myFace6 = myFace1;
-
   qApp->processEvents();
   updateGeometry();
-  resize( minimumSize() );
+  resize(minimumSize());
 
-  globalSelection( GEOM_FACE );
+  // on dialog initialization we init the first field with a selected object (if any)
   SelectionIntoArgument();
-  connect( ( (SalomeApp_Application*)( SUIT_Session::session()->activeApplication() ) )->selectionMgr(), 
-         SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
 }
 
 //=================================================================================
@@ -201,7 +202,7 @@ void BlocksGUI_BlockDlg::ConstructorsClicked( int constructorId )
 //=================================================================================
 void BlocksGUI_BlockDlg::ClickOnOk()
 {
-  if ( ClickOnApply() )
+  if (ClickOnApply())
     ClickOnCancel();
 }
 
@@ -211,7 +212,7 @@ void BlocksGUI_BlockDlg::ClickOnOk()
 //=================================================================================
 bool BlocksGUI_BlockDlg::ClickOnApply()
 {
-  if ( !onAccept() )
+  if (!onAccept())
     return false;
 
   initName();
@@ -220,55 +221,111 @@ bool BlocksGUI_BlockDlg::ClickOnApply()
 
 //=================================================================================
 // function : SelectionIntoArgument()
-// purpose  : Called when selection as changed or other case
+// purpose  : Called when selection is changed or on dialog initialization or activation
 //=================================================================================
 void BlocksGUI_BlockDlg::SelectionIntoArgument()
 {
   erasePreview();
-  myEditCurrentArgument->setText( "" );
-
-  if ( IObjectCount() != 1 ) {
-    if ( myEditCurrentArgument == Group2F->LineEdit1 ||
-        myEditCurrentArgument == Group6F->LineEdit1 )
-      myFace1 = GEOM::GEOM_Object::_nil();
-    else if ( myEditCurrentArgument == Group2F->LineEdit2 ||
-             myEditCurrentArgument == Group6F->LineEdit2 )
-      myFace2 = GEOM::GEOM_Object::_nil();
-    else if ( myEditCurrentArgument == Group6F->LineEdit3 )
-      myFace3 = GEOM::GEOM_Object::_nil();
-    else if ( myEditCurrentArgument == Group6F->LineEdit4 )
-      myFace4 = GEOM::GEOM_Object::_nil();
-    else if ( myEditCurrentArgument == Group6F->LineEdit5 )
-      myFace5 = GEOM::GEOM_Object::_nil();
-    else if ( myEditCurrentArgument == Group6F->LineEdit6 )
-      myFace6 = GEOM::GEOM_Object::_nil();
+  myEditCurrentArgument->setText("");
+
+  LightApp_SelectionMgr* aSelMgr = myGeomGUI->getApp()->selectionMgr();
+  SALOME_ListIO aSelList;
+  aSelMgr->selectedObjects(aSelList);
+
+  if (aSelList.Extent() != 1) {
+    if (myEditCurrentArgument == Group2F->LineEdit1)      myFace1 = GEOM::GEOM_Object::_nil();
+    else if (myEditCurrentArgument == Group2F->LineEdit2) myFace2 = GEOM::GEOM_Object::_nil();
+    else if (myEditCurrentArgument == Group6F->LineEdit1) myFace1 = GEOM::GEOM_Object::_nil();
+    else if (myEditCurrentArgument == Group6F->LineEdit2) myFace2 = GEOM::GEOM_Object::_nil();
+    else if (myEditCurrentArgument == Group6F->LineEdit3) myFace3 = GEOM::GEOM_Object::_nil();
+    else if (myEditCurrentArgument == Group6F->LineEdit4) myFace4 = GEOM::GEOM_Object::_nil();
+    else if (myEditCurrentArgument == Group6F->LineEdit5) myFace5 = GEOM::GEOM_Object::_nil();
+    else if (myEditCurrentArgument == Group6F->LineEdit6) myFace6 = GEOM::GEOM_Object::_nil();
     return;
   }
 
   // nbSel == 1
   Standard_Boolean testResult = Standard_False;
   GEOM::GEOM_Object_var aSelectedObject =
-    GEOMBase::ConvertIOinGEOMObject( firstIObject(), testResult );
+    GEOMBase::ConvertIOinGEOMObject(aSelList.First(), testResult);
 
-  if ( !testResult || CORBA::is_nil( aSelectedObject ) )
+  if (!testResult || CORBA::is_nil(aSelectedObject))
     return;
 
-  if ( myEditCurrentArgument == Group2F->LineEdit1 ||
-       myEditCurrentArgument == Group6F->LineEdit1 )
+  QString aName = GEOMBase::GetName(aSelectedObject);
+
+  // Get Selected object if selected subshape
+  TopoDS_Shape aShape;
+  if (GEOMBase::GetShape(aSelectedObject, aShape, TopAbs_SHAPE) && !aShape.IsNull())
+  {
+    TColStd_IndexedMapOfInteger aMap;
+    aSelMgr->GetIndexes(aSelList.First(), aMap);
+    if (aMap.Extent() == 1) // Local Selection
+    {
+      int anIndex = aMap(1);
+      aName += QString(":face_%1").arg(anIndex);
+
+      //Find SubShape Object in Father
+      GEOM::GEOM_Object_var aFindedObject = GEOMBase_Helper::findObjectInFather(aSelectedObject, aName);
+
+      if (aFindedObject == GEOM::GEOM_Object::_nil()) { // Object not found in study
+        GEOM::GEOM_IShapesOperations_var aShapesOp = getGeomEngine()->GetIShapesOperations(getStudyId());
+        aSelectedObject = aShapesOp->GetSubShape(aSelectedObject, anIndex);
+      }
+      else
+        aSelectedObject = aFindedObject; // get Object from study
+    }
+    else // Global Selection
+    {
+      if (aShape.ShapeType() != TopAbs_FACE) {
+        aSelectedObject = GEOM::GEOM_Object::_nil();
+        aName = "";
+      }
+    }
+  }
+
+  myEditCurrentArgument->setText(aName);
+
+  if (myEditCurrentArgument == Group2F->LineEdit1) {
+    myFace1 = aSelectedObject;
+    if (!myFace1->_is_nil() && myFace2->_is_nil())
+      Group2F->PushButton2->click();
+  }
+  else if (myEditCurrentArgument == Group2F->LineEdit2) {
+    myFace2 = aSelectedObject;
+    if (!myFace2->_is_nil() && myFace1->_is_nil())
+      Group2F->PushButton1->click();
+  }
+  else if (myEditCurrentArgument == Group6F->LineEdit1) {
     myFace1 = aSelectedObject;
-  else if ( myEditCurrentArgument == Group2F->LineEdit2 ||
-           myEditCurrentArgument == Group6F->LineEdit2 )
+    if (!myFace1->_is_nil() && myFace2->_is_nil())
+      Group6F->PushButton2->click();
+  }
+  else if (myEditCurrentArgument == Group6F->LineEdit2) {
     myFace2 = aSelectedObject;
-  else if ( myEditCurrentArgument == Group6F->LineEdit3 )
+    if (!myFace2->_is_nil() && myFace3->_is_nil())
+      Group6F->PushButton3->click();
+  }
+  else if (myEditCurrentArgument == Group6F->LineEdit3) {
     myFace3 = aSelectedObject;
-  else if ( myEditCurrentArgument == Group6F->LineEdit4 )
+    if (!myFace3->_is_nil() && myFace4->_is_nil())
+      Group6F->PushButton4->click();
+  }
+  else if (myEditCurrentArgument == Group6F->LineEdit4) {
     myFace4 = aSelectedObject;
-  else if ( myEditCurrentArgument == Group6F->LineEdit5 )
+    if (!myFace4->_is_nil() && myFace5->_is_nil())
+      Group6F->PushButton5->click();
+  }
+  else if (myEditCurrentArgument == Group6F->LineEdit5) {
     myFace5 = aSelectedObject;
-  else if ( myEditCurrentArgument == Group6F->LineEdit6 )
+    if (!myFace5->_is_nil() && myFace6->_is_nil())
+      Group6F->PushButton6->click();
+  }
+  else if (myEditCurrentArgument == Group6F->LineEdit6) {
     myFace6 = aSelectedObject;
-
-  myEditCurrentArgument->setText( GEOMBase::GetName( aSelectedObject ) );
+    if (!myFace6->_is_nil() && myFace1->_is_nil())
+      Group6F->PushButton1->click();
+  }
 
   displayPreview();
 }
@@ -281,35 +338,78 @@ void BlocksGUI_BlockDlg::SetEditCurrentArgument()
 {
   QPushButton* aSender = (QPushButton*)sender();
 
-  if ( aSender == Group2F->PushButton1 ) {
+  // clear selection
+  disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0);
+  if (myInitial)
+    myInitial = false;
+  else
+    myGeomGUI->getApp()->selectionMgr()->clearSelected();
+
+  // disable all
+  switch (myConstructorId) {
+  case 0:
+    Group2F->PushButton1->setDown(false);
+    Group2F->PushButton2->setDown(false);
+
+    Group2F->LineEdit1->setEnabled(false);
+    Group2F->LineEdit2->setEnabled(false);
+    break;
+  case 1:
+    Group6F->PushButton1->setDown(false);
+    Group6F->PushButton2->setDown(false);
+    Group6F->PushButton3->setDown(false);
+    Group6F->PushButton4->setDown(false);
+    Group6F->PushButton5->setDown(false);
+    Group6F->PushButton6->setDown(false);
+
+    Group6F->LineEdit1->setEnabled(false);
+    Group6F->LineEdit2->setEnabled(false);
+    Group6F->LineEdit3->setEnabled(false);
+    Group6F->LineEdit4->setEnabled(false);
+    Group6F->LineEdit5->setEnabled(false);
+    Group6F->LineEdit6->setEnabled(false);
+    break;
+  default:
+    break;
+  }
+
+  // enable push button
+  aSender->setDown(true);
+
+  // set line edit as current argument
+  if (aSender == Group2F->PushButton1) {
     myEditCurrentArgument = Group2F->LineEdit1;
-  } 
-  else if ( aSender == Group2F->PushButton2 ) {
+  }
+  else if (aSender == Group2F->PushButton2) {
     myEditCurrentArgument = Group2F->LineEdit2;
   }
-  else if ( aSender == Group6F->PushButton1 ) {
+  else if (aSender == Group6F->PushButton1) {
     myEditCurrentArgument = Group6F->LineEdit1;
   }
-  else if ( aSender == Group6F->PushButton2 ) {
+  else if (aSender == Group6F->PushButton2) {
     myEditCurrentArgument = Group6F->LineEdit2;
-  } 
-  else if ( aSender == Group6F->PushButton3 ) {
+  }
+  else if (aSender == Group6F->PushButton3) {
     myEditCurrentArgument = Group6F->LineEdit3;
-  } 
-  else if ( aSender == Group6F->PushButton4 ) {
+  }
+  else if (aSender == Group6F->PushButton4) {
     myEditCurrentArgument = Group6F->LineEdit4;
-  } 
-  else if ( aSender == Group6F->PushButton5 ) {
+  }
+  else if (aSender == Group6F->PushButton5) {
     myEditCurrentArgument = Group6F->LineEdit5;
-  } 
-  else if ( aSender == Group6F->PushButton6 ) {
+  }
+  else if (aSender == Group6F->PushButton6) {
     myEditCurrentArgument = Group6F->LineEdit6;
   }
 
-  globalSelection( GEOM_FACE );
-
+  // enable line edit
+  myEditCurrentArgument->setEnabled(true);
   myEditCurrentArgument->setFocus();
-  SelectionIntoArgument();
+
+  globalSelection(); // close local contexts, if any
+  localSelection(GEOM::GEOM_Object::_nil(), TopAbs_FACE); //Select Faces on All Shapes
+  connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()),
+          this, SLOT(SelectionIntoArgument()));
 }
 
 //=================================================================================
@@ -319,21 +419,19 @@ void BlocksGUI_BlockDlg::SetEditCurrentArgument()
 void BlocksGUI_BlockDlg::ActivateThisDialog()
 {
   GEOMBase_Skeleton::ActivateThisDialog();
-  connect( ( (SalomeApp_Application*)( SUIT_Session::session()->activeApplication() ) )->selectionMgr(), 
-          SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) );
-
-  globalSelection( GEOM_FACE ); 
-
-  SelectionIntoArgument();
+  globalSelection(); // close local contexts, if any
+  localSelection(GEOM::GEOM_Object::_nil(), TopAbs_FACE); //Select Faces on All Shapes
+  connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()),
+          this, SLOT(SelectionIntoArgument()));
 }
 
 //=================================================================================
 // function : enterEvent()
 // purpose  :
 //=================================================================================
-void BlocksGUI_BlockDlg::enterEvent( QEvent* )
+void BlocksGUI_BlockDlg::enterEvent (QEvent*)
 {
-  if ( !mainFrame()->GroupConstructors->isEnabled() )
+  if (!mainFrame()->GroupConstructors->isEnabled())
     ActivateThisDialog();
 }
 
@@ -343,7 +441,7 @@ void BlocksGUI_BlockDlg::enterEvent( QEvent* )
 //=================================================================================
 GEOM::GEOM_IOperations_ptr BlocksGUI_BlockDlg::createOperation()
 {
-  return getGeomEngine()->GetIBlocksOperations( getStudyId() );
+  return getGeomEngine()->GetIBlocksOperations(getStudyId());
 }
 
 //=================================================================================
@@ -353,14 +451,14 @@ GEOM::GEOM_IOperations_ptr BlocksGUI_BlockDlg::createOperation()
 bool BlocksGUI_BlockDlg::isValid (QString&)
 {
   bool ok = false;
-  switch ( getConstructorId() ) {
+  switch (getConstructorId()) {
   case 0:
-    ok = !( myFace1->_is_nil() || myFace2->_is_nil() );
+    ok = !(myFace1->_is_nil() || myFace2->_is_nil());
     break;
   case 1:
-    ok =  !( myFace1->_is_nil() || myFace2->_is_nil() ||
-            myFace3->_is_nil() || myFace4->_is_nil() ||
-            myFace5->_is_nil() || myFace6->_is_nil() );
+    ok =  !(myFace1->_is_nil() || myFace2->_is_nil() ||
+            myFace3->_is_nil() || myFace4->_is_nil() ||
+            myFace5->_is_nil() || myFace6->_is_nil());
     break;
   default:
     break;
@@ -372,33 +470,58 @@ bool BlocksGUI_BlockDlg::isValid (QString&)
 // function : execute
 // purpose  :
 //=================================================================================
-bool BlocksGUI_BlockDlg::execute( ObjectList& objects )
+bool BlocksGUI_BlockDlg::execute (ObjectList& objects)
 {
   bool res = false;
 
   GEOM::GEOM_Object_var anObj;
 
-  switch ( getConstructorId() ) {
+  switch (getConstructorId()) {
   case 0:
-    if ( !CORBA::is_nil( myFace1 ) && !CORBA::is_nil( myFace2 ) ) {
-      anObj = GEOM::GEOM_IBlocksOperations::_narrow( getOperation() )->
-       MakeHexa2Faces( myFace1, myFace2 );
+    if (!CORBA::is_nil(myFace1) && !CORBA::is_nil(myFace2)) {
+      anObj = GEOM::GEOM_IBlocksOperations::_narrow(getOperation())->
+        MakeHexa2Faces(myFace1, myFace2);
       res = true;
     }
     break;
   case 1:
-    if ( !CORBA::is_nil( myFace1 ) && !CORBA::is_nil( myFace2 ) &&
-        !CORBA::is_nil(myFace3 )  && !CORBA::is_nil( myFace4 ) &&
-        !CORBA::is_nil( myFace5 ) && !CORBA::is_nil( myFace6 ) ) {
-        anObj = GEOM::GEOM_IBlocksOperations::_narrow( getOperation() )->
-          MakeHexa( myFace1, myFace2, myFace3, myFace4, myFace5, myFace6 );
-        res = true;
+    if (!CORBA::is_nil(myFace1) && !CORBA::is_nil(myFace2) &&
+        !CORBA::is_nil(myFace3) && !CORBA::is_nil(myFace4) &&
+        !CORBA::is_nil(myFace5) && !CORBA::is_nil(myFace6)) {
+      anObj = GEOM::GEOM_IBlocksOperations::_narrow(getOperation())->
+        MakeHexa(myFace1, myFace2, myFace3, myFace4, myFace5, myFace6);
+      res = true;
     }
     break;
   }
 
-  if ( !anObj->_is_nil() )
-    objects.push_back( anObj._retn() );
+  if (!anObj->_is_nil())
+    objects.push_back(anObj._retn());
 
   return res;
 }
+
+//=================================================================================
+// function : addSubshapeToStudy
+// purpose  : virtual method to add new SubObjects if local selection
+//=================================================================================
+void BlocksGUI_BlockDlg::addSubshapesToStudy()
+{
+  QMap<QString, GEOM::GEOM_Object_var> objMap;
+
+  switch (getConstructorId()) {
+  case 0:
+    objMap[Group2F->LineEdit1->text()] = myFace1;
+    objMap[Group2F->LineEdit2->text()] = myFace2;
+    break;
+  case 1:
+    objMap[Group6F->LineEdit1->text()] = myFace1;
+    objMap[Group6F->LineEdit2->text()] = myFace2;
+    objMap[Group6F->LineEdit3->text()] = myFace3;
+    objMap[Group6F->LineEdit4->text()] = myFace4;
+    objMap[Group6F->LineEdit5->text()] = myFace5;
+    objMap[Group6F->LineEdit6->text()] = myFace6;
+    break;
+  }
+  addSubshapesToFather(objMap);
+}
index 643ad5ca3786abdd189e3c22761837e975c9059b..661b7f877cbb0332e914f05d830e4a380b23710f 100644 (file)
@@ -39,18 +39,19 @@ class BlocksGUI_BlockDlg : public GEOMBase_Skeleton
   Q_OBJECT
 
 public:
-  BlocksGUI_BlockDlg( GeometryGUI*, QWidget* );
+  BlocksGUI_BlockDlg (GeometryGUI*, QWidget*);
   ~BlocksGUI_BlockDlg();
 
 protected:
   // redefined from GEOMBase_Helper
   virtual GEOM::GEOM_IOperations_ptr createOperation();
-  virtual bool                       isValid( QString& );
-  virtual bool                       execute( ObjectList&);
+  virtual bool                       isValid (QString&);
+  virtual bool                       execute (ObjectList&);
+  virtual void                       addSubshapesToStudy();
 
 private:
   void                               Init();
-  void                               enterEvent( QEvent* );
+  void                               enterEvent (QEvent*);
 
 private:
   int                                myConstructorId;
@@ -58,6 +59,9 @@ private:
   GEOM::GEOM_Object_var              myFace1, myFace2;
   GEOM::GEOM_Object_var              myFace3, myFace4, myFace5, myFace6;
 
+  // to initialize the first selection field with a selected object on the dialog creation
+  bool                               myInitial;
+
   DlgRef_2Sel*                       Group2F;
   DlgRef_6Sel*                       Group6F;
 
@@ -65,7 +69,7 @@ private slots:
   void                               ClickOnOk();
   bool                               ClickOnApply();
   void                               ActivateThisDialog();
-  void                               ConstructorsClicked( int );
+  void                               ConstructorsClicked (int);
 
   void                               SelectionIntoArgument();
   void                               SetEditCurrentArgument();