diff options
author | Florin Malita <fmalita@chromium.org> | 2017-10-09 15:14:13 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2017-10-09 19:36:44 +0000 |
commit | df007e1a7ae808ad41eb2bd01f6a658c5b438285 (patch) | |
tree | 708f8fba7bc23a2e4b8740ade111f4607bead8c1 /experimental/svg/model/SkSVGLinearGradient.h | |
parent | 7fc1d12e67d381a401555d5a7a1fa6af1eb8d7d6 (diff) |
[SVGDom] Factor out common gradient logic
In preparation of radial gradient support, move common logic into an
abstract base class (SkSVGGradient).
Change-Id: Ie5361048ca8fddd9070c573c8daef0d0f57dc95e
Reviewed-on: https://skia-review.googlesource.com/57108
Commit-Queue: Florin Malita <fmalita@chromium.org>
Reviewed-by: Robert Phillips <robertphillips@google.com>
Diffstat (limited to 'experimental/svg/model/SkSVGLinearGradient.h')
-rw-r--r-- | experimental/svg/model/SkSVGLinearGradient.h | 22 |
1 files changed, 6 insertions, 16 deletions
diff --git a/experimental/svg/model/SkSVGLinearGradient.h b/experimental/svg/model/SkSVGLinearGradient.h index 4e5905c02d..e878baf67d 100644 --- a/experimental/svg/model/SkSVGLinearGradient.h +++ b/experimental/svg/model/SkSVGLinearGradient.h @@ -8,46 +8,36 @@ #ifndef SkSVGLinearGradient_DEFINED #define SkSVGLinearGradient_DEFINED -#include "SkSVGHiddenContainer.h" +#include "SkSVGGradient.h" #include "SkSVGTypes.h" -class SkSVGLinearGradient : public SkSVGHiddenContainer { +class SkSVGLinearGradient final : public SkSVGGradient { public: ~SkSVGLinearGradient() override = default; static sk_sp<SkSVGLinearGradient> Make() { return sk_sp<SkSVGLinearGradient>(new SkSVGLinearGradient()); } - void setHref(const SkSVGStringType&); - void setGradientTransform(const SkSVGTransformType&); - void setSpreadMethod(const SkSVGSpreadMethod&); void setX1(const SkSVGLength&); void setY1(const SkSVGLength&); void setX2(const SkSVGLength&); void setY2(const SkSVGLength&); protected: - bool onAsPaint(const SkSVGRenderContext&, SkPaint*) const override; - void onSetAttribute(SkSVGAttribute, const SkSVGValue&) override; + sk_sp<SkShader> onMakeShader(const SkSVGRenderContext&, + const SkColor*, const SkScalar*, int count, + SkShader::TileMode, const SkMatrix&) const override; private: SkSVGLinearGradient(); - void collectColorStops(const SkSVGRenderContext&, - SkSTArray<2, SkScalar, true>*, - SkSTArray<2, SkColor, true>*) const; - SkSVGLength fX1 = SkSVGLength(0 , SkSVGLength::Unit::kPercentage); SkSVGLength fY1 = SkSVGLength(0 , SkSVGLength::Unit::kPercentage); SkSVGLength fX2 = SkSVGLength(100, SkSVGLength::Unit::kPercentage); SkSVGLength fY2 = SkSVGLength(0 , SkSVGLength::Unit::kPercentage); - SkSVGStringType fHref; - SkSVGTransformType fGradientTransform = SkSVGTransformType(SkMatrix::I()); - SkSVGSpreadMethod fSpreadMethod = SkSVGSpreadMethod(SkSVGSpreadMethod::Type::kPad); - - typedef SkSVGHiddenContainer INHERITED; + typedef SkSVGGradient INHERITED; }; #endif // SkSVGLinearGradient_DEFINED |