1 # Copyright (C) 2007-2019 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, or (at your option) any later version.
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
23 import SHAPERSTUDY_ORB__POA
25 from SHAPERSTUDY_utils import getEngine
29 class SHAPERSTUDY_Object(SHAPERSTUDY_ORB__POA.SHAPER_Object):
31 Construct an instance of SHAPERSTUDY Object.
33 def __init__ ( self, *args):
38 def GetShapeType( self ):
40 Get a GEOM.shape_type of the object value.
44 types = {0:GEOM.COMPOUND, 1:GEOM.COMPSOLID, 2:GEOM.SOLID,
45 3:GEOM.SHELL, 4:GEOM.FACE, 5:GEOM.WIRE,
46 6:GEOM.EDGE, 7:GEOM.VERTEX, 8:GEOM.SHAPE, 9:GEOM.FLAT}
47 return types[self.data.type()];
49 def IsMainShape( self ):
51 Returns True if this object is not a sub-shape of another object.
55 def GetSubShapeIndices( self ):
57 Get a list of ID's of sub-shapes in the main shape.
61 def GetMainShape( self ):
63 Get a main shape object to which this object is a sub-shape.
69 Get the TopoDS_Shape, for colocated case only.
70 Called by GEOM_Client to get TopoDS_Shape pointer
74 return self.data.shape()
76 def GetShapeStream( self ):
78 Get geometric shape of the object as a byte stream in BRep format
82 return self.data.shapeStream()
84 def SetShapeByStream(self, theStream):
86 Sets geometric shape content of the object as a byte stream in BRep format
89 self.data.updateShape(theStream)
91 self.data = StudyData_Swig.StudyData_Object(theStream)
94 Methods from BaseObject
98 Get name of the object associated with this object.
100 return self.SO.GetName()
102 def SetEntry( self, theInternalEntry ):
104 Sets internal (unique) entry of the object in the component's data tree.
106 self.entry = theInternalEntry
108 def GetEntry( self ):
110 Get internal (unique) entry of the object in the component's data tree.
116 Get internal type of operation created this object.
117 In SMESH is used to find out if an object is GROUP (type == 37)
119 # 1 corresponds to the Import feature (GEOMImpl_Types.hxx )
124 Get value of a modification counter of the object
127 return self.data.getTick()
130 def GetStudyEntry( self ):
132 Get a Study entry where this object was published.
134 return self.SO.GetID()
138 Return true if geom object represents a shape.
139 For example, method return false for GEOM_MARKER
143 def IsSame( self, other ):
145 Return true if passed object is identical to this object
147 return self.GetType() == other.GetType() and self.GetEntry() == other.GetEntry()
151 Return the engine creating this object
155 def SetSO( self, theSO ):
157 Sets SObject of this object (when it is published)
163 Returns SObject of this object
167 def IsParametrical(self):
169 Returns true if the current object has connection to a parametrical model
170 which can be modified by parameters change.