diff options
author | fmalita <fmalita@chromium.org> | 2016-08-17 14:51:03 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2016-08-17 14:51:03 -0700 |
commit | 280e282d2a89ba3b9ff05dd2475d7452b7dccdbe (patch) | |
tree | ee443d714c8320f8b996b1b347212ead9661d272 /experimental/svg/model/SkSVGRenderContext.cpp | |
parent | 0a61270f4ba85d10659fb63a86817b435ec04c94 (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/model/SkSVGRenderContext.cpp')
-rw-r--r-- | experimental/svg/model/SkSVGRenderContext.cpp | 17 |
1 files changed, 17 insertions, 0 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; |