OLD | NEW |
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2012 Google Inc. | 3 * Copyright 2012 Google Inc. |
4 * | 4 * |
5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
7 */ | 7 */ |
8 | 8 |
9 #include "SkBenchmark.h" | 9 #include "SkBenchmark.h" |
10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
(...skipping 29 matching lines...) Expand all Loading... |
40 return backend == kNonRendering_Backend; | 40 return backend == kNonRendering_Backend; |
41 } | 41 } |
42 | 42 |
43 virtual ~BBoxBuildBench() { | 43 virtual ~BBoxBuildBench() { |
44 fTree->unref(); | 44 fTree->unref(); |
45 } | 45 } |
46 protected: | 46 protected: |
47 virtual const char* onGetName() SK_OVERRIDE { | 47 virtual const char* onGetName() SK_OVERRIDE { |
48 return fName.c_str(); | 48 return fName.c_str(); |
49 } | 49 } |
50 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { | 50 virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE { |
51 SkRandom rand; | 51 SkRandom rand; |
52 for (int i = 0; i < this->getLoops(); ++i) { | 52 for (int i = 0; i < loops; ++i) { |
53 for (int j = 0; j < NUM_BUILD_RECTS; ++j) { | 53 for (int j = 0; j < NUM_BUILD_RECTS; ++j) { |
54 fTree->insert(reinterpret_cast<void*>(j), fProc(rand, j, NUM_BUI
LD_RECTS), | 54 fTree->insert(reinterpret_cast<void*>(j), fProc(rand, j, NUM_BUI
LD_RECTS), |
55 fBulkLoad); | 55 fBulkLoad); |
56 } | 56 } |
57 fTree->flushDeferredInserts(); | 57 fTree->flushDeferredInserts(); |
58 fTree->clear(); | 58 fTree->clear(); |
59 } | 59 } |
60 } | 60 } |
61 private: | 61 private: |
62 SkBBoxHierarchy* fTree; | 62 SkBBoxHierarchy* fTree; |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 virtual void onPreDraw() SK_OVERRIDE { | 104 virtual void onPreDraw() SK_OVERRIDE { |
105 SkRandom rand; | 105 SkRandom rand; |
106 for (int j = 0; j < NUM_QUERY_RECTS; ++j) { | 106 for (int j = 0; j < NUM_QUERY_RECTS; ++j) { |
107 fTree->insert(reinterpret_cast<void*>(j), | 107 fTree->insert(reinterpret_cast<void*>(j), |
108 fProc(rand, j, NUM_QUERY_RECTS), | 108 fProc(rand, j, NUM_QUERY_RECTS), |
109 fBulkLoad); | 109 fBulkLoad); |
110 } | 110 } |
111 fTree->flushDeferredInserts(); | 111 fTree->flushDeferredInserts(); |
112 } | 112 } |
113 | 113 |
114 virtual void onDraw(SkCanvas* canvas) SK_OVERRIDE { | 114 virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE { |
115 SkRandom rand; | 115 SkRandom rand; |
116 for (int i = 0; i < this->getLoops(); ++i) { | 116 for (int i = 0; i < loops; ++i) { |
117 SkTDArray<void*> hits; | 117 SkTDArray<void*> hits; |
118 SkIRect query; | 118 SkIRect query; |
119 switch(fQuery) { | 119 switch(fQuery) { |
120 case kSmall_QueryType: | 120 case kSmall_QueryType: |
121 query.fLeft = rand.nextU() % GENERATE_EXTENTS; | 121 query.fLeft = rand.nextU() % GENERATE_EXTENTS; |
122 query.fTop = rand.nextU() % GENERATE_EXTENTS; | 122 query.fTop = rand.nextU() % GENERATE_EXTENTS; |
123 query.fRight = query.fLeft + (GENERATE_EXTENTS / 20); | 123 query.fRight = query.fLeft + (GENERATE_EXTENTS / 20); |
124 query.fBottom = query.fTop + (GENERATE_EXTENTS / 20); | 124 query.fBottom = query.fTop + (GENERATE_EXTENTS / 20); |
125 break; | 125 break; |
126 case kLarge_QueryType: | 126 case kLarge_QueryType: |
(...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
260 &make_concentric_rects_increasing, true, SkRTree::Create(5
, 16, 1, false))); | 260 &make_concentric_rects_increasing, true, SkRTree::Create(5
, 16, 1, false))); |
261 ) | 261 ) |
262 DEF_BENCH( | 262 DEF_BENCH( |
263 return SkNEW_ARGS(BBoxQueryBench, ("concentric", &make_concentric_rects_incr
easing, true, | 263 return SkNEW_ARGS(BBoxQueryBench, ("concentric", &make_concentric_rects_incr
easing, true, |
264 BBoxQueryBench::kRandom_QueryType, SkRTree::Create(5, 16))
); | 264 BBoxQueryBench::kRandom_QueryType, SkRTree::Create(5, 16))
); |
265 ) | 265 ) |
266 DEF_BENCH( | 266 DEF_BENCH( |
267 return SkNEW_ARGS(BBoxQueryBench, ("(unsorted)concentric", &make_concentric_
rects_increasing, true, | 267 return SkNEW_ARGS(BBoxQueryBench, ("(unsorted)concentric", &make_concentric_
rects_increasing, true, |
268 BBoxQueryBench::kRandom_QueryType, SkRTree::Create(5, 16,
1, false))); | 268 BBoxQueryBench::kRandom_QueryType, SkRTree::Create(5, 16,
1, false))); |
269 ) | 269 ) |
OLD | NEW |