mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-13 18:20:35 +05:00
445 lines
14 KiB
Python
445 lines
14 KiB
Python
|
# GEOM GEOM_SWIG : binding of C++ omplementaion with Python
|
||
|
#
|
||
|
# Copyright (C) 2003 CEA/DEN, EDF R&D
|
||
|
#
|
||
|
#
|
||
|
#
|
||
|
# File : geompy.py
|
||
|
# Author : Paul RASCLE, EDF
|
||
|
# Module : GEOM
|
||
|
# $Header$
|
||
|
|
||
|
from batchmode_salome import *
|
||
|
|
||
|
#--------------------------------------------------------------------------
|
||
|
|
||
|
geom = lcc.FindOrLoadComponent("FactoryServer", "Geometry")
|
||
|
geom.GetCurrentStudy(myStudyId)
|
||
|
myBuilder = myStudy.NewBuilder()
|
||
|
|
||
|
father = myStudy.FindComponent("GEOM")
|
||
|
if father is None:
|
||
|
father = myBuilder.NewComponent("GEOM")
|
||
|
A1 = myBuilder.FindOrCreateAttribute(father, "AttributeName");
|
||
|
FName = A1._narrow(SALOMEDS.AttributeName)
|
||
|
FName.SetValue("Geometry")
|
||
|
A2 = myBuilder.FindOrCreateAttribute(father, "AttributePixMap");
|
||
|
aPixmap = A2._narrow(SALOMEDS.AttributePixMap);
|
||
|
aPixmap.SetPixMap( "ICON_OBJBROWSER_Geometry" );
|
||
|
myBuilder.DefineComponentInstance(father,geom)
|
||
|
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# add To Study
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def SubShapeName(aSubId, aMainId):
|
||
|
# index = gg.getIndexTopology(aSubId, aMainId)
|
||
|
# print index
|
||
|
# name = gg.getShapeTypeString(aSubId) + "_%d"%(index)
|
||
|
name = "Shape"
|
||
|
print name
|
||
|
return name
|
||
|
|
||
|
def addArguments(aShape):
|
||
|
ListIOR = []
|
||
|
ListIOR = geom.GetReferencedObjects(aShape)
|
||
|
|
||
|
if aShape._get_StudyShapeId()!="":
|
||
|
father = IDToSObject(aShape._get_StudyShapeId())
|
||
|
|
||
|
myBuilder.NewCommand()
|
||
|
if len(ListIOR) > 0:
|
||
|
Arg = myBuilder.NewObject(father)
|
||
|
A1 = myBuilder.FindOrCreateAttribute(Arg, "AttributeName");
|
||
|
ArgName = A1._narrow(SALOMEDS.AttributeName)
|
||
|
ArgName.SetValue("Arguments")
|
||
|
A2 = myBuilder.FindOrCreateAttribute(Arg, "AttributeSelectable");
|
||
|
SelAttr = A2._narrow(SALOMEDS.AttributeSelectable);
|
||
|
SelAttr.SetSelectable(0);
|
||
|
|
||
|
OneObject = 0
|
||
|
for anIOR in ListIOR:
|
||
|
Shape = orb.string_to_object(anIOR)
|
||
|
if Shape is not None:
|
||
|
if Shape._get_StudyShapeId()!="":
|
||
|
Obj = IDToSObject(Shape._get_StudyShapeId())
|
||
|
if Obj is not None:
|
||
|
Obj1 = myBuilder.NewObject(Arg)
|
||
|
myBuilder.Addreference(Obj1,Obj)
|
||
|
OneObject = 1
|
||
|
|
||
|
if OneObject == 0:
|
||
|
myBuilder.RemoveObject(Arg)
|
||
|
|
||
|
myBuilder.CommitCommand()
|
||
|
return 1
|
||
|
|
||
|
def addToStudy(aShape, aName):
|
||
|
try:
|
||
|
myBuilder.NewCommand()
|
||
|
newObj = myBuilder.NewObject(father)
|
||
|
ior = orb.object_to_string(aShape)
|
||
|
A1 = myBuilder.FindOrCreateAttribute(newObj, "AttributeIOR");
|
||
|
ObjIOR = A1._narrow(SALOMEDS.AttributeIOR)
|
||
|
ObjIOR.SetValue(ior)
|
||
|
A2 = myBuilder.FindOrCreateAttribute(newObj, "AttributeName");
|
||
|
ObjName = A2._narrow(SALOMEDS.AttributeName)
|
||
|
ObjName.SetValue(aName)
|
||
|
id = newObj.GetID()
|
||
|
aShape._set_StudyShapeId(id)
|
||
|
myBuilder.CommitCommand()
|
||
|
|
||
|
addArguments( aShape )
|
||
|
|
||
|
except:
|
||
|
return None
|
||
|
return id
|
||
|
|
||
|
def addToStudyInFather(aFather, aShape, aName):
|
||
|
myBuilder.NewCommand()
|
||
|
newObj = myBuilder.NewObject( IDToSObject(aFather._get_StudyShapeId()) )
|
||
|
ior = orb.object_to_string(aShape)
|
||
|
A1 = myBuilder.FindOrCreateAttribute(newObj, "AttributeIOR");
|
||
|
ObjIOR = A1._narrow(SALOMEDS.AttributeIOR)
|
||
|
ObjIOR.SetValue(ior)
|
||
|
A2 = myBuilder.FindOrCreateAttribute(newObj, "AttributeName");
|
||
|
ObjName = A2._narrow(SALOMEDS.AttributeName)
|
||
|
ObjName.SetValue(aName)
|
||
|
id = newObj.GetID()
|
||
|
aShape._set_StudyShapeId(id)
|
||
|
myBuilder.CommitCommand()
|
||
|
addArguments( aShape )
|
||
|
return id
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Create Geometry 2D
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeVertex(x,y,z):
|
||
|
anObj = geom.MakeVertex(x,y,z)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeVector(p1,p2):
|
||
|
anObj = geom.MakeVector(p1,p2)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeLine(p1,d1):
|
||
|
anObj = geom.MakeLine(p1,d1)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeArc(p1,p2,p3):
|
||
|
anObj = geom.MakeArc(p1,p2,p3)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeCircle(p1,d1,radius):
|
||
|
anObj = geom.MakeCircle(p1,d1,radius)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakePlane(p1,d1,trimsize):
|
||
|
anObj = geom.MakePlane(p1,d1,trimsize)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Create Geometry 3D
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeBox(x1,y1,z1,x2,y2,z2):
|
||
|
anObj = geom.MakeBox(x1,y1,z1,x2,y2,z2)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeCylinder(p1,d1,radius,height):
|
||
|
anObj = geom.MakeCylinder(p1,d1,radius,height)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeSphere(x,y,z,radius):
|
||
|
anObj = geom.MakeSphere(x,y,z,radius)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeCone(p1,d1,radius1,radius2,height):
|
||
|
anObj = geom.MakeCone(p1,d1,radius1,radius2,height)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeTorus(p1,d1,major_radius,minor_radius):
|
||
|
anObj = geom.MakeTorus(p1,d1,major_radius,minor_radius)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Create base objects
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeEdge(p1,p2):
|
||
|
anObj = geom.MakeEdge(p1,p2)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeWire(ListShape):
|
||
|
anObj = geom.MakeWire(ListShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeFace(aShapeWire,WantPlanarFace):
|
||
|
anObj = geom.MakeFace(aShapeWire,WantPlanarFace)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeCompound(ListShape):
|
||
|
anObj = geom.MakeCompound(ListShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Create advanced objects
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeCopy(aShape):
|
||
|
anObj = geom.MakeCopy(aShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakePrism(baseShape,p1,p2):
|
||
|
anObj = geom.MakePrism(baseShape,p1,p2)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeRevolution(aShape,axis,angle):
|
||
|
anObj = geom.MakeRevolution(aShape,axis,angle)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeFilling(aShape,mindeg,maxdeg,tol3d,tol2d,nbiter):
|
||
|
anObj = geom.MakeFilling(aShape,mindeg,maxdeg,tol3d,tol2d,nbiter)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakePipe(pathShape,baseShape):
|
||
|
anObj = geom.MakePipe(pathShape,baseShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeSewing(ListShape,precision):
|
||
|
anObj = geom.MakeSewing(ListShape,precision)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Boolean (Common, Cut, Fuse, Section)
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeBoolean(shape1,shape2,operation):
|
||
|
anObj = geom.MakeBoolean(shape1,shape2,operation)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Transform objects
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeTranslation(aShape,x,y,z):
|
||
|
anObj = geom.MakeTranslation(aShape,x,y,z)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeRotation(aShape,axis,angle):
|
||
|
anObj = geom.MakeRotation(aShape,axis,angle)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeScaleTransform(aShape,theCenterofScale,factor):
|
||
|
anObj = geom.MakeScaleTransform(aShape,theCenterofScale,factor)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeMirrorByPlane(aShape,aPlane):
|
||
|
anObj = geom.MakeMirrorByPlane(aShape,aPlane)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def OrientationChange(aShape):
|
||
|
anObj = geom.OrientationChange(aShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeFillet(aShape,radius,ShapeType,ListShape):
|
||
|
anObj = geom.MakeFillet(aShape,radius,ShapeType,ListShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeChamfer(aShape,d1,d2,ShapeType,ListShape):
|
||
|
anObj = geom.MakeChamfer(aShape,d1,d2,ShapeType,ListShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Decompose objects
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def SubShape(aShape,type,ListOfId):
|
||
|
anObj = geom.SubShape(aShape,type, ListOfId)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def SubShapeAll(aShape,type):
|
||
|
ListObj = geom.SubShapeAll(aShape,type)
|
||
|
for anObj in ListObj :
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return ListObj
|
||
|
|
||
|
def SubShapeSorted(aShape,type,ListOfId):
|
||
|
anObj = geom.SubShapeSorted(aShape,type, ListOfId)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def SubShapeAllSorted(aShape,type):
|
||
|
ListObj = geom.SubShapeAllSorted(aShape,type)
|
||
|
for anObj in ListObj :
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return ListObj
|
||
|
|
||
|
# -- enumeration ShapeType as a dictionary --
|
||
|
ShapeType = {"COMPOUND":0, "COMPSOLID":1, "SOLID":2, "SHELL":3, "FACE":4, "WIRE":5, "EDGE":6, "VERTEX":7, "SHAPE":8}
|
||
|
|
||
|
def Partition(ListShapes, ListTools=[], ListKeepInside=[], ListRemoveInside=[], Limit=ShapeType["SHAPE"]):
|
||
|
anObj = geom.Partition(ListShapes, ListTools, ListKeepInside, ListRemoveInside, Limit);
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def SuppressFaces(aShape,ListOfId):
|
||
|
anObj = geom.SuppressFaces(aShape,ListOfId)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def SuppressHole(aShape,ListOfFace,ListOfWire,ListOfEndFace):
|
||
|
anObj = geom.SuppressHole(aShape,ListOfFace,ListOfWire,ListOfEndFace)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Patterns
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeMultiTranslation1D(aShape,aDir,aStep,aNbTimes):
|
||
|
anObj = geom.MakeMultiTranslation1D(aShape,aDir,aStep,aNbTimes)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeMultiTranslation2D(aShape,d1,step1,nbtimes1,d2,step2,nbtimes2):
|
||
|
anObj = geom.MakeMultiTranslation2D(aShape,d1,step1,nbtimes1,d2,step2,nbtimes2)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeMultiRotation1D(aShape,aDir,aPoint,aNbTimes):
|
||
|
anObj = geom.MakeMultiRotation1D(aShape,aDir,aPoint,aNbTimes)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def MakeMultiRotation2D(aShape,aDir,aPoint,anAngle,nbtimes1,aStep,nbtimes2):
|
||
|
anObj = geom.MakeMultiRotation2D(aShape,aDir,aPoint,anAngle,nbtimes1,aStep,nbtimes2)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Import objects
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def ImportBREP(filename):
|
||
|
anObj = geom.ImportBREP(filename)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def ImportIGES(filename):
|
||
|
anObj = geom.ImportIGES(filename)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def ImportSTEP(filename):
|
||
|
anObj = geom.ImportSTEP(filename)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Export objects
|
||
|
# -----------------------------------------------------------------------------
|
||
|
def ExportBREP(filename,aShape):
|
||
|
geom.ExportBREP(filename,aShape)
|
||
|
|
||
|
def ExportIGES(filename,aShape):
|
||
|
geom.ExportIGES(filename,aShape)
|
||
|
|
||
|
def ExportSTEP(filename,aShape):
|
||
|
geom.ExportSTEP(filename,aShape)
|
||
|
|
||
|
# -----------------------------------------------------------------------------
|
||
|
# Information objects
|
||
|
# -----------------------------------------------------------------------------
|
||
|
|
||
|
def MakeCDG(aShape):
|
||
|
anObj = geom.MakeCDG(aShape)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def Archimede(aShape,weight,WaterDensity,MeshingDeflection):
|
||
|
anObj = geom.Archimede(aShape,weight,WaterDensity,MeshingDeflection)
|
||
|
ior = orb.object_to_string(anObj)
|
||
|
anObj._set_Name(ior)
|
||
|
return anObj
|
||
|
|
||
|
def CheckShape(aShape):
|
||
|
Status = geom.CheckShape(aShape)
|
||
|
return Status
|