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

Side by Side Diff: tests/ImageFilterTest.cpp

Issue 1343123002: Convert unit tests, GMs from SkBitmapSource to SkImagesource (Closed) Base URL: https://chromium.googlesource.com/skia.git@master
Patch Set: Created 5 years, 3 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2013 Google Inc. 2 * Copyright 2013 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #include "SkBitmap.h" 8 #include "SkBitmap.h"
9 #include "SkBitmapDevice.h" 9 #include "SkBitmapDevice.h"
10 #include "SkBitmapSource.h"
11 #include "SkBlurImageFilter.h" 10 #include "SkBlurImageFilter.h"
12 #include "SkCanvas.h" 11 #include "SkCanvas.h"
13 #include "SkColorFilterImageFilter.h" 12 #include "SkColorFilterImageFilter.h"
14 #include "SkColorMatrixFilter.h" 13 #include "SkColorMatrixFilter.h"
15 #include "SkComposeImageFilter.h" 14 #include "SkComposeImageFilter.h"
16 #include "SkDisplacementMapEffect.h" 15 #include "SkDisplacementMapEffect.h"
17 #include "SkDropShadowImageFilter.h" 16 #include "SkDropShadowImageFilter.h"
18 #include "SkFlattenableSerialization.h" 17 #include "SkFlattenableSerialization.h"
19 #include "SkGradientShader.h" 18 #include "SkGradientShader.h"
19 #include "SkImage.h"
20 #include "SkImageSource.h" 20 #include "SkImageSource.h"
21 #include "SkLightingImageFilter.h" 21 #include "SkLightingImageFilter.h"
22 #include "SkMatrixConvolutionImageFilter.h" 22 #include "SkMatrixConvolutionImageFilter.h"
23 #include "SkMergeImageFilter.h" 23 #include "SkMergeImageFilter.h"
24 #include "SkMorphologyImageFilter.h" 24 #include "SkMorphologyImageFilter.h"
25 #include "SkOffsetImageFilter.h" 25 #include "SkOffsetImageFilter.h"
26 #include "SkPerlinNoiseShader.h" 26 #include "SkPerlinNoiseShader.h"
27 #include "SkPicture.h" 27 #include "SkPicture.h"
28 #include "SkPictureImageFilter.h" 28 #include "SkPictureImageFilter.h"
29 #include "SkPictureRecorder.h" 29 #include "SkPictureRecorder.h"
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after
85 return new MatrixTestImageFilter(reporter, matrix); 85 return new MatrixTestImageFilter(reporter, matrix);
86 } 86 }
87 87
88 #ifndef SK_IGNORE_TO_STRING 88 #ifndef SK_IGNORE_TO_STRING
89 void MatrixTestImageFilter::toString(SkString* str) const { 89 void MatrixTestImageFilter::toString(SkString* str) const {
90 str->appendf("MatrixTestImageFilter: ("); 90 str->appendf("MatrixTestImageFilter: (");
91 str->append(")"); 91 str->append(")");
92 } 92 }
93 #endif 93 #endif
94 94
95 static void make_small_bitmap(SkBitmap& bitmap) { 95 static SkImage* make_small_image() {
96 bitmap.allocN32Pixels(kBitmapSize, kBitmapSize); 96 SkAutoTUnref<SkSurface> surface(SkSurface::NewRasterN32Premul(kBitmapSize, k BitmapSize));
97 SkCanvas canvas(bitmap); 97 SkCanvas* canvas = surface->getCanvas();
98 canvas.clear(0x00000000); 98 canvas->clear(0x00000000);
99 SkPaint darkPaint; 99 SkPaint darkPaint;
100 darkPaint.setColor(0xFF804020); 100 darkPaint.setColor(0xFF804020);
101 SkPaint lightPaint; 101 SkPaint lightPaint;
102 lightPaint.setColor(0xFF244484); 102 lightPaint.setColor(0xFF244484);
103 const int i = kBitmapSize / 4; 103 const int i = kBitmapSize / 4;
104 for (int y = 0; y < kBitmapSize; y += i) { 104 for (int y = 0; y < kBitmapSize; y += i) {
105 for (int x = 0; x < kBitmapSize; x += i) { 105 for (int x = 0; x < kBitmapSize; x += i) {
106 canvas.save(); 106 canvas->save();
107 canvas.translate(SkIntToScalar(x), SkIntToScalar(y)); 107 canvas->translate(SkIntToScalar(x), SkIntToScalar(y));
108 canvas.drawRect(SkRect::MakeXYWH(0, 0, 108 canvas->drawRect(SkRect::MakeXYWH(0, 0,
109 SkIntToScalar(i), 109 SkIntToScalar(i),
110 SkIntToScalar(i)), darkPaint); 110 SkIntToScalar(i)), darkPaint);
111 canvas.drawRect(SkRect::MakeXYWH(SkIntToScalar(i), 111 canvas->drawRect(SkRect::MakeXYWH(SkIntToScalar(i),
112 0, 112 0,
113 SkIntToScalar(i), 113 SkIntToScalar(i),
114 SkIntToScalar(i)), lightPaint); 114 SkIntToScalar(i)), lightPaint);
115 canvas.drawRect(SkRect::MakeXYWH(0, 115 canvas->drawRect(SkRect::MakeXYWH(0,
116 SkIntToScalar(i), 116 SkIntToScalar(i),
117 SkIntToScalar(i), 117 SkIntToScalar(i),
118 SkIntToScalar(i)), lightPaint); 118 SkIntToScalar(i)), lightPaint);
119 canvas.drawRect(SkRect::MakeXYWH(SkIntToScalar(i), 119 canvas->drawRect(SkRect::MakeXYWH(SkIntToScalar(i),
120 SkIntToScalar(i), 120 SkIntToScalar(i),
121 SkIntToScalar(i), 121 SkIntToScalar(i),
122 SkIntToScalar(i)), darkPaint); 122 SkIntToScalar(i)), darkPaint);
123 canvas.restore(); 123 canvas->restore();
124 } 124 }
125 } 125 }
126
127 return surface->newImageSnapshot();
126 } 128 }
127 129
128 static SkImageFilter* make_scale(float amount, SkImageFilter* input = nullptr) { 130 static SkImageFilter* make_scale(float amount, SkImageFilter* input = nullptr) {
129 SkScalar s = amount; 131 SkScalar s = amount;
130 SkScalar matrix[20] = { s, 0, 0, 0, 0, 132 SkScalar matrix[20] = { s, 0, 0, 0, 0,
131 0, s, 0, 0, 0, 133 0, s, 0, 0, 0,
132 0, 0, s, 0, 0, 134 0, 0, s, 0, 0,
133 0, 0, 0, s, 0 }; 135 0, 0, 0, s, 0 };
134 SkAutoTUnref<SkColorFilter> filter(SkColorMatrixFilter::Create(matrix)); 136 SkAutoTUnref<SkColorFilter> filter(SkColorMatrixFilter::Create(matrix));
135 return SkColorFilterImageFilter::Create(filter, input); 137 return SkColorFilterImageFilter::Create(filter, input);
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after
234 canvas.clear(0x0); 236 canvas.clear(0x0);
235 SkRect rect = SkRect::Make(SkIRect::MakeWH(kBitmapSize, kBitmapSize)); 237 SkRect rect = SkRect::Make(SkIRect::MakeWH(kBitmapSize, kBitmapSize));
236 canvas.drawRect(rect, paint); 238 canvas.drawRect(rect, paint);
237 uint32_t pixel = *result.getAddr32(0, 0); 239 uint32_t pixel = *result.getAddr32(0, 0);
238 // The result here should be green, since we have effectively shifted bl ue to green. 240 // The result here should be green, since we have effectively shifted bl ue to green.
239 REPORTER_ASSERT(reporter, pixel == SK_ColorGREEN); 241 REPORTER_ASSERT(reporter, pixel == SK_ColorGREEN);
240 } 242 }
241 243
242 { 244 {
243 // Tests pass by not asserting 245 // Tests pass by not asserting
244 SkBitmap bitmap, result; 246 SkAutoTUnref<SkImage> image(make_small_image());
245 make_small_bitmap(bitmap); 247 SkBitmap result;
246 result.allocN32Pixels(kBitmapSize, kBitmapSize); 248 result.allocN32Pixels(kBitmapSize, kBitmapSize);
247 249
248 { 250 {
249 // This tests for : 251 // This tests for :
250 // 1 ) location at (0,0,1) 252 // 1 ) location at (0,0,1)
251 SkPoint3 location = SkPoint3::Make(0, 0, SK_Scalar1); 253 SkPoint3 location = SkPoint3::Make(0, 0, SK_Scalar1);
252 // 2 ) location and target at same value 254 // 2 ) location and target at same value
253 SkPoint3 target = SkPoint3::Make(location.fX, location.fY, location. fZ); 255 SkPoint3 target = SkPoint3::Make(location.fX, location.fY, location. fZ);
254 // 3 ) large negative specular exponent value 256 // 3 ) large negative specular exponent value
255 SkScalar specularExponent = -1000; 257 SkScalar specularExponent = -1000;
256 258
257 SkAutoTUnref<SkImageFilter> bmSrc(SkBitmapSource::Create(bitmap)); 259 SkAutoTUnref<SkImageFilter> bmSrc(SkImageSource::Create(image));
258 SkPaint paint; 260 SkPaint paint;
259 paint.setImageFilter(SkLightingImageFilter::CreateSpotLitSpecular( 261 paint.setImageFilter(SkLightingImageFilter::CreateSpotLitSpecular(
260 location, target, specularExponent, 180, 262 location, target, specularExponent, 180,
261 0xFFFFFFFF, SK_Scalar1, SK_Scalar1, SK_Scalar1, 263 0xFFFFFFFF, SK_Scalar1, SK_Scalar1, SK_Scalar1,
262 bmSrc))->unref(); 264 bmSrc))->unref();
263 SkCanvas canvas(result); 265 SkCanvas canvas(result);
264 SkRect r = SkRect::MakeWH(SkIntToScalar(kBitmapSize), 266 SkRect r = SkRect::MakeWH(SkIntToScalar(kBitmapSize),
265 SkIntToScalar(kBitmapSize)); 267 SkIntToScalar(kBitmapSize));
266 canvas.drawRect(r, paint); 268 canvas.drawRect(r, paint);
267 } 269 }
(...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after
417 SkPoint3 location = SkPoint3::Make(0, 0, SK_Scalar1); 419 SkPoint3 location = SkPoint3::Make(0, 0, SK_Scalar1);
418 SkScalar kernel[9] = { 420 SkScalar kernel[9] = {
419 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1), 421 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1),
420 SkIntToScalar( 1), SkIntToScalar(-7), SkIntToScalar( 1), 422 SkIntToScalar( 1), SkIntToScalar(-7), SkIntToScalar( 1),
421 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1), 423 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1),
422 }; 424 };
423 SkISize kernelSize = SkISize::Make(3, 3); 425 SkISize kernelSize = SkISize::Make(3, 3);
424 SkScalar gain = SK_Scalar1, bias = 0; 426 SkScalar gain = SK_Scalar1, bias = 0;
425 SkScalar five = SkIntToScalar(5); 427 SkScalar five = SkIntToScalar(5);
426 428
427 SkAutoTUnref<SkImageFilter> gradient_source(SkBitmapSource::Create(make_grad ient_circle(64, 64))); 429 SkAutoTUnref<SkImage> gradientImage(SkImage::NewFromBitmap(make_gradient_cir cle(64, 64)));
robertphillips 2015/09/15 17:43:52 gradientSource ?
f(malita) 2015/09/15 18:12:54 Done.
430 SkAutoTUnref<SkImageFilter> gradient_source(SkImageSource::Create(gradientIm age));
428 SkAutoTUnref<SkImageFilter> blur(SkBlurImageFilter::Create(five, five)); 431 SkAutoTUnref<SkImageFilter> blur(SkBlurImageFilter::Create(five, five));
429 SkMatrix matrix; 432 SkMatrix matrix;
430 433
431 matrix.setTranslate(SK_Scalar1, SK_Scalar1); 434 matrix.setTranslate(SK_Scalar1, SK_Scalar1);
432 matrix.postRotate(SkIntToScalar(45), SK_Scalar1, SK_Scalar1); 435 matrix.postRotate(SkIntToScalar(45), SK_Scalar1, SK_Scalar1);
433 436
434 SkRTreeFactory factory; 437 SkRTreeFactory factory;
435 SkPictureRecorder recorder; 438 SkPictureRecorder recorder;
436 SkCanvas* recordingCanvas = recorder.beginRecording(64, 64, &factory, 0); 439 SkCanvas* recordingCanvas = recorder.beginRecording(64, 64, &factory, 0);
437 440
(...skipping 867 matching lines...) Expand 10 before | Expand all | Expand 10 after
1305 SkSurface::kNo_Budgeted , 1308 SkSurface::kNo_Budgeted ,
1306 SkImageInfo::MakeN32Pre mul(1, 1), 1309 SkImageInfo::MakeN32Pre mul(1, 1),
1307 0, 1310 0,
1308 &props, 1311 &props,
1309 SkGpuDevice::kUninit_In itContents)); 1312 SkGpuDevice::kUninit_In itContents));
1310 SkImageFilter::Proxy proxy(device); 1313 SkImageFilter::Proxy proxy(device);
1311 1314
1312 test_negative_blur_sigma(&proxy, reporter); 1315 test_negative_blur_sigma(&proxy, reporter);
1313 } 1316 }
1314 #endif 1317 #endif
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698