X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FOBJECT%2FSMESH_Actor.h;h=744571e41360280a92dbb6cfd3a50821ad74b496;hb=refs%2Ftags%2FRELIQUAT_5x_15112010;hp=2cb9628a8d81d2097db2f3f6d30d139f4a5e7e4e;hpb=c3bf92bd87b770fd81631a3853f7f5bb1ac6a4e8;p=modules%2Fsmesh.git diff --git a/src/OBJECT/SMESH_Actor.h b/src/OBJECT/SMESH_Actor.h index 2cb9628a8..744571e41 100644 --- a/src/OBJECT/SMESH_Actor.h +++ b/src/OBJECT/SMESH_Actor.h @@ -1,233 +1,148 @@ -// SMESH OBJECT : interactive object for SMESH visualization +// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE +// +// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, +// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS // -// 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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org +// 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 +// + +// SMESH OBJECT : interactive object for SMESH visualization // File : SMESH_Actor.h // Author : Nicolas REJNERI // Module : SMESH -// $Header$ - +// #ifndef SMESH_ACTOR_H #define SMESH_ACTOR_H -#include "SALOME_Actor.h" +#include #include "SMESH_Object.h" -class vtkProperty; -class vtkShrinkFilter; -class vtkPolyDataMapper; -class vtkUnstructuredGrid; -class vtkMergeFilter; -class vtkPolyData; +#include -class vtkMapper; -class vtkActor2D; -class vtkMaskPoints; -class vtkLabeledDataMapper; -class vtkSelectVisiblePoints; +class vtkUnstructuredGrid; -class vtkScalarBarActor; -class vtkLookupTable; +class SMESH_ScalarBarActor; -class SMESH_DeviceActor; -class SALOME_ExtractUnstructuredGrid; +class vtkPlane; +class vtkImplicitBoolean; +namespace SMESH +{ + const vtkIdType DeleteActorEvent = vtkCommand::UserEvent + 100; +} -class SMESH_Actor : public SALOME_Actor{ - friend class SMESH_VisualObj; +class SMESHOBJECT_EXPORT SMESH_Actor: public SALOME_Actor +{ + static SMESH_Actor* New() { return NULL;} public: vtkTypeMacro(SMESH_Actor,SALOME_Actor); static SMESH_Actor* New(TVisualObjPtr theVisualObj, - SMESH::FilterManager_ptr theFilterMgr, - const char* theEntry, - const char* theName, - int theIsClear); + const char* theEntry, + const char* theName, + int theIsClear); - virtual void ReleaseGraphicsResources(vtkWindow *renWin); - virtual int RenderOpaqueGeometry(vtkViewport *viewport); - virtual int RenderTranslucentGeometry(vtkViewport *viewport); - virtual void Render(vtkRenderer *ren); - - virtual void AddToRender(vtkRenderer* theRenderer); - virtual void RemoveFromRender(vtkRenderer* theRenderer); - - virtual bool hasHighlight() { return true; } - virtual void highlight(Standard_Boolean highlight); - virtual void SetPreSelected(Standard_Boolean presel = Standard_False); - - virtual bool IsInfinitive(); - - virtual void SetOpacity(float theValue); - virtual float GetOpacity(); - - void SetSufaceColor(float r,float g,float b); - void GetSufaceColor(float& r,float& g,float& b); - - void SetBackSufaceColor(float r,float g,float b); - void GetBackSufaceColor(float& r,float& g,float& b); + virtual void SetSufaceColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b) = 0; + virtual void GetSufaceColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b) = 0; + + virtual void SetBackSufaceColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b) = 0; + virtual void GetBackSufaceColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b) = 0; + + virtual void SetEdgeColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b) = 0; + virtual void GetEdgeColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b) = 0; - void SetEdgeColor(float r,float g,float b); - void GetEdgeColor(float& r,float& g,float& b); + virtual void SetNodeColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b) = 0; + virtual void GetNodeColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b) = 0; - void SetNodeColor(float r,float g,float b); - void GetNodeColor(float& r,float& g,float& b); + virtual void Set0DColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b) = 0; + virtual void Get0DColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b) = 0; - void SetHighlightColor(float r,float g,float b); - void GetHighlightColor(float& r,float& g,float& b); + virtual void SetHighlightColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b) = 0; + virtual void GetHighlightColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b) = 0; - void SetPreHighlightColor(float r,float g,float b); - void GetPreHighlightColor(float& r,float& g,float& b); + virtual void SetPreHighlightColor(vtkFloatingPointType r,vtkFloatingPointType g,vtkFloatingPointType b) = 0; + virtual void GetPreHighlightColor(vtkFloatingPointType& r,vtkFloatingPointType& g,vtkFloatingPointType& b) = 0; - float GetLineWidth(); - void SetLineWidth(float theVal); - - void SetNodeSize(float size) ; - float GetNodeSize() ; - - virtual int GetObjId(int theVtkID); - virtual TVectorId GetVtkId(int theObjID); + virtual vtkFloatingPointType GetLineWidth() = 0; + virtual void SetLineWidth(vtkFloatingPointType theVal) = 0; - virtual int GetNodeObjId(int theVtkID); - virtual TVectorId GetNodeVtkId(int theObjID); - - virtual int GetElemObjId(int theVtkID); - virtual TVectorId GetElemVtkId(int theObjID); - - virtual int GetObjDimension( const int theObjId ); - - virtual void SetVisibility(int theMode); + virtual void Set0DSize(vtkFloatingPointType size) = 0; + virtual vtkFloatingPointType Get0DSize() = 0; enum EReperesent { ePoint, eEdge, eSurface}; - virtual void SetRepresentation(int theMode); - void SetPointRepresentation(int theIsPointsVisible); - bool GetPointRepresentation(){ return myIsPointsVisible;} - - virtual vtkPolyData* GetPolyDataInput(); - virtual void SetTransform(SALOME_Transform* theTransform); + + enum EEntityMode { e0DElements = 0x01, eEdges = 0x02, eFaces = 0x04, eVolumes = 0x08, eAllEntity = 0x0f}; - vtkUnstructuredGrid* GetUnstructuredGrid(); - virtual vtkMapper* GetMapper(); + enum EQuadratic2DRepresentation { eLines = 0x01, eArcs = 0x02 }; - float GetShrinkFactor(); - void SetShrinkFactor(float value ); + virtual void SetEntityMode(unsigned int theMode) = 0; + virtual unsigned int GetEntityMode() const = 0; - bool IsShrunkable() { return myIsShrinkable;} - bool IsShrunk() { return myIsShrunk;} - void SetShrink(); - void UnShrink(); + virtual void SetQuadratic2DRepresentation(EQuadratic2DRepresentation) = 0; + virtual EQuadratic2DRepresentation GetQuadratic2DRepresentation() = 0; - void SetPointsLabeled(bool theIsPointsLabeled); - bool GetPointsLabeled(){ return myIsPointsLabeled;} + virtual void SetPointRepresentation(bool theIsPointsVisible) = 0; + virtual bool GetPointRepresentation() = 0; - void SetCellsLabeled(bool theIsCellsLabeled); - bool GetCellsLabeled(){ return myIsCellsLabeled;} + virtual vtkUnstructuredGrid* GetUnstructuredGrid() = 0; - enum eControl{eNone, eLengthEdges, eFreeBorders, eMultiConnection, - eArea, eTaper, eAspectRatio, eMinimumAngle, eWarping, eSkew}; - void SetControlMode(eControl theMode); - eControl GetControlMode(){ return myColorMode;} + virtual void SetShrinkFactor(vtkFloatingPointType theValue) = 0; - enum e1DControl{e1DNone, e1DColored, e1DHighlited}; - e1DControl Get1DControlMode(){ return my1DColorMode;} + virtual void SetPointsLabeled(bool theIsPointsLabeled) = 0; + virtual bool GetPointsLabeled() = 0; - vtkScalarBarActor* GetScalarBarActor(){ return myScalarBarActor;} + virtual void SetCellsLabeled(bool theIsCellsLabeled) = 0; + virtual bool GetCellsLabeled() = 0; - TVisualObjPtr GetObject() { return myVisualObj;} + virtual void SetFacesOriented(bool theIsFacesOriented) = 0; + virtual bool GetFacesOriented() = 0; - protected: - TVisualObjPtr myVisualObj; + virtual void SetFacesOrientationColor(vtkFloatingPointType theColor[3]) = 0; + virtual void GetFacesOrientationColor(vtkFloatingPointType theColor[3]) = 0; - SMESH::FilterManager_var myFilterMgr; - vtkScalarBarActor* myScalarBarActor; - vtkLookupTable* myLookupTable; + virtual void SetFacesOrientationScale(vtkFloatingPointType theScale) = 0; + virtual vtkFloatingPointType GetFacesOrientationScale() = 0; - vtkProperty* mySurfaceProp; - vtkProperty* myBackSurfaceProp; - vtkProperty* myEdgeProp; - vtkProperty* myNodeProp; + virtual void SetFacesOrientation3DVectors(bool theState) = 0; + virtual bool GetFacesOrientation3DVectors() = 0; - SMESH_DeviceActor* myBaseActor; - SMESH_DeviceActor* myNodeActor; - SMESH_DeviceActor* myPickableActor; + enum eControl{eNone, eLength, eLength2D, eFreeBorders, eFreeEdges, eFreeNodes, + eFreeFaces, eMultiConnection, eArea, eTaper, eAspectRatio, + eMinimumAngle, eWarping, eSkew, eAspectRatio3D, eMultiConnection2D, eVolume3D, + eMaxElementLength2D, eMaxElementLength3D, eBareBorderFace, eBareBorderVolume, + eOverConstrainedFace, eOverConstrainedVolume}; + virtual void SetControlMode(eControl theMode) = 0; + virtual eControl GetControlMode() = 0; + virtual SMESH::Controls::FunctorPtr GetFunctor() = 0; - vtkProperty* myHighlightProp; - vtkProperty* myPreselectProp; - SMESH_DeviceActor* myHighlitableActor; + virtual SMESH_ScalarBarActor* GetScalarBarActor() = 0; - eControl myColorMode; - SMESH_DeviceActor* my2DActor; - SMESH_DeviceActor* my3DActor; - SMESH_DeviceActor* myControlActor; + virtual void RemoveAllClippingPlanes() = 0; + virtual vtkIdType GetNumberOfClippingPlanes() = 0; + virtual vtkPlane* GetClippingPlane(vtkIdType theID) = 0; + virtual vtkIdType AddClippingPlane(vtkPlane* thePlane) = 0; - e1DControl my1DColorMode; - vtkProperty* my1DProp; - SMESH_DeviceActor* my1DActor; - vtkProperty* my1DExtProp; - SMESH_DeviceActor* my1DExtActor; + virtual TVisualObjPtr GetObject() = 0; - bool myIsPointsVisible; + virtual void SetControlsPrecision( const long ) = 0; + virtual long GetControlsPrecision() const = 0; - bool myIsShrinkable; - bool myIsShrunk; - - bool myIsPointsLabeled; - vtkUnstructuredGrid* myPointsNumDataSet; - vtkActor2D *myPointLabels; - vtkMaskPoints* myPtsMaskPoints; - vtkLabeledDataMapper* myPtsLabeledDataMapper; - vtkSelectVisiblePoints* myPtsSelectVisiblePoints; - - bool myIsCellsLabeled; - vtkUnstructuredGrid* myCellsNumDataSet; - vtkActor2D *myCellsLabels; - vtkMaskPoints* myClsMaskPoints; - vtkCellCenters* myCellCenters; - vtkLabeledDataMapper* myClsLabeledDataMapper; - vtkSelectVisiblePoints* myClsSelectVisiblePoints; - - SMESH_Actor(); - ~SMESH_Actor(); - - void Init(TVisualObjPtr theVisualObj, - SMESH::FilterManager_ptr theFilterMgr, - const char* theEntry, - const char* theName, - int theIsClear); - - void SetUnstructuredGrid(vtkUnstructuredGrid* theGrid); - void SetIsShrunkable(bool theShrunkable); - void UpdateHighlight(); - - private: - // hide the two parameter Render() method from the user and the compiler. - virtual void Render(vtkRenderer *, vtkMapper *) {}; - virtual void ShallowCopy(vtkProp *prop); - virtual void SetMapper(vtkMapper *); - static SMESH_Actor* New(); - - // Not implemented. - SMESH_Actor(const SMESH_Actor&); - void operator=(const SMESH_Actor&); + virtual void UpdateScalarBar() = 0; + virtual void UpdateDistribution() = 0; };