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 /include/effects/SkXfermodeImageFilter.h | |
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 'include/effects/SkXfermodeImageFilter.h')
-rw-r--r-- | include/effects/SkXfermodeImageFilter.h | 46 |
1 files changed, 13 insertions, 33 deletions
diff --git a/include/effects/SkXfermodeImageFilter.h b/include/effects/SkXfermodeImageFilter.h index 135c0f6dc3..e39157550c 100644 --- a/include/effects/SkXfermodeImageFilter.h +++ b/include/effects/SkXfermodeImageFilter.h @@ -10,19 +10,18 @@ #include "SkImageFilter.h" -class SkBitmap; class SkXfermode; -class SK_API SkXfermodeImageFilter : public SkImageFilter { - /** - * This filter takes an xfermode, and uses it to composite the foreground - * over the background. If foreground or background is NULL, the input - * bitmap (src) is used instead. - */ - +/** + * This filter takes an xfermode, and uses it to composite the foreground + * over the background. If foreground or background is NULL, the input + * bitmap (src) is used instead. + */ +class SK_API SkXfermodeImageFilter { public: static sk_sp<SkImageFilter> Make(sk_sp<SkXfermode> mode, sk_sp<SkImageFilter> background, - sk_sp<SkImageFilter> foreground, const CropRect* cropRect); + sk_sp<SkImageFilter> foreground, + const SkImageFilter::CropRect* cropRect); static sk_sp<SkImageFilter> Make(sk_sp<SkXfermode> mode, sk_sp<SkImageFilter> background) { return Make(std::move(mode), std::move(background), nullptr, nullptr); } @@ -30,7 +29,7 @@ public: #ifdef SK_SUPPORT_LEGACY_XFERMODE_PTR static SkImageFilter* Create(SkXfermode* mode, SkImageFilter* background, SkImageFilter* foreground = NULL, - const CropRect* cropRect = NULL) { + const SkImageFilter::CropRect* cropRect = NULL) { return Make(sk_ref_sp(mode), sk_ref_sp(background), sk_ref_sp(foreground), @@ -39,7 +38,8 @@ public: #endif #ifdef SK_SUPPORT_LEGACY_IMAGEFILTER_PTR static sk_sp<SkImageFilter> Make(sk_sp<SkXfermode> mode, SkImageFilter* background, - SkImageFilter* foreground, const CropRect* cropRect) { + SkImageFilter* foreground, + const SkImageFilter::CropRect* cropRect) { return Make(std::move(mode), sk_ref_sp(background), sk_ref_sp(foreground), @@ -50,30 +50,10 @@ public: } #endif - SK_TO_STRING_OVERRIDE() - SK_DECLARE_PUBLIC_FLATTENABLE_DESERIALIZATION_PROCS(SkXfermodeImageFilter) - -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 - - SkXfermodeImageFilter(sk_sp<SkXfermode> mode, sk_sp<SkImageFilter> inputs[2], - const CropRect* cropRect); - void flatten(SkWriteBuffer&) const override; + SK_DECLARE_FLATTENABLE_REGISTRAR_GROUP(); private: - sk_sp<SkXfermode> fMode; - typedef SkImageFilter INHERITED; + SkXfermodeImageFilter(); // can't instantiate }; #endif |