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.
71 lines
1.5 KiB
Plaintext
Executable File
71 lines
1.5 KiB
Plaintext
Executable File
#INTERFACE CAF
|
|
# NamedShape
|
|
#
|
|
# Testing attribute: TNaming_NamedShape
|
|
#
|
|
# Testing command: SelectGeometry (FACE)
|
|
#
|
|
|
|
puts "caf002-D2"
|
|
set QA_DUP 0
|
|
|
|
set ter _*
|
|
foreach OS [directory [concat aBox1$ter]] {
|
|
unset $OS
|
|
}
|
|
|
|
# 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}
|
|
|
|
# Create a label
|
|
set aLabel 0:3
|
|
Label D ${aLabel}
|
|
|
|
# Set a shape to the label
|
|
ImportShape D ${aLabel} aBox1
|
|
|
|
# Close/Open transaction
|
|
NewCommand D
|
|
|
|
# Select all the sub-shapes of type <aType>
|
|
# aType = FACE
|
|
set aType f
|
|
explode ${aBox1} ${aType}
|
|
|
|
set i 0
|
|
set iSubLabel 2000
|
|
foreach S [directory [concat $aBox1$ter]] {
|
|
incr i
|
|
incr iSubLabel
|
|
puts "SubShape=$S"
|
|
|
|
#Memorize a bounding box of the selected sub-shape
|
|
bounding -s ${S} -save X1_Box1 Y1_Box1 Z1_Box1 X2_Box1 Y2_Box1 Z2_Box1
|
|
|
|
# Select a sub-shape
|
|
set LABEL [Label D 0:$iSubLabel]
|
|
SelectGeometry D ${LABEL} ${S} ${aBox1}
|
|
|
|
# Solve selected sub-shape
|
|
SolveSelection D ${LABEL}
|
|
|
|
# Get selected (and solved) sub-shape
|
|
GetShape D ${LABEL} aSubShape
|
|
|
|
# Get bounding box
|
|
bounding -s aSubShape -save X1_Box2 Y1_Box2 Z1_Box2 X2_Box2 Y2_Box2 Z2_Box2
|
|
|
|
if {[dval X1_Box1] != [dval X1_Box2] || [dval Y1_Box1] != [dval Y1_Box2] || [dval Z1_Box1] != [dval Z1_Box2] || [dval X2_Box1] != [dval X2_Box2] || [dval Y2_Box1] != [dval Y2_Box2] || [dval Z2_Box1] != [dval Z2_Box2]} {
|
|
puts "SelectGeometry command (${i}): Error"
|
|
}
|
|
}
|
|
|
|
puts "SelectGeometry command: OK"
|