geometry: fix incorrect 45 degree miter generation (likely a side bug after introduction of EDA_ANGLE)
This commit is contained in:
parent
a0105efc0c
commit
0a69340953
|
@ -144,7 +144,7 @@ const SHAPE_LINE_CHAIN DIRECTION_45::BuildInitialTrace( const VECTOR2I& aP0, con
|
|||
{
|
||||
// Positive tangentLength, diagonal start: arc goes at the start
|
||||
arcEndpoint = aP1 - mp0.Resize( tangentLength );
|
||||
arc.ConstructFromStartEndAngle( aP0, arcEndpoint, - ANGLE_45 * rotationSign );
|
||||
arc.ConstructFromStartEndAngle( aP0, arcEndpoint, ANGLE_45 * rotationSign );
|
||||
|
||||
if( arc.GetP0() == arc.GetP1() )
|
||||
pl.Append( aP0 );
|
||||
|
@ -157,7 +157,7 @@ const SHAPE_LINE_CHAIN DIRECTION_45::BuildInitialTrace( const VECTOR2I& aP0, con
|
|||
{
|
||||
// Negative tangentLength, diagonal start: arc goes at the end
|
||||
arcEndpoint = aP0 + mp1.Resize( std::abs( tangentLength ) );
|
||||
arc.ConstructFromStartEndAngle( arcEndpoint, aP1, - ANGLE_45 * rotationSign );
|
||||
arc.ConstructFromStartEndAngle( arcEndpoint, aP1, ANGLE_45 * rotationSign );
|
||||
|
||||
pl.Append( aP0 );
|
||||
|
||||
|
@ -178,7 +178,7 @@ const SHAPE_LINE_CHAIN DIRECTION_45::BuildInitialTrace( const VECTOR2I& aP0, con
|
|||
{
|
||||
// Positive tangentLength: arc goes at the end
|
||||
arcEndpoint = aP0 + mp0.Resize( tangentLength );
|
||||
arc.ConstructFromStartEndAngle( arcEndpoint, aP1, ANGLE_45 * rotationSign );
|
||||
arc.ConstructFromStartEndAngle( arcEndpoint, aP1, - ANGLE_45 * rotationSign );
|
||||
|
||||
pl.Append( aP0 );
|
||||
|
||||
|
@ -202,12 +202,12 @@ const SHAPE_LINE_CHAIN DIRECTION_45::BuildInitialTrace( const VECTOR2I& aP0, con
|
|||
if( std::abs( endpoint.y - aP1.y ) < SHAPE_ARC::MIN_PRECISION_IU )
|
||||
{
|
||||
VECTOR2I fixedEnd( endpoint.x, aP1.y );
|
||||
ca.ConstructFromStartEndAngle( ca.GetP0(), fixedEnd, - ANGLE_45 * rotationSign );
|
||||
ca.ConstructFromStartEndAngle( ca.GetP0(), fixedEnd, ANGLE_45 * rotationSign );
|
||||
}
|
||||
else if( std::abs( endpoint.x - aP1.x ) < SHAPE_ARC::MIN_PRECISION_IU )
|
||||
{
|
||||
VECTOR2I fixedEnd( aP1.x, endpoint.y );
|
||||
ca.ConstructFromStartEndAngle( ca.GetP0(), fixedEnd, - ANGLE_45 * rotationSign );
|
||||
ca.ConstructFromStartEndAngle( ca.GetP0(), fixedEnd, ANGLE_45 * rotationSign );
|
||||
}
|
||||
|
||||
if( ca.GetP0() == ca.GetP1() )
|
||||
|
|
Loading…
Reference in New Issue