1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-03 17:56:21 +03:00

0033759: Modeling Algorithms - Offset is in wrong direction

Changed the condition to avoid reversing offset
  for reversed edges.
Added a test case.
This commit is contained in:
astromko 2024-09-09 15:12:11 +01:00
parent ed20837d8b
commit 32c19c4cd4
4 changed files with 44 additions and 5 deletions

View File

@ -264,12 +264,12 @@ static Standard_Boolean KPartCircle
}
else if (AHC->GetType() == GeomAbs_Circle)
{
if (E.Orientation() == TopAbs_FORWARD)
anOffset *= -1;
if (!BRep_Tool::IsClosed(E))
// Reverse the offset function when the edge is FORWARD and CLOSED
if (E.Orientation() == TopAbs_FORWARD && BRep_Tool::IsClosed(E))
{
anOffset *= -1;
}
gp_Circ2d theCirc = AHC->Circle();
if (anOffset > 0. || Abs(anOffset) < theCirc.Radius())
OC = new Geom2d_Circle (theCirc.Position(), theCirc.Radius() + anOffset);

View File

@ -23,7 +23,7 @@ vori result
fit
checkprops result -l 613.39
checkprops result -l 644.509
checkshape result
checksection result

View File

@ -23,7 +23,7 @@ vori result
fit
checkprops result -l 354.958
checkprops result -l 386.077
checkshape result
checksection result

View File

@ -0,0 +1,39 @@
puts "==========================================================="
puts "0033759: Modeling Algorithms - Offset is in wrong direction"
puts "==========================================================="
puts ""
pload MODELING
circle c1 0 0 0 30
# make and check FORWARD, NOT CLOSED edge
mkedge e1 c1 1.5*pi 0
wire w1 e1
plane pln1 0 0 0 0 0 1 1 0 0
mkface f1 pln1 w1
openoffset of1 f1 1 7
checkprops of1_1 -l 58.1195
# make and check REVERSED, NOT CLOSED edge
complement e1
wire w1 e1
plane pln1 0 0 0 0 0 1 1 0 0
mkface f1 pln1 w1
openoffset of1 f1 1 7
checkprops of1_1 -l 58.1195
# make and check FORWARD CLOSED edge
mkedge e1 c1 0 0
wire w1 e1
plane pln1 0 0 0 0 0 1 1 0 0
mkface f1 pln1 w1
openoffset of1 f1 1 7
checkprops of1_1 -l 232.478
# make and check REVERSED CLOSED edge
complement e1
wire w1 e1
plane pln1 0 0 0 0 0 1 1 0 0
mkface f1 pln1 w1
openoffset of1 f1 1 7
checkprops of1_1 -l 232.478