mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
Implementation of the new class *BOPAlgo_MakePeriodic* for making the shape periodic in 3D space. Periodicity of the shape means that the shape can be repeated in any periodic direction any number of times without creation of the new geometry or splits. The idea of this algorithm is to make the shape look similarly on the opposite sides or on the period bounds of periodic directions. It does not mean that the opposite sides of the shape will be mirrored. It just means the the opposite sides of the shape should be split by each other and obtain the same geometry on opposite sides. Such approach will allow repeating the shape, i.e. translating the copy of a shape on the period, without creation of new geometry because there will be no coinciding parts of different dimension. Draw commands for the new algorithm: * makeperiodic - makes the shape periodic in required directions; * repeatshape - repeats the periodic shape in requested periodic direction; * periodictwins - returns the periodic twins for the shape; * clearrepetitions - clears all previous repetitions of the periodic shape. Documentation & test cases for the algorithm.
63 lines
1.4 KiB
Plaintext
63 lines
1.4 KiB
Plaintext
box b 10 10 10
|
|
|
|
foreach bf [explode b f] {
|
|
# replace face with the nurbs one
|
|
nurbsconvert nf $bf
|
|
eval mkvolume s nf [explode b f]
|
|
|
|
savehistory mv_hist
|
|
modified m mv_hist nf
|
|
|
|
mksurface surf m
|
|
if {![regexp "BSplineSurface" [dump surf]]} {
|
|
puts "Error: Boolean Operation took the second face"
|
|
}
|
|
|
|
# make the shape periodic in all directions
|
|
makeperiodic res s -x 10 -y 10 -z 10
|
|
|
|
savehistory h
|
|
modified mf h m
|
|
|
|
mksurface s_mf mf
|
|
|
|
# get twins for the face
|
|
periodictwins tf mf
|
|
|
|
checknbshapes tf -face 1 -m "Periodic twins" -t
|
|
|
|
mksurface s_tf tf
|
|
|
|
if {![regexp {\*\n([^ \n]*)} [dump s_mf] full mf_type]} {
|
|
puts "Error: Unable to get the type"
|
|
}
|
|
if {![regexp {\*\n([^ \n]*)} [dump s_tf] full tf_type]} {
|
|
puts "Error: Unable to get the type"
|
|
}
|
|
|
|
if {$mf_type != $tf_type} {
|
|
puts "Error: Twins have different geometries"
|
|
}
|
|
|
|
# get twins for edges of the face
|
|
foreach e [explode mf e] {
|
|
periodictwins twins $e
|
|
checknbshapes twins -edge 2 -m "Periodic twins" -t
|
|
mkcurve c_$e $e
|
|
if {![regexp {Basis curve :\n([^ \n]*)} [dump c_$e] full e_type]} {
|
|
puts "Error: Unable to get the type"
|
|
}
|
|
|
|
foreach t [explode twins e] {
|
|
mkcurve c_$t $t
|
|
if {![regexp {Basis curve :\n([^ \n]*)} [dump c_$t] full t_type]} {
|
|
puts "Error: Unable to get the type"
|
|
}
|
|
if {$e_type != $t_type} {
|
|
puts "Error: Twins have different geometries"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|