mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-06 23:00:34 +05:00
PAL16617 (Modification/Transformation operations with copy don't create a new mesh)
+ SMESH_Mesh MirrorMakeMesh (in long_array IDsOfElements, + SMESH_Mesh MirrorObjectMakeMesh (in SMESH_IDSource theObject, + SMESH_Mesh TranslateMakeMesh (in long_array IDsOfElements, + SMESH_Mesh TranslateObjectMakeMesh (in SMESH_IDSource theObject, + SMESH_Mesh RotateMakeMesh (in long_array IDsOfElements, + SMESH_Mesh RotateObjectMakeMesh (in SMESH_IDSource theObject,
This commit is contained in:
parent
556f0b415d
commit
a818f7f6ff
@ -231,7 +231,7 @@ class smeshDC(SMESH._objref_SMESH_Gen):
|
|||||||
# @return an instance of Mesh class
|
# @return an instance of Mesh class
|
||||||
def CreateMeshesFromUNV( self,theFileName ):
|
def CreateMeshesFromUNV( self,theFileName ):
|
||||||
aSmeshMesh = SMESH._objref_SMESH_Gen.CreateMeshesFromUNV(self,theFileName)
|
aSmeshMesh = SMESH._objref_SMESH_Gen.CreateMeshesFromUNV(self,theFileName)
|
||||||
aMesh = Mesh(self,self.geompyD,aSmeshMesh)
|
aMesh = Mesh(self.smeshpyD, self.geompyD, aSmeshMesh)
|
||||||
return aMesh
|
return aMesh
|
||||||
|
|
||||||
## Create Mesh object(s) importing data from given MED file
|
## Create Mesh object(s) importing data from given MED file
|
||||||
@ -240,7 +240,7 @@ class smeshDC(SMESH._objref_SMESH_Gen):
|
|||||||
aSmeshMeshes, aStatus = SMESH._objref_SMESH_Gen.CreateMeshesFromMED(self,theFileName)
|
aSmeshMeshes, aStatus = SMESH._objref_SMESH_Gen.CreateMeshesFromMED(self,theFileName)
|
||||||
aMeshes = []
|
aMeshes = []
|
||||||
for iMesh in range(len(aSmeshMeshes)) :
|
for iMesh in range(len(aSmeshMeshes)) :
|
||||||
aMesh = Mesh(self,self.geompyD,aSmeshMeshes[iMesh])
|
aMesh = Mesh(self.smeshpyD, self.geompyD, aSmeshMeshes[iMesh])
|
||||||
aMeshes.append(aMesh)
|
aMeshes.append(aMesh)
|
||||||
return aMeshes, aStatus
|
return aMeshes, aStatus
|
||||||
|
|
||||||
@ -248,7 +248,7 @@ class smeshDC(SMESH._objref_SMESH_Gen):
|
|||||||
# @return an instance of Mesh class
|
# @return an instance of Mesh class
|
||||||
def CreateMeshesFromSTL( self, theFileName ):
|
def CreateMeshesFromSTL( self, theFileName ):
|
||||||
aSmeshMesh = SMESH._objref_SMESH_Gen.CreateMeshesFromSTL(self,theFileName)
|
aSmeshMesh = SMESH._objref_SMESH_Gen.CreateMeshesFromSTL(self,theFileName)
|
||||||
aMesh = Mesh(self,self.geompyD,aSmeshMesh)
|
aMesh = Mesh(self.smeshpyD, self.geompyD, aSmeshMesh)
|
||||||
return aMesh
|
return aMesh
|
||||||
|
|
||||||
## From SMESH_Gen interface
|
## From SMESH_Gen interface
|
||||||
@ -1759,7 +1759,7 @@ class Mesh:
|
|||||||
'its expectation' % ( glob, dim, name ))
|
'its expectation' % ( glob, dim, name ))
|
||||||
else:
|
else:
|
||||||
reason = "For unknown reason."+\
|
reason = "For unknown reason."+\
|
||||||
" Revise Mesh.Compute() implementation in smesh.py!"
|
" Revise Mesh.Compute() implementation in smeshDC.py!"
|
||||||
pass
|
pass
|
||||||
if allReasons != "":
|
if allReasons != "":
|
||||||
allReasons += "\n"
|
allReasons += "\n"
|
||||||
@ -2557,6 +2557,8 @@ class Mesh:
|
|||||||
## Reorient all elements of the object
|
## Reorient all elements of the object
|
||||||
# @param theObject is mesh, submesh or group
|
# @param theObject is mesh, submesh or group
|
||||||
def ReorientObject(self, theObject):
|
def ReorientObject(self, theObject):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
return self.editor.ReorientObject(theObject)
|
return self.editor.ReorientObject(theObject)
|
||||||
|
|
||||||
## Fuse neighbour triangles into quadrangles.
|
## Fuse neighbour triangles into quadrangles.
|
||||||
@ -2577,6 +2579,8 @@ class Mesh:
|
|||||||
# is still performed; theMaxAngle is mesured in radians.
|
# is still performed; theMaxAngle is mesured in radians.
|
||||||
# @return TRUE in case of success, FALSE otherwise.
|
# @return TRUE in case of success, FALSE otherwise.
|
||||||
def TriToQuadObject (self, theObject, theCriterion, MaxAngle):
|
def TriToQuadObject (self, theObject, theCriterion, MaxAngle):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
return self.editor.TriToQuadObject(theObject, self.smeshpyD.GetFunctor(theCriterion), MaxAngle)
|
return self.editor.TriToQuadObject(theObject, self.smeshpyD.GetFunctor(theCriterion), MaxAngle)
|
||||||
|
|
||||||
## Split quadrangles into triangles.
|
## Split quadrangles into triangles.
|
||||||
@ -2592,6 +2596,8 @@ class Mesh:
|
|||||||
# @param theObject object to taking list of elements from, is mesh, submesh or group
|
# @param theObject object to taking list of elements from, is mesh, submesh or group
|
||||||
# @param theCriterion is FT_...; used to choose a diagonal for splitting.
|
# @param theCriterion is FT_...; used to choose a diagonal for splitting.
|
||||||
def QuadToTriObject (self, theObject, theCriterion):
|
def QuadToTriObject (self, theObject, theCriterion):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
return self.editor.QuadToTriObject(theObject, self.smeshpyD.GetFunctor(theCriterion))
|
return self.editor.QuadToTriObject(theObject, self.smeshpyD.GetFunctor(theCriterion))
|
||||||
|
|
||||||
## Split quadrangles into triangles.
|
## Split quadrangles into triangles.
|
||||||
@ -2606,6 +2612,8 @@ class Mesh:
|
|||||||
## Split quadrangles into triangles.
|
## Split quadrangles into triangles.
|
||||||
# @param theObject is object to taking list of elements from, is mesh, submesh or group
|
# @param theObject is object to taking list of elements from, is mesh, submesh or group
|
||||||
def SplitQuadObject (self, theObject, Diag13):
|
def SplitQuadObject (self, theObject, Diag13):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
return self.editor.SplitQuadObject(theObject, Diag13)
|
return self.editor.SplitQuadObject(theObject, Diag13)
|
||||||
|
|
||||||
## Find better splitting of the given quadrangle.
|
## Find better splitting of the given quadrangle.
|
||||||
@ -2778,6 +2786,8 @@ class Mesh:
|
|||||||
# @param Method is Laplacian(LAPLACIAN_SMOOTH) or Centroidal(CENTROIDAL_SMOOTH)
|
# @param Method is Laplacian(LAPLACIAN_SMOOTH) or Centroidal(CENTROIDAL_SMOOTH)
|
||||||
def SmoothObject(self, theObject, IDsOfFixedNodes,
|
def SmoothObject(self, theObject, IDsOfFixedNodes,
|
||||||
MaxNbOfIterations, MaxxAspectRatio, Method):
|
MaxNbOfIterations, MaxxAspectRatio, Method):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
return self.editor.SmoothObject(theObject, IDsOfFixedNodes,
|
return self.editor.SmoothObject(theObject, IDsOfFixedNodes,
|
||||||
MaxNbOfIterations, MaxxAspectRatio, Method)
|
MaxNbOfIterations, MaxxAspectRatio, Method)
|
||||||
|
|
||||||
@ -2804,6 +2814,8 @@ class Mesh:
|
|||||||
# @param Method is Laplacian(LAPLACIAN_SMOOTH) or Centroidal(CENTROIDAL_SMOOTH)
|
# @param Method is Laplacian(LAPLACIAN_SMOOTH) or Centroidal(CENTROIDAL_SMOOTH)
|
||||||
def SmoothParametricObject(self, theObject, IDsOfFixedNodes,
|
def SmoothParametricObject(self, theObject, IDsOfFixedNodes,
|
||||||
MaxNbOfIterations, MaxAspectRatio, Method):
|
MaxNbOfIterations, MaxAspectRatio, Method):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
return self.editor.SmoothParametricObject(theObject, IDsOfFixedNodes,
|
return self.editor.SmoothParametricObject(theObject, IDsOfFixedNodes,
|
||||||
MaxNbOfIterations, MaxAspectRatio, Method)
|
MaxNbOfIterations, MaxAspectRatio, Method)
|
||||||
|
|
||||||
@ -2852,6 +2864,8 @@ class Mesh:
|
|||||||
# @param Tolerance tolerance
|
# @param Tolerance tolerance
|
||||||
# @param MakeGroups to generate new groups from existing ones
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
def RotationSweepObject(self, theObject, Axix, AngleInRadians, NbOfSteps, Tolerance, MakeGroups=False):
|
def RotationSweepObject(self, theObject, Axix, AngleInRadians, NbOfSteps, Tolerance, MakeGroups=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( Axix, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( Axix, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
Axix = self.smeshpyD.GetAxisStruct(Axix)
|
Axix = self.smeshpyD.GetAxisStruct(Axix)
|
||||||
if MakeGroups:
|
if MakeGroups:
|
||||||
@ -2899,6 +2913,8 @@ class Mesh:
|
|||||||
# @param NbOfSteps the number of steps
|
# @param NbOfSteps the number of steps
|
||||||
# @param MakeGroups to generate new groups from existing ones
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
def ExtrusionSweepObject(self, theObject, StepVector, NbOfSteps, MakeGroups=False):
|
def ExtrusionSweepObject(self, theObject, StepVector, NbOfSteps, MakeGroups=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( StepVector, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( StepVector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
StepVector = self.smeshpyD.GetDirStruct(StepVector)
|
StepVector = self.smeshpyD.GetDirStruct(StepVector)
|
||||||
if MakeGroups:
|
if MakeGroups:
|
||||||
@ -2912,6 +2928,8 @@ class Mesh:
|
|||||||
# @param NbOfSteps the number of steps
|
# @param NbOfSteps the number of steps
|
||||||
# @param MakeGroups to generate new groups from existing ones
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
def ExtrusionSweepObject1D(self, theObject, StepVector, NbOfSteps, MakeGroups=False):
|
def ExtrusionSweepObject1D(self, theObject, StepVector, NbOfSteps, MakeGroups=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( StepVector, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( StepVector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
StepVector = self.smeshpyD.GetDirStruct(StepVector)
|
StepVector = self.smeshpyD.GetDirStruct(StepVector)
|
||||||
if MakeGroups:
|
if MakeGroups:
|
||||||
@ -2925,6 +2943,8 @@ class Mesh:
|
|||||||
# @param NbOfSteps the number of steps
|
# @param NbOfSteps the number of steps
|
||||||
# @param MakeGroups to generate new groups from existing ones
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
def ExtrusionSweepObject2D(self, theObject, StepVector, NbOfSteps, MakeGroups=False):
|
def ExtrusionSweepObject2D(self, theObject, StepVector, NbOfSteps, MakeGroups=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( StepVector, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( StepVector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
StepVector = self.smeshpyD.GetDirStruct(StepVector)
|
StepVector = self.smeshpyD.GetDirStruct(StepVector)
|
||||||
if MakeGroups:
|
if MakeGroups:
|
||||||
@ -2976,6 +2996,8 @@ class Mesh:
|
|||||||
def ExtrusionAlongPathObject(self, theObject, PathMesh, PathShape, NodeStart,
|
def ExtrusionAlongPathObject(self, theObject, PathMesh, PathShape, NodeStart,
|
||||||
HasAngles, Angles, HasRefPoint, RefPoint,
|
HasAngles, Angles, HasRefPoint, RefPoint,
|
||||||
MakeGroups=False, LinearVariation=False):
|
MakeGroups=False, LinearVariation=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( RefPoint, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( RefPoint, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
RefPoint = self.smeshpyD.GetPointStruct(RefPoint)
|
RefPoint = self.smeshpyD.GetPointStruct(RefPoint)
|
||||||
if MakeGroups:
|
if MakeGroups:
|
||||||
@ -3003,6 +3025,22 @@ class Mesh:
|
|||||||
self.editor.Mirror(IDsOfElements, Mirror, theMirrorType, Copy)
|
self.editor.Mirror(IDsOfElements, Mirror, theMirrorType, Copy)
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
## Create a new mesh by symmetrical copy of mesh elements
|
||||||
|
# @param IDsOfElements list of elements ids
|
||||||
|
# @param Mirror is AxisStruct or geom object(point, line, plane)
|
||||||
|
# @param theMirrorType is POINT, AXIS or PLANE
|
||||||
|
# If the Mirror is geom object this parameter is unnecessary
|
||||||
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
|
# @param NewMeshName is a name of new mesh to create
|
||||||
|
def MirrorMakeMesh(self, IDsOfElements, Mirror, theMirrorType, MakeGroups=0, NewMeshName=""):
|
||||||
|
if IDsOfElements == []:
|
||||||
|
IDsOfElements = self.GetElementsId()
|
||||||
|
if ( isinstance( Mirror, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
|
Mirror = self.smeshpyD.GetAxisStruct(Mirror)
|
||||||
|
mesh = self.editor.MirrorMakeMesh(IDsOfElements, Mirror, theMirrorType,
|
||||||
|
MakeGroups, NewMeshName)
|
||||||
|
return Mesh(self.smeshpyD,self.geompyD,mesh)
|
||||||
|
|
||||||
## Symmetrical copy of object
|
## Symmetrical copy of object
|
||||||
# @param theObject mesh, submesh or group
|
# @param theObject mesh, submesh or group
|
||||||
# @param Mirror is AxisStruct or geom object(point, line, plane)
|
# @param Mirror is AxisStruct or geom object(point, line, plane)
|
||||||
@ -3011,6 +3049,8 @@ class Mesh:
|
|||||||
# @param Copy allows to copy element(Copy is 1) or to replace with its mirroring(Copy is 0)
|
# @param Copy allows to copy element(Copy is 1) or to replace with its mirroring(Copy is 0)
|
||||||
# @param MakeGroups to generate new groups from existing ones (if Copy)
|
# @param MakeGroups to generate new groups from existing ones (if Copy)
|
||||||
def MirrorObject (self, theObject, Mirror, theMirrorType, Copy=0, MakeGroups=False):
|
def MirrorObject (self, theObject, Mirror, theMirrorType, Copy=0, MakeGroups=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( Mirror, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( Mirror, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
Mirror = self.smeshpyD.GetAxisStruct(Mirror)
|
Mirror = self.smeshpyD.GetAxisStruct(Mirror)
|
||||||
if Copy and MakeGroups:
|
if Copy and MakeGroups:
|
||||||
@ -3018,6 +3058,22 @@ class Mesh:
|
|||||||
self.editor.MirrorObject(theObject, Mirror, theMirrorType, Copy)
|
self.editor.MirrorObject(theObject, Mirror, theMirrorType, Copy)
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
## Create a new mesh by symmetrical copy of object
|
||||||
|
# @param theObject mesh, submesh or group
|
||||||
|
# @param Mirror is AxisStruct or geom object(point, line, plane)
|
||||||
|
# @param theMirrorType is POINT, AXIS or PLANE
|
||||||
|
# If the Mirror is geom object this parameter is unnecessary
|
||||||
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
|
# @param NewMeshName is a name of new mesh to create
|
||||||
|
def MirrorObjectMakeMesh (self, theObject, Mirror, theMirrorType,MakeGroups=0, NewMeshName=""):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
|
if ( isinstance( Mirror, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
|
Mirror = GetAxisStruct(Mirror)
|
||||||
|
mesh = self.editor.MirrorObjectMakeMesh(theObject, Mirror, theMirrorType,
|
||||||
|
MakeGroups, NewMeshName)
|
||||||
|
return Mesh( self.smeshpyD,self.geompyD,mesh )
|
||||||
|
|
||||||
## Translates the elements
|
## Translates the elements
|
||||||
# @param IDsOfElements list of elements ids
|
# @param IDsOfElements list of elements ids
|
||||||
# @param Vector direction of translation(DirStruct or vector)
|
# @param Vector direction of translation(DirStruct or vector)
|
||||||
@ -3033,12 +3089,27 @@ class Mesh:
|
|||||||
self.editor.Translate(IDsOfElements, Vector, Copy)
|
self.editor.Translate(IDsOfElements, Vector, Copy)
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
## Create a new mesh of translated elements
|
||||||
|
# @param IDsOfElements list of elements ids
|
||||||
|
# @param Vector direction of translation(DirStruct or vector)
|
||||||
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
|
# @param NewMeshName is a name of new mesh to create
|
||||||
|
def TranslateMakeMesh(self, IDsOfElements, Vector, MakeGroups=False, NewMeshName=""):
|
||||||
|
if IDsOfElements == []:
|
||||||
|
IDsOfElements = self.GetElementsId()
|
||||||
|
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
|
Vector = self.smeshpyD.GetDirStruct(Vector)
|
||||||
|
mesh = self.editor.TranslateMakeMesh(IDsOfElements, Vector, MakeGroups, NewMeshName)
|
||||||
|
return Mesh ( self.smeshpyD, self.geompyD, mesh )
|
||||||
|
|
||||||
## Translates the object
|
## Translates the object
|
||||||
# @param theObject object to translate(mesh, submesh, or group)
|
# @param theObject object to translate(mesh, submesh, or group)
|
||||||
# @param Vector direction of translation(DirStruct or geom vector)
|
# @param Vector direction of translation(DirStruct or geom vector)
|
||||||
# @param Copy allows to copy the translated elements
|
# @param Copy allows to copy the translated elements
|
||||||
# @param MakeGroups to generate new groups from existing ones (if Copy)
|
# @param MakeGroups to generate new groups from existing ones (if Copy)
|
||||||
def TranslateObject(self, theObject, Vector, Copy, MakeGroups=False):
|
def TranslateObject(self, theObject, Vector, Copy, MakeGroups=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
Vector = self.smeshpyD.GetDirStruct(Vector)
|
Vector = self.smeshpyD.GetDirStruct(Vector)
|
||||||
if Copy and MakeGroups:
|
if Copy and MakeGroups:
|
||||||
@ -3046,6 +3117,19 @@ class Mesh:
|
|||||||
self.editor.TranslateObject(theObject, Vector, Copy)
|
self.editor.TranslateObject(theObject, Vector, Copy)
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
## Create a new mesh from translated object
|
||||||
|
# @param theObject object to translate(mesh, submesh, or group)
|
||||||
|
# @param Vector direction of translation(DirStruct or geom vector)
|
||||||
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
|
# @param NewMeshName is a name of new mesh to create
|
||||||
|
def TranslateObjectMakeMesh(self, theObject, Vector, MakeGroups=False, NewMeshName=""):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
|
if ( isinstance( Vector, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
|
Vector = self.smeshpyD.GetDirStruct(Vector)
|
||||||
|
mesh = self.editor.TranslateObjectMakeMesh(theObject, Vector, MakeGroups, NewMeshName)
|
||||||
|
return Mesh( self.smeshpyD, self.geompyD, mesh )
|
||||||
|
|
||||||
## Rotates the elements
|
## Rotates the elements
|
||||||
# @param IDsOfElements list of elements ids
|
# @param IDsOfElements list of elements ids
|
||||||
# @param Axis axis of rotation(AxisStruct or geom line)
|
# @param Axis axis of rotation(AxisStruct or geom line)
|
||||||
@ -3062,6 +3146,21 @@ class Mesh:
|
|||||||
self.editor.Rotate(IDsOfElements, Axis, AngleInRadians, Copy)
|
self.editor.Rotate(IDsOfElements, Axis, AngleInRadians, Copy)
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
## Create a new mesh of rotated elements
|
||||||
|
# @param IDsOfElements list of element ids
|
||||||
|
# @param Axis axis of rotation(AxisStruct or geom line)
|
||||||
|
# @param AngleInRadians angle of rotation(in radians)
|
||||||
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
|
# @param NewMeshName is a name of new mesh to create
|
||||||
|
def RotateMakeMesh (self, IDsOfElements, Axis, AngleInRadians, MakeGroups=0, NewMeshName=""):
|
||||||
|
if IDsOfElements == []:
|
||||||
|
IDsOfElements = self.GetElementsId()
|
||||||
|
if ( isinstance( Axis, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
|
Axis = self.smeshpyD.GetAxisStruct(Axis)
|
||||||
|
mesh = self.editor.RotateMakeMesh(IDsOfElements, Axis, AngleInRadians,
|
||||||
|
MakeGroups, NewMeshName)
|
||||||
|
return Mesh( self.smeshpyD, self.geompyD, mesh )
|
||||||
|
|
||||||
## Rotates the object
|
## Rotates the object
|
||||||
# @param theObject object to rotate(mesh, submesh, or group)
|
# @param theObject object to rotate(mesh, submesh, or group)
|
||||||
# @param Axis axis of rotation(AxisStruct or geom line)
|
# @param Axis axis of rotation(AxisStruct or geom line)
|
||||||
@ -3069,6 +3168,8 @@ class Mesh:
|
|||||||
# @param Copy allows to copy the rotated elements
|
# @param Copy allows to copy the rotated elements
|
||||||
# @param MakeGroups to generate new groups from existing ones (if Copy)
|
# @param MakeGroups to generate new groups from existing ones (if Copy)
|
||||||
def RotateObject (self, theObject, Axis, AngleInRadians, Copy, MakeGroups=False):
|
def RotateObject (self, theObject, Axis, AngleInRadians, Copy, MakeGroups=False):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
if ( isinstance( Axis, geompyDC.GEOM._objref_GEOM_Object)):
|
if ( isinstance( Axis, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
Axis = self.smeshpyD.GetAxisStruct(Axis)
|
Axis = self.smeshpyD.GetAxisStruct(Axis)
|
||||||
if Copy and MakeGroups:
|
if Copy and MakeGroups:
|
||||||
@ -3076,6 +3177,21 @@ class Mesh:
|
|||||||
self.editor.RotateObject(theObject, Axis, AngleInRadians, Copy)
|
self.editor.RotateObject(theObject, Axis, AngleInRadians, Copy)
|
||||||
return []
|
return []
|
||||||
|
|
||||||
|
## Create a new mesh from a rotated object
|
||||||
|
# @param theObject object to rotate (mesh, submesh, or group)
|
||||||
|
# @param Axis axis of rotation(AxisStruct or geom line)
|
||||||
|
# @param AngleInRadians angle of rotation(in radians)
|
||||||
|
# @param MakeGroups to generate new groups from existing ones
|
||||||
|
# @param NewMeshName is a name of new mesh to create
|
||||||
|
def RotateObjectMakeMesh(self, theObject, Axis, AngleInRadians, MakeGroups=0,NewMeshName=""):
|
||||||
|
if ( isinstance( theObject, Mesh )):
|
||||||
|
theObject = theObject.GetMesh()
|
||||||
|
if ( isinstance( Axis, geompyDC.GEOM._objref_GEOM_Object)):
|
||||||
|
Axis = self.smeshpyD.GetAxisStruct(Axis)
|
||||||
|
mesh = self.editor.RotateObjectMakeMesh(theObject, Axis, AngleInRadians,
|
||||||
|
MakeGroups, NewMeshName)
|
||||||
|
return Mesh( self.smeshpyD, self.geompyD, mesh )
|
||||||
|
|
||||||
## Find group of nodes close to each other within Tolerance.
|
## Find group of nodes close to each other within Tolerance.
|
||||||
# @param Tolerance tolerance value
|
# @param Tolerance tolerance value
|
||||||
# @param list of group of nodes
|
# @param list of group of nodes
|
||||||
|
Loading…
Reference in New Issue
Block a user