blob: df48c007d7008953c640819b367ac844b8f583eb [file] [log] [blame]
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +00001/*
2 * Copyright 2014 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
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "gm/gm.h"
Ben Wagner7fde8e12019-05-01 17:28:53 -04009#include "include/core/SkBitmap.h"
10#include "include/core/SkCanvas.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050011#include "include/core/SkColor.h"
Ben Wagner7fde8e12019-05-01 17:28:53 -040012#include "include/core/SkFilterQuality.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050013#include "include/core/SkImage.h"
Ben Wagner7fde8e12019-05-01 17:28:53 -040014#include "include/core/SkImageFilter.h"
15#include "include/core/SkMatrix.h"
16#include "include/core/SkPaint.h"
17#include "include/core/SkPoint.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050018#include "include/core/SkPoint3.h"
Ben Wagner7fde8e12019-05-01 17:28:53 -040019#include "include/core/SkRect.h"
20#include "include/core/SkRefCnt.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050021#include "include/core/SkScalar.h"
Ben Wagner7fde8e12019-05-01 17:28:53 -040022#include "include/core/SkShader.h"
23#include "include/core/SkSize.h"
24#include "include/core/SkString.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050025#include "include/core/SkSurface.h"
Ben Wagner7fde8e12019-05-01 17:28:53 -040026#include "include/core/SkTileMode.h"
27#include "include/core/SkTypes.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050028#include "include/effects/SkGradientShader.h"
Michael Ludwig898bbfa2019-08-02 15:21:23 -040029#include "include/effects/SkImageFilters.h"
Mike Kleinc0bd9f92019-04-23 12:05:21 -050030#include "include/effects/SkPerlinNoiseShader.h"
31#include "tools/ToolUtils.h"
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +000032
Ben Wagner7fde8e12019-05-01 17:28:53 -040033#include <utility>
34
senorblanco@chromium.org897b73f2014-02-19 22:10:12 +000035#define RESIZE_FACTOR_X SkIntToScalar(2)
36#define RESIZE_FACTOR_Y SkIntToScalar(5)
37
robertphillips549c8992016-04-01 09:28:51 -070038static sk_sp<SkImage> make_gradient_circle(int width, int height) {
39 SkScalar x = SkIntToScalar(width / 2);
40 SkScalar y = SkIntToScalar(height / 2);
Brian Osman116b33e2020-02-05 13:34:09 -050041 SkScalar radius = std::min(x, y) * 0.8f;
robertphillips549c8992016-04-01 09:28:51 -070042 auto surface(SkSurface::MakeRasterN32Premul(width, height));
43 SkCanvas* canvas = surface->getCanvas();
44 canvas->clear(0x00000000);
45 SkColor colors[2];
46 colors[0] = SK_ColorWHITE;
47 colors[1] = SK_ColorBLACK;
48 SkPaint paint;
49 paint.setShader(SkGradientShader::MakeRadial(SkPoint::Make(x, y), radius, colors, nullptr,
Mike Reedfae8fce2019-04-03 10:27:45 -040050 2, SkTileMode::kClamp));
robertphillips549c8992016-04-01 09:28:51 -070051 canvas->drawCircle(x, y, radius, paint);
52 return surface->makeImageSnapshot();
53}
54
robertphillips12fa47d2016-04-08 16:28:09 -070055static void draw_clipped_filter(SkCanvas* canvas, sk_sp<SkImageFilter> filter, size_t i,
robertphillips549c8992016-04-01 09:28:51 -070056 const SkRect& primBounds, const SkRect& clipBounds) {
57 SkPaint paint;
58 paint.setColor(SK_ColorWHITE);
robertphillips12fa47d2016-04-08 16:28:09 -070059 paint.setImageFilter(std::move(filter));
robertphillips549c8992016-04-01 09:28:51 -070060 paint.setAntiAlias(true);
61 canvas->save();
62 canvas->clipRect(clipBounds);
63 if (5 == i) {
64 canvas->translate(SkIntToScalar(16), SkIntToScalar(-32));
65 } else if (6 == i) {
66 canvas->scale(SkScalarInvert(RESIZE_FACTOR_X), SkScalarInvert(RESIZE_FACTOR_Y));
67 }
68 canvas->drawCircle(primBounds.centerX(), primBounds.centerY(),
69 primBounds.width() * 2 / 5, paint);
70 canvas->restore();
71}
72
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +000073namespace skiagm {
74
75class ImageFiltersClippedGM : public GM {
76public:
robertphillips943a4622015-09-03 13:32:33 -070077 ImageFiltersClippedGM() {
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +000078 this->setBGColor(0x00000000);
79 }
80
81protected:
mtklein36352bf2015-03-25 18:17:31 -070082 SkString onShortName() override {
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +000083 return SkString("imagefiltersclipped");
84 }
85
mtklein36352bf2015-03-25 18:17:31 -070086 SkISize onISize() override {
tfarinaf5393182014-06-09 23:59:03 -070087 return SkISize::Make(860, 500);
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +000088 }
89
robertphillips943a4622015-09-03 13:32:33 -070090 void onOnceBeforeDraw() override {
Mike Kleinea3f0142019-03-20 11:12:10 -050091 fCheckerboard = SkImage::MakeFromBitmap(
92 ToolUtils::create_checkerboard_bitmap(64, 64, 0xFFA0A0A0, 0xFF404040, 8));
robertphillips549c8992016-04-01 09:28:51 -070093 fGradientCircle = make_gradient_circle(64, 64);
robertphillips943a4622015-09-03 13:32:33 -070094 }
halcanary878fa022015-01-26 11:24:32 -080095
robertphillips943a4622015-09-03 13:32:33 -070096 void onDraw(SkCanvas* canvas) override {
senorblanco16b254a2015-04-09 11:13:24 -070097 canvas->clear(SK_ColorBLACK);
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +000098
Michael Ludwig898bbfa2019-08-02 15:21:23 -040099 sk_sp<SkImageFilter> gradient(SkImageFilters::Image(fGradientCircle));
100 sk_sp<SkImageFilter> checkerboard(SkImageFilters::Image(fCheckerboard));
senorblanco@chromium.orgfd0ec2c2014-03-25 17:35:10 +0000101 SkMatrix resizeMatrix;
102 resizeMatrix.setScale(RESIZE_FACTOR_X, RESIZE_FACTOR_Y);
senorblanco7b7ecfc2015-08-26 14:26:40 -0700103 SkPoint3 pointLocation = SkPoint3::Make(32, 32, SkIntToScalar(10));
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +0000104
robertphillips12fa47d2016-04-08 16:28:09 -0700105 sk_sp<SkImageFilter> filters[] = {
Michael Ludwig898bbfa2019-08-02 15:21:23 -0400106 SkImageFilters::Blur(SkIntToScalar(12), SkIntToScalar(12), nullptr),
107 SkImageFilters::DropShadow(SkIntToScalar(10), SkIntToScalar(10),
108 SkIntToScalar(3), SkIntToScalar(3), SK_ColorGREEN, nullptr),
109 SkImageFilters::DisplacementMap(SkColorChannel::kR, SkColorChannel::kR,
110 SkIntToScalar(12), std::move(gradient), checkerboard),
111 SkImageFilters::Dilate(2, 2, checkerboard),
112 SkImageFilters::Erode(2, 2, checkerboard),
113 SkImageFilters::Offset(SkIntToScalar(-16), SkIntToScalar(32), nullptr),
114 SkImageFilters::MatrixTransform(resizeMatrix, kNone_SkFilterQuality, nullptr),
115 SkImageFilters::PointLitDiffuse(pointLocation, SK_ColorWHITE, SK_Scalar1,
116 SkIntToScalar(2), checkerboard),
senorblanco7b7ecfc2015-08-26 14:26:40 -0700117
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +0000118 };
119
120 SkRect r = SkRect::MakeWH(SkIntToScalar(64), SkIntToScalar(64));
121 SkScalar margin = SkIntToScalar(16);
122 SkRect bounds = r;
123 bounds.outset(margin, margin);
124
jvanverth02781972015-07-21 08:38:06 -0700125 canvas->save();
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +0000126 for (int xOffset = 0; xOffset < 80; xOffset += 16) {
127 canvas->save();
128 bounds.fLeft = SkIntToScalar(xOffset);
129 for (size_t i = 0; i < SK_ARRAY_COUNT(filters); ++i) {
jvanverth02781972015-07-21 08:38:06 -0700130 draw_clipped_filter(canvas, filters[i], i, r, bounds);
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +0000131 canvas->translate(r.width() + margin, 0);
132 }
133 canvas->restore();
134 canvas->translate(0, r.height() + margin);
135 }
jvanverth02781972015-07-21 08:38:06 -0700136 canvas->restore();
senorblanco@chromium.org67117802014-02-06 00:36:01 +0000137
ajuma77b6ba32016-01-08 14:58:35 -0800138 SkPaint noisePaint;
robertphillips549c8992016-04-01 09:28:51 -0700139 noisePaint.setShader(SkPerlinNoiseShader::MakeFractalNoise(0.1f, 0.05f, 1, 0));
140
Michael Ludwig898bbfa2019-08-02 15:21:23 -0400141 sk_sp<SkImageFilter> rectFilter(SkImageFilters::Paint(noisePaint));
jvanverth02781972015-07-21 08:38:06 -0700142 canvas->translate(SK_ARRAY_COUNT(filters)*(r.width() + margin), 0);
143 for (int xOffset = 0; xOffset < 80; xOffset += 16) {
144 bounds.fLeft = SkIntToScalar(xOffset);
robertphillips12fa47d2016-04-08 16:28:09 -0700145 draw_clipped_filter(canvas, rectFilter, 0, r, bounds);
jvanverth02781972015-07-21 08:38:06 -0700146 canvas->translate(0, r.height() + margin);
147 }
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +0000148 }
149
150private:
reed9ce9d672016-03-17 10:51:11 -0700151 sk_sp<SkImage> fCheckerboard, fGradientCircle;
robertphillips943a4622015-09-03 13:32:33 -0700152
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +0000153 typedef GM INHERITED;
154};
155
156//////////////////////////////////////////////////////////////////////////////
157
robertphillips943a4622015-09-03 13:32:33 -0700158DEF_GM(return new ImageFiltersClippedGM;)
senorblanco@chromium.orgc4b12f12014-02-05 17:51:22 +0000159}