Index: gm/imagefilterscropped.cpp |
diff --git a/gm/imagefilterscropped.cpp b/gm/imagefilterscropped.cpp |
index 49b0a97f97d0af7048841f3fbcf8c15a9e7a396e..86dfbcb2dfa03b9b59a7453e93b2f04aade80f1a 100644 |
--- a/gm/imagefilterscropped.cpp |
+++ b/gm/imagefilterscropped.cpp |
@@ -12,7 +12,9 @@ |
#include "SkShader.h" |
#include "SkBlurImageFilter.h" |
+#include "SkMorphologyImageFilter.h" |
#include "SkColorFilterImageFilter.h" |
+#include "SkBitmapSource.h" |
#include "SkMergeImageFilter.h" |
#include "SkOffsetImageFilter.h" |
#include "SkTestImageFilters.h" |
@@ -98,7 +100,28 @@ protected: |
return SkString("imagefilterscropped"); |
} |
- virtual SkISize onISize() { return SkISize::Make(400, 640); } |
+ virtual SkISize onISize() { return SkISize::Make(400, 880); } |
+ |
+ void make_checkerboard() { |
+ fCheckerboard.allocN32Pixels(80, 80); |
+ SkCanvas canvas(fCheckerboard); |
+ canvas.clear(SK_ColorTRANSPARENT); |
+ SkPaint darkPaint; |
+ darkPaint.setColor(0xFF404040); |
+ SkPaint lightPaint; |
+ lightPaint.setColor(0xFFA0A0A0); |
+ for (int y = 0; y < 80; y += 16) { |
+ for (int x = 0; x < 80; x += 16) { |
+ canvas.save(); |
+ canvas.translate(SkIntToScalar(x), SkIntToScalar(y)); |
+ canvas.drawRect(SkRect::MakeXYWH(0, 0, 8, 8), darkPaint); |
+ canvas.drawRect(SkRect::MakeXYWH(8, 0, 8, 8), lightPaint); |
+ canvas.drawRect(SkRect::MakeXYWH(0, 8, 8, 8), lightPaint); |
+ canvas.drawRect(SkRect::MakeXYWH(8, 8, 8, 8), darkPaint); |
+ canvas.restore(); |
+ } |
+ } |
+ } |
void draw_frame(SkCanvas* canvas, const SkRect& r) { |
SkPaint paint; |
@@ -107,6 +130,10 @@ protected: |
canvas->drawRect(r, paint); |
} |
+ virtual void onOnceBeforeDraw() SK_OVERRIDE{ |
+ make_checkerboard(); |
+ } |
+ |
virtual void onDraw(SkCanvas* canvas) { |
void (*drawProc[])(SkCanvas*, const SkRect&, SkImageFilter*) = { |
draw_sprite, draw_bitmap, draw_path, draw_paint, draw_text |
@@ -122,6 +149,9 @@ protected: |
SkAutoTUnref<SkImageFilter> cfOffset(SkColorFilterImageFilter::Create(cf.get(), offset.get())); |
+ SkAutoTUnref<SkImageFilter> erodeX(SkErodeImageFilter::Create(8, 0, NULL, &cropRect)); |
+ SkAutoTUnref<SkImageFilter> erodeY(SkErodeImageFilter::Create(0, 8, NULL, &cropRect)); |
+ |
SkImageFilter* filters[] = { |
NULL, |
SkColorFilterImageFilter::Create(cf.get(), NULL, &cropRect), |
@@ -129,6 +159,10 @@ protected: |
SkBlurImageFilter::Create(8.0f, 0.0f, NULL, &cropRect), |
SkBlurImageFilter::Create(0.0f, 8.0f, NULL, &cropRect), |
SkBlurImageFilter::Create(8.0f, 8.0f, NULL, &cropRect), |
+ SkErodeImageFilter::Create(1, 1, NULL, &cropRect), |
+ SkErodeImageFilter::Create(8, 0, erodeY, &cropRect), |
+ SkErodeImageFilter::Create(0, 8, erodeX, &cropRect), |
+ SkErodeImageFilter::Create(8, 8, NULL, &cropRect), |
SkMergeImageFilter::Create(NULL, cfOffset.get(), SkXfermode::kSrcOver_Mode, &cropRect), |
SkBlurImageFilter::Create(8.0f, 8.0f, NULL, &bogusRect), |
SkColorFilterImageFilter::Create(cf.get(), NULL, &bogusRect), |
@@ -143,6 +177,8 @@ protected: |
for (size_t j = 0; j < SK_ARRAY_COUNT(drawProc); ++j) { |
canvas->save(); |
for (size_t i = 0; i < SK_ARRAY_COUNT(filters); ++i) { |
+ SkPaint paint; |
+ canvas->drawBitmap(fCheckerboard, 0, 0); |
drawProc[j](canvas, r, filters[i]); |
canvas->translate(0, DY); |
} |
@@ -156,6 +192,7 @@ protected: |
} |
private: |
+ SkBitmap fCheckerboard; |
typedef GM INHERITED; |
}; |