diff options
author | Stephen White <senorblanco@chromium.org> | 2017-01-12 17:15:50 -0500 |
---|---|---|
committer | Skia Commit-Bot <skia-commit-bot@chromium.org> | 2017-01-13 18:49:11 +0000 |
commit | 930f69eef346b0ad4164752a074f3a45c6f46770 (patch) | |
tree | 966ba9d99fedfe369dc3b664ae8e2ea1af47bcb0 /gm/localmatriximagefilter.cpp | |
parent | cf5d6caff7a58f1c7ecc36d9a91ccdada5fc7b78 (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.cpp | 104 |
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; ) +} |