| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 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 "SkDebuggerGUI.h" | 8 #include "SkDebuggerGUI.h" |
| 9 #include "SkForceLinking.h" | 9 #include "SkForceLinking.h" |
| 10 #include "SkGraphics.h" | 10 #include "SkGraphics.h" |
| (...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 152 QListWidgetItem *item = fListWidget.item(row); | 152 QListWidgetItem *item = fListWidget.item(row); |
| 153 item->setHidden(fDebugger.isCommandVisible(row) && fDeletesActivated); | 153 item->setHidden(fDebugger.isCommandVisible(row) && fDeletesActivated); |
| 154 } | 154 } |
| 155 } | 155 } |
| 156 | 156 |
| 157 // The timed picture playback uses the SkPicturePlayback's profiling stubs | 157 // The timed picture playback uses the SkPicturePlayback's profiling stubs |
| 158 // to time individual commands. The offsets are needed to map SkPicture | 158 // to time individual commands. The offsets are needed to map SkPicture |
| 159 // offsets to individual commands. | 159 // offsets to individual commands. |
| 160 class SkTimedPicturePlayback : public SkPicturePlayback { | 160 class SkTimedPicturePlayback : public SkPicturePlayback { |
| 161 public: | 161 public: |
| 162 static SkTimedPicturePlayback* CreateFromStream(SkStream* stream, const SkPi
ctInfo& info, | 162 static SkTimedPicturePlayback* CreateFromStream(SkPicture* picture, |
| 163 SkStream* stream, const SkPi
ctInfo& info, |
| 163 SkPicture::InstallPixelRefPr
oc proc, | 164 SkPicture::InstallPixelRefPr
oc proc, |
| 164 const SkTDArray<bool>& delet
edCommands) { | 165 const SkTDArray<bool>& delet
edCommands) { |
| 165 // Mimics SkPicturePlayback::CreateFromStream | 166 // Mimics SkPicturePlayback::CreateFromStream |
| 166 SkAutoTDelete<SkTimedPicturePlayback> playback(SkNEW_ARGS(SkTimedPicture
Playback, | 167 SkAutoTDelete<SkTimedPicturePlayback> playback(SkNEW_ARGS(SkTimedPicture
Playback, |
| 167 (deletedComman
ds, info))); | 168 (picture, deleted
Commands, info))); |
| 168 if (!playback->parseStream(stream, proc)) { | 169 if (!playback->parseStream(picture, stream, proc)) { |
| 169 return NULL; // we're invalid | 170 return NULL; // we're invalid |
| 170 } | 171 } |
| 171 return playback.detach(); | 172 return playback.detach(); |
| 172 } | 173 } |
| 173 | 174 |
| 174 SkTimedPicturePlayback(const SkTDArray<bool>& deletedCommands, const SkPictI
nfo& info) | 175 SkTimedPicturePlayback(SkPicture* picture, |
| 175 : INHERITED(info) | 176 const SkTDArray<bool>& deletedCommands, |
| 177 const SkPictInfo& info) |
| 178 : INHERITED(picture, info) |
| 176 , fSkipCommands(deletedCommands) | 179 , fSkipCommands(deletedCommands) |
| 177 , fTot(0.0) | 180 , fTot(0.0) |
| 178 , fCurCommand(0) { | 181 , fCurCommand(0) { |
| 179 fTimes.setCount(deletedCommands.count()); | 182 fTimes.setCount(deletedCommands.count()); |
| 180 fTypeTimes.setCount(LAST_DRAWTYPE_ENUM+1); | 183 fTypeTimes.setCount(LAST_DRAWTYPE_ENUM+1); |
| 181 this->resetTimes(); | 184 this->resetTimes(); |
| 182 } | 185 } |
| 183 | 186 |
| 184 void resetTimes() { | 187 void resetTimes() { |
| 185 for (int i = 0; i < fTimes.count(); ++i) { | 188 for (int i = 0; i < fTimes.count(); ++i) { |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 261 class SkTimedPicture : public SkPicture { | 264 class SkTimedPicture : public SkPicture { |
| 262 public: | 265 public: |
| 263 static SkTimedPicture* CreateTimedPicture(SkStream* stream, | 266 static SkTimedPicture* CreateTimedPicture(SkStream* stream, |
| 264 SkPicture::InstallPixelRefProc pro
c, | 267 SkPicture::InstallPixelRefProc pro
c, |
| 265 const SkTDArray<bool>& deletedComm
ands) { | 268 const SkTDArray<bool>& deletedComm
ands) { |
| 266 SkPictInfo info; | 269 SkPictInfo info; |
| 267 if (!InternalOnly_StreamIsSKP(stream, &info)) { | 270 if (!InternalOnly_StreamIsSKP(stream, &info)) { |
| 268 return NULL; | 271 return NULL; |
| 269 } | 272 } |
| 270 | 273 |
| 271 SkTimedPicturePlayback* playback; | 274 SkTimedPicture* newPict = SkNEW_ARGS(SkTimedPicture, (NULL, info.fWidth,
info.fHeight)); |
| 272 // Check to see if there is a playback to recreate. | 275 // Check to see if there is a playback to recreate. |
| 273 if (stream->readBool()) { | 276 if (stream->readBool()) { |
| 274 playback = SkTimedPicturePlayback::CreateFromStream(stream, info, pr
oc, | 277 SkTimedPicturePlayback* playback = SkTimedPicturePlayback::CreateFro
mStream( |
| 278 newPict, stream, |
| 279 info, proc, |
| 275 deletedCommands)
; | 280 deletedCommands)
; |
| 276 if (NULL == playback) { | 281 if (NULL == playback) { |
| 282 SkDELETE(newPict); |
| 277 return NULL; | 283 return NULL; |
| 278 } | 284 } |
| 279 } else { | 285 newPict->fPlayback = playback; |
| 280 playback = NULL; | |
| 281 } | 286 } |
| 282 | 287 |
| 283 return SkNEW_ARGS(SkTimedPicture, (playback, info.fWidth, info.fHeight))
; | 288 return newPict; |
| 284 } | 289 } |
| 285 | 290 |
| 286 void resetTimes() { ((SkTimedPicturePlayback*) fPlayback)->resetTimes(); } | 291 void resetTimes() { ((SkTimedPicturePlayback*) fPlayback)->resetTimes(); } |
| 287 | 292 |
| 288 int count() const { return ((SkTimedPicturePlayback*) fPlayback)->count(); } | 293 int count() const { return ((SkTimedPicturePlayback*) fPlayback)->count(); } |
| 289 | 294 |
| 290 // return the fraction of the total time this command consumed | 295 // return the fraction of the total time this command consumed |
| 291 double time(int index) const { return ((SkTimedPicturePlayback*) fPlayback)-
>time(index); } | 296 double time(int index) const { return ((SkTimedPicturePlayback*) fPlayback)-
>time(index); } |
| 292 | 297 |
| 293 const SkTDArray<double>* typeTimes() const { return ((SkTimedPicturePlayback
*) fPlayback)->typeTimes(); } | 298 const SkTDArray<double>* typeTimes() const { return ((SkTimedPicturePlayback
*) fPlayback)->typeTimes(); } |
| (...skipping 759 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1053 } | 1058 } |
| 1054 | 1059 |
| 1055 // NOTE(chudy): Makes first item unselectable. | 1060 // NOTE(chudy): Makes first item unselectable. |
| 1056 QStandardItemModel* model = qobject_cast<QStandardItemModel*>( | 1061 QStandardItemModel* model = qobject_cast<QStandardItemModel*>( |
| 1057 fFilter.model()); | 1062 fFilter.model()); |
| 1058 QModelIndex firstIndex = model->index(0, fFilter.modelColumn(), | 1063 QModelIndex firstIndex = model->index(0, fFilter.modelColumn(), |
| 1059 fFilter.rootModelIndex()); | 1064 fFilter.rootModelIndex()); |
| 1060 QStandardItem* firstItem = model->itemFromIndex(firstIndex); | 1065 QStandardItem* firstItem = model->itemFromIndex(firstIndex); |
| 1061 firstItem->setSelectable(false); | 1066 firstItem->setSelectable(false); |
| 1062 } | 1067 } |
| OLD | NEW |