aboutsummaryrefslogtreecommitdiffhomepage
path: root/experimental/svg
diff options
context:
space:
mode:
authorGravatar fmalita <fmalita@chromium.org>2016-08-17 14:51:03 -0700
committerGravatar Commit bot <commit-bot@chromium.org>2016-08-17 14:51:03 -0700
commit280e282d2a89ba3b9ff05dd2475d7452b7dccdbe (patch)
treeee443d714c8320f8b996b1b347212ead9661d272 /experimental/svg
parent0a61270f4ba85d10659fb63a86817b435ec04c94 (diff)
[SVGDom] Add support for assorted absolute units
R=robertphillips@google.com,stephana@google.com GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2259473002 Review-Url: https://codereview.chromium.org/2259473002
Diffstat (limited to 'experimental/svg')
-rw-r--r--experimental/svg/model/SkSVGRenderContext.cpp17
-rw-r--r--experimental/svg/model/SkSVGRenderContext.h6
2 files changed, 21 insertions, 2 deletions
diff --git a/experimental/svg/model/SkSVGRenderContext.cpp b/experimental/svg/model/SkSVGRenderContext.cpp
index 8ad881429a..4a1d77d6e4 100644
--- a/experimental/svg/model/SkSVGRenderContext.cpp
+++ b/experimental/svg/model/SkSVGRenderContext.cpp
@@ -26,6 +26,13 @@ SkScalar length_size_for_type(const SkSize& viewport, SkSVGLengthContext::Length
return 0;
}
+// Multipliers for DPI-relative units.
+constexpr SkScalar kINMultiplier = 1.00f;
+constexpr SkScalar kPTMultiplier = kINMultiplier / 72.272f;
+constexpr SkScalar kPCMultiplier = kPTMultiplier * 12;
+constexpr SkScalar kMMMultiplier = kINMultiplier / 25.4f;
+constexpr SkScalar kCMMultiplier = kMMMultiplier * 10;
+
} // anonymous ns
SkScalar SkSVGLengthContext::resolve(const SkSVGLength& l, LengthType t) const {
@@ -36,6 +43,16 @@ SkScalar SkSVGLengthContext::resolve(const SkSVGLength& l, LengthType t) const {
return l.value();
case SkSVGLength::Unit::kPercentage:
return l.value() * length_size_for_type(fViewport, t) / 100;
+ case SkSVGLength::Unit::kCM:
+ return l.value() * fDPI * kCMMultiplier;
+ case SkSVGLength::Unit::kMM:
+ return l.value() * fDPI * kMMMultiplier;
+ case SkSVGLength::Unit::kIN:
+ return l.value() * fDPI * kINMultiplier;
+ case SkSVGLength::Unit::kPT:
+ return l.value() * fDPI * kPTMultiplier;
+ case SkSVGLength::Unit::kPC:
+ return l.value() * fDPI * kPCMultiplier;
default:
SkDebugf("unsupported unit type: <%d>\n", l.unit());
return 0;
diff --git a/experimental/svg/model/SkSVGRenderContext.h b/experimental/svg/model/SkSVGRenderContext.h
index e6df725a5c..61f8746376 100644
--- a/experimental/svg/model/SkSVGRenderContext.h
+++ b/experimental/svg/model/SkSVGRenderContext.h
@@ -20,7 +20,8 @@ class SkSVGLength;
class SkSVGLengthContext {
public:
- SkSVGLengthContext(const SkSize& viewport) : fViewport(viewport) {}
+ SkSVGLengthContext(const SkSize& viewport, SkScalar dpi = 90)
+ : fViewport(viewport), fDPI(dpi) {}
enum class LengthType {
kHorizontal,
@@ -36,7 +37,8 @@ public:
const SkSVGLength& w, const SkSVGLength& h) const;
private:
- SkSize fViewport;
+ SkSize fViewport;
+ SkScalar fDPI;
};
struct SkSVGPresentationContext {