diff options
author | Mike Reed <reed@google.com> | 2016-09-23 11:43:54 -0400 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2016-09-23 17:13:31 +0000 |
commit | 667a007ab3a0e46c78cece172d8720ee62c99cdf (patch) | |
tree | 06a3f667bf3c4887e022d2b1e22e8a44651426db /src/effects | |
parent | cc09372730301be78b9d26c1198db1584622cdd9 (diff) |
change SkXfermodeImageFilter to carry no impl information
BUG=skia:
NOTREECHECKS=True
GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2584
Change-Id: Ibf2dfa7722348ae71a99f1c895de0d2996350e58
Reviewed-on: https://skia-review.googlesource.com/2584
Commit-Queue: Mike Reed <reed@google.com>
Reviewed-by: Florin Malita <fmalita@chromium.org>
Reviewed-by: Robert Phillips <robertphillips@google.com>
Diffstat (limited to 'src/effects')
-rw-r--r-- | src/effects/SkXfermodeImageFilter.cpp | 61 |
1 files changed, 52 insertions, 9 deletions
diff --git a/src/effects/SkXfermodeImageFilter.cpp b/src/effects/SkXfermodeImageFilter.cpp index c7e4143e11..bbba0a511e 100644 --- a/src/effects/SkXfermodeImageFilter.cpp +++ b/src/effects/SkXfermodeImageFilter.cpp @@ -24,35 +24,69 @@ #include "SkGrPriv.h" #endif +class SK_API SkXfermodeImageFilter_Base : public SkImageFilter { +public: + SkXfermodeImageFilter_Base(sk_sp<SkXfermode> mode, sk_sp<SkImageFilter> inputs[2], + const CropRect* cropRect); + + SK_TO_STRING_OVERRIDE() + SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkXfermodeImageFilter_Base) + +protected: + sk_sp<SkSpecialImage> onFilterImage(SkSpecialImage* source, const Context&, + SkIPoint* offset) const override; + +#if SK_SUPPORT_GPU + sk_sp<SkSpecialImage> filterImageGPU(SkSpecialImage* source, + sk_sp<SkSpecialImage> background, + const SkIPoint& backgroundOffset, + sk_sp<SkSpecialImage> foreground, + const SkIPoint& foregroundOffset, + const SkIRect& bounds, + const OutputProperties& outputProperties) const; +#endif + + void flatten(SkWriteBuffer&) const override; + + +private: + sk_sp<SkXfermode> fMode; + + friend class SkXfermodeImageFilter; + + typedef SkImageFilter INHERITED; +}; + /////////////////////////////////////////////////////////////////////////////// sk_sp<SkImageFilter> SkXfermodeImageFilter::Make(sk_sp<SkXfermode> mode, sk_sp<SkImageFilter> background, sk_sp<SkImageFilter> foreground, - const CropRect* cropRect) { + const SkImageFilter::CropRect* cropRect) { sk_sp<SkImageFilter> inputs[2] = { std::move(background), std::move(foreground) }; - return sk_sp<SkImageFilter>(new SkXfermodeImageFilter(mode, inputs, cropRect)); + return sk_sp<SkImageFilter>(new SkXfermodeImageFilter_Base(mode, inputs, cropRect)); } -SkXfermodeImageFilter::SkXfermodeImageFilter(sk_sp<SkXfermode> mode, +SkXfermodeImageFilter_Base::SkXfermodeImageFilter_Base(sk_sp<SkXfermode> mode, sk_sp<SkImageFilter> inputs[2], const CropRect* cropRect) : INHERITED(inputs, 2, cropRect) , fMode(std::move(mode)) { } -sk_sp<SkFlattenable> SkXfermodeImageFilter::CreateProc(SkReadBuffer& buffer) { +sk_sp<SkFlattenable> SkXfermodeImageFilter_Base::CreateProc(SkReadBuffer& buffer) { SK_IMAGEFILTER_UNFLATTEN_COMMON(common, 2); sk_sp<SkXfermode> mode(buffer.readXfermode()); - return Make(std::move(mode), common.getInput(0), common.getInput(1), &common.cropRect()); + return SkXfermodeImageFilter::Make(std::move(mode), common.getInput(0), common.getInput(1), + &common.cropRect()); } -void SkXfermodeImageFilter::flatten(SkWriteBuffer& buffer) const { +void SkXfermodeImageFilter_Base::flatten(SkWriteBuffer& buffer) const { this->INHERITED::flatten(buffer); buffer.writeFlattenable(fMode.get()); } -sk_sp<SkSpecialImage> SkXfermodeImageFilter::onFilterImage(SkSpecialImage* source, +sk_sp<SkSpecialImage> SkXfermodeImageFilter_Base::onFilterImage(SkSpecialImage* source, const Context& ctx, SkIPoint* offset) const { SkIPoint backgroundOffset = SkIPoint::Make(0, 0); @@ -134,7 +168,7 @@ sk_sp<SkSpecialImage> SkXfermodeImageFilter::onFilterImage(SkSpecialImage* sourc } #ifndef SK_IGNORE_TO_STRING -void SkXfermodeImageFilter::toString(SkString* str) const { +void SkXfermodeImageFilter_Base::toString(SkString* str) const { str->appendf("SkXfermodeImageFilter: ("); str->appendf("xfermode: ("); if (fMode) { @@ -159,7 +193,7 @@ void SkXfermodeImageFilter::toString(SkString* str) const { #include "SkXfermode_proccoeff.h" -sk_sp<SkSpecialImage> SkXfermodeImageFilter::filterImageGPU( +sk_sp<SkSpecialImage> SkXfermodeImageFilter_Base::filterImageGPU( SkSpecialImage* source, sk_sp<SkSpecialImage> background, const SkIPoint& backgroundOffset, @@ -263,3 +297,12 @@ sk_sp<SkSpecialImage> SkXfermodeImageFilter::filterImageGPU( } #endif + +/////////////////////////////////////////////////////////////////////////////////////////////////// + +SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_START(SkXfermodeImageFilter) + SK_DEFINE_FLATTENABLE_REGISTRAR_ENTRY(SkXfermodeImageFilter_Base) + // manually register the legacy serialized name "SkXfermodeImageFilter" + SkFlattenable::Register("SkXfermodeImageFilter", SkXfermodeImageFilter_Base::CreateProc, + SkFlattenable::kSkImageFilter_Type); +SK_DEFINE_FLATTENABLE_REGISTRAR_GROUP_END |