]> SALOME platform Git repositories - modules/smesh.git/commitdiff
Salome HOME
Add function to erase an actor in current viewer or in all viewers where it is displa...
authorvsr <vsr@opencascade.com>
Tue, 2 Oct 2012 08:17:28 +0000 (08:17 +0000)
committervsr <vsr@opencascade.com>
Tue, 2 Oct 2012 08:17:28 +0000 (08:17 +0000)
src/SMESH_SWIG_WITHIHM/libSMESH_Swig.cxx
src/SMESH_SWIG_WITHIHM/libSMESH_Swig.h
src/SMESH_SWIG_WITHIHM/libSMESH_Swig.i

index eca22e91e77323f0d982a7df4b755de0010658b3..679a8d8532f5d04f6c26bc661b19270cff099aba 100644 (file)
@@ -37,6 +37,9 @@
 
 // SALOME GUI includes
 #include <SUIT_Session.h>
+#include <SUIT_ViewManager.h>
+#include <SALOME_Prs.h>
+#include <SUIT_ViewWindow.h>
 #include <VTKViewer_ViewModel.h>
 #include <SALOME_Event.h>
 #include <SalomeApp_Application.h>
@@ -575,6 +578,44 @@ void SMESH_Swig::CreateAndDisplayActor( const char* Mesh_Entry )
   ProcessVoidEvent(new TEvent(Mesh_Entry));
 }
 
+void SMESH_Swig::EraseActor( const char* Mesh_Entry, const bool allViewers )
+{
+  class TEvent: public SALOME_Event
+  {
+  private:
+    const char* _entry;
+    bool _allViewers;
+  public:
+    TEvent(const char* Mesh_Entry, const bool allViewers ) {
+      _entry = Mesh_Entry;
+      _allViewers = allViewers;
+    }
+    virtual void Execute() {
+      SUIT_Session* aSession = SUIT_Session::session();
+      SUIT_Application* anApplication = aSession->activeApplication();
+      SalomeApp_Application* anApp = dynamic_cast<SalomeApp_Application*>(anApplication);
+      SMESHGUI_Displayer* aDisp = new SMESHGUI_Displayer(anApp);
+      ViewManagerList aManagers;
+      if ( !_allViewers ) {
+       aManagers << anApp->activeViewManager();
+      }
+      else {
+       aManagers = anApp->viewManagers();
+      }
+      foreach( SUIT_ViewManager* aMgr, aManagers ) {
+       if ( aMgr && aMgr->getType() == VTKViewer_Viewer::Type() ) {
+         SALOME_View* aSalomeView = dynamic_cast<SALOME_View*>(aMgr->getViewModel());
+         if (aSalomeView) {
+           aDisp->Erase(_entry,true, true, aSalomeView);
+         }
+       }
+      }
+    }
+  };
+
+  ProcessVoidEvent(new TEvent(Mesh_Entry, allViewers));
+}
+
 void SMESH_Swig::SetName(const char* theEntry,
                          const char* theName)
 {
index 4a7b8e719a8e2e949c5a4bcfff223fdd9ec3febd..504eba84579172148c557fcc67279648c4e9c57b 100644 (file)
@@ -65,6 +65,8 @@ public:
 
   void                       SetName( const char*, const char* );
 
+  void                       EraseActor( const char*, const bool allViewers = false );
+
   /*!
    * \brief Set mesh icon according to compute status
     * \param Mesh_Entry - entry of a mesh
index 52d2bb87fa4aab38309d362f30de565b0ed4f809..db8ef31aa9919aaac36aa946d023d37167a6def7 100644 (file)
@@ -75,4 +75,5 @@ class SMESH_Swig
   void SetMeshIcon(const char* Mesh_Entry, const bool isComputed, const bool isEmpty);
 
   void CreateAndDisplayActor( const char* Mesh_Entry );
+  void EraseActor( const char* Mesh_Entry, const bool allViewers = false );
 };