From 221722b7f9eaa00a1904e5ad1b8f2cb67eda8a95 Mon Sep 17 00:00:00 2001 From: fmalita Date: Tue, 6 Sep 2016 14:37:02 -0700 Subject: [SVGDevice] Observe even-odd path fills BUG=skia:5712 R=reed@google.com GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2311333002 Review-Url: https://codereview.chromium.org/2311333002 --- src/svg/SkSVGDevice.cpp | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/svg/SkSVGDevice.cpp b/src/svg/SkSVGDevice.cpp index 3ba721ee39..d4d18da83f 100644 --- a/src/svg/SkSVGDevice.cpp +++ b/src/svg/SkSVGDevice.cpp @@ -652,6 +652,11 @@ void SkSVGDevice::drawPath(const SkDraw& draw, const SkPath& path, const SkPaint const SkMatrix* prePathMatrix, bool pathIsMutable) { AutoElement elem("path", fWriter, fResourceBucket, draw, paint); elem.addPathAttributes(path); + + // TODO: inverse fill types? + if (path.getFillType() == SkPath::kEvenOdd_FillType) { + elem.addAttribute("fill-rule", "evenodd"); + } } void SkSVGDevice::drawBitmapCommon(const SkDraw& draw, const SkBitmap& bm, -- cgit v1.2.3