| OLD | NEW |
| 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 "SkBlurImageFilter.h" | 10 #include "SkBlurImageFilter.h" |
| (...skipping 336 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 347 ); | 347 ); |
| 348 SkPaint paint; | 348 SkPaint paint; |
| 349 paint.setShader(shader); | 349 paint.setShader(shader); |
| 350 canvas.drawCircle(x, y, radius, paint); | 350 canvas.drawCircle(x, y, radius, paint); |
| 351 return bitmap; | 351 return bitmap; |
| 352 } | 352 } |
| 353 | 353 |
| 354 static void test_negative_blur_sigma(SkImageFilter::Proxy* proxy, skiatest::Repo
rter* reporter) { | 354 static void test_negative_blur_sigma(SkImageFilter::Proxy* proxy, skiatest::Repo
rter* reporter) { |
| 355 // Check that SkBlurImageFilter will accept a negative sigma, either in | 355 // Check that SkBlurImageFilter will accept a negative sigma, either in |
| 356 // the given arguments or after CTM application. | 356 // the given arguments or after CTM application. |
| 357 const int width = 32, height = 32; | 357 int width = 32, height = 32; |
| 358 const SkScalar five = SkIntToScalar(5); | 358 SkScalar five = SkIntToScalar(5); |
| 359 | 359 |
| 360 SkAutoTUnref<SkImageFilter> positiveFilter(SkBlurImageFilter::Create(five, f
ive)); | 360 SkAutoTUnref<SkBlurImageFilter> positiveFilter( |
| 361 SkAutoTUnref<SkImageFilter> negativeFilter(SkBlurImageFilter::Create(-five,
five)); | 361 SkBlurImageFilter::Create(five, five) |
| 362 ); |
| 363 |
| 364 SkAutoTUnref<SkBlurImageFilter> negativeFilter( |
| 365 SkBlurImageFilter::Create(-five, five) |
| 366 ); |
| 362 | 367 |
| 363 SkBitmap gradient = make_gradient_circle(width, height); | 368 SkBitmap gradient = make_gradient_circle(width, height); |
| 364 SkBitmap positiveResult1, negativeResult1; | 369 SkBitmap positiveResult1, negativeResult1; |
| 365 SkBitmap positiveResult2, negativeResult2; | 370 SkBitmap positiveResult2, negativeResult2; |
| 366 SkIPoint offset; | 371 SkIPoint offset; |
| 367 SkImageFilter::Context ctx(SkMatrix::I(), SkIRect::MakeLargest(), nullptr); | 372 SkImageFilter::Context ctx(SkMatrix::I(), SkIRect::MakeLargest(), nullptr); |
| 368 positiveFilter->filterImage(proxy, gradient, ctx, &positiveResult1, &offset)
; | 373 positiveFilter->filterImage(proxy, gradient, ctx, &positiveResult1, &offset)
; |
| 369 negativeFilter->filterImage(proxy, gradient, ctx, &negativeResult1, &offset)
; | 374 negativeFilter->filterImage(proxy, gradient, ctx, &negativeResult1, &offset)
; |
| 370 SkMatrix negativeScale; | 375 SkMatrix negativeScale; |
| 371 negativeScale.setScale(-SK_Scalar1, SK_Scalar1); | 376 negativeScale.setScale(-SK_Scalar1, SK_Scalar1); |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 410 // match the same filters drawn with a single full-canvas bitmap draw. | 415 // match the same filters drawn with a single full-canvas bitmap draw. |
| 411 // Tests pass by not asserting. | 416 // Tests pass by not asserting. |
| 412 | 417 |
| 413 SkAutoTUnref<SkColorFilter> cf(SkColorFilter::CreateModeFilter(SK_ColorRED,
SkXfermode::kSrcIn_Mode)); | 418 SkAutoTUnref<SkColorFilter> cf(SkColorFilter::CreateModeFilter(SK_ColorRED,
SkXfermode::kSrcIn_Mode)); |
| 414 SkPoint3 location = SkPoint3::Make(0, 0, SK_Scalar1); | 419 SkPoint3 location = SkPoint3::Make(0, 0, SK_Scalar1); |
| 415 SkScalar kernel[9] = { | 420 SkScalar kernel[9] = { |
| 416 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1), | 421 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1), |
| 417 SkIntToScalar( 1), SkIntToScalar(-7), SkIntToScalar( 1), | 422 SkIntToScalar( 1), SkIntToScalar(-7), SkIntToScalar( 1), |
| 418 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1), | 423 SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1), |
| 419 }; | 424 }; |
| 420 const SkISize kernelSize = SkISize::Make(3, 3); | 425 SkISize kernelSize = SkISize::Make(3, 3); |
| 421 const SkScalar gain = SK_Scalar1, bias = 0; | 426 SkScalar gain = SK_Scalar1, bias = 0; |
| 422 const SkScalar five = SkIntToScalar(5); | 427 SkScalar five = SkIntToScalar(5); |
| 423 | 428 |
| 424 SkAutoTUnref<SkImage> gradientImage(SkImage::NewFromBitmap(make_gradient_cir
cle(64, 64))); | 429 SkAutoTUnref<SkImage> gradientImage(SkImage::NewFromBitmap(make_gradient_cir
cle(64, 64))); |
| 425 SkAutoTUnref<SkImageFilter> gradientSource(SkImageSource::Create(gradientIma
ge)); | 430 SkAutoTUnref<SkImageFilter> gradientSource(SkImageSource::Create(gradientIma
ge)); |
| 426 SkAutoTUnref<SkImageFilter> blur(SkBlurImageFilter::Create(five, five)); | 431 SkAutoTUnref<SkImageFilter> blur(SkBlurImageFilter::Create(five, five)); |
| 427 SkMatrix matrix; | 432 SkMatrix matrix; |
| 428 | 433 |
| 429 matrix.setTranslate(SK_Scalar1, SK_Scalar1); | 434 matrix.setTranslate(SK_Scalar1, SK_Scalar1); |
| 430 matrix.postRotate(SkIntToScalar(45), SK_Scalar1, SK_Scalar1); | 435 matrix.postRotate(SkIntToScalar(45), SK_Scalar1, SK_Scalar1); |
| 431 | 436 |
| 432 SkRTreeFactory factory; | 437 SkRTreeFactory factory; |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 477 { "erode", SkErodeImageFilter::Create(2, 3) }, | 482 { "erode", SkErodeImageFilter::Create(2, 3) }, |
| 478 { "tile", SkTileImageFilter::Create(SkRect::MakeXYWH(0, 0, 50, 50), | 483 { "tile", SkTileImageFilter::Create(SkRect::MakeXYWH(0, 0, 50, 50), |
| 479 SkRect::MakeXYWH(0, 0, 100, 100), nu
llptr) }, | 484 SkRect::MakeXYWH(0, 0, 100, 100), nu
llptr) }, |
| 480 { "matrix", SkImageFilter::CreateMatrixFilter(matrix, kLow_SkFilterQuali
ty) }, | 485 { "matrix", SkImageFilter::CreateMatrixFilter(matrix, kLow_SkFilterQuali
ty) }, |
| 481 { "blur and offset", SkOffsetImageFilter::Create(five, five, blur.get())
}, | 486 { "blur and offset", SkOffsetImageFilter::Create(five, five, blur.get())
}, |
| 482 { "picture and blur", SkBlurImageFilter::Create(five, five, pictureFilte
r.get()) }, | 487 { "picture and blur", SkBlurImageFilter::Create(five, five, pictureFilte
r.get()) }, |
| 483 { "rect shader and blur", SkBlurImageFilter::Create(five, five, rectShad
erFilter.get()) }, | 488 { "rect shader and blur", SkBlurImageFilter::Create(five, five, rectShad
erFilter.get()) }, |
| 484 }; | 489 }; |
| 485 | 490 |
| 486 SkBitmap untiledResult, tiledResult; | 491 SkBitmap untiledResult, tiledResult; |
| 487 const int width = 64, height = 64; | 492 int width = 64, height = 64; |
| 488 untiledResult.allocN32Pixels(width, height); | 493 untiledResult.allocN32Pixels(width, height); |
| 489 tiledResult.allocN32Pixels(width, height); | 494 tiledResult.allocN32Pixels(width, height); |
| 490 SkCanvas tiledCanvas(tiledResult); | 495 SkCanvas tiledCanvas(tiledResult); |
| 491 SkCanvas untiledCanvas(untiledResult); | 496 SkCanvas untiledCanvas(untiledResult); |
| 492 int tileSize = 8; | 497 int tileSize = 8; |
| 493 | 498 |
| 494 for (int scale = 1; scale <= 2; ++scale) { | 499 for (int scale = 1; scale <= 2; ++scale) { |
| 495 for (size_t i = 0; i < SK_ARRAY_COUNT(filters); ++i) { | 500 for (size_t i = 0; i < SK_ARRAY_COUNT(filters); ++i) { |
| 496 tiledCanvas.clear(0); | 501 tiledCanvas.clear(0); |
| 497 untiledCanvas.clear(0); | 502 untiledCanvas.clear(0); |
| (...skipping 806 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1304 SkSurface::kNo_Budgeted
, | 1309 SkSurface::kNo_Budgeted
, |
| 1305 SkImageInfo::MakeN32Pre
mul(1, 1), | 1310 SkImageInfo::MakeN32Pre
mul(1, 1), |
| 1306 0, | 1311 0, |
| 1307 &props, | 1312 &props, |
| 1308 SkGpuDevice::kUninit_In
itContents)); | 1313 SkGpuDevice::kUninit_In
itContents)); |
| 1309 SkImageFilter::Proxy proxy(device); | 1314 SkImageFilter::Proxy proxy(device); |
| 1310 | 1315 |
| 1311 test_negative_blur_sigma(&proxy, reporter); | 1316 test_negative_blur_sigma(&proxy, reporter); |
| 1312 } | 1317 } |
| 1313 #endif | 1318 #endif |
| OLD | NEW |