Merge pull request #89 from X-Ryl669/master
Fix for wrong computation in ArcTo function
This commit is contained in:
commit
5ec585ce1a
@ -2079,13 +2079,10 @@ static void nsvg__pathArcTo(NSVGparser* p, float* cpx, float* cpy, float* args,
|
|||||||
// if (vecrat(ux,uy,vx,vy) <= -1.0f) da = NSVG_PI;
|
// if (vecrat(ux,uy,vx,vy) <= -1.0f) da = NSVG_PI;
|
||||||
// if (vecrat(ux,uy,vx,vy) >= 1.0f) da = 0;
|
// if (vecrat(ux,uy,vx,vy) >= 1.0f) da = 0;
|
||||||
|
|
||||||
if (fa) {
|
if (fs == 0 && da > 0)
|
||||||
// Choose large arc
|
da -= 2 * NSVG_PI;
|
||||||
if (da > 0.0f)
|
else if (fs == 1 && da < 0)
|
||||||
da = da - 2*NSVG_PI;
|
da += 2 * NSVG_PI;
|
||||||
else
|
|
||||||
da = 2*NSVG_PI + da;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Approximate the arc using cubic spline segments.
|
// Approximate the arc using cubic spline segments.
|
||||||
t[0] = cosrx; t[1] = sinrx;
|
t[0] = cosrx; t[1] = sinrx;
|
||||||
|
Loading…
Reference in New Issue
Block a user