1 2 /* 3 * Copyright 2012 Google Inc. 4 * 5 * Use of this source code is governed by a BSD-style license that can be 6 * found in the LICENSE file. 7 */ 8 9 #ifndef SKDEBUGGERUI_H 10 #define SKDEBUGGERUI_H 11 12 13 #include "SkCanvas.h" 14 #include "SkCanvasWidget.h" 15 #include "SkDebugger.h" 16 #include "SkGLWidget.h" 17 #include "SkListWidget.h" 18 #include "SkInspectorWidget.h" 19 #include "SkRasterWidget.h" 20 #include "SkDrawCommandGeometryWidget.h" 21 #include "SkSettingsWidget.h" 22 #include <QtCore/QFileSystemWatcher> 23 #include <QtCore/QSignalMapper> 24 #include <QtCore/QVariant> 25 #include <QtGui/QAction> 26 #include <QtGui/QApplication> 27 #include <QtGui/QButtonGroup> 28 #include <QtGui/QHBoxLayout> 29 #include <QtGui/QHeaderView> 30 #include <QtGui/QListView> 31 #include <QtGui/QListWidget> 32 #include <QtGui/QMainWindow> 33 #include <QtGui/QSplitter> 34 #include <QtGui/QStatusBar> 35 #include <QtGui/QToolBar> 36 #include <QtGui/QVBoxLayout> 37 #include <QtGui/QWidget> 38 #include <QtGui/QMenu> 39 #include <QtGui/QMenuBar> 40 #include <vector> 41 42 /** \class SkDebuggerGUI 43 44 Container for the UI and it's functions. 45 */ 46 class SkDebuggerGUI : public QMainWindow { 47 Q_OBJECT 48 49 public: 50 /** 51 Constructs the view of the application. 52 @param parent The parent container of this widget. 53 */ 54 SkDebuggerGUI(QWidget *parent = 0); 55 56 /** 57 Updates the directory widget with the latest directory path stored in 58 the global class variable fPath. 59 */ 60 void setupDirectoryWidget(const QString& path); 61 62 /** 63 Loads the specified file. 64 */ 65 void openFile(const QString& filename); 66 67 Q_SIGNALS: 68 void commandChanged(int command); 69 70 private Q_SLOTS: 71 /** 72 Toggles breakpoint view in the list widget. 73 */ 74 void actionBreakpoints(); 75 76 /** 77 Cancels the command filter in the list widget. 78 */ 79 void actionCancel(); 80 81 /** 82 Clears the breakpoint state off of all commands marked as breakpoints. 83 */ 84 void actionClearBreakpoints(); 85 86 /** 87 Clears the deleted state off of all commands marked as deleted. 88 */ 89 void actionClearDeletes(); 90 91 /** 92 Closes the application. 93 */ 94 void actionClose(); 95 96 /** 97 Deletes the command in question. 98 */ 99 void actionDelete(); 100 101 #if SK_SUPPORT_GPU 102 /** 103 Updates the visibility of the GL canvas widget and sample count of the GL surface. 104 */ 105 void actionGLSettingsChanged(); 106 #endif 107 108 /** 109 Toggles the visibility of the inspector widget. 110 */ 111 void actionInspector(); 112 113 /** 114 Plays from the current step to the next breakpoint if it exists, otherwise 115 executes all remaining draw commands. 116 */ 117 void actionPlay(); 118 119 /** 120 Sets the visibility of the raster canvas widget according to the settings widget. 121 */ 122 void actionRasterSettingsChanged(); 123 124 /** 125 Sets the visualization settings according to the settings widget. 126 */ 127 void actionVisualizationsChanged(); 128 129 /** 130 Applies the new texture filter override 131 */ 132 void actionTextureFilter(); 133 134 /** 135 Rewinds from the current step back to the start of the commands. 136 */ 137 void actionRewind(); 138 139 /** 140 Saves the current SKP with all modifications. 141 */ 142 void actionSave(); 143 144 /** 145 Saves the current SKP under a different name and/or location. 146 */ 147 void actionSaveAs(); 148 149 /** 150 Sends the scale factor information to the settings widget. 151 */ 152 void actionScale(float scaleFactor); 153 154 /** 155 Toggles the settings widget visibility. 156 */ 157 void actionSettings(); 158 159 /** 160 Steps forward to the next draw command. 161 */ 162 void actionStepBack(); 163 164 /** 165 Steps backwards to the next draw command. 166 */ 167 void actionStepForward(); 168 169 /** 170 Called when the canvas is done being drawn to by SkCanvasWidget. 171 */ 172 void drawComplete(); 173 174 /** 175 Loads an skpicture selected from the directory. 176 */ 177 void loadFile(QListWidgetItem *item); 178 179 /** 180 Toggles a dialog with a file browser for navigating to a skpicture. Loads 181 the selected file. 182 */ 183 void openFile(); 184 185 /** 186 Toggles whether drawing to a new command requires a double click 187 or simple focus. 188 */ 189 void pauseDrawing(bool isPaused = true); 190 191 /** 192 Updates the UI based on the selected command. 193 */ 194 void updateDrawCommandInfo(); 195 196 /** 197 Sets the command to active in the list widget. 198 */ 199 void selectCommand(int command); 200 201 /** 202 Toggles the exclusive listing of commands set as deleted. 203 */ 204 void showDeletes(); 205 206 /** 207 Toggles a breakpoint on the current step in the list widget. 208 */ 209 void toggleBreakpoint(); 210 211 /** 212 Toggles the visibility of the directory widget. 213 */ 214 void toggleDirectory(); 215 216 /** 217 Populates the contents of the directory widget with the skp files in the 218 current directory pointed to by fFile. 219 */ 220 void populateDirectoryWidget(); 221 222 /** 223 Filters the list widgets command visibility based on the currently 224 active selection. 225 */ 226 void toggleFilter(QString string); 227 228 void updateHit(int newHit); 229 230 void updateImage(); 231 private: 232 QSplitter fCentralSplitter; 233 QStatusBar fStatusBar; 234 QToolBar fToolBar; 235 236 QAction fActionOpen; 237 QAction fActionBreakpoint; 238 QAction fActionCancel; 239 QAction fActionClearBreakpoints; 240 QAction fActionClearDeletes; 241 QAction fActionClose; 242 QAction fActionCreateBreakpoint; 243 QAction fActionDelete; 244 QAction fActionDirectory; 245 QAction fActionGoToLine; 246 QAction fActionInspector; 247 QAction fActionSettings; 248 QAction fActionPlay; 249 QAction fActionPause; 250 QAction fActionRewind; 251 QAction fActionSave; 252 QAction fActionSaveAs; 253 QAction fActionShowDeletes; 254 QAction fActionStepBack; 255 QAction fActionStepForward; 256 QAction fActionZoomIn; 257 QAction fActionZoomOut; 258 QSignalMapper fMapper; 259 260 QWidget fSpacer; 261 QComboBox fFilter; 262 263 QSplitter fLeftColumnSplitter; 264 QWidget fMainAndRightColumnWidget; 265 QVBoxLayout fMainAndRightColumnLayout; 266 QHBoxLayout fCanvasSettingsAndImageLayout; 267 QVBoxLayout fSettingsAndImageLayout; 268 269 QListWidget fListWidget; 270 QListWidget fDirectoryWidget; 271 272 QFileSystemWatcher fDirectoryWatcher; 273 274 SkDebugger fDebugger; 275 SkCanvasWidget fCanvasWidget; 276 277 SkInspectorWidget fInspectorWidget; 278 SkSettingsWidget fSettingsWidget; 279 280 QFrame fViewStateFrame; 281 QVBoxLayout fViewStateFrameLayout; 282 QGroupBox fViewStateGroup; 283 QFormLayout fViewStateLayout; 284 QLineEdit fCurrentCommandBox; 285 QLineEdit fCommandHitBox; 286 QLineEdit fZoomBox; 287 SkDrawCommandGeometryWidget fDrawCommandGeometryWidget; 288 289 QString fPath; 290 SkString fFileName; 291 SkTDArray<bool> fSkipCommands; // has a specific command been deleted? 292 293 QMenuBar fMenuBar; 294 QMenu fMenuFile; 295 QMenu fMenuEdit; 296 QMenu fMenuNavigate; 297 QMenu fMenuView; 298 QMenu fMenuWindows; 299 300 bool fLoading; 301 int fPausedRow; 302 303 /** 304 Creates the entire UI. 305 */ 306 void setupUi(QMainWindow *SkDebuggerGUI); 307 308 /** 309 Pipes a QString in with the location of the filename, proceeds to updating 310 the listwidget, combowidget and inspectorwidget. 311 */ 312 void loadPicture(const SkString& fileName); 313 314 /** 315 Creates a picture of the current canvas. 316 */ 317 void saveToFile(const SkString& filename); 318 319 /** 320 Populates the list widget with the debugger draw command info. 321 */ 322 void setupListWidget(); 323 324 /** 325 Populates the combo box widget with with the debugger draw command info. 326 */ 327 void setupComboBox(); 328 329 /** 330 Fills in the overview pane with text 331 */ 332 void setupOverviewText(const SkTDArray<double>* typeTimes, double totTime, int numRuns); 333 isPaused()334 bool isPaused() const { 335 return fActionPause.isChecked(); 336 } 337 }; 338 339 #endif // SKDEBUGGERUI_H 340