mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-05 18:16:23 +03:00
0025841: Incorrect edge displaying
Handling of too big step changed. Test-case for issue #25841 Small correction in test-case
This commit is contained in:
parent
3629864d0b
commit
77e39787b4
@ -73,7 +73,7 @@ BRepMesh_EdgeTessellator::BRepMesh_EdgeTessellator(
|
||||
|
||||
if (aCurveType == GeomAbs_BSplineCurve)
|
||||
{
|
||||
// TODO: remove this code block when #24959 is fixed
|
||||
// bug24220
|
||||
const Standard_Integer aNbInt = myCOnS.NbIntervals(GeomAbs_C1);
|
||||
if ( aNbInt > 0 )
|
||||
{
|
||||
@ -99,7 +99,7 @@ BRepMesh_EdgeTessellator::BRepMesh_EdgeTessellator(
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// PTv, chl/922/G9, Take into account internal vertices
|
||||
// it is necessary for internal edges, which do not split other edges, by their vertex
|
||||
TopExp_Explorer aVertexIt(theEdge, TopAbs_VERTEX);
|
||||
|
@ -473,6 +473,11 @@ void GCPnts_TangentialDeflection::PerformCurve (const TheCurve& C)
|
||||
else {
|
||||
|
||||
if (Coef >= 1.5) {
|
||||
if (!aPrevPoint.IsEqual(points.Last(), Precision::Confusion()))
|
||||
{
|
||||
parameters.Append (U1);
|
||||
points .Append (aPrevPoint);
|
||||
}
|
||||
U2 = MiddleU;
|
||||
Du = U2-U1;
|
||||
CurrentPoint = MiddlePoint;
|
||||
|
15
tests/bugs/modalg_5/bug25841
Normal file
15
tests/bugs/modalg_5/bug25841
Normal file
@ -0,0 +1,15 @@
|
||||
puts "========"
|
||||
puts "OCC25841"
|
||||
puts "========"
|
||||
puts ""
|
||||
#############################
|
||||
# Incorrect edge displaying
|
||||
#############################
|
||||
|
||||
restore [locate_data_file OCC25841_Curve_2.brep] a
|
||||
vinit
|
||||
vclear
|
||||
vfront
|
||||
vdisplay a
|
||||
vfit
|
||||
set only_screen 1
|
Loading…
x
Reference in New Issue
Block a user