1 // Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
2 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
4 // This library is free software; you can redistribute it and/or
5 // modify it under the terms of the GNU Lesser General Public
6 // License as published by the Free Software Foundation; either
7 // version 2.1 of the License.
9 // This library is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 // Lesser General Public License for more details.
14 // You should have received a copy of the GNU Lesser General Public
15 // License along with this library; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
20 #ifndef SMESHGUI_VTKUtils_HeaderFile
21 #define SMESHGUI_VTKUtils_HeaderFile
23 #include "SMESH_SMESHGUI.hxx"
25 #include "SALOMEDSClient_definitions.hxx"
26 #include "SALOME_InteractiveObject.hxx"
27 #include "VTKViewer_Filter.h"
29 #include "SMESH_Object.h"
30 #include "SMESHGUI_Utils.h"
34 #include "SALOMEconfig.h"
35 #include CORBA_CLIENT_HEADER(SALOMEDS)
37 #include <boost/shared_ptr.hpp>
41 class TColStd_IndexedMapOfInteger;
43 class SALOMEDSClient_Study;
46 class SUIT_ViewWindow;
47 class SUIT_ViewManager;
49 class SVTK_ViewWindow;
52 class LightApp_SelectionMgr;
53 class SalomeApp_Module;
61 //----------------------------------------------------------------------------
62 typedef pair<int,string> TKeyOfVisualObj;
65 TVisualObjPtr GetVisualObj(int theStudyId,
66 const char* theEntry);
68 void OnVisuException(); // PAL16631
70 //----------------------------------------------------------------------------
72 SVTK_ViewWindow* GetViewWindow(const SalomeApp_Module* theModule = NULL,
73 bool createIfNotFound = false);
75 SVTK_ViewWindow* FindVtkViewWindow(SUIT_ViewManager*, SUIT_ViewWindow*);
77 SVTK_ViewWindow* GetVtkViewWindow(SUIT_ViewWindow*);
80 SVTK_ViewWindow* GetCurrentVtkView();
82 //----------------------------------------------------------------------------
84 void RepaintCurrentView();
86 void RepaintViewWindow(SVTK_ViewWindow*);
88 void RenderViewWindow(SVTK_ViewWindow*);
92 //----------------------------------------------------------------------------
94 SMESH_Actor* FindActorByEntry (SUIT_ViewWindow*, const char* theEntry);
96 SMESH_Actor* FindActorByEntry (const char* theEntry);
99 SMESH_Actor* FindActorByObject (CORBA::Object_ptr theObject);
101 //----------------------------------------------------------------------------
103 SMESH_Actor* CreateActor (_PTR(Study), const char*, int = false);
105 void DisplayActor (SUIT_ViewWindow*, SMESH_Actor* theActor);
107 void RemoveActor (SUIT_ViewWindow*, SMESH_Actor* theActor);
109 void RemoveVisuData(int studyID);
111 //----------------------------------------------------------------------------
112 enum EDisplaing {eDisplayAll, eDisplay, eDisplayOnly, eErase, eEraseAll};
114 bool UpdateView (SUIT_ViewWindow*,
115 EDisplaing theAction,
116 const char* theEntry = "" );
118 bool UpdateView (EDisplaing theAction,
119 const char* theEntry = "");
125 bool Update(const Handle(SALOME_InteractiveObject)& theIO,
129 //----------------------------------------------------------------------------
131 void SetPointRepresentation(bool theIsVisible);
134 void SetPickable(SMESH_Actor* theActor = NULL);
137 void UpdateSelectionProp( SMESHGUI* );
140 //----------------------------------------------------------------------------
142 SVTK_Selector* GetSelector (SUIT_ViewWindow* = GetActiveWindow());
145 void SetFilter (const Handle(VTKViewer_Filter)& theFilter,
146 SVTK_Selector* theSelector = GetSelector());
148 Handle(VTKViewer_Filter) GetFilter (int theId, SVTK_Selector* theSelector = GetSelector());
150 bool IsFilterPresent (int theId, SVTK_Selector* theSelector = GetSelector());
152 void RemoveFilter (int theId, SVTK_Selector* theSelector = GetSelector());
155 void RemoveFilters (SVTK_Selector* theSelector = GetSelector());
158 bool IsValid (SALOME_Actor* theActor, int theCellId,
159 SVTK_Selector* theSelector = GetSelector());
161 //----------------------------------------------------------------------------
163 int GetNameOfSelectedNodes(SVTK_Selector* theSelector,
164 const Handle(SALOME_InteractiveObject)& theIO,
167 int GetNameOfSelectedElements(SVTK_Selector* theSelector,
168 const Handle(SALOME_InteractiveObject)& theIO,
171 int GetEdgeNodes(SVTK_Selector* theSelector,
172 const TVisualObjPtr& theVisualObj,
176 //----------------------------------------------------------------------------
178 int GetNameOfSelectedNodes (LightApp_SelectionMgr*,
179 const Handle(SALOME_InteractiveObject)& theIO,
182 int GetNameOfSelectedNodes (LightApp_SelectionMgr*,
185 int GetNameOfSelectedElements (LightApp_SelectionMgr*,
186 const Handle(SALOME_InteractiveObject)& theIO,
189 int GetNameOfSelectedElements (LightApp_SelectionMgr*,
192 int GetSelected (LightApp_SelectionMgr*,
193 TColStd_IndexedMapOfInteger& theMap,
194 const bool theIsElement = true );
197 int GetEdgeNodes (LightApp_SelectionMgr*, int& theId1, int& theId2);
200 void SetControlsPrecision (const long theVal);