X-Git-Url: http://git.salome-platform.org/gitweb/?p=modules%2Fsmesh.git;a=blobdiff_plain;f=src%2FOBJECT%2FSMESH_Object.h;h=b96a26cdc1c2a134257756b72e841899862dfa8b;hp=6ed30e2fa0533146757ce2bd0155bacf75c0847b;hb=4b5fd249abfca52265832f10435f18f5bb9c69ae;hpb=c3bf92bd87b770fd81631a3853f7f5bb1ac6a4e8 diff --git a/src/OBJECT/SMESH_Object.h b/src/OBJECT/SMESH_Object.h index 6ed30e2fa..b96a26cdc 100644 --- a/src/OBJECT/SMESH_Object.h +++ b/src/OBJECT/SMESH_Object.h @@ -1,207 +1,82 @@ -// SMESH OBJECT : interactive object for SMESH visualization +// Copyright (C) 2007-2011 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 +// +// 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. // -// 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 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_Object.h // Author : Nicolas REJNERI // Module : SMESH // $Header$ - +// #ifndef SMESH_OBJECT_H #define SMESH_OBJECT_H -// IDL Headers -#include -#include CORBA_SERVER_HEADER(SMESH_Mesh) -#include CORBA_SERVER_HEADER(SMESH_Group) -#include CORBA_SERVER_HEADER(SMESH_Filter) +#ifdef WNT + #if defined SMESHOBJECT_EXPORTS || defined SMESHObject_EXPORTS + #define SMESHOBJECT_EXPORT __declspec( dllexport ) + #else + #define SMESHOBJECT_EXPORT __declspec( dllimport ) + #endif +#else + #define SMESHOBJECT_EXPORT +#endif -#include -#include #include #include -class vtkUnstructuredGrid; -class vtkPoints; -class SALOME_ExtractUnstructuredGrid; +#include "SMESH_Controls.hxx" +#include "SMDSAbs_ElementType.hxx" -class SMESH_Actor; class SMDS_Mesh; -class SMDS_MeshNode; -class SMDS_MeshElement; - -class SMESH_VisualObj; -typedef boost::shared_ptr TVisualObjPtr; - +class vtkUnstructuredGrid; /* Class : SMESH_VisualObj Description : Base class for all mesh objects to be visuilised */ - -class SMESH_VisualObj -{ -protected: - - typedef std::list TEntityList; - typedef std::map TMapOfIds; - -public: - SMESH_VisualObj(); - virtual ~SMESH_VisualObj(); - - virtual void Update( int theIsClear = true ) = 0; - virtual void UpdateFunctor( SMESH::Functor_ptr theFunctor ) = 0; - virtual int GetElemDimension( const int theObjId ) = 0; - - virtual int GetNbEntities( const SMESH::ElementType) const = 0; - virtual int GetEntities( const SMESH::ElementType, TEntityList& ) const = 0; - virtual bool IsNodePrs() const = 0; - - vtkUnstructuredGrid* GetUnstructuredGrid() { return myGrid; } - - vtkIdType GetNodeObjId( int theVTKID ); - vtkIdType GetNodeVTKId( int theObjID ); - vtkIdType GetElemObjId( int theVTKID ); - vtkIdType GetElemVTKId( int theObjID ); - -protected: - - void createPoints( vtkPoints* ); - void buildPrs(); - void buildNodePrs(); - void buildElemPrs(); - -private: - - TMapOfIds mySMDS2VTKNodes; - TMapOfIds myVTK2SMDSNodes; - TMapOfIds mySMDS2VTKElems; - TMapOfIds myVTK2SMDSElems; - - vtkUnstructuredGrid* myGrid; -}; - - -/* - Class : SMESH_MeshObj - Description : Class for visualisation of mesh -*/ - -class SMESH_MeshObj: public SMESH_VisualObj -{ -public: - - SMESH_MeshObj( SMESH::SMESH_Mesh_ptr ); - virtual ~SMESH_MeshObj(); - - virtual void Update( int theIsClear = true ); - - virtual int GetNbEntities( const SMESH::ElementType) const; - virtual int GetEntities( const SMESH::ElementType, TEntityList& ) const; - virtual bool IsNodePrs() const; - - virtual int GetElemDimension( const int theObjId ); - - virtual void UpdateFunctor( SMESH::Functor_ptr f ); - - SMESH::SMESH_Mesh_ptr GetMeshServer() { return myMeshServer.in(); } - SMDS_Mesh* GetMesh() { return myMesh; } - -protected: - - SMESH::SMESH_Mesh_var myMeshServer; - SMDS_Mesh* myMesh; -}; - - -/* - Class : SMESH_SubMeshObj - Description : Base class for visualisation of submeshes and groups -*/ - -class SMESH_SubMeshObj: public SMESH_VisualObj +class SMESHOBJECT_EXPORT SMESH_VisualObj { public: - - SMESH_SubMeshObj(SMESH_MeshObj* theMeshObj); - virtual ~SMESH_SubMeshObj(); - - virtual void Update( int theIsClear = true ); + virtual bool Update( int theIsClear = true ) = 0; + virtual bool NulData() = 0; + virtual void UpdateFunctor( const SMESH::Controls::FunctorPtr& theFunctor ) = 0; + virtual int GetElemDimension( const int theObjId ) = 0; + + virtual int GetNbEntities( const SMDSAbs_ElementType theType) const = 0; + virtual SMDS_Mesh* GetMesh() const = 0; + + virtual bool GetEdgeNodes( const int theElemId, + const int theEdgeNum, + int& theNodeId1, + int& theNodeId2 ) const = 0; + virtual bool IsValid() const = 0; - virtual void UpdateFunctor( SMESH::Functor_ptr ); - virtual int GetElemDimension( const int theObjId ); + virtual vtkUnstructuredGrid* GetUnstructuredGrid() = 0; -protected: - - SMESH_MeshObj* myMeshObj; + virtual vtkIdType GetNodeObjId( int theVTKID ) = 0; + virtual vtkIdType GetNodeVTKId( int theObjID ) = 0; + virtual vtkIdType GetElemObjId( int theVTKID ) = 0; + virtual vtkIdType GetElemVTKId( int theObjID ) = 0; }; - -/* - Class : SMESH_GroupObj - Description : Class for visualisation of groups -*/ - -class SMESH_GroupObj: public SMESH_SubMeshObj -{ -public: - SMESH_GroupObj( SMESH::SMESH_Group_ptr, SMESH_MeshObj* ); - virtual ~SMESH_GroupObj(); - - virtual int GetNbEntities( const SMESH::ElementType) const; - virtual int GetEntities( const SMESH::ElementType, TEntityList& ) const; - virtual bool IsNodePrs() const; - -private: - - SMESH::SMESH_Group_var myGroupServer; -}; - - -/* - Class : SMESH_subMeshObj - Description : Class for visualisation of submeshes -*/ - -class SMESH_subMeshObj : public SMESH_SubMeshObj -{ -public: - - SMESH_subMeshObj( SMESH::SMESH_subMesh_ptr, - SMESH_MeshObj* ); - virtual ~SMESH_subMeshObj(); - - virtual int GetNbEntities( const SMESH::ElementType) const; - virtual int GetEntities( const SMESH::ElementType, TEntityList& ) const; - virtual bool IsNodePrs() const; - -protected: - - SMESH::SMESH_subMesh_var mySubMeshServer; -}; - - -extern void WriteUnstructuredGrid(vtkUnstructuredGrid* theGrid, const char* theFileName); - +typedef boost::shared_ptr TVisualObjPtr; #endif