1 // Copyright (C) 2007-2008 CEA/DEN, EDF R&D, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
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.
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.
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
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
22 // SMESH OBJECT : interactive object for SMESH visualization
23 // File : SMESH_ActorDef.h
24 // Author : Nicolas REJNERI
28 #ifndef SMESH_ACTORDEF_H
29 #define SMESH_ACTORDEF_H
31 #include "SMESH_Actor.h"
32 #include "SMESH_Object.h"
34 #include <vtkSmartPointer.h>
37 class TVTKSmartPtr: public vtkSmartPointer<T>
41 TVTKSmartPtr(T* r, bool theIsOwner = false): vtkSmartPointer<T>(r) {
45 TVTKSmartPtr& operator()(T* r, bool theIsOwner = false){
46 vtkSmartPointer<T>::operator=(r);
51 TVTKSmartPtr& operator=(T* r){ vtkSmartPointer<T>::operator=(r); return *this;}
52 T* Get() const { return this->GetPointer();}
57 class vtkShrinkFilter;
58 class vtkPolyDataMapper;
59 class vtkUnstructuredGrid;
67 class vtkLabeledDataMapper;
68 class vtkSelectVisiblePoints;
70 class vtkScalarBarActor;
74 class vtkImplicitBoolean;
78 class SMESH_DeviceActor;
81 class SMESH_ActorDef : public SMESH_Actor
83 friend class SMESH_VisualObj;
84 friend class SMESH_Actor;
87 vtkTypeMacro(SMESH_ActorDef,SMESH_Actor);
89 virtual void ReleaseGraphicsResources(vtkWindow *renWin);
90 virtual int RenderOpaqueGeometry(vtkViewport *viewport);
91 virtual int RenderTranslucentGeometry(vtkViewport *viewport);
92 virtual void Render(vtkRenderer *ren);
94 virtual void AddToRender(vtkRenderer* theRenderer);
95 virtual void RemoveFromRender(vtkRenderer* theRenderer);
97 virtual bool hasHighlight() { return true; }
98 virtual void highlight(bool theHighlight);
99 virtual void SetPreSelected(bool thePreselect = false);
101 virtual bool IsInfinitive();
103 virtual void SetOpacity(vtkFloatingPointType theValue);
104 virtual vtkFloatingPointType GetOpacity();
106 virtual void SetSufaceColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b);
107 virtual void GetSufaceColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b);
109 virtual void SetBackSufaceColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b);
110 virtual void GetBackSufaceColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b);
112 virtual void SetEdgeColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b);
113 virtual void GetEdgeColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b);
115 virtual void SetNodeColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b);
116 virtual void GetNodeColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b);
118 virtual void Set0DColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b);
119 virtual void Get0DColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b);
121 virtual void SetHighlightColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b);
122 virtual void GetHighlightColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b);
124 virtual void SetPreHighlightColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b);
125 virtual void GetPreHighlightColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b);
127 virtual vtkFloatingPointType GetLineWidth();
128 virtual void SetLineWidth(vtkFloatingPointType theVal);
130 virtual void SetNodeSize(vtkFloatingPointType size) ;
131 virtual vtkFloatingPointType GetNodeSize() ;
133 virtual void Set0DSize(vtkFloatingPointType size);
134 virtual vtkFloatingPointType Get0DSize();
136 virtual int GetNodeObjId(int theVtkID);
137 virtual vtkFloatingPointType* GetNodeCoord(int theObjID);
139 virtual int GetElemObjId(int theVtkID);
140 virtual vtkCell* GetElemCell(int theObjID);
142 virtual int GetObjDimension( const int theObjId );
144 virtual void SetVisibility(int theMode);
145 void SetVisibility(int theMode, bool theIsUpdateRepersentation);
147 virtual void SetRepresentation(int theMode);
149 virtual unsigned int GetEntityMode() const { return myEntityMode;}
150 virtual void SetEntityMode(unsigned int theMode);
152 virtual void SetPointRepresentation(bool theIsPointsVisible);
153 virtual bool GetPointRepresentation();
155 virtual vtkFloatingPointType* GetBounds();
156 virtual void SetTransform(VTKViewer_Transform* theTransform);
158 virtual vtkUnstructuredGrid* GetUnstructuredGrid();
159 virtual vtkDataSet* GetInput();
160 virtual vtkMapper* GetMapper();
162 virtual vtkFloatingPointType GetShrinkFactor();
163 virtual void SetShrinkFactor(vtkFloatingPointType theValue);
165 virtual bool IsShrunkable() { return myIsShrinkable;}
166 virtual bool IsShrunk() { return myIsShrunk;}
167 virtual void SetShrink();
168 virtual void UnShrink();
170 virtual void SetPointsLabeled(bool theIsPointsLabeled);
171 virtual bool GetPointsLabeled(){ return myIsPointsLabeled;}
173 virtual void SetCellsLabeled(bool theIsCellsLabeled);
174 virtual bool GetCellsLabeled(){ return myIsCellsLabeled;}
176 virtual void SetFacesOriented(bool theIsFacesOriented);
177 virtual bool GetFacesOriented();
179 virtual void SetFacesOrientationColor(vtkFloatingPointType theColor[3]);
180 virtual void GetFacesOrientationColor(vtkFloatingPointType theColor[3]);
182 virtual void SetFacesOrientationScale(vtkFloatingPointType theScale);
183 virtual vtkFloatingPointType GetFacesOrientationScale();
185 virtual void SetFacesOrientation3DVectors(bool theState);
186 virtual bool GetFacesOrientation3DVectors();
188 virtual void SetControlMode(eControl theMode);
189 virtual eControl GetControlMode(){ return myControlMode;}
191 virtual vtkScalarBarActor* GetScalarBarActor(){ return myScalarBarActor;}
193 virtual void SetPlaneParam(vtkFloatingPointType theDir[3], vtkFloatingPointType theDist, vtkPlane* thePlane);
194 virtual void GetPlaneParam(vtkFloatingPointType theDir[3], vtkFloatingPointType& theDist, vtkPlane* thePlane);
196 virtual void RemoveAllClippingPlanes();
197 virtual vtkIdType GetNumberOfClippingPlanes();
198 virtual vtkPlane* GetClippingPlane(vtkIdType theID);
199 virtual vtkIdType AddClippingPlane(vtkPlane* thePlane);
201 virtual TVisualObjPtr GetObject() { return myVisualObj;}
203 virtual void SetControlsPrecision( const long p ) { myControlsPrecision = p; }
204 virtual long GetControlsPrecision() const { return myControlsPrecision; }
206 virtual void UpdateScalarBar();
209 virtual void SetQuadratic2DRepresentation(EQuadratic2DRepresentation);
210 virtual EQuadratic2DRepresentation GetQuadratic2DRepresentation();
213 void SetControlMode(eControl theMode, bool theCheckEntityMode);
214 void SetImplicitFunctionUsed(bool theIsImplicitFunctionUsed);
215 bool IsImplicitFunctionUsed() const;
217 TVisualObjPtr myVisualObj;
218 vtkTimeStamp* myTimeStamp;
220 vtkScalarBarActor* myScalarBarActor;
221 vtkLookupTable* myLookupTable;
223 vtkProperty* mySurfaceProp;
224 vtkProperty* myBackSurfaceProp;
225 vtkProperty* myEdgeProp;
226 vtkProperty* myNodeProp;
228 SMESH_DeviceActor* myBaseActor;
229 SMESH_DeviceActor* myNodeActor;
230 SMESH_DeviceActor* myPickableActor;
232 vtkProperty* myHighlightProp;
233 vtkProperty* myPreselectProp;
234 SMESH_DeviceActor* myHighlitableActor;
236 eControl myControlMode;
237 vtkProperty* my2DExtProp;
238 SMESH_DeviceActor* my2DActor;
239 SMESH_DeviceActor* my2DExtActor;
240 SMESH_DeviceActor* my3DActor;
241 SMESH_DeviceActor* myControlActor;
243 vtkProperty* myNodeExtProp;
244 SMESH_DeviceActor* myNodeExtActor;
246 vtkProperty* my1DProp;
247 SMESH_DeviceActor* my1DActor;
248 vtkProperty* my1DExtProp;
249 SMESH_DeviceActor* my1DExtActor;
251 vtkProperty* my0DProp;
252 SMESH_DeviceActor* my0DActor;
253 vtkProperty* my0DExtProp;
254 SMESH_DeviceActor* my0DExtActor;
256 unsigned int myEntityMode;
257 unsigned int myEntityState;
258 bool myIsPointsVisible;
263 bool myIsPointsLabeled;
264 vtkUnstructuredGrid* myPointsNumDataSet;
265 vtkActor2D *myPointLabels;
266 vtkMaskPoints* myPtsMaskPoints;
267 vtkLabeledDataMapper* myPtsLabeledDataMapper;
268 vtkSelectVisiblePoints* myPtsSelectVisiblePoints;
270 bool myIsCellsLabeled;
271 vtkUnstructuredGrid* myCellsNumDataSet;
272 vtkActor2D *myCellsLabels;
273 vtkMaskPoints* myClsMaskPoints;
274 vtkCellCenters* myCellCenters;
275 vtkLabeledDataMapper* myClsLabeledDataMapper;
276 vtkSelectVisiblePoints* myClsSelectVisiblePoints;
278 vtkImplicitBoolean* myImplicitBoolean;
279 typedef TVTKSmartPtr<vtkPlane> TPlanePtr;
280 typedef std::vector<TPlanePtr> TCippingPlaneCont;
281 TCippingPlaneCont myCippingPlaneCont;
282 long myControlsPrecision;
284 bool myIsFacesOriented;
289 bool Init(TVisualObjPtr theVisualObj,
290 const char* theEntry,
294 void SetIsShrunkable(bool theShrunkable);
295 void UpdateHighlight();
299 // hide the two parameter Render() method from the user and the compiler.
300 virtual void Render(vtkRenderer *, vtkMapper *) {};
301 virtual void ShallowCopy(vtkProp *prop);
302 virtual void SetMapper(vtkMapper *);
303 static SMESH_ActorDef* New();
306 SMESH_ActorDef(const SMESH_ActorDef&);
307 void operator=(const SMESH_ActorDef&);
311 #endif //SMESH_ACTORDEF_H