Salome HOME
Task #3230: Sketcher: create a curve passing through selected points or vertices...
[modules/shaper.git] / src / SketchPlugin / doc / examples / interpolation.py
1 from salome.shaper import model
2
3 model.begin()
4 partSet = model.moduleDocument()
5
6 ### Create Part
7 Part_1 = model.addPart(partSet)
8 Part_1_doc = Part_1.document()
9
10 ### Create Sketch
11 Sketch_1 = model.addSketch(Part_1_doc, model.defaultPlane("XOY"))
12
13 ### Create SketchPoints
14 SketchPoint_1 = Sketch_1.addPoint(-70.28350515463917, 1.388316151202744)
15 SketchPoint_2 = Sketch_1.addPoint(-26.89862542955327, 51.7147766323024)
16 SketchPoint_3 = Sketch_1.addPoint(40.08762886597938, 32.27835051546391)
17 SketchPoint_4 = Sketch_1.addPoint(66.46563573883162, -29.8487972508591)
18
19 ### Create interpolation curve
20 InterpolationPoints = [SketchPoint_1.coordinates(),
21                        SketchPoint_2.coordinates(),
22                        SketchPoint_3.coordinates(),
23                        SketchPoint_4.coordinates()]
24 SketchBSpline_1 = Sketch_1.addInterpolation(InterpolationPoints)
25 Sketch_1.setCoincident(SketchPoint_1.coordinates(), SketchBSpline_1.startPoint())
26 Sketch_1.setCoincident(SketchPoint_2.coordinates(), SketchBSpline_1.result())
27 Sketch_1.setCoincident(SketchPoint_3.coordinates(), SketchBSpline_1.result())
28 Sketch_1.setCoincident(SketchPoint_4.coordinates(), SketchBSpline_1.endPoint())
29
30 ### Create periodic interpolation curve
31 SketchBSpline_2 = Sketch_1.addInterpolation(InterpolationPoints, periodic = True)
32 Sketch_1.setCoincident(SketchPoint_1.coordinates(), SketchBSpline_2.result())
33 Sketch_1.setCoincident(SketchPoint_2.coordinates(), SketchBSpline_2.result())
34 Sketch_1.setCoincident(SketchPoint_3.coordinates(), SketchBSpline_2.result())
35 Sketch_1.setCoincident(SketchPoint_4.coordinates(), SketchBSpline_2.result())
36
37 ### Create closed interpolation curve
38 SketchBSpline_3 = Sketch_1.addInterpolation(InterpolationPoints, closed = True)
39 Sketch_1.setCoincident(SketchPoint_1.coordinates(), SketchBSpline_3.startPoint())
40 Sketch_1.setCoincident(SketchPoint_2.coordinates(), SketchBSpline_3.result())
41 Sketch_1.setCoincident(SketchPoint_3.coordinates(), SketchBSpline_3.result())
42 Sketch_1.setCoincident(SketchPoint_4.coordinates(), SketchBSpline_3.result())
43 Sketch_1.setCoincident(SketchPoint_1.coordinates(), SketchBSpline_3.endPoint())
44
45 model.do()
46
47 model.end()