From ce8840e3842f3a702c5d7bf440ff730bdfaf8e70 Mon Sep 17 00:00:00 2001 From: Florin Malita Date: Thu, 8 Dec 2016 09:26:47 -0500 Subject: [SVGDom] ClipPath support * clip-path attribute handling * clipPath container element * asPath() SkSVGNode virtual for capturing subtree geometry R=robertphillips@google.com,stephana@google.com Change-Id: I9597534fe3047b631da6309eafac055dff5696e9 Reviewed-on: https://skia-review.googlesource.com/5650 Reviewed-by: Robert Phillips Commit-Queue: Florin Malita --- experimental/svg/model/SkSVGNode.cpp | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'experimental/svg/model/SkSVGNode.cpp') diff --git a/experimental/svg/model/SkSVGNode.cpp b/experimental/svg/model/SkSVGNode.cpp index a5c8147554..ec452ec9c6 100644 --- a/experimental/svg/model/SkSVGNode.cpp +++ b/experimental/svg/model/SkSVGNode.cpp @@ -30,6 +30,11 @@ bool SkSVGNode::asPaint(const SkSVGRenderContext& ctx, SkPaint* paint) const { return this->onPrepareToRender(&localContext) && this->onAsPaint(localContext, paint); } +SkPath SkSVGNode::asPath(const SkSVGRenderContext& ctx) const { + SkSVGRenderContext localContext(ctx); + return this->onPrepareToRender(&localContext) ? this->onAsPath(localContext) : SkPath(); +} + bool SkSVGNode::onPrepareToRender(SkSVGRenderContext* ctx) const { ctx->applyPresentationAttributes(fPresentationAttributes, this->hasChildren() ? 0 : SkSVGRenderContext::kLeaf); @@ -40,6 +45,10 @@ void SkSVGNode::setAttribute(SkSVGAttribute attr, const SkSVGValue& v) { this->onSetAttribute(attr, v); } +void SkSVGNode::setClipPath(const SkSVGClip& clip) { + fPresentationAttributes.fClipPath.set(clip); +} + void SkSVGNode::setFill(const SkSVGPaint& svgPaint) { fPresentationAttributes.fFill.set(svgPaint); } @@ -73,6 +82,11 @@ void SkSVGNode::setStrokeWidth(const SkSVGLength& strokeWidth) { void SkSVGNode::onSetAttribute(SkSVGAttribute attr, const SkSVGValue& v) { switch (attr) { + case SkSVGAttribute::kClipPath: + if (const SkSVGClipValue* clip = v.as()) { + this->setClipPath(*clip); + } + break; case SkSVGAttribute::kFill: if (const SkSVGPaintValue* paint = v.as()) { this->setFill(*paint); -- cgit v1.2.3