+ # GetShapesOnSphereIDs
+ vertices_on_sph_ids = geompy.GetShapesOnSphereIDs(blocksComp, geompy.ShapeType["VERTEX"],
+ p0, 100, GEOM.ST_ON)
+ vertices_on = geompy.CreateGroup(blocksComp, geompy.ShapeType["VERTEX"])
+ geompy.UnionIDs(vertices_on, vertices_on_sph_ids)
+ geompy.addToStudy(vertices_on, "Group of vertices on Sphere (center = (0, 0, 0), r = 100)")
+
+ # GetShapesOnQuadrangle
+
+ geompy.addToStudy(f12, "F12" )
+
+ bl = geompy.MakeVertex(10,-10, 0)
+ br = geompy.MakeVertex(40,-10, 0)
+ tr = geompy.MakeVertex(40, 20, 0)
+ tl = geompy.MakeVertex(10, 20, 0)
+ qe1 = geompy.MakeEdge(bl, br)
+ qe2 = geompy.MakeEdge(br, tr)
+ qe3 = geompy.MakeEdge(tr, tl)
+ qe4 = geompy.MakeEdge(tl, bl)
+ quadrangle = geompy.MakeWire([qe1, qe2, qe3, qe4])
+ geompy.addToStudy(quadrangle, "Quadrangle")
+
+ edges_onin_quad = geompy.GetShapesOnQuadrangle(f12, geompy.ShapeType["EDGE"],
+ tl, tr, bl, br, GEOM.ST_ONIN)
+ comp = geompy.MakeCompound(edges_onin_quad)
+ geompy.addToStudy(comp, "Edges of F12 ONIN Quadrangle")
+ if len( edges_onin_quad ) != 4:
+ print "Error in GetShapesOnQuadrangle()"
+
+ # GetShapesOnQuadrangleIDs
+ vertices_on_quad_ids = geompy.GetShapesOnQuadrangleIDs(f12, geompy.ShapeType["VERTEX"],
+ tl, tr, bl, br, GEOM.ST_ON)
+ vertices_on_quad = geompy.CreateGroup(f12, geompy.ShapeType["VERTEX"])
+ geompy.UnionIDs(vertices_on_quad, vertices_on_quad_ids)
+ geompy.addToStudy(vertices_on_quad, "Group of vertices on Quadrangle F12")
+
+ # GetShapesOnBox
+ edges_on_box = geompy.GetShapesOnBox(b0, part, geompy.ShapeType["EDGE"],
+ GEOM.ST_ON)
+ comp = geompy.MakeCompound(edges_on_box)
+ geompy.addToStudy(comp, "Edges of part ON box b0")
+ if len( edges_on_box ) != 12:
+ print "Error in GetShapesOnBox()"
+
+ # GetShapesOnBoxIDs
+ faces_on_box_ids = geompy.GetShapesOnBoxIDs(b0, part, geompy.ShapeType["FACE"],
+ GEOM.ST_ON)
+ faces_on_box = geompy.CreateGroup(part, geompy.ShapeType["FACE"])
+ geompy.UnionIDs(faces_on_box, faces_on_box_ids)
+ geompy.addToStudyInFather(part, faces_on_box, "Group of faces on box b0")
+
+ # Prepare arguments for GetShapesOnShape
+ sph1 = geompy.MakeSphere(50, 50, 50, 40)
+ sph2 = geompy.MakeSphere(50, 50, -50, 40)
+ pcyl = geompy.MakeVertex(50, 50, -50)
+ cyli = geompy.MakeCylinder(pcyl, vz, 40, 100)
+ sh_1 = geompy.MakeFuseList([sph1, cyli, sph2])
+ # As after Fuse we have a compound, we need to obtain a solid from it
+ #shsh = geompy.SubShapeAll(sh_1, geompy.ShapeType["SOLID"])
+ #sh_1 = shsh[0]
+ geompy.addToStudy(sh_1, "sh_1")
+
+ # GetShapesOnShape
+ faces_in_sh = geompy.GetShapesOnShape(sh_1, part, geompy.ShapeType["FACE"],
+ GEOM.ST_IN)
+ comp = geompy.MakeCompound(faces_in_sh)
+ geompy.addToStudy(comp, "Faces of part IN shape sh_1")
+ if len(faces_in_sh) != 11:
+ print "Error in GetShapesOnShape()"
+
+ # GetShapesOnShapeAsCompound
+ faces_in_sh_c = geompy.GetShapesOnShapeAsCompound(sh_1, part, geompy.ShapeType["FACE"],
+ GEOM.ST_IN)
+ geompy.addToStudy(faces_in_sh_c, "Faces of part IN shape sh_1 (as compound)")
+
+ # GetShapesOnShapeIDs
+ edges_in_sh_ids = geompy.GetShapesOnShapeIDs(sh_1, part, geompy.ShapeType["EDGE"],
+ GEOM.ST_IN)
+ edges_in_sh = geompy.CreateGroup(part, geompy.ShapeType["EDGE"])
+ geompy.UnionIDs(edges_in_sh, edges_in_sh_ids)
+ geompy.addToStudyInFather(part, edges_in_sh, "Group of edges in shape sh_1")
+ if len(edges_in_sh_ids) != 15:
+ print "Error in GetShapesOnShapeIDs()"
+
+ # Prepare arguments for GetInPlace and GetInPlaceByHistory
+ box5 = geompy.MakeBoxDXDYDZ(100, 100, 100)
+ box6 = geompy.MakeTranslation(box5, 50, 50, 0)
+
+ geompy.addToStudy(box5, "Box 5")
+ geompy.addToStudy(box6, "Box 6")
+
+ part = geompy.MakePartition([box5], [box6])
+ geompy.addToStudy(part, "Partitioned")
+
+ box5_faces = geompy.SubShapeAll(box5, geompy.ShapeType["FACE"])
+ box6_faces = geompy.SubShapeAll(box6, geompy.ShapeType["FACE"])
+
+ for ifa in range(6):
+ geompy.addToStudyInFather(box5, box5_faces[ifa], "Face" + `ifa + 1`)
+ geompy.addToStudyInFather(box6, box6_faces[ifa], "Face" + `ifa + 1`)
+