1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00
nbv 1a0339b464 0029311: Implementation of the Oriented Bounding Boxes (OBB) functionality
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.
2017-12-08 16:39:11 +03:00

79 lines
1.8 KiB
Plaintext
Executable File

#INTERFACE CAF
# XLink attributes
#
# Testing attribute: TDocStd_XLink
#
# Testing command: CopyWithLink
#
puts "caf004-B4"
# Create two new documents Doc1, Doc2
NewDocument Doc1 BinOcaf
NewDocument Doc2 BinOcaf
# Set UndoLimit for them
UndoLimit Doc1 100
UndoLimit Doc2 100
# Set a shape in Doc1 to label 'SLabel'
set aLabel1 0:2
Label Doc1 ${aLabel1}
SetName Doc1 ${aLabel1} SLabel
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
SetShape Doc1 ${aLabel1} aBox1
# Create a new label 'TLabel1' in Doc2
set aLabel2 0:3
Label Doc2 ${aLabel2}
SetName Doc2 ${aLabel2} TLabel1
# Open transaction in Doc2
NewCommand Doc2
# Copy 'SLabel' to the label 'TLabel1' with link
CopyWithLink Doc2 ${aLabel2} Doc1 ${aLabel1}
# Close/Open transaction in Doc2
NewCommand Doc2
# Undo Doc2
Undo Doc2
# Redo Doc2
Redo Doc2
# Get a shape from 'TLabel1'
GetShape Doc2 ${aLabel2} aBox2
bounding -s aBox2 -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 "X1_Box1=[dval X1_Box1] X1_Box2=[dval X1_Box2]"
puts "Y1_Box1=[dval Y1_Box1] Y1_Box2=[dval Y1_Box2]"
puts "Z1_Box1=[dval Z1_Box1] Z1_Box2=[dval Z1_Box2]"
puts "X2_Box1=[dval X2_Box1] X2_Box2=[dval X2_Box2]"
puts "Y2_Box1=[dval Y2_Box1] Y2_Box2=[dval Y2_Box2]"
puts "Z2_Box1=[dval Z2_Box1] Z2_Box2=[dval Z2_Box2]"
puts "Set a link between attributes of another document: Error"
return
}
puts "Set a link between attributes of another document: OK"