Chromium Code Reviews| Index: gm/imagefilterstransformed.cpp |
| diff --git a/gm/imagefiltersclipped.cpp b/gm/imagefilterstransformed.cpp |
| similarity index 59% |
| copy from gm/imagefiltersclipped.cpp |
| copy to gm/imagefilterstransformed.cpp |
| index 9b91929e3a17b6878fe9fd27eb8caf101683731f..d7e012ec8669ff7d6aa04e82dc63452920999647 100644 |
| --- a/gm/imagefiltersclipped.cpp |
| +++ b/gm/imagefilterstransformed.cpp |
| @@ -1,5 +1,5 @@ |
| /* |
| - * Copyright 2014 Google Inc. |
| + * Copyright 2015 Google Inc. |
| * |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| @@ -13,31 +13,25 @@ |
| #include "SkDropShadowImageFilter.h" |
| #include "SkGradientShader.h" |
| #include "SkMorphologyImageFilter.h" |
| -#include "SkOffsetImageFilter.h" |
| -#include "SkPerlinNoiseShader.h" |
| -#include "SkRectShaderImageFilter.h" |
| #include "SkScalar.h" |
| #include "gm.h" |
| -#define RESIZE_FACTOR_X SkIntToScalar(2) |
| -#define RESIZE_FACTOR_Y SkIntToScalar(5) |
| - |
| namespace skiagm { |
|
robertphillips
2015/03/20 14:01:09
// This GM checks that the scale portion of the ap
Stephen White
2015/03/20 14:19:08
Done (with tweaks).
|
| -class ImageFiltersClippedGM : public GM { |
| +class ImageFiltersTransformedGM : public GM { |
| public: |
| - ImageFiltersClippedGM() : fInitialized(false) { |
| - this->setBGColor(0x00000000); |
| + ImageFiltersTransformedGM() : fInitialized(false) { |
| + this->setBGColor(SK_ColorBLACK); |
| } |
| protected: |
|
robertphillips
2015/03/20 14:01:09
one line ?
Stephen White
2015/03/20 14:19:08
Done.
|
| SkString onShortName() SK_OVERRIDE { |
| - return SkString("imagefiltersclipped"); |
| + return SkString("imagefilterstransformed"); |
| } |
|
robertphillips
2015/03/20 14:01:09
one line ?
Stephen White
2015/03/20 14:19:08
Done.
|
| SkISize onISize() SK_OVERRIDE { |
| - return SkISize::Make(860, 500); |
| + return SkISize::Make(560, 300); |
| } |
|
robertphillips
2015/03/20 14:01:09
makeGradientCircle ?
Stephen White
2015/03/20 14:19:08
Done.
|
| void make_gradient_circle(int width, int height) { |
| @@ -68,60 +62,49 @@ protected: |
| this->make_gradient_circle(64, 64); |
| fInitialized = true; |
| } |
| - canvas->clear(0x00000000); |
| + |
| + canvas->clear(SK_ColorBLACK); |
| SkAutoTUnref<SkImageFilter> gradient(SkBitmapSource::Create(fGradientCircle)); |
| SkAutoTUnref<SkImageFilter> checkerboard(SkBitmapSource::Create(fCheckerboard)); |
| - SkAutoTUnref<SkShader> noise(SkPerlinNoiseShader::CreateFractalNoise( |
| - SkDoubleToScalar(0.1), SkDoubleToScalar(0.05), 1, 0)); |
| - SkMatrix resizeMatrix; |
| - resizeMatrix.setScale(RESIZE_FACTOR_X, RESIZE_FACTOR_Y); |
| - |
| SkImageFilter* filters[] = { |
| - SkBlurImageFilter::Create(SkIntToScalar(12), SkIntToScalar(12)), |
| - SkDropShadowImageFilter::Create(SkIntToScalar(10), SkIntToScalar(10), |
| - SkIntToScalar(3), SkIntToScalar(3), SK_ColorGREEN, |
| + SkBlurImageFilter::Create(12, 0), |
| + SkDropShadowImageFilter::Create(0, 15, 8, 0, SK_ColorGREEN, |
| SkDropShadowImageFilter::kDrawShadowAndForeground_ShadowMode), |
| SkDisplacementMapEffect::Create(SkDisplacementMapEffect::kR_ChannelSelectorType, |
| SkDisplacementMapEffect::kR_ChannelSelectorType, |
| - SkIntToScalar(12), |
| + 12, |
| gradient.get(), |
| checkerboard.get()), |
| SkDilateImageFilter::Create(2, 2, checkerboard.get()), |
| SkErodeImageFilter::Create(2, 2, checkerboard.get()), |
| - SkOffsetImageFilter::Create(SkIntToScalar(-16), SkIntToScalar(32)), |
| - SkImageFilter::CreateMatrixFilter(resizeMatrix, kNone_SkFilterQuality), |
| - SkRectShaderImageFilter::Create(noise), |
| }; |
|
robertphillips
2015/03/20 14:01:09
Can we make these two guys const ?
Stephen White
2015/03/20 14:19:08
Done.
|
| - SkRect r = SkRect::MakeWH(SkIntToScalar(64), SkIntToScalar(64)); |
| - SkScalar margin = SkIntToScalar(16); |
| - SkRect bounds = r; |
| - bounds.outset(margin, margin); |
| + SkScalar margin = SkIntToScalar(40); |
| + SkScalar size = SkIntToScalar(60); |
| - for (int xOffset = 0; xOffset < 80; xOffset += 16) { |
| + for (size_t j = 0; j < 3; j++) { |
| canvas->save(); |
| - bounds.fLeft = SkIntToScalar(xOffset); |
| + canvas->translate(margin, 0); |
| for (size_t i = 0; i < SK_ARRAY_COUNT(filters); ++i) { |
| SkPaint paint; |
| paint.setColor(SK_ColorWHITE); |
| paint.setImageFilter(filters[i]); |
| paint.setAntiAlias(true); |
| canvas->save(); |
| - canvas->clipRect(bounds); |
| - if (5 == i) { |
| - canvas->translate(SkIntToScalar(16), SkIntToScalar(-32)); |
| - } else if (6 == i) { |
| - canvas->scale(SkScalarInvert(RESIZE_FACTOR_X), |
| - SkScalarInvert(RESIZE_FACTOR_Y)); |
| + canvas->translate(size * 0.5, size * 0.5); |
| + if (j == 1) { |
| + canvas->rotate(SkIntToScalar(45)); |
| + } else if (j == 2) { |
| + canvas->skew(0.5, 0.2); |
| } |
| - canvas->drawCircle(r.centerX(), r.centerY(), |
| - SkScalarDiv(r.width()*2, SkIntToScalar(5)), paint); |
| + canvas->translate(-size * 0.5, -size * 0.5); |
| + canvas->drawOval(SkRect::MakeXYWH(0, size * 0.1, size, size * 0.6), paint); |
| canvas->restore(); |
| - canvas->translate(r.width() + margin, 0); |
| + canvas->translate(size + margin, 0); |
| } |
| canvas->restore(); |
| - canvas->translate(0, r.height() + margin); |
| + canvas->translate(0, size + margin); |
| } |
| for (size_t i = 0; i < SK_ARRAY_COUNT(filters); ++i) { |
| @@ -138,7 +121,7 @@ private: |
| ////////////////////////////////////////////////////////////////////////////// |
|
robertphillips
2015/03/20 14:01:09
Use DEF_GM macro ?
Stephen White
2015/03/20 14:19:08
Done.
|
| -static GM* MyFactory(void*) { return new ImageFiltersClippedGM; } |
| +static GM* MyFactory(void*) { return new ImageFiltersTransformedGM; } |
| static GMRegistry reg(MyFactory); |
| } |