Index: bench/MergeBench.cpp |
diff --git a/bench/MergeBench.cpp b/bench/MergeBench.cpp |
index e1f7d97b5eb5483293f5850567a38b1816c07990..061a4d36f3201478b230d590534168193ad235d3 100644 |
--- a/bench/MergeBench.cpp |
+++ b/bench/MergeBench.cpp |
@@ -16,6 +16,41 @@ |
#define FILTER_WIDTH_LARGE SkIntToScalar(256) |
#define FILTER_HEIGHT_LARGE SkIntToScalar(256) |
+static sk_sp<SkImage> make_bitmap() { |
+ sk_sp<SkSurface> surface(SkSurface::MakeRasterN32Premul(80, 80)); |
+ surface->getCanvas()->clear(0x00000000); |
+ SkPaint paint; |
+ paint.setAntiAlias(true); |
+ paint.setColor(0xFF884422); |
+ paint.setTextSize(SkIntToScalar(96)); |
+ const char* str = "g"; |
+ surface->getCanvas()->drawText(str, strlen(str), 15, 55, paint); |
+ return surface->makeImageSnapshot(); |
+} |
+ |
+static sk_sp<SkImage> make_checkerboard() { |
+ sk_sp<SkSurface> surface(SkSurface::MakeRasterN32Premul(80, 80)); |
+ SkCanvas* canvas = surface->getCanvas(); |
+ canvas->clear(0x00000000); |
+ SkPaint darkPaint; |
+ darkPaint.setColor(0xFF804020); |
+ SkPaint lightPaint; |
+ lightPaint.setColor(0xFF244484); |
+ 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(); |
+ } |
+ } |
+ |
+ return surface->makeImageSnapshot(); |
+} |
+ |
class MergeBench : public Benchmark { |
public: |
MergeBench(bool small) : fIsSmall(small), fInitialized(false) { } |
@@ -27,8 +62,8 @@ protected: |
void onDelayedSetup() override { |
if (!fInitialized) { |
- make_bitmap(); |
- make_checkerboard(); |
+ fImage = make_bitmap(); |
+ fCheckerboard = make_checkerboard(); |
fInitialized = true; |
} |
} |
@@ -37,52 +72,17 @@ protected: |
SkRect r = fIsSmall ? SkRect::MakeWH(FILTER_WIDTH_SMALL, FILTER_HEIGHT_SMALL) : |
SkRect::MakeWH(FILTER_WIDTH_LARGE, FILTER_HEIGHT_LARGE); |
SkPaint paint; |
- paint.setImageFilter(mergeBitmaps())->unref(); |
+ paint.setImageFilter(this->mergeBitmaps()); |
for (int i = 0; i < loops; i++) { |
canvas->drawRect(r, paint); |
} |
} |
private: |
- SkImageFilter* mergeBitmaps() { |
- SkAutoTUnref<SkImageFilter> first(SkImageSource::Create(fCheckerboard.get())); |
- SkAutoTUnref<SkImageFilter> second(SkImageSource::Create(fImage.get())); |
- return SkMergeImageFilter::Create(first, second); |
- } |
- |
- void make_bitmap() { |
- auto surface(SkSurface::MakeRasterN32Premul(80, 80)); |
- surface->getCanvas()->clear(0x00000000); |
- SkPaint paint; |
- paint.setAntiAlias(true); |
- paint.setColor(0xFF884422); |
- paint.setTextSize(SkIntToScalar(96)); |
- const char* str = "g"; |
- surface->getCanvas()->drawText(str, strlen(str), 15, 55, paint); |
- fImage = surface->makeImageSnapshot(); |
- } |
- |
- void make_checkerboard() { |
- auto surface(SkSurface::MakeRasterN32Premul(80, 80)); |
- SkCanvas* canvas = surface->getCanvas(); |
- canvas->clear(0x00000000); |
- SkPaint darkPaint; |
- darkPaint.setColor(0xFF804020); |
- SkPaint lightPaint; |
- lightPaint.setColor(0xFF244484); |
- 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(); |
- } |
- } |
- |
- fCheckerboard = surface->makeImageSnapshot(); |
+ sk_sp<SkImageFilter> mergeBitmaps() { |
+ sk_sp<SkImageFilter> first(SkImageSource::Create(fCheckerboard.get())); |
+ sk_sp<SkImageFilter> second(SkImageSource::Create(fImage.get())); |
+ return SkMergeImageFilter::Make(std::move(first), std::move(second)); |
} |
bool fIsSmall; |