aboutsummaryrefslogtreecommitdiffhomepage
path: root/include/effects/SkXfermodeImageFilter.h
diff options
context:
space:
mode:
authorGravatar Mike Reed <reed@google.com>2016-09-23 11:43:54 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2016-09-23 17:13:31 +0000
commit667a007ab3a0e46c78cece172d8720ee62c99cdf (patch)
tree06a3f667bf3c4887e022d2b1e22e8a44651426db /include/effects/SkXfermodeImageFilter.h
parentcc09372730301be78b9d26c1198db1584622cdd9 (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.h46
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