mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
1. The partition operation allows splitting an arbitrary number of shapes of an arbitrary dimension by other arbitrary shapes. The algorithm has been implemented in the class BOPAlgo_Splitter. The API operator Splitter has been implemented in the class BRepAlgoAPI_Splitter. 2. The draw commands for usage the new algorithm have been implemented - bsplit and bapisplit. The commands are identical, but one uses the BOPAlgo_Splitter, the other uses BRepAlgoAPI_Splitter. Both commands should be used after Pave Filler is filled. 3. Test cases for the new algorithm. 4. Documentation has been updated. Small corrections.
46 lines
904 B
Plaintext
46 lines
904 B
Plaintext
puts "============"
|
|
puts "OCC26874"
|
|
puts "============"
|
|
puts ""
|
|
#######################################################################
|
|
# Implementation of the Partition operator in OCCT
|
|
#######################################################################
|
|
|
|
# split face by set of edges
|
|
|
|
cylinder cyl 0 0 0 0 0 1 10
|
|
set height 20
|
|
mkface f cyl 0 2*pi -$height $height
|
|
|
|
bclearobjects
|
|
bcleartools
|
|
baddobjects f
|
|
|
|
# create tool edges
|
|
compound edges
|
|
|
|
set nb_uedges 10
|
|
set pi2 [dval 2*pi]
|
|
set ustep [expr $pi2/$nb_uedges]
|
|
for {set i 0} {$i <= $pi2} {set i [expr $i + $ustep]} {
|
|
uiso c cyl $i
|
|
mkedge e c -25 25
|
|
add e edges
|
|
}
|
|
|
|
set nb_vedges 10
|
|
set vstep [expr 2*$height/$nb_vedges]
|
|
for {set i -20} {$i <= 20} {set i [expr $i + $vstep]} {
|
|
viso c cyl $i
|
|
mkedge e c
|
|
add e edges
|
|
}
|
|
|
|
baddctools edges
|
|
|
|
bfillds
|
|
bapisplit result
|
|
|
|
checkshape result
|
|
checknbshapes result -face 100
|
|
checkprops result -s 2513.27 |