mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
Sometimes curve or surface, which is defined as C0, has continuity G1 or above. Offset can be built from these shapes. Therefore, this extended checking was added into SetBasisCurve and SetBasisSurface methods. Main changes in function BRepOffset_Tool::ExtentFace(...): * "return" is added if intersection (in 2D-space) between two edges in a face cannot be found. Basis curve/surface continuity value found (if G1-checking is OK) is set up as BasisContinuity (see myBasisCurveContinuity and myBasisSurfContinuity members which is returned by GetBasisCurveContinuity and GetBasisSurfContinuity() methods). This fact is used in Geom2dAdaptor and in GeomAdaptor classes. Possibility is entered, which allows for basis elements of offset curve/surface to avoid of C0-checking. Test cases were changed according to their new behavior. Test-cases for issue #25124
39 lines
943 B
Plaintext
39 lines
943 B
Plaintext
puts "========"
|
|
puts "OCC25124"
|
|
puts "========"
|
|
puts ""
|
|
######################################################
|
|
# Removal of continuity checks for offset geometries
|
|
######################################################
|
|
|
|
smallview
|
|
|
|
point pp 0 0 1
|
|
circle cc 20 40 30 20
|
|
convert bc cc
|
|
trim bc bc 1 6
|
|
offsetcurve oc bc 10 pp
|
|
trim bc oc 2 5
|
|
revsurf se bc 0 0 0 0 1 0
|
|
offset os se 15
|
|
|
|
set bug_info [getsurfcontinuity se]
|
|
getsurfcontinuity os
|
|
|
|
if {[string compare $bug_info "se has G1 continuity.\n"] != 0} {
|
|
puts "ERROR: OCC25124 is reproduced (se does not have G1 continuity)."
|
|
}
|
|
|
|
set bug_info_1 [dump se]
|
|
set bug_info_1 [string range $bug_info_1 39 [expr {[string length $bug_info_1] -1}]]
|
|
set bug_info_2 [dump os]
|
|
set bug_info_2 [string range $bug_info_2 39 [expr {[string length $bug_info_2] -1}]]
|
|
if {[string compare $bug_info_1 $bug_info_2] == 0} {
|
|
puts "ERROR: OCC25124 is reproduced (se = os)."
|
|
}
|
|
|
|
donly os se
|
|
fit
|
|
|
|
set only_screen_axo 1
|