mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0031202: Shape Healing - FixMissingSeam creates degenerated edge
Adding tolerance to prevent degenerated cuts in cases where all vertex tolerance is covered by distance of the edge curve from vertex point.
This commit is contained in:
parent
72f6dc612c
commit
4e8c1d8666
@ -985,8 +985,11 @@ ShapeFix_WireSegment ShapeFix_ComposeShell::SplitWire (ShapeFix_WireSegment &wir
|
||||
currPnt = myGrid->Value ( currPnt2d );
|
||||
if ( currPnt.Distance ( lastVPnt ) <= lastVTol &&
|
||||
lastPnt.Distance ( currPnt ) <= tol &&
|
||||
// Tolerance is increased to prevent degenerated cuts in cases where all vertex
|
||||
// tolerance is covered by distance of the edge curve from vertex point.
|
||||
// Doubled to prevent edge being fully covered by its vertices tolerance (invalid edge).
|
||||
CheckByCurve3d ( lastVPnt, c3d, f3d+(currPar-firstPar)*(l3d-f3d)/span2d,
|
||||
T, lastVTol ) &&
|
||||
T, lastVTol + 2 * Precision::Confusion() ) &&
|
||||
lastPnt.Distance ( myGrid->Value ( C2d->Value(0.5*(currPar+lastPar)) ) ) <= tol ) {
|
||||
V = lastV;
|
||||
Standard_Real uRes = myUResolution;
|
||||
@ -1005,8 +1008,11 @@ ShapeFix_WireSegment ShapeFix_ComposeShell::SplitWire (ShapeFix_WireSegment &wir
|
||||
}
|
||||
else if ( currPnt.Distance ( prevVPnt ) <= prevVTol &&
|
||||
prevPnt.Distance ( currPnt ) <= tol &&
|
||||
// Tolerance is increased to prevent degenerated cuts in cases where all vertex
|
||||
// tolerance is covered by distance of the edge curve from vertex point.
|
||||
// Doubled to prevent edge being fully covered by its vertices tolerance (invalid edge).
|
||||
CheckByCurve3d ( prevVPnt, c3d, f3d+(currPar-firstPar)*(l3d-f3d)/span2d,
|
||||
T, prevVTol ) &&
|
||||
T, prevVTol + 2 * Precision::Confusion()) &&
|
||||
prevPnt.Distance ( myGrid->Value ( C2d->Value(0.5*(currPar+prevPar)) ) ) <= tol ) {
|
||||
V = prevV;
|
||||
Standard_Real uRes = myUResolution;
|
||||
|
4
tests/bugs/heal/bug31202
Normal file
4
tests/bugs/heal/bug31202
Normal file
@ -0,0 +1,4 @@
|
||||
restore [locate_data_file bug31202.brep] shape
|
||||
fixshape result shape 0.000001137 0.0001137
|
||||
checkshape result
|
||||
checknbshapes result -edge 4
|
@ -1,6 +1,5 @@
|
||||
# !!!! This file is generated automatically, do not edit manually! See end script
|
||||
puts "TODO CR23096 ALL: TPSTAT : Faulty"
|
||||
puts "TODO CR23096 ALL: CHECKSHAPE : Faulty"
|
||||
|
||||
|
||||
set filename bm1_sy_exhaust.stp
|
||||
|
Loading…
x
Reference in New Issue
Block a user