blob: 51109c5cff18a79d14ba0b6959525ade9b1c29ec [file] [log] [blame]
wutao0dc1f4f2017-06-26 15:03:55 -07001/*
2 * Copyright 2017 Google Inc.
3 *
4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file.
6 */
7
8#include "gm.h"
9#include "sk_tool_utils.h"
10#include "SkSurface.h"
11#include "SkBlurImageFilter.h"
12
wutao0dc1f4f2017-06-26 15:03:55 -070013static sk_sp<SkImage> make_image(SkCanvas* canvas) {
14 SkImageInfo info = SkImageInfo::MakeN32Premul(250, 200);
Mike Reed46596ae2018-01-02 15:40:29 -050015 auto surface = sk_tool_utils::makeSurface(canvas, info);
wutao0dc1f4f2017-06-26 15:03:55 -070016 SkCanvas* c = surface->getCanvas();
17 SkPaint paint;
18 paint.setAntiAlias(true);
19
20 paint.setColor(SK_ColorBLUE);
21 c->drawRect(SkRect::MakeIWH(info.width(), info.height()), paint);
22 paint.setColor(SK_ColorGREEN);
23 c->drawCircle(125, 100, 100, paint);
24 paint.setColor(SK_ColorRED);
25 c->drawRect(SkRect::MakeIWH(80, 80), paint);
26
27 return surface->makeImageSnapshot();
28}
29
30static void draw_image(SkCanvas* canvas, const sk_sp<SkImage> image, sk_sp<SkImageFilter> filter) {
31 SkAutoCanvasRestore acr(canvas, true);
32 SkPaint paint;
33 paint.setImageFilter(std::move(filter));
34
35 canvas->translate(SkIntToScalar(30), 0);
36 canvas->clipRect(SkRect::MakeIWH(image->width(),image->height()));
37 canvas->drawImage(image, 0, 0, &paint);
38}
39
40namespace skiagm {
41
42// This GM draws one rectangle, one green inscribed circle, and one red square
43// with different blur settings.
44class ImageBlurClampModeGM : public GM {
45public:
46 ImageBlurClampModeGM() {
47 this->setBGColor(sk_tool_utils::color_to_565(0xFFCCCCCC));
48 }
49
50protected:
51
52 SkString onShortName() override {
53 return SkString("imageblurclampmode");
54 }
55
56 SkISize onISize() override {
57 return SkISize::Make(850, 920);
58 }
59
wutao039a7c72017-06-30 10:44:45 -070060 bool runAsBench() const override { return true; }
61
wutao0dc1f4f2017-06-26 15:03:55 -070062 void onDraw(SkCanvas* canvas) override {
63 sk_sp<SkImage> image(make_image(canvas));
64
65 canvas->translate(0, 30);
66 // Test different kernel size, including the one to launch 2d Gaussian
67 // blur.
68 for (auto sigma: { 0.6f, 3.0f, 8.0f, 20.0f }) {
69 canvas->save();
wutao039a7c72017-06-30 10:44:45 -070070 sk_sp<SkImageFilter> filter(
71 SkBlurImageFilter::Make(sigma, 0.0f, nullptr, nullptr,
72 SkBlurImageFilter::kClamp_TileMode));
wutao0dc1f4f2017-06-26 15:03:55 -070073 draw_image(canvas, image, std::move(filter));
74 canvas->translate(image->width() + 20, 0);
75
wutao039a7c72017-06-30 10:44:45 -070076 filter = SkBlurImageFilter::Make(0.0f, sigma, nullptr, nullptr,
77 SkBlurImageFilter::kClamp_TileMode);
wutao0dc1f4f2017-06-26 15:03:55 -070078 draw_image(canvas, image, std::move(filter));
79 canvas->translate(image->width() + 20, 0);
80
wutao039a7c72017-06-30 10:44:45 -070081 filter = SkBlurImageFilter::Make(sigma, sigma, nullptr, nullptr,
82 SkBlurImageFilter::kClamp_TileMode);
wutao0dc1f4f2017-06-26 15:03:55 -070083 draw_image(canvas, image, std::move(filter));
84 canvas->translate(image->width() + 20, 0);
85
86 canvas->restore();
87 canvas->translate(0, image->height() + 20);
88 }
89 }
90
91private:
92 typedef GM INHERITED;
93};
94
95//////////////////////////////////////////////////////////////////////////////
96
97DEF_GM(return new ImageBlurClampModeGM;)
98}