mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
1. The class Bnd_OBB has been created to describe the Oriented Bounding Box. 2. Several key methods have been implemented: Bnd_OBB::IsOut(...), Bnd_OBB::Add(...) and Bnd_OBB::Enlarge(...). 3. Interface of Bnd_Box class has changed. New methods have been created. See Bnd_Box.hxx for detailed information. 4. BRepBndLib and Draw_Box classes have been amended in order to provide correct work with Bnd_OBB class. 5. Interface of "bounding" DRAW-command has been changed. Please see help for detailed information. 6. New DRAW-command "isbbinterf" has been created. Please see help for detailed information. 7. "boundingstr" and "optbounding" DRAW-commands have been eliminated because their function can be made by "bounding" DRAW-command (e.g. see tests/bugs/vis/buc60857 or samples/tcl/snowflake.tcl test cases). 8. Documentation has been updated.
77 lines
1.8 KiB
Plaintext
Executable File
77 lines
1.8 KiB
Plaintext
Executable File
#INTERFACE CAF
|
|
# NamedShape
|
|
#
|
|
# Testing attribute: TNaming_NamedShape
|
|
#
|
|
# Testing command: GetShape
|
|
#
|
|
|
|
puts "caf002-C1"
|
|
|
|
# Create a box
|
|
set aSetX1 10
|
|
set aSetY1 20
|
|
set aSetZ1 30
|
|
set aSetDX1 100
|
|
set aSetDY1 200
|
|
set aSetDZ1 300
|
|
|
|
box aBox1 ${aSetX1} ${aSetY1} ${aSetZ1} ${aSetDX1} ${aSetDY1} ${aSetDZ1}
|
|
|
|
bounding -s aBox1 -save X1_Box1 Y1_Box1 Z1_Box1 X2_Box1 Y2_Box1 Z2_Box1
|
|
|
|
# Create a label
|
|
set aLabel 0:2
|
|
Label D ${aLabel}
|
|
|
|
# Close/Open transaction
|
|
NewCommand D
|
|
|
|
# Set a shape to the label
|
|
SetShape D ${aLabel} aBox1
|
|
|
|
# Close/Open transaction
|
|
NewCommand D
|
|
|
|
# Save the document
|
|
set aFile ${imagedir}/caf002-C1.cbf
|
|
file delete ${aFile}
|
|
SaveAs D ${aFile}
|
|
#catch {exec chmod 777 ${aFile}}
|
|
if { ![file exists ${aFile}] } {
|
|
puts "There is not ${aFile} file; SaveAs command: Error"
|
|
return
|
|
}
|
|
|
|
# Restore the document
|
|
Close D
|
|
Open ${aFile} DD
|
|
|
|
# Get a shape from the label
|
|
set IsDone [catch {GetShape DD ${aLabel} aBox3} aResult]
|
|
if { ${IsDone} != 0 } {
|
|
puts ${aResult}
|
|
puts "Get a value of TNaming_NamedShape attribute from restoring document: Error"
|
|
return
|
|
}
|
|
|
|
bounding -s aBox3 -save X1_Box3 Y1_Box3 Z1_Box3 X2_Box3 Y2_Box3 Z2_Box3
|
|
|
|
if { [dval X1_Box1] != [dval X1_Box3] ||
|
|
[dval Y1_Box1] != [dval Y1_Box3] ||
|
|
[dval Z1_Box1] != [dval Z1_Box3] ||
|
|
[dval X2_Box1] != [dval X2_Box3] ||
|
|
[dval Y2_Box1] != [dval Y2_Box3] ||
|
|
[dval Z2_Box1] != [dval Z2_Box3] } {
|
|
puts "X1_Box1=[dval X1_Box1] X1_Box3=[dval X1_Box3]"
|
|
puts "Y1_Box1=[dval Y1_Box1] Y1_Box3=[dval Y1_Box3]"
|
|
puts "Z1_Box1=[dval Z1_Box1] Z1_Box3=[dval Z1_Box3]"
|
|
puts "X2_Box1=[dval X2_Box1] X2_Box3=[dval X2_Box3]"
|
|
puts "Y2_Box1=[dval Y2_Box1] Y2_Box3=[dval Y2_Box3]"
|
|
puts "Z2_Box1=[dval Z2_Box1] Z2_Box3=[dval Z2_Box3]"
|
|
puts "Get a value of TNaming_NamedShape attribute from restoring document: Error"
|
|
return
|
|
}
|
|
|
|
puts "Get a value of TNaming_NamedShape attribute from restoring document: OK"
|