diff options
-rw-r--r-- | gm/tileimagefilter.cpp | 16 | ||||
-rw-r--r-- | src/effects/SkTileImageFilter.cpp | 4 |
2 files changed, 17 insertions, 3 deletions
diff --git a/gm/tileimagefilter.cpp b/gm/tileimagefilter.cpp index f75e7f9722..e067d3ee04 100644 --- a/gm/tileimagefilter.cpp +++ b/gm/tileimagefilter.cpp @@ -14,7 +14,7 @@ #include "gm.h" #define WIDTH 400 -#define HEIGHT 100 +#define HEIGHT 200 #define MARGIN 12 namespace skiagm { @@ -107,6 +107,20 @@ protected: canvas->drawRect(srcRect, red); canvas->drawRect(dstRect, blue); canvas->restore(); + + canvas->translate(0, SkIntToScalar(100)); + + srcRect = SkRect::MakeXYWH(0, 0, 50, 50); + dstRect = SkRect::MakeXYWH(0, 0, 100, 100); + SkImageFilter::CropRect cropRect(SkRect::MakeXYWH(5, 5, 40, 40)); + sk_sp<SkColorFilter> greenCF = SkColorFilter::MakeModeFilter(SK_ColorGREEN, + SkXfermode::kSrc_Mode); + SkAutoTUnref<SkImageFilter> green(SkColorFilterImageFilter::Create(greenCF.get(), nullptr, + &cropRect)); + tile.reset(SkTileImageFilter::Create(srcRect, dstRect, green)); + paint.setColor(SK_ColorRED); + paint.setImageFilter(tile); + canvas->drawRect(dstRect, paint); } private: sk_sp<SkImage> fBitmap, fCheckerboard; diff --git a/src/effects/SkTileImageFilter.cpp b/src/effects/SkTileImageFilter.cpp index ab127f6fdf..8f556ff4d0 100644 --- a/src/effects/SkTileImageFilter.cpp +++ b/src/effects/SkTileImageFilter.cpp @@ -83,8 +83,8 @@ bool SkTileImageFilter::onFilterImageDeprecated(Proxy* proxy, const SkBitmap& sr return false; } SkCanvas canvas(device); - canvas.drawBitmap(src, SkIntToScalar(srcOffset.x()), - SkIntToScalar(srcOffset.y())); + canvas.drawBitmap(source, SkIntToScalar(srcOffset.x()), + SkIntToScalar(srcOffset.y())); subset = device->accessBitmap(false); } SkASSERT(subset.width() == srcIRect.width()); |