Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(50)

Unified Diff: gm/imagefilterstransformed.cpp

Issue 986623003: Implement support for non-scale/translate CTM in image filters. Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Update to latest rev of SkMatrixImageFilter move Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | gyp/gmslides.gypi » ('j') | src/core/SkCanvas.cpp » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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);
}
« no previous file with comments | « no previous file | gyp/gmslides.gypi » ('j') | src/core/SkCanvas.cpp » ('J')

Powered by Google App Engine
This is Rietveld 408576698