Salome HOME
1ae412a8e23dbd747e0a045b7e0641046bc87ea9
[modules/geom.git] / doc / salome / examples / free_boundaries.py
1 # Check Free Boundaries
2
3 import salome
4 salome.salome_init()
5 from salome.geom import geomBuilder
6 geompy = geomBuilder.New()
7
8 # create a shape
9 box1 = geompy.MakeBox(0,   0,   0, 100, 100, 100)
10 box2 = geompy.MakeBox(20, 20, -20,  80,  80, 120)
11 cut  = geompy.MakeCut(box1, box2)
12 sid = geompy.addToStudy(cut, "Shape")
13
14 # get all faces
15 faces = geompy.SubShapeAllSortedCentres(cut, geompy.ShapeType["FACE"])
16
17 # for each face, get free boundaries
18 for fi in range(len(faces)):
19     fid = geompy.addToStudyInFather(cut, faces[fi], "Face %d" % (fi+1))
20     isSuccess, closedWires, openWires = geompy.GetFreeBoundary(faces[fi])
21     if isSuccess:
22         print("Check free boundaries in face %d: OK" % (fi+1))
23         print("-- Nb of closed boundaries = %d" % len(closedWires))
24         for wi in range(len(closedWires)):
25             wid = geompy.addToStudyInFather(faces[fi], closedWires[wi], "Closed wire %d" % (wi+1))
26             pass
27         print("-- Nb of open boundaries = %d" % len(openWires))
28         for wi in range(len(openWires)):
29             wid = geompy.addToStudyInFather(faces[fi], openWires[wi], "Open wire %d" % (wi+1))
30             pass
31         pass
32     else:
33         print("Check free boundaries in face %d: KO" % (fi+1))
34         pass
35     pass