Salome HOME
Mantis issues 0020573 and 0020603: Partition problems. A fix by Peter KURNEV.
[modules/geom.git] / src / TransformationGUI / TransformationGUI.cxx
index eb69c9037a216077a410643b9c9ee1d3a2e6476b..1361025037bed80e10c67fc536d2ebe26acf88e4 100644 (file)
@@ -1,38 +1,41 @@
-//  GEOM GEOMGUI : GUI for Geometry component
+//  Copyright (C) 2007-2008  CEA/DEN, EDF R&D, OPEN CASCADE
 //
-//  Copyright (C) 2003  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
-//  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS 
-// 
-//  This library is free software; you can redistribute it and/or 
-//  modify it under the terms of the GNU Lesser General Public 
-//  License as published by the Free Software Foundation; either 
-//  version 2.1 of the License. 
-// 
-//  This library is distributed in the hope that it will be useful, 
-//  but WITHOUT ANY WARRANTY; without even the implied warranty of 
-//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU 
-//  Lesser General Public License for more details. 
-// 
-//  You should have received a copy of the GNU Lesser General Public 
-//  License along with this library; if not, write to the Free Software 
-//  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA 
-// 
-//  See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//  Copyright (C) 2003-2007  OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
+//  CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
 //
+//  This library is free software; you can redistribute it and/or
+//  modify it under the terms of the GNU Lesser General Public
+//  License as published by the Free Software Foundation; either
+//  version 2.1 of the License.
 //
+//  This library is distributed in the hope that it will be useful,
+//  but WITHOUT ANY WARRANTY; without even the implied warranty of
+//  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+//  Lesser General Public License for more details.
+//
+//  You should have received a copy of the GNU Lesser General Public
+//  License along with this library; if not, write to the Free Software
+//  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
+//
+//  See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+//
+// GEOM GEOMGUI : GUI for Geometry component
+// File   : TransformationGUI.cxx
+// Author : Damien COQUERET, Open CASCADE S.A.S.
 //
-//  File   : TransformationGUI.cxx
-//  Author : Damien COQUERET
-//  Module : GEOM
-//  $Header$
-
 #include "TransformationGUI.h"
-#include "GeometryGUI.h"
 
-#include "SUIT_Session.h"
-#include "SUIT_Desktop.h"
+#include <GEOMBase.h>
+#include <GeometryGUI.h>
 
-#include "SalomeApp_Application.h"
+#include <SUIT_Desktop.h>
+#include <SUIT_ViewModel.h>
+#include <SUIT_ViewWindow.h>
+#include <SUIT_ViewManager.h>
+#include <LightApp_SelectionMgr.h>
+#include <SalomeApp_Application.h>
+#include <SalomeApp_Study.h>
+#include <SALOME_ListIteratorOfListIO.hxx>
 
 #include "TransformationGUI_MultiTranslationDlg.h"   // Method MULTI TRANSLATION
 #include "TransformationGUI_MultiRotationDlg.h"      // Method MULTI ROTATION
 #include "TransformationGUI_OffsetDlg.h"             // Method OFFSET
 #include "TransformationGUI_PositionDlg.h"           // Method POSITION
 
-using namespace std;
-
 //=======================================================================
 // function : TransformationGUI()
 // purpose  : Constructor
 //=======================================================================
-TransformationGUI::TransformationGUI(GeometryGUI* parent) : GEOMGUI(parent)
+TransformationGUI::TransformationGUI( GeometryGUI* parent )
+  : GEOMGUI( parent )
 {
 }
 
@@ -66,46 +68,89 @@ TransformationGUI::~TransformationGUI()
 // function : OnGUIEvent()
 // purpose  : 
 //=======================================================================
-bool TransformationGUI::OnGUIEvent(int theCommandID, SUIT_Desktop* parent)
+bool TransformationGUI::OnGUIEvent( int theCommandID, SUIT_Desktop* parent )
 {
   SalomeApp_Application* app = getGeometryGUI()->getApp();
-  if (!app) return false;
+  if ( !app ) return false;
 
   getGeometryGUI()->EmitSignalDeactivateDialog();
   QDialog* aDlg = NULL;
 
-  switch (theCommandID)
-  {
+  switch ( theCommandID ) {
   case 5021: // TRANSLATION
-    aDlg = new TransformationGUI_TranslationDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_TranslationDlg( getGeometryGUI(), parent );
     break;
   case 5022: // ROTATION
-    aDlg = new TransformationGUI_RotationDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_RotationDlg( getGeometryGUI(), parent );
     break;
   case 5023: // POSITION
-    aDlg = new TransformationGUI_PositionDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_PositionDlg( getGeometryGUI(), parent );
     break;
   case 5024: // MIRROR
-    aDlg = new TransformationGUI_MirrorDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_MirrorDlg( getGeometryGUI(), parent );
     break;
   case 5025: // SCALE
-    aDlg = new TransformationGUI_ScaleDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_ScaleDlg( getGeometryGUI(), parent );
     break;
   case 5026: // OFFSET
-    aDlg = new TransformationGUI_OffsetDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_OffsetDlg( getGeometryGUI(), parent );
     break;
   case 5027: // MULTI TRANSLATION
-    aDlg = new TransformationGUI_MultiTranslationDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_MultiTranslationDlg( getGeometryGUI(), parent );
     break;
   case 5028: // MULTI ROTATION
-    aDlg = new TransformationGUI_MultiRotationDlg( getGeometryGUI(), parent, "" );
+    aDlg = new TransformationGUI_MultiRotationDlg( getGeometryGUI(), parent );
+    break;
+  case 5029: // RELOAD IMPORTED SHAPE
+    {
+      SalomeApp_Study* anAppStudy = dynamic_cast<SalomeApp_Study*>(app->activeStudy());
+
+      GEOM::GEOM_ITransformOperations_var anOp =
+        GeometryGUI::GetGeomGen()->GetITransformOperations(anAppStudy->id());
+      if (anOp->_is_nil()) return false;
+
+      GEOM_Displayer aDisp (anAppStudy);
+      SUIT_Desktop* desk = app->desktop();
+      QList<SUIT_ViewWindow*> wnds = desk->windows();
+
+      LightApp_SelectionMgr* aSelMgr = app->selectionMgr();
+      SALOME_ListIO aSelList;
+      aSelMgr->selectedObjects(aSelList);
+
+      SALOME_ListIteratorOfListIO aSelIt (aSelList);
+      for (; aSelIt.More(); aSelIt.Next()) {
+        Handle(SALOME_InteractiveObject) io = aSelIt.Value();
+        Standard_Boolean testResult = Standard_False;
+        GEOM::GEOM_Object_var aGeomObj = GEOMBase::ConvertIOinGEOMObject(io, testResult);
+        if (testResult) {
+          anOp->RecomputeObject(aGeomObj);
+
+          SUIT_ViewWindow* wnd;
+          QListIterator<SUIT_ViewWindow*> it (wnds);
+          while (it.hasNext() && (wnd = it.next()))
+          {
+            if (SUIT_ViewManager* vman = wnd->getViewManager()) {
+              if (SUIT_ViewModel* vmodel = vman->getViewModel()) {
+                if (SALOME_View* view = dynamic_cast<SALOME_View*>(vmodel)) {
+                  if (view->isVisible(io)) {
+                    aDisp.Erase(io, false, false, view);
+                    aDisp.Display(io, true, view);
+                  }
+                  // ? Redisplay subshapes ?
+                }
+              }
+            }
+          }
+        }
+      } // for (; aSelIt.More(); aSelIt.Next())
+    }
     break;
   default:
-    app->putInfo(tr("GEOM_PRP_COMMAND").arg(theCommandID));
+    app->putInfo( tr( "GEOM_PRP_COMMAND" ).arg( theCommandID ) );
     break;
   }
 
-  if (aDlg != NULL)
+  if ( aDlg != NULL )
     aDlg->show();
 
   return true;
@@ -118,7 +163,7 @@ bool TransformationGUI::OnGUIEvent(int theCommandID, SUIT_Desktop* parent)
 extern "C"
 {
 #ifdef WNT
-       __declspec( dllexport )
+  __declspec( dllexport )
 #endif
   GEOMGUI* GetLibGUI( GeometryGUI* parent )
   {