mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-02 21:00:34 +05:00
0021859: SMESH : Add conversion from QUAD8 to QUAD9 and from HEXA20 to HEXA27
- def ConvertToQuadratic(self, theForce3d, theSubMesh=None): + def ConvertToQuadratic(self, theForce3d, theSubMesh=None, theToBiQuad=False):
This commit is contained in:
parent
4b7538ca03
commit
e8589cb6af
@ -691,6 +691,20 @@ class smeshDC(SMESH._objref_SMESH_Gen):
|
|||||||
return None
|
return None
|
||||||
pass
|
pass
|
||||||
pass
|
pass
|
||||||
|
elif CritType == FT_EntityType:
|
||||||
|
# Checks the Threshold
|
||||||
|
try:
|
||||||
|
aCriterion.Threshold = self.EnumToLong(aThreshold)
|
||||||
|
assert( aThreshold in SMESH.EntityType._items )
|
||||||
|
except:
|
||||||
|
if isinstance(aThreshold, int):
|
||||||
|
aCriterion.Threshold = aThreshold
|
||||||
|
else:
|
||||||
|
print "Error: The Threshold should be an integer or SMESH.EntityType."
|
||||||
|
return None
|
||||||
|
pass
|
||||||
|
pass
|
||||||
|
|
||||||
elif CritType == FT_GroupColor:
|
elif CritType == FT_GroupColor:
|
||||||
# Checks the Threshold
|
# Checks the Threshold
|
||||||
try:
|
try:
|
||||||
@ -2161,7 +2175,7 @@ class Mesh:
|
|||||||
def GetElemNbNodes(self, id):
|
def GetElemNbNodes(self, id):
|
||||||
return self.mesh.GetElemNbNodes(id)
|
return self.mesh.GetElemNbNodes(id)
|
||||||
|
|
||||||
## Returns the node ID the given index for the given element
|
## Returns the node ID the given (zero based) index for the given element
|
||||||
# \n If there is no element for the given ID - returns -1
|
# \n If there is no element for the given ID - returns -1
|
||||||
# \n If there is no node for the given index - returns -2
|
# \n If there is no node for the given index - returns -2
|
||||||
# @return an integer value
|
# @return an integer value
|
||||||
@ -3002,18 +3016,22 @@ class Mesh:
|
|||||||
return self.editor.SmoothParametricObject(theObject, IDsOfFixedNodes,
|
return self.editor.SmoothParametricObject(theObject, IDsOfFixedNodes,
|
||||||
MaxNbOfIterations, MaxAspectRatio, Method)
|
MaxNbOfIterations, MaxAspectRatio, Method)
|
||||||
|
|
||||||
## Converts the mesh to quadratic, deletes old elements, replacing
|
## Converts the mesh to quadratic or bi-quadratic, deletes old elements, replacing
|
||||||
# them with quadratic with the same id.
|
# them with quadratic with the same id.
|
||||||
# @param theForce3d new node creation method:
|
# @param theForce3d new node creation method:
|
||||||
# 0 - the medium node lies at the geometrical entity from which the mesh element is built
|
# 0 - the medium node lies at the geometrical entity from which the mesh element is built
|
||||||
# 1 - the medium node lies at the middle of the line segments connecting start and end node of a mesh element
|
# 1 - the medium node lies at the middle of the line segments connecting start and end node of a mesh element
|
||||||
# @param theSubMesh a group or a sub-mesh to convert; WARNING: in this case the mesh can become not conformal
|
# @param theSubMesh a group or a sub-mesh to convert; WARNING: in this case the mesh can become not conformal
|
||||||
|
# @param theToBiQuad If True, converts the mesh to bi-quadratic
|
||||||
# @ingroup l2_modif_tofromqu
|
# @ingroup l2_modif_tofromqu
|
||||||
def ConvertToQuadratic(self, theForce3d, theSubMesh=None):
|
def ConvertToQuadratic(self, theForce3d, theSubMesh=None, theToBiQuad=False):
|
||||||
if theSubMesh:
|
if theToBiQuad:
|
||||||
self.editor.ConvertToQuadraticObject(theForce3d,theSubMesh)
|
self.editor.ConvertToBiQuadratic(theForce3d,theSubMesh)
|
||||||
else:
|
else:
|
||||||
self.editor.ConvertToQuadratic(theForce3d)
|
if theSubMesh:
|
||||||
|
self.editor.ConvertToQuadraticObject(theForce3d,theSubMesh)
|
||||||
|
else:
|
||||||
|
self.editor.ConvertToQuadratic(theForce3d)
|
||||||
|
|
||||||
## Converts the mesh from quadratic to ordinary,
|
## Converts the mesh from quadratic to ordinary,
|
||||||
# deletes old quadratic elements, \n replacing
|
# deletes old quadratic elements, \n replacing
|
||||||
|
Loading…
Reference in New Issue
Block a user