mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
Select3D_SensitiveCircle now inherits directly from Select3D_SensitiveEntity. The sensitive circle sector is created using the Select3D_SensitivePoly class directly. Added appropriate methods for selecting sensitive circles. Added parameter myIsHollow to Select3D_SensitiveCylinder class. It allows you to search for intersections with cylinders without covers. The Draw vcircle command has been extended with UStart and UEnd parameters to create a sector of a circle. Added tests: vselect/cone_cylinder/circle_sector vselect/cone_cylinder/circle_wire vselect/cone_cylinder/filled_circle vselect/cone_cylinder/transformed vselect/cone_cylinder/hollow_cone_cyl
143 lines
3.5 KiB
Plaintext
143 lines
3.5 KiB
Plaintext
puts "=================================="
|
|
puts "AIS_Manipulator - rotate an object"
|
|
puts "=================================="
|
|
|
|
pload MODELING VISUALIZATION
|
|
|
|
set anImage1 $imagedir/${casename}_1.png
|
|
set anImage2 $imagedir/${casename}_2.png
|
|
set anImage3 $imagedir/${casename}_3.png
|
|
set anImage4 $imagedir/${casename}_4.png
|
|
set anImage5 $imagedir/${casename}_5.png
|
|
|
|
# -------------------------------------
|
|
# create manipulated and helper objects
|
|
# -------------------------------------
|
|
|
|
pcylinder c1_1 5 10
|
|
pcylinder c1_2 3 10
|
|
pcylinder c2 10 20
|
|
ttranslate c1_1 100 0 20
|
|
ttranslate c1_2 100 0 20
|
|
trotate c1_2 100 0 25 0 1 0 90
|
|
trotate c1_2 100 0 25 0 0 1 10
|
|
ttranslate c2 100 0 0
|
|
|
|
compound c1_1 c1_2 c1
|
|
|
|
# ------------------------------------
|
|
# display manipulated objects (test 1)
|
|
# ------------------------------------
|
|
|
|
vdisplay c1
|
|
vdisplay c2
|
|
vsetdispmode 1
|
|
vaxo
|
|
vfit
|
|
|
|
# ------------------
|
|
# attach manipulator
|
|
# ------------------
|
|
|
|
vmanipulator m -attach c1 -adjustPosition 1 -adjustSize 0 -enableModes 1 -size 40
|
|
|
|
# ----------------------------------------------------
|
|
# test rotation around x axis (object reference frame)
|
|
# ----------------------------------------------------
|
|
|
|
vmanipulator m -followRotation 1
|
|
|
|
set mouse_pick {200 092}
|
|
set mouse_drag {176 142}
|
|
|
|
vmoveto {*}$mouse_pick
|
|
vselect {*}$mouse_pick
|
|
vmanipulator m -startTransform {*}$mouse_pick
|
|
vmanipulator m -transform {*}$mouse_drag
|
|
vmanipulator m -stopTransform
|
|
vselect 0 0
|
|
vmoveto {*}$mouse_drag
|
|
vdump $anImage1
|
|
|
|
# ----------------------------------------------------
|
|
# test rotation around y axis (object reference frame)
|
|
# ----------------------------------------------------
|
|
|
|
vmanipulator m -followRotation 1
|
|
|
|
set mouse_pick {173 137}
|
|
set mouse_drag {233 144}
|
|
|
|
vmoveto {*}$mouse_pick
|
|
vselect {*}$mouse_pick
|
|
vmanipulator m -startTransform {*}$mouse_pick
|
|
vmanipulator m -transform {*}$mouse_drag
|
|
vmanipulator m -stopTransform
|
|
vselect 0 0
|
|
vmoveto {*}$mouse_drag
|
|
vdump $anImage2
|
|
|
|
# ----------------------------------------------------
|
|
# test rotation around z axis (object reference frame)
|
|
# ----------------------------------------------------
|
|
|
|
vmanipulator m -followRotation 1
|
|
|
|
set mouse_pick {200 094}
|
|
set mouse_drag {182 117}
|
|
|
|
vmoveto {*}$mouse_pick
|
|
vselect {*}$mouse_pick
|
|
vmanipulator m -startTransform {*}$mouse_pick
|
|
vmanipulator m -transform {*}$mouse_drag
|
|
vmanipulator m -stopTransform
|
|
vselect 0 0
|
|
vmoveto {*}$mouse_drag
|
|
vdump $anImage3
|
|
|
|
# ------------------------------------
|
|
# display manipulated objects (test 2)
|
|
# ------------------------------------
|
|
|
|
vremove -all
|
|
vdisplay c1
|
|
vdisplay c2
|
|
vsetdispmode 1
|
|
vaxo
|
|
vfit
|
|
|
|
vmanipulator m -attach c1 -adjustPosition 1 -adjustSize 0 -enableModes 1 -size 40
|
|
vmanipulator m -followRotation 0
|
|
|
|
# ---------------------------------------------------
|
|
# test rotation around y axis (world reference frame)
|
|
# ---------------------------------------------------
|
|
|
|
set mouse_pick {205 087}
|
|
set mouse_drag {232 127}
|
|
|
|
vmoveto {*}$mouse_pick
|
|
vselect {*}$mouse_pick
|
|
vmanipulator m -startTransform {*}$mouse_pick
|
|
vmanipulator m -transform {*}$mouse_drag
|
|
vmanipulator m -stopTransform
|
|
vselect 0 0
|
|
vmoveto {*}$mouse_drag
|
|
vdump $anImage4
|
|
|
|
# ---------------------------------------------------
|
|
# test rotation around z axis (world reference frame)
|
|
# ---------------------------------------------------
|
|
|
|
set mouse_pick {228 141}
|
|
set mouse_drag {184 143}
|
|
|
|
vmoveto {*}$mouse_pick
|
|
vselect {*}$mouse_pick
|
|
vmanipulator m -startTransform {*}$mouse_pick
|
|
vmanipulator m -transform {*}$mouse_drag
|
|
vmanipulator m -stopTransform
|
|
vselect 0 0
|
|
vmoveto {*}$mouse_drag
|
|
vdump $anImage5
|