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 #ifndef nanobench_DEFINED | 8 #ifndef nanobench_DEFINED |
9 #define nanobench_DEFINED | 9 #define nanobench_DEFINED |
10 | 10 |
(...skipping 29 matching lines...) Expand all Loading... |
40 explicit Target(const Config& c) : config(c) { } | 40 explicit Target(const Config& c) : config(c) { } |
41 virtual ~Target() { } | 41 virtual ~Target() { } |
42 | 42 |
43 const Config config; | 43 const Config config; |
44 SkAutoTDelete<SkSurface> surface; | 44 SkAutoTDelete<SkSurface> surface; |
45 | 45 |
46 /** Called once per target, immediately before any timing or drawing. */ | 46 /** Called once per target, immediately before any timing or drawing. */ |
47 virtual void setup() { } | 47 virtual void setup() { } |
48 | 48 |
49 /** Called *after* the clock timer is started, before the benchmark | 49 /** Called *after* the clock timer is started, before the benchmark |
50 is drawn. */ | 50 is drawn. Most back ends just return the canvas passed in, |
| 51 but some may replace it. */ |
51 virtual SkCanvas* beginTiming(SkCanvas* canvas) { return canvas; } | 52 virtual SkCanvas* beginTiming(SkCanvas* canvas) { return canvas; } |
52 | 53 |
53 /** Called *after* a benchmark is drawn, but before the clock timer | 54 /** Called *after* a benchmark is drawn, but before the clock timer |
54 is stopped. */ | 55 is stopped. */ |
55 virtual void endTiming() { } | 56 virtual void endTiming() { } |
56 | 57 |
57 /** Called between benchmarks (or between calibration and measured | 58 /** Called between benchmarks (or between calibration and measured |
58 runs) to make sure all pending work in drivers / threads is | 59 runs) to make sure all pending work in drivers / threads is |
59 complete. */ | 60 complete. */ |
60 virtual void fence() { } | 61 virtual void fence() { } |
61 | 62 |
62 /** CPU-like targets can just be timed, but GPU-like | 63 /** CPU-like targets can just be timed, but GPU-like |
63 targets need to pay attention to frame boundaries | 64 targets need to pay attention to frame boundaries |
64 or other similar details. */ | 65 or other similar details. */ |
65 virtual bool needsFrameTiming() const { return false; } | 66 virtual bool needsFrameTiming() const { return false; } |
66 | 67 |
67 /** Called once per target, during program initialization. | 68 /** Called once per target, during program initialization. |
68 Returns false if initialization fails. */ | 69 Returns false if initialization fails. */ |
69 virtual bool init(SkImageInfo info, Benchmark* bench); | 70 virtual bool init(SkImageInfo info, Benchmark* bench); |
70 | 71 |
71 /** Stores any pixels drawn to the screen in the bitmap. | 72 /** Stores any pixels drawn to the screen in the bitmap. |
72 Returns false on error. */ | 73 Returns false on error. */ |
73 virtual bool capturePixels(SkBitmap* bmp); | 74 virtual bool capturePixels(SkBitmap* bmp); |
74 | 75 |
75 /** Writes any config-specific data to the log. */ | 76 /** Writes any config-specific data to the log. */ |
76 virtual void fillOptions(ResultsWriter*) { } | 77 virtual void fillOptions(ResultsWriter*) { } |
| 78 |
| 79 SkCanvas* getCanvas() const { |
| 80 if (!surface.get()) { |
| 81 return NULL; |
| 82 } |
| 83 return surface->getCanvas(); |
| 84 } |
77 }; | 85 }; |
78 | 86 |
79 #endif // nanobench_DEFINED | 87 #endif // nanobench_DEFINED |
OLD | NEW |