Version: 9.12.0
SMDS_MeshNode.hxx
Go to the documentation of this file.
1 // Copyright (C) 2007-2023 CEA, EDF, OPEN CASCADE
2 //
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
5 //
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, or (at your option) any later version.
10 //
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.
15 //
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
19 //
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
21 //
22 
23 // SMESH SMDS : implementation of Salome mesh data structure
24 // File : SMDS_MeshNode.hxx
25 // Module : SMESH
26 //
27 #ifndef _SMDS_MeshNode_HeaderFile
28 #define _SMDS_MeshNode_HeaderFile
29 
30 #include "SMESH_SMDS.hxx"
31 
32 #include "SMDS_MeshElement.hxx"
33 #include "SMDS_Position.hxx"
34 
36 {
37  public:
38 
39  void setXYZ(double x, double y, double z);
40  double X() const; // ! NOT thread safe methods !
41  double Y() const;
42  double Z() const;
43  void GetXYZ(double xyz[3]) const; // thread safe getting coords
44 
45  SMDS_ElemIteratorPtr GetInverseElementIterator(SMDSAbs_ElementType type=SMDSAbs_All) const;
46  int NbInverseElements(SMDSAbs_ElementType type=SMDSAbs_All) const;
47 
48  SMDS_PositionPtr GetPosition() const; // WARNING result is std::unique_ptr !
49  void SetPosition(const SMDS_PositionPtr& aPos, int shapeID = 0 );
50 
51  virtual SMDSAbs_ElementType GetType() const { return SMDSAbs_Node; }
52  virtual VTKCellType GetVtkType() const { return VTK_VERTEX; }
54  virtual SMDSAbs_GeometryType GetGeomType() const { return SMDSGeom_NONE; }
55  virtual int NbNodes() const { return 1; }
56  virtual int NbEdges() const { return 0; }
57  virtual int NbFaces() const { return 0; }
58 
59  virtual SMDS_ElemIteratorPtr nodesIterator() const;
60  virtual SMDS_NodeIteratorPtr nodeIterator() const;
61  virtual const SMDS_MeshNode* GetNode(const int ind) const;
62 
63  virtual bool IsPoly() const { return false; }
64  virtual bool IsQuadratic() const { return false; }
65  virtual bool IsMediumNode(const SMDS_MeshNode* /*node*/) const { return false; }
66  virtual int NbCornerNodes() const { return 1; }
67 
68  void Print(std::ostream & OS) const;
69 
70  private:
71 
72  void init(double x=0, double y=0, double z=0);
73 
74  double* getCoord() const;
75  void AddInverseElement (const SMDS_MeshElement * elem);
76  void RemoveInverseElement(const SMDS_MeshElement * elem);
77  void ClearInverseElements();
78 
79  friend class SMDS_Mesh;
80 
81 };
82 
83 #endif
SMDSAbs_GeometryType
enumeration for element geometry type
Definition: SMDSAbs_ElementType.hxx:47
@ SMDSGeom_NONE
Definition: SMDSAbs_ElementType.hxx:66
SMDSAbs_ElementType
Type (node, edge, face or volume) of elements.
Definition: SMDSAbs_ElementType.hxx:34
@ SMDSAbs_Node
Definition: SMDSAbs_ElementType.hxx:36
@ SMDSAbs_All
Definition: SMDSAbs_ElementType.hxx:35
SMDSAbs_EntityType
Enumeration of entity type used in mesh info array.
Definition: SMDSAbs_ElementType.hxx:79
@ SMDSEntity_Node
Definition: SMDSAbs_ElementType.hxx:80
boost::shared_ptr< SMDS_Iterator< const SMDS_MeshElement * > > SMDS_ElemIteratorPtr
Definition: SMDS_ElemIterator.hxx:43
boost::shared_ptr< SMDS_Iterator< const SMDS_MeshNode * > > SMDS_NodeIteratorPtr
Definition: SMDS_ElemIterator.hxx:46
#define SMDS_EXPORT
Definition: SMESH_SMDS.hxx:37
Base class for elements.
Definition: SMDS_MeshElement.hxx:56
virtual SMDS_ElemIteratorPtr nodesIterator() const =0
virtual const SMDS_MeshNode * GetNode(const int ind) const =0
Return node by its index.
void Print(std::ostream &OS) const
Print self.
Definition: SMDS_MeshElement.cxx:207
virtual SMDS_NodeIteratorPtr nodeIterator() const =0
Definition: SMDS_MeshNode.hxx:36
virtual int NbEdges() const
Definition: SMDS_MeshNode.hxx:56
virtual VTKCellType GetVtkType() const
Definition: SMDS_MeshNode.hxx:52
virtual int NbNodes() const
Definition: SMDS_MeshNode.hxx:55
virtual SMDSAbs_GeometryType GetGeomType() const
Definition: SMDS_MeshNode.hxx:54
virtual bool IsPoly() const
Definition: SMDS_MeshNode.hxx:63
virtual bool IsQuadratic() const
Definition: SMDS_MeshNode.hxx:64
virtual bool IsMediumNode(const SMDS_MeshNode *) const
Check if a node is a medium node of a quadratic cell.
Definition: SMDS_MeshNode.hxx:65
virtual int NbCornerNodes() const
Definition: SMDS_MeshNode.hxx:66
virtual int NbFaces() const
Definition: SMDS_MeshNode.hxx:57
virtual SMDSAbs_ElementType GetType() const
Definition: SMDS_MeshNode.hxx:51
virtual SMDSAbs_EntityType GetEntityType() const
Definition: SMDS_MeshNode.hxx:53
Definition: SMDS_Mesh.hxx:53
Replace "typedef SMDS_Position* SMDS_PositionPtr" by a smart pointer allowing implicit casting to der...
Definition: SMDS_Position.hxx:58