Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1629)

Unified Diff: experimental/svg/model/SkSVGNode.cpp

Issue 2222793002: [SVGDom] Add <svg> viewBox support (Closed) Base URL: https://chromium.googlesource.com/skia.git@master
Patch Set: typo Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « experimental/svg/model/SkSVGNode.h ('k') | experimental/svg/model/SkSVGRect.cpp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: experimental/svg/model/SkSVGNode.cpp
diff --git a/experimental/svg/model/SkSVGNode.cpp b/experimental/svg/model/SkSVGNode.cpp
index eb82834f38cb99ed2141a3812c9ada03f37f100b..34c6e17d619a34f9f97325ec8f01a3a5b89482e3 100644
--- a/experimental/svg/model/SkSVGNode.cpp
+++ b/experimental/svg/model/SkSVGNode.cpp
@@ -16,18 +16,17 @@ SkSVGNode::SkSVGNode(SkSVGTag t) : fTag(t) { }
SkSVGNode::~SkSVGNode() { }
-void SkSVGNode::render(SkCanvas* canvas, const SkSVGRenderContext& ctx) const {
- SkTCopyOnFirstWrite<SkSVGRenderContext> localContext(ctx);
- fPresentationAttributes.applyTo(localContext);
-
- SkAutoCanvasRestore acr(canvas, false);
- const SkMatrix& m = this->onLocalMatrix();
- if (!m.isIdentity()) {
- canvas->save();
- canvas->concat(m);
+void SkSVGNode::render(const SkSVGRenderContext& ctx) const {
+ SkSVGRenderContext localContext(ctx);
+
+ if (this->onPrepareToRender(&localContext)) {
+ this->onRender(localContext);
}
+}
- this->onRender(canvas, *localContext);
+bool SkSVGNode::onPrepareToRender(SkSVGRenderContext* ctx) const {
+ fPresentationAttributes.applyTo(ctx);
+ return true;
}
void SkSVGNode::setAttribute(SkSVGAttribute attr, const SkSVGValue& v) {
@@ -51,7 +50,3 @@ void SkSVGNode::onSetAttribute(SkSVGAttribute attr, const SkSVGValue& v) {
break;
}
}
-
-const SkMatrix& SkSVGNode::onLocalMatrix() const {
- return SkMatrix::I();
-}
« no previous file with comments | « experimental/svg/model/SkSVGNode.h ('k') | experimental/svg/model/SkSVGRect.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698