| Index: gm/imagealphathreshold.cpp
 | 
| diff --git a/gm/imagealphathreshold.cpp b/gm/imagealphathreshold.cpp
 | 
| index 13a0ffa90b404fcf2a1c8c098940107ff5b1b2e5..ea7185be1dbb8747d8cadcd9109f8ef3a602ed38 100644
 | 
| --- a/gm/imagealphathreshold.cpp
 | 
| +++ b/gm/imagealphathreshold.cpp
 | 
| @@ -8,10 +8,39 @@
 | 
|  #include "gm.h"
 | 
|  #include "SkAlphaThresholdFilter.h"
 | 
|  #include "SkRandom.h"
 | 
| +#include "SkSurface.h"
 | 
|  
 | 
|  #define WIDTH 500
 | 
|  #define HEIGHT 500
 | 
|  
 | 
| +namespace {
 | 
| +
 | 
| +void draw_rects(SkCanvas* canvas) {
 | 
| +    SkPaint rectPaint;
 | 
| +    rectPaint.setColor(0xFF0000FF);
 | 
| +    canvas->drawRect(SkRect::MakeXYWH(0, 0, WIDTH / 2, HEIGHT / 2), rectPaint);
 | 
| +    rectPaint.setColor(0xBFFF0000);
 | 
| +    canvas->drawRect(SkRect::MakeXYWH(WIDTH / 2, 0, WIDTH / 2, HEIGHT / 2), rectPaint);
 | 
| +    rectPaint.setColor(0x3F00FF00);
 | 
| +    canvas->drawRect(SkRect::MakeXYWH(0, HEIGHT / 2, WIDTH / 2, HEIGHT / 2), rectPaint);
 | 
| +    rectPaint.setColor(0x00000000);
 | 
| +    canvas->drawRect(SkRect::MakeXYWH(WIDTH / 2, HEIGHT / 2, WIDTH / 2, HEIGHT / 2), rectPaint);
 | 
| +}
 | 
| +
 | 
| +SkPaint create_filter_paint() {
 | 
| +    SkIRect rects[2];
 | 
| +    rects[0] = SkIRect::MakeXYWH(0, 150, WIDTH, HEIGHT - 300);
 | 
| +    rects[1] = SkIRect::MakeXYWH(150, 0, WIDTH - 300, HEIGHT);
 | 
| +    SkRegion region;
 | 
| +    region.setRects(rects, 2);
 | 
| +
 | 
| +    SkPaint paint;
 | 
| +    paint.setImageFilter(SkAlphaThresholdFilter::Create(region, 0.2f, 0.7f))->unref();
 | 
| +    return paint;
 | 
| +}
 | 
| +
 | 
| +};
 | 
| +
 | 
|  namespace skiagm {
 | 
|  
 | 
|  class ImageAlphaThresholdGM : public GM {
 | 
| @@ -31,12 +60,6 @@ protected:
 | 
|      }
 | 
|  
 | 
|      void onDraw(SkCanvas* canvas) override {
 | 
| -        SkIRect rects[2];
 | 
| -        rects[0] = SkIRect::MakeXYWH(0, 150, WIDTH, HEIGHT - 300);
 | 
| -        rects[1] = SkIRect::MakeXYWH(150, 0, WIDTH - 300, HEIGHT);
 | 
| -        SkRegion region;
 | 
| -        region.setRects(rects, 2);
 | 
| -
 | 
|          SkMatrix matrix;
 | 
|          matrix.reset();
 | 
|          matrix.setTranslate(WIDTH * .1f, HEIGHT * .1f);
 | 
| @@ -44,25 +67,9 @@ protected:
 | 
|  
 | 
|          canvas->concat(matrix);
 | 
|  
 | 
| -        SkPaint paint;
 | 
| -        paint.setImageFilter(
 | 
| -            SkAlphaThresholdFilter::Create(region, 0.2f, 0.7f))->unref();
 | 
| +        SkPaint paint = create_filter_paint();
 | 
|          canvas->saveLayer(nullptr, &paint);
 | 
| -        paint.setAntiAlias(true);
 | 
| -
 | 
| -        SkPaint rect_paint;
 | 
| -        rect_paint.setColor(0xFF0000FF);
 | 
| -        canvas->drawRect(SkRect::MakeXYWH(0, 0, WIDTH / 2, HEIGHT / 2),
 | 
| -                         rect_paint);
 | 
| -        rect_paint.setColor(0xBFFF0000);
 | 
| -        canvas->drawRect(SkRect::MakeXYWH(WIDTH / 2, 0, WIDTH / 2, HEIGHT / 2),
 | 
| -                         rect_paint);
 | 
| -        rect_paint.setColor(0x3F00FF00);
 | 
| -        canvas->drawRect(SkRect::MakeXYWH(0, HEIGHT / 2, WIDTH / 2, HEIGHT / 2),
 | 
| -                         rect_paint);
 | 
| -        rect_paint.setColor(0x00000000);
 | 
| -        canvas->drawRect(SkRect::MakeXYWH(WIDTH / 2, HEIGHT / 2, WIDTH / 2, HEIGHT / 2),
 | 
| -                         rect_paint);
 | 
| +        draw_rects(canvas);
 | 
|  
 | 
|          canvas->restore();
 | 
|      }
 | 
| @@ -71,9 +78,43 @@ private:
 | 
|      typedef GM INHERITED;
 | 
|  };
 | 
|  
 | 
| +class ImageAlphaThresholdSurfaceGM : public GM {
 | 
| +public:
 | 
| +    ImageAlphaThresholdSurfaceGM() {
 | 
| +        this->setBGColor(0xFFFFFFFF);
 | 
| +    }
 | 
| +
 | 
| +protected:
 | 
| +    SkString onShortName() override {
 | 
| +        return SkString("imagealphathreshold_surface");
 | 
| +    }
 | 
| +
 | 
| +    SkISize onISize() override {
 | 
| +        return SkISize::Make(WIDTH, HEIGHT);
 | 
| +    }
 | 
| +
 | 
| +    void onDraw(SkCanvas* canvas) override {
 | 
| +        SkImageInfo info = SkImageInfo::MakeN32(WIDTH, HEIGHT, kOpaque_SkAlphaType);
 | 
| +        SkAutoTUnref<SkSurface> surface(canvas->newSurface(info));
 | 
| +        if (nullptr == surface) {
 | 
| +            surface.reset(SkSurface::NewRaster(info));
 | 
| +        }
 | 
| +        surface->getCanvas()->clear(SK_ColorWHITE);
 | 
| +        draw_rects(surface->getCanvas());
 | 
| +
 | 
| +        SkAutoTUnref<SkImage> image(surface->newImageSnapshot());
 | 
| +        SkPaint paint = create_filter_paint();
 | 
| +        canvas->clipRect(SkRect::MakeLTRB(100, 100, WIDTH - 100, HEIGHT - 100));
 | 
| +        canvas->drawImage(image, 0, 0, &paint);
 | 
| +    }
 | 
| +
 | 
| +private:
 | 
| +    typedef GM INHERITED;
 | 
| +};
 | 
| +
 | 
|  //////////////////////////////////////////////////////////////////////////////
 | 
|  
 | 
| -static GM* MyFactory(void*) { return new ImageAlphaThresholdGM; }
 | 
| -static GMRegistry reg(MyFactory);
 | 
| +DEF_GM(return new ImageAlphaThresholdGM();)
 | 
| +DEF_GM(return new ImageAlphaThresholdSurfaceGM();)
 | 
|  
 | 
|  }
 | 
| 
 |