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 return self.data.type();
46 def IsMainShape( self ):
48 Returns True if this object is not a sub-shape of another object.
52 def GetSubShapeIndices( self ):
54 Get a list of ID's of sub-shapes in the main shape.
58 def GetMainShape( self ):
60 Get a main shape object to which this object is a sub-shape.
66 Get the TopoDS_Shape, for colocated case only.
67 Called by GEOM_Client to get TopoDS_Shape pointer
71 return self.data.shape()
73 def GetShapeStream( self ):
75 Get geometric shape of the object as a byte stream in BRep format
79 return self.data.shapeStream()
81 def SetShapeByStream(self, theStream):
83 Sets geometric shape content of the object as a byte stream in BRep format
86 self.data.updateShape(theStream)
88 self.data = StudyData_Swig.StudyData_Object(theStream)
91 Methods from BaseObject
95 Get name of the object associated with this object.
97 return self.SO.GetName()
99 def SetEntry( self, theInternalEntry ):
101 Sets internal (unique) entry of the object in the component's data tree.
103 self.entry = theInternalEntry
105 def GetEntry( self ):
107 Get internal (unique) entry of the object in the component's data tree.
113 Get internal type of operation created this object.
114 In SMESH is used to find out if an object is GROUP (type == 37)
116 # 1 corresponds to the Import feature (GEOMImpl_Types.hxx )
121 Get value of a modification counter of the object
124 return self.data.getTick()
127 def GetStudyEntry( self ):
129 Get a Study entry where this object was published.
131 return self.SO.GetID()
135 Return true if geom object represents a shape.
136 For example, method return false for GEOM_MARKER
140 def IsSame( self, other ):
142 Return true if passed object is identical to this object
144 return self.GetType() == other.GetType() and self.GetEntry() == other.GetEntry()
148 Return the engine creating this object
152 def SetSO( self, theSO ):
154 Sets SObject of this object (when it is published)
160 Returns SObject of this object
164 def IsParametrical(self):
166 Returns true if the current object has connection to a parametrical model
167 which can be modified by parameters change.
171 def BreakLinks(self):
173 Breaks links to parametrical mode for parametrical shape
175 print("##### Break parametrical links")