Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(529)

Unified Diff: bench/ImageBench.cpp

Issue 1261043003: update image bench to test gpu and cpu images against raster surface (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: bench/ImageBench.cpp
diff --git a/bench/ImageBench.cpp b/bench/ImageBench.cpp
index e3fe230353ec907f738f12516e30822ef7c0450f..69ab17f2c1583a9369753b22ae9c1498201b722d 100644
--- a/bench/ImageBench.cpp
+++ b/bench/ImageBench.cpp
@@ -10,14 +10,14 @@
#include "SkImage.h"
#include "SkSurface.h"
-class GPU2RasterImageBench : public Benchmark {
+class Image2RasterBench : public Benchmark {
public:
- GPU2RasterImageBench() {
- fName.set("gpu2raster_image");
+ Image2RasterBench() {
+ fName.set("native_image_to_raster_surface");
}
bool isSuitableFor(Backend backend) override {
- return kGPU_Backend == backend;
+ return kGPU_Backend == backend || kRaster_Backend == backend;
}
protected:
@@ -25,33 +25,35 @@ protected:
return fName.c_str();
}
+ // We explicitly want to bench drawing a Image [cpu or gpu backed] into a raster target,
+ // to ensure that we can cache the read-back in the case of gpu -> raster
+ //
void onPerCanvasPreDraw(SkCanvas* canvas) override {
- // create a gpu-backed Image
- SkImageInfo info = SkImageInfo::MakeN32Premul(500, 500);
+ // create an Image reflecting the canvas (gpu or cpu)
+ SkImageInfo info = SkImageInfo::MakeN32Premul(100, 100);
SkAutoTUnref<SkSurface> surface(canvas->newSurface(info));
canvas->drawColor(SK_ColorRED);
- fGpuImage.reset(surface->newImageSnapshot());
+ fImage.reset(surface->newImageSnapshot());
// create a cpu-backed Surface
fRasterSurface.reset(SkSurface::NewRaster(info));
}
void onDraw(const int loops, SkCanvas*) override {
- // Time drawing a gpu-image into a raster-surface
for (int i = 0; i < loops; i++) {
for (int inner = 0; inner < 10; ++inner) {
- fRasterSurface->getCanvas()->drawImage(fGpuImage, 0, 0);
+ fRasterSurface->getCanvas()->drawImage(fImage, 0, 0);
}
}
}
private:
SkString fName;
- SkAutoTUnref<SkImage> fGpuImage;
+ SkAutoTUnref<SkImage> fImage;
SkAutoTUnref<SkSurface> fRasterSurface;
typedef Benchmark INHERITED;
};
-DEF_BENCH( return new GPU2RasterImageBench; )
+DEF_BENCH( return new Image2RasterBench; )
« no previous file with comments | « no previous file | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698