summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2016-08-21 12:53:03 +0100
committerCaolán McNamara <caolanm@redhat.com>2016-08-21 13:05:26 +0100
commit43297fc501cd51982db1e7ed1fa1d4a1c18d0871 (patch)
tree93c27726cffed2c51e60f388017ea0c87853ff12
parent454e1ebcfc589ce82c8c2d5585e22bea1ea5fc79 (diff)
Related: tdf#86473 git rid of special pixel snapping for rectangles
Change-Id: Ia9ab5c58975df2de8c261d92a866cbe264d03205
-rw-r--r--canvas/source/cairo/cairo_canvashelper.cxx23
1 files changed, 1 insertions, 22 deletions
diff --git a/canvas/source/cairo/cairo_canvashelper.cxx b/canvas/source/cairo/cairo_canvashelper.cxx
index 9b64c08a991f..4f28f5dc9010 100644
--- a/canvas/source/cairo/cairo_canvashelper.cxx
+++ b/canvas/source/cairo/cairo_canvashelper.cxx
@@ -973,27 +973,6 @@ namespace cairocanvas
if( nPointCount > 1)
{
bool bIsBezier = aPolygon.areControlPointsUsed();
- bool bIsRectangle = ::basegfx::tools::isRectangle(aPolygon);
- if (bIsRectangle)
- {
- //tdf#86473, if this rectangle will end up after rounding
- //to have no area, then nothing will be drawn, so remove
- //such rectangles from the rounding optimization(?) effort
- basegfx::B2DRange aRange = ::basegfx::tools::getRange(aPolygon);
- double x1 = aRange.getMinX();
- double x2 = aRange.getMaxX();
- double y1 = aRange.getMinY();
- double y2 = aRange.getMaxY();
- cairo_matrix_transform_point(&aOrigMatrix, &x1, &y1);
- cairo_matrix_transform_point(&aOrigMatrix, &x2, &y2);
- basegfx::B2DRange aRoundedRange(basegfx::fround(x1),
- basegfx::fround(y1),
- basegfx::fround(x2),
- basegfx::fround(y2));
- bIsRectangle = aRoundedRange.getWidth() != 0.0 &&
- aRoundedRange.getHeight() != 0.0;
- }
-
::basegfx::B2DPoint aA, aB, aP;
for( sal_uInt32 j=0; j < nExtendedPointCount; j++ )
@@ -1004,7 +983,7 @@ namespace cairocanvas
nY = aP.getY();
cairo_matrix_transform_point( &aOrigMatrix, &nX, &nY );
- if( ! bIsBezier && (bIsRectangle || aOperation == Clip) )
+ if (!bIsBezier && aOperation == Clip)
{
nX = basegfx::fround( nX );
nY = basegfx::fround( nY );