OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 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 #include "Benchmark.h" | 7 #include "Benchmark.h" |
8 #include "SkCanvas.h" | 8 #include "SkCanvas.h" |
9 #include "SkColor.h" | 9 #include "SkColor.h" |
10 #include "SkPaint.h" | 10 #include "SkPaint.h" |
(...skipping 24 matching lines...) Expand all Loading... |
35 protected: | 35 protected: |
36 virtual const char* onGetName() { | 36 virtual const char* onGetName() { |
37 return fName.c_str(); | 37 return fName.c_str(); |
38 } | 38 } |
39 | 39 |
40 virtual void onDraw(int loops, SkCanvas* canvas) { | 40 virtual void onDraw(int loops, SkCanvas* canvas) { |
41 | 41 |
42 SkPictureRecorder recorder; | 42 SkPictureRecorder recorder; |
43 SkCanvas* pCanvas = recorder.beginRecording(PICTURE_WIDTH, PICTURE_HEIGH
T, nullptr, 0); | 43 SkCanvas* pCanvas = recorder.beginRecording(PICTURE_WIDTH, PICTURE_HEIGH
T, nullptr, 0); |
44 this->recordCanvas(pCanvas); | 44 this->recordCanvas(pCanvas); |
45 SkAutoTUnref<SkPicture> picture(recorder.endRecording()); | 45 sk_sp<SkPicture> picture(recorder.finishRecordingAsPicture()); |
46 | 46 |
47 const SkPoint translateDelta = getTranslateDelta(loops); | 47 const SkPoint translateDelta = getTranslateDelta(loops); |
48 | 48 |
49 for (int i = 0; i < loops; i++) { | 49 for (int i = 0; i < loops; i++) { |
50 picture->playback(canvas); | 50 picture->playback(canvas); |
51 canvas->translate(translateDelta.fX, translateDelta.fY); | 51 canvas->translate(translateDelta.fX, translateDelta.fY); |
52 } | 52 } |
53 } | 53 } |
54 | 54 |
55 virtual void recordCanvas(SkCanvas* canvas) = 0; | 55 virtual void recordCanvas(SkCanvas* canvas) = 0; |
(...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
175 for (int i = 0; i < 10000; i++) { | 175 for (int i = 0; i < 10000; i++) { |
176 SkScalar x = rand.nextRangeScalar(0, 1024), | 176 SkScalar x = rand.nextRangeScalar(0, 1024), |
177 y = rand.nextRangeScalar(0, 1024), | 177 y = rand.nextRangeScalar(0, 1024), |
178 w = rand.nextRangeScalar(0, 128), | 178 w = rand.nextRangeScalar(0, 128), |
179 h = rand.nextRangeScalar(0, 128); | 179 h = rand.nextRangeScalar(0, 128); |
180 SkPaint paint; | 180 SkPaint paint; |
181 paint.setColor(rand.nextU()); | 181 paint.setColor(rand.nextU()); |
182 paint.setAlpha(0xFF); | 182 paint.setAlpha(0xFF); |
183 canvas->drawRect(SkRect::MakeXYWH(x,y,w,h), paint); | 183 canvas->drawRect(SkRect::MakeXYWH(x,y,w,h), paint); |
184 } | 184 } |
185 fPic.reset(recorder.endRecording()); | 185 fPic = recorder.finishRecordingAsPicture(); |
186 } | 186 } |
187 | 187 |
188 void onDraw(int loops, SkCanvas* canvas) override { | 188 void onDraw(int loops, SkCanvas* canvas) override { |
189 for (int i = 0; i < loops; i++) { | 189 for (int i = 0; i < loops; i++) { |
190 // This inner loop guarantees we make the same choices for all bench
variants. | 190 // This inner loop guarantees we make the same choices for all bench
variants. |
191 SkRandom rand; | 191 SkRandom rand; |
192 for (int j = 0; j < 10; j++) { | 192 for (int j = 0; j < 10; j++) { |
193 SkScalar x = 0, y = 0; | 193 SkScalar x = 0, y = 0; |
194 switch (fMode) { | 194 switch (fMode) { |
195 case kTiled: x = SkScalar(256 * rand.nextULessThan(4)); | 195 case kTiled: x = SkScalar(256 * rand.nextULessThan(4)); |
196 y = SkScalar(256 * rand.nextULessThan(4)); | 196 y = SkScalar(256 * rand.nextULessThan(4)); |
197 break; | 197 break; |
198 case kRandom: x = rand.nextRangeScalar(0, 768); | 198 case kRandom: x = rand.nextRangeScalar(0, 768); |
199 y = rand.nextRangeScalar(0, 768); | 199 y = rand.nextRangeScalar(0, 768); |
200 break; | 200 break; |
201 } | 201 } |
202 SkAutoCanvasRestore ar(canvas, true/*save now*/); | 202 SkAutoCanvasRestore ar(canvas, true/*save now*/); |
203 canvas->clipRect(SkRect::MakeXYWH(x,y,256,256)); | 203 canvas->clipRect(SkRect::MakeXYWH(x,y,256,256)); |
204 fPic->playback(canvas); | 204 fPic->playback(canvas); |
205 } | 205 } |
206 } | 206 } |
207 } | 207 } |
208 | 208 |
209 private: | 209 private: |
210 BBH fBBH; | 210 BBH fBBH; |
211 Mode fMode; | 211 Mode fMode; |
212 SkString fName; | 212 SkString fName; |
213 SkAutoTUnref<SkPicture> fPic; | 213 sk_sp<SkPicture> fPic; |
214 }; | 214 }; |
215 | 215 |
216 DEF_BENCH( return new TiledPlaybackBench(kNone, kRandom); ) | 216 DEF_BENCH( return new TiledPlaybackBench(kNone, kRandom); ) |
217 DEF_BENCH( return new TiledPlaybackBench(kNone, kTiled ); ) | 217 DEF_BENCH( return new TiledPlaybackBench(kNone, kTiled ); ) |
218 DEF_BENCH( return new TiledPlaybackBench(kRTree, kRandom); ) | 218 DEF_BENCH( return new TiledPlaybackBench(kRTree, kRandom); ) |
219 DEF_BENCH( return new TiledPlaybackBench(kRTree, kTiled ); ) | 219 DEF_BENCH( return new TiledPlaybackBench(kRTree, kTiled ); ) |
OLD | NEW |