diff options
author | Michael Meeks <michael.meeks@suse.com> | 2013-06-07 14:45:59 +0100 |
---|---|---|
committer | Michael Meeks <michael.meeks@suse.com> | 2013-06-07 15:27:50 +0100 |
commit | 79c13d5d861d2884c6e0b386970d197d51a41211 (patch) | |
tree | f9208ccb5bf1e550c593a3489db4e3d5f017a93c /cppcanvas | |
parent | 7765fbc5300587bd23fd9e56a325140ad89cface (diff) |
fdo#65502 - EmfFillPie fix.
Diffstat (limited to 'cppcanvas')
-rw-r--r-- | cppcanvas/source/mtfrenderer/emfplus.cxx | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/cppcanvas/source/mtfrenderer/emfplus.cxx b/cppcanvas/source/mtfrenderer/emfplus.cxx index 4c7419325e3c..501ed01ef73f 100644 --- a/cppcanvas/source/mtfrenderer/emfplus.cxx +++ b/cppcanvas/source/mtfrenderer/emfplus.cxx @@ -1293,18 +1293,18 @@ namespace cppcanvas B2DPoint mappedCenter (Map (dx + dw/2, dy + dh/2)); B2DSize mappedSize( MapSize (dw/2, dh/2)); - double endAngle = startAngle + sweepAngle; + float endAngle = startAngle + sweepAngle; + startAngle = fmod (startAngle, M_PI*2); + if (startAngle < 0) + startAngle += M_PI*2; + endAngle = fmod (endAngle, M_PI*2); if (endAngle < 0) endAngle += M_PI*2; - endAngle = fmod (endAngle, M_PI*2); - - if (sweepAngle < 0) { - double tmp = startAngle; - startAngle = endAngle; - endAngle = tmp; - } + if (sweepAngle < 0) + std::swap (endAngle, startAngle); - EMFP_DEBUG (printf ("EMF+ angles: %f,%f ---> %f,%f\n", startAngle, sweepAngle, startAngle, endAngle)); + EMFP_DEBUG (printf ("EMF+ adjusted angles to: %f,%f\n", + 360.0*startAngle/M_PI, 360.0*endAngle/M_PI)); B2DPolygon polygon = tools::createPolygonFromEllipseSegment (mappedCenter, mappedSize.getX (), mappedSize.getY (), startAngle, endAngle); polygon.append (mappedCenter); |