aboutsummaryrefslogtreecommitdiffhomepage
path: root/gm/localmatriximagefilter.cpp
diff options
context:
space:
mode:
authorGravatar Stephen White <senorblanco@chromium.org>2017-01-12 17:15:50 -0500
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2017-01-13 18:49:11 +0000
commit930f69eef346b0ad4164752a074f3a45c6f46770 (patch)
tree966ba9d99fedfe369dc3b664ae8e2ea1af47bcb0 /gm/localmatriximagefilter.cpp
parentcf5d6caff7a58f1c7ecc36d9a91ccdada5fc7b78 (diff)
Switch a bunch of tests to use DEF_SIMPLE_GM.
Should be no user- or test-visible changes. BUG=skia: Change-Id: I6499dc978a41fee344b847c118f84227271561c5 Reviewed-on: https://skia-review.googlesource.com/6906 Reviewed-by: Brian Salomon <bsalomon@google.com> Commit-Queue: Stephan White <senorblanco@chromium.org>
Diffstat (limited to 'gm/localmatriximagefilter.cpp')
-rw-r--r--gm/localmatriximagefilter.cpp104
1 files changed, 43 insertions, 61 deletions
diff --git a/gm/localmatriximagefilter.cpp b/gm/localmatriximagefilter.cpp
index d5b7e3e50d..14bbd32b84 100644
--- a/gm/localmatriximagefilter.cpp
+++ b/gm/localmatriximagefilter.cpp
@@ -28,6 +28,18 @@ static sk_sp<SkImage> make_image(SkCanvas* rootCanvas) {
return surface->makeImageSnapshot();
}
+static void show_image(SkCanvas* canvas, SkImage* image, sk_sp<SkImageFilter> filter) {
+ SkPaint paint;
+ paint.setStyle(SkPaint::kStroke_Style);
+ SkRect r = SkRect::MakeIWH(image->width(), image->height()).makeOutset(SK_ScalarHalf,
+ SK_ScalarHalf);
+ canvas->drawRect(r, paint);
+
+ paint.setStyle(SkPaint::kFill_Style);
+ paint.setImageFilter(filter);
+ canvas->drawImage(image, 0, 0, &paint);
+}
+
typedef sk_sp<SkImageFilter> (*ImageFilterFactory)();
// +[]{...} did not work on windows (VS)
@@ -36,66 +48,36 @@ typedef sk_sp<SkImageFilter> (*ImageFilterFactory)();
template <typename T> ImageFilterFactory IFCCast(T arg) { return arg; }
// Show the effect of localmatriximagefilter with various matrices, on various filters
-class LocalMatrixImageFilterGM : public skiagm::GM {
-public:
- LocalMatrixImageFilterGM() {}
-
-protected:
- SkString onShortName() override {
- return SkString("localmatriximagefilter");
- }
-
- SkISize onISize() override {
- return SkISize::Make(640, 640);
- }
-
- static void show_image(SkCanvas* canvas, SkImage* image, sk_sp<SkImageFilter> filter) {
- SkPaint paint;
- paint.setStyle(SkPaint::kStroke_Style);
- SkRect r = SkRect::MakeIWH(image->width(), image->height()).makeOutset(SK_ScalarHalf,
- SK_ScalarHalf);
- canvas->drawRect(r, paint);
-
- paint.setStyle(SkPaint::kFill_Style);
- paint.setImageFilter(filter);
- canvas->drawImage(image, 0, 0, &paint);
- }
-
- void onDraw(SkCanvas* canvas) override {
- sk_sp<SkImage> image0(make_image(canvas));
-
- const ImageFilterFactory factories[] = {
- IFCCast([]{ return SkBlurImageFilter::Make(8, 8, nullptr); }),
- IFCCast([]{ return SkDilateImageFilter::Make(8, 8, nullptr); }),
- IFCCast([]{ return SkErodeImageFilter::Make(8, 8, nullptr); }),
- IFCCast([]{ return SkOffsetImageFilter::Make(8, 8, nullptr); }),
- };
-
- const SkMatrix matrices[] = {
- SkMatrix::MakeScale(SK_ScalarHalf, SK_ScalarHalf),
- SkMatrix::MakeScale(2, 2),
- SkMatrix::MakeTrans(10, 10)
- };
-
- const SkScalar spacer = image0->width() * 3.0f / 2;
-
- canvas->translate(40, 40);
- for (auto&& factory : factories) {
- sk_sp<SkImageFilter> filter(factory());
-
- canvas->save();
- show_image(canvas, image0.get(), filter);
- for (const auto& matrix : matrices) {
- sk_sp<SkImageFilter> localFilter(filter->makeWithLocalMatrix(matrix));
- canvas->translate(spacer, 0);
- show_image(canvas, image0.get(), std::move(localFilter));
- }
- canvas->restore();
- canvas->translate(0, spacer);
+DEF_SIMPLE_GM(localmatriximagefilter, canvas, 640, 640) {
+ sk_sp<SkImage> image0(make_image(canvas));
+
+ const ImageFilterFactory factories[] = {
+ IFCCast([]{ return SkBlurImageFilter::Make(8, 8, nullptr); }),
+ IFCCast([]{ return SkDilateImageFilter::Make(8, 8, nullptr); }),
+ IFCCast([]{ return SkErodeImageFilter::Make(8, 8, nullptr); }),
+ IFCCast([]{ return SkOffsetImageFilter::Make(8, 8, nullptr); }),
+ };
+
+ const SkMatrix matrices[] = {
+ SkMatrix::MakeScale(SK_ScalarHalf, SK_ScalarHalf),
+ SkMatrix::MakeScale(2, 2),
+ SkMatrix::MakeTrans(10, 10)
+ };
+
+ const SkScalar spacer = image0->width() * 3.0f / 2;
+
+ canvas->translate(40, 40);
+ for (auto&& factory : factories) {
+ sk_sp<SkImageFilter> filter(factory());
+
+ canvas->save();
+ show_image(canvas, image0.get(), filter);
+ for (const auto& matrix : matrices) {
+ sk_sp<SkImageFilter> localFilter(filter->makeWithLocalMatrix(matrix));
+ canvas->translate(spacer, 0);
+ show_image(canvas, image0.get(), std::move(localFilter));
}
+ canvas->restore();
+ canvas->translate(0, spacer);
}
-
-private:
- typedef GM INHERITED;
-};
-DEF_GM( return new LocalMatrixImageFilterGM; )
+}