| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 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 "SKPBench.h" | 8 #include "SKPBench.h" |
| 9 #include "SkCommandLineFlags.h" | 9 #include "SkCommandLineFlags.h" |
| 10 #include "SkMultiPictureDraw.h" | 10 #include "SkMultiPictureDraw.h" |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 103 bool SKPBench::isSuitableFor(Backend backend) { | 103 bool SKPBench::isSuitableFor(Backend backend) { |
| 104 return backend != kNonRendering_Backend; | 104 return backend != kNonRendering_Backend; |
| 105 } | 105 } |
| 106 | 106 |
| 107 SkIPoint SKPBench::onGetSize() { | 107 SkIPoint SKPBench::onGetSize() { |
| 108 return SkIPoint::Make(fClip.width(), fClip.height()); | 108 return SkIPoint::Make(fClip.width(), fClip.height()); |
| 109 } | 109 } |
| 110 | 110 |
| 111 void SKPBench::onDraw(int loops, SkCanvas* canvas) { | 111 void SKPBench::onDraw(int loops, SkCanvas* canvas) { |
| 112 SkASSERT(fDoLooping || 1 == loops); | 112 SkASSERT(fDoLooping || 1 == loops); |
| 113 if (fUseMultiPictureDraw) { | 113 while (1) { |
| 114 for (int i = 0; i < loops; i++) { | 114 if (fUseMultiPictureDraw) { |
| 115 this->drawMPDPicture(); | 115 this->drawMPDPicture(); |
| 116 } | 116 } else { |
| 117 } else { | |
| 118 for (int i = 0; i < loops; i++) { | |
| 119 this->drawPicture(); | 117 this->drawPicture(); |
| 120 } | 118 } |
| 119 if (0 == --loops) { |
| 120 break; |
| 121 } |
| 122 #if SK_SUPPORT_GPU |
| 123 // Ensure the GrContext doesn't batch across draw loops. |
| 124 if (GrContext* context = canvas->getGrContext()) { |
| 125 context->flush(); |
| 126 } |
| 127 #endif |
| 121 } | 128 } |
| 122 #if SK_SUPPORT_GPU | |
| 123 // Ensure the GrContext doesn't batch across draw loops. | |
| 124 if (GrContext* context = canvas->getGrContext()) { | |
| 125 context->flush(); | |
| 126 } | |
| 127 #endif | |
| 128 } | 129 } |
| 129 | 130 |
| 130 void SKPBench::drawMPDPicture() { | 131 void SKPBench::drawMPDPicture() { |
| 131 SkMultiPictureDraw mpd; | 132 SkMultiPictureDraw mpd; |
| 132 | 133 |
| 133 for (int j = 0; j < fTileRects.count(); ++j) { | 134 for (int j = 0; j < fTileRects.count(); ++j) { |
| 134 SkMatrix trans; | 135 SkMatrix trans; |
| 135 trans.setTranslate(-fTileRects[j].fLeft/fScale, | 136 trans.setTranslate(-fTileRects[j].fLeft/fScale, |
| 136 -fTileRects[j].fTop/fScale); | 137 -fTileRects[j].fTop/fScale); |
| 137 mpd.add(fSurfaces[j]->getCanvas(), fPic, &trans); | 138 mpd.add(fSurfaces[j]->getCanvas(), fPic, &trans); |
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 189 context->freeGpuResources(); | 190 context->freeGpuResources(); |
| 190 context->resetContext(); | 191 context->resetContext(); |
| 191 context->getGpu()->resetShaderCacheForTesting(); | 192 context->getGpu()->resetShaderCacheForTesting(); |
| 192 draw_pic_for_stats(canvas, context, fPic, keys, values, "first_frame"); | 193 draw_pic_for_stats(canvas, context, fPic, keys, values, "first_frame"); |
| 193 | 194 |
| 194 // draw second frame | 195 // draw second frame |
| 195 draw_pic_for_stats(canvas, context, fPic, keys, values, "second_frame"); | 196 draw_pic_for_stats(canvas, context, fPic, keys, values, "second_frame"); |
| 196 | 197 |
| 197 #endif | 198 #endif |
| 198 } | 199 } |
| OLD | NEW |