Blame SOURCES/0001-Resolves-tdf-112145-pdf-export-of-editengine-highlig.patch

dc0b3e
From f41ae9bc40fae21ac66d859057488801c1d47ccd Mon Sep 17 00:00:00 2001
dc0b3e
From: =?UTF-8?q?Caol=C3=A1n=20McNamara?= <caolanm@redhat.com>
dc0b3e
Date: Thu, 31 Aug 2017 16:22:58 +0100
dc0b3e
Subject: [PATCH] Resolves: tdf#112145 pdf export of editengine highlight color
dc0b3e
 fails sometimes
dc0b3e
dc0b3e
When setting a fill or line color on the outputdevice, put it back to its previous
dc0b3e
setting when finished with the record, PRIMITIVE2D_ID_POLYPOLYGONCOLORPRIMITIVE2D
dc0b3e
was the one in this case but protect the other similar ones here too
dc0b3e
dc0b3e
Change-Id: Ifb9b182d72bb6c48a9d9480270fde4384be6291e
dc0b3e
---
dc0b3e
 drawinglayer/source/processor2d/vclmetafileprocessor2d.cxx | 8 ++++++++
dc0b3e
 1 file changed, 8 insertions(+)
dc0b3e
dc0b3e
diff --git a/drawinglayer/source/processor2d/vclmetafileprocessor2d.cxx b/drawinglayer/source/processor2d/vclmetafileprocessor2d.cxx
dc0b3e
index 885367d..0274b7c 100644
dc0b3e
--- a/drawinglayer/source/processor2d/vclmetafileprocessor2d.cxx
dc0b3e
+++ b/drawinglayer/source/processor2d/vclmetafileprocessor2d.cxx
dc0b3e
@@ -1219,6 +1219,8 @@ namespace drawinglayer
dc0b3e
                     }
dc0b3e
                     else
dc0b3e
                     {
dc0b3e
+                        mpOutputDevice->Push(PushFlags::LINECOLOR | PushFlags::FILLCOLOR);
dc0b3e
+
dc0b3e
                         // support SvtGraphicStroke MetaCommentAction
dc0b3e
                         SvtGraphicStroke* pSvtGraphicStroke = impTryToCreateSvtGraphicStroke(
dc0b3e
                             rBasePolygon, nullptr,
dc0b3e
@@ -1274,6 +1276,8 @@ namespace drawinglayer
dc0b3e
                         }
dc0b3e
 
dc0b3e
                         impEndSvtGraphicStroke(pSvtGraphicStroke);
dc0b3e
+
dc0b3e
+                        mpOutputDevice->Pop();
dc0b3e
                     }
dc0b3e
 
dc0b3e
                     break;
dc0b3e
@@ -1666,6 +1670,7 @@ namespace drawinglayer
dc0b3e
                 }
dc0b3e
                 case PRIMITIVE2D_ID_POLYPOLYGONCOLORPRIMITIVE2D :
dc0b3e
                 {
dc0b3e
+                    mpOutputDevice->Push(PushFlags::LINECOLOR | PushFlags::FILLCOLOR);
dc0b3e
                     const primitive2d::PolyPolygonColorPrimitive2D& rPolygonCandidate(static_cast< const primitive2d::PolyPolygonColorPrimitive2D& >(rCandidate));
dc0b3e
                     basegfx::B2DPolyPolygon aLocalPolyPolygon(rPolygonCandidate.getB2DPolyPolygon());
dc0b3e
 
dc0b3e
@@ -1722,6 +1727,7 @@ namespace drawinglayer
dc0b3e
                         impEndSvtGraphicFill(pSvtGraphicFill);
dc0b3e
                     }
dc0b3e
 
dc0b3e
+                    mpOutputDevice->Pop();
dc0b3e
                     break;
dc0b3e
                 }
dc0b3e
                 case PRIMITIVE2D_ID_METAFILEPRIMITIVE2D :
dc0b3e
@@ -1811,6 +1817,7 @@ namespace drawinglayer
dc0b3e
                 }
dc0b3e
                 case PRIMITIVE2D_ID_UNIFIEDTRANSPARENCEPRIMITIVE2D :
dc0b3e
                 {
dc0b3e
+                    mpOutputDevice->Push(PushFlags::LINECOLOR | PushFlags::FILLCOLOR);
dc0b3e
                     // for metafile: Need to examine what the pure vcl version is doing here actually
dc0b3e
                     // - uses DrawTransparent with metafile for content and a gradient
dc0b3e
                     // - uses DrawTransparent for single PolyPoylgons directly. Can be detected by
dc0b3e
@@ -1945,6 +1952,7 @@ namespace drawinglayer
dc0b3e
                         }
dc0b3e
                     }
dc0b3e
 
dc0b3e
+                    mpOutputDevice->Pop();
dc0b3e
                     break;
dc0b3e
                 }
dc0b3e
                 case PRIMITIVE2D_ID_TRANSPARENCEPRIMITIVE2D :
dc0b3e
-- 
dc0b3e
2.13.5
dc0b3e