| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2015 Google Inc. | 2 * Copyright 2015 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #include "Benchmark.h" | 8 #include "Benchmark.h" |
| 9 #include "SkCanvas.h" | 9 #include "SkCanvas.h" |
| 10 #include "SkImage.h" | 10 #include "SkImage.h" |
| 11 #include "SkSurface.h" | 11 #include "SkSurface.h" |
| 12 | 12 |
| 13 class GPU2RasterImageBench : public Benchmark { | 13 class Image2RasterBench : public Benchmark { |
| 14 public: | 14 public: |
| 15 GPU2RasterImageBench() { | 15 Image2RasterBench() { |
| 16 fName.set("gpu2raster_image"); | 16 fName.set("native_image_to_raster_surface"); |
| 17 } | 17 } |
| 18 | 18 |
| 19 bool isSuitableFor(Backend backend) override { | 19 bool isSuitableFor(Backend backend) override { |
| 20 return kGPU_Backend == backend; | 20 return kGPU_Backend == backend || kRaster_Backend == backend; |
| 21 } | 21 } |
| 22 | 22 |
| 23 protected: | 23 protected: |
| 24 const char* onGetName() override { | 24 const char* onGetName() override { |
| 25 return fName.c_str(); | 25 return fName.c_str(); |
| 26 } | 26 } |
| 27 | 27 |
| 28 // We explicitly want to bench drawing a Image [cpu or gpu backed] into a ra
ster target, |
| 29 // to ensure that we can cache the read-back in the case of gpu -> raster |
| 30 // |
| 28 void onPerCanvasPreDraw(SkCanvas* canvas) override { | 31 void onPerCanvasPreDraw(SkCanvas* canvas) override { |
| 29 // create a gpu-backed Image | 32 // create an Image reflecting the canvas (gpu or cpu) |
| 30 SkImageInfo info = SkImageInfo::MakeN32Premul(500, 500); | 33 SkImageInfo info = SkImageInfo::MakeN32Premul(100, 100); |
| 31 SkAutoTUnref<SkSurface> surface(canvas->newSurface(info)); | 34 SkAutoTUnref<SkSurface> surface(canvas->newSurface(info)); |
| 32 canvas->drawColor(SK_ColorRED); | 35 canvas->drawColor(SK_ColorRED); |
| 33 fGpuImage.reset(surface->newImageSnapshot()); | 36 fImage.reset(surface->newImageSnapshot()); |
| 34 | 37 |
| 35 // create a cpu-backed Surface | 38 // create a cpu-backed Surface |
| 36 fRasterSurface.reset(SkSurface::NewRaster(info)); | 39 fRasterSurface.reset(SkSurface::NewRaster(info)); |
| 37 } | 40 } |
| 38 | 41 |
| 39 void onDraw(const int loops, SkCanvas*) override { | 42 void onDraw(const int loops, SkCanvas*) override { |
| 40 // Time drawing a gpu-image into a raster-surface | |
| 41 for (int i = 0; i < loops; i++) { | 43 for (int i = 0; i < loops; i++) { |
| 42 for (int inner = 0; inner < 10; ++inner) { | 44 for (int inner = 0; inner < 10; ++inner) { |
| 43 fRasterSurface->getCanvas()->drawImage(fGpuImage, 0, 0); | 45 fRasterSurface->getCanvas()->drawImage(fImage, 0, 0); |
| 44 } | 46 } |
| 45 } | 47 } |
| 46 } | 48 } |
| 47 | 49 |
| 48 private: | 50 private: |
| 49 SkString fName; | 51 SkString fName; |
| 50 SkAutoTUnref<SkImage> fGpuImage; | 52 SkAutoTUnref<SkImage> fImage; |
| 51 SkAutoTUnref<SkSurface> fRasterSurface; | 53 SkAutoTUnref<SkSurface> fRasterSurface; |
| 52 | 54 |
| 53 typedef Benchmark INHERITED; | 55 typedef Benchmark INHERITED; |
| 54 }; | 56 }; |
| 55 | 57 |
| 56 | 58 |
| 57 DEF_BENCH( return new GPU2RasterImageBench; ) | 59 DEF_BENCH( return new Image2RasterBench; ) |
| OLD | NEW |