Skia Debugger can now save modified pictures.
Review URL: https://codereview.appspot.com/6442055
git-svn-id: http://skia.googlecode.com/svn/trunk@4821 2bbb7eff-a529-9590-31e7-b0007b416f81
diff --git a/debugger/QT/SkDebuggerGUI.cpp b/debugger/QT/SkDebuggerGUI.cpp
index 823fffc..830f0f6 100644
--- a/debugger/QT/SkDebuggerGUI.cpp
+++ b/debugger/QT/SkDebuggerGUI.cpp
@@ -25,6 +25,8 @@
, fActionPlay(this)
, fActionPause(this)
, fActionRewind(this)
+ , fActionSave(this)
+ , fActionSaveAs(this)
, fActionShowDeletes(this)
, fActionStepBack(this)
, fActionStepForward(this)
@@ -78,6 +80,8 @@
connect(&fCanvasWidget, SIGNAL(hitChanged(int)), &fSettingsWidget, SLOT(updateHit(int)));
connect(&fCanvasWidget, SIGNAL(scaleFactorChanged(float)), this, SLOT(actionScale(float)));
connect(&fCanvasWidget, SIGNAL(commandChanged(int)), &fSettingsWidget, SLOT(updateCommand(int)));
+ connect(&fActionSaveAs, SIGNAL(triggered()), this, SLOT(actionSaveAs()));
+ connect(&fActionSave, SIGNAL(triggered()), this, SLOT(actionSave()));
fMapper.setMapping(&fActionZoomIn, 1);
fMapper.setMapping(&fActionZoomOut, -1);
@@ -202,6 +206,23 @@
fListWidget.setCurrentRow(0);
}
+void SkDebuggerGUI::actionSave() {
+ QString filename;
+ filename.append(fPath);
+ filename.append("/");
+ filename.append(fDirectoryWidget.currentItem()->text());
+ saveToFile(filename);
+}
+
+void SkDebuggerGUI::actionSaveAs() {
+ QString filename = QFileDialog::getSaveFileName(this, "Save File", "",
+ "Skia Picture (*skp)");
+ if (!filename.endsWith(".skp", Qt::CaseInsensitive))
+ filename.append(".skp");
+ }
+ saveToFile(filename);
+}
+
void SkDebuggerGUI::actionScale(float scaleFactor) {
fSettingsWidget.setZoomText(scaleFactor);
}
@@ -230,6 +251,15 @@
}
}
+void SkDebuggerGUI::saveToFile(QString filename) {
+ SkFILEWStream file(filename.toAscii());
+ SkPicture picture;
+ SkCanvas* canvas = picture.beginRecording(100,100);
+ fCanvasWidget.getCurrentDebugCanvas()->draw(canvas);
+ picture.endRecording();
+ picture.serialize(&file);
+}
+
void SkDebuggerGUI::loadFile(QListWidgetItem *item) {
if (fDirectoryWidgetActive) {
QString fileName;
@@ -406,6 +436,13 @@
fActionRewind.setIcon(rewind);
fActionRewind.setText("Rewind");
+ fActionSave.setShortcut(QKeySequence::Save);
+ fActionSave.setText("Save");
+ fActionSave.setDisabled(true);
+ fActionSaveAs.setShortcut(QKeySequence::SaveAs);
+ fActionSaveAs.setText("Save As");
+ fActionSaveAs.setDisabled(true);
+
fActionShowDeletes.setShortcut(QKeySequence(tr("Ctrl+X")));
fActionShowDeletes.setText("Deleted Commands");
@@ -472,8 +509,7 @@
fToolBar.setToolButtonStyle(Qt::ToolButtonTextUnderIcon);
SkDebuggerGUI->addToolBar(Qt::TopToolBarArea, &fToolBar);
- QWidget *spacer = new QWidget();
- spacer->setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
+ fSpacer.setSizePolicy(QSizePolicy::Expanding, QSizePolicy::Expanding);
fToolBar.addAction(&fActionRewind);
fToolBar.addAction(&fActionStepBack);
@@ -483,7 +519,7 @@
fToolBar.addSeparator();
fToolBar.addAction(&fActionInspector);
fToolBar.addSeparator();
- fToolBar.addWidget(spacer);
+ fToolBar.addWidget(&fSpacer);
fToolBar.addWidget(&fFilter);
fToolBar.addAction(&fActionCancel);
@@ -496,6 +532,8 @@
// Menu Bar
fMenuFile.setTitle("File");
fMenuFile.addAction(&fActionOpen);
+ fMenuFile.addAction(&fActionSave);
+ fMenuFile.addAction(&fActionSaveAs);
fMenuFile.addAction(&fActionClose);
fMenuEdit.setTitle("Edit");
@@ -563,6 +601,8 @@
fMenuEdit.setDisabled(false);
fMenuNavigate.setDisabled(false);
fMenuView.setDisabled(false);
+ fActionSave.setDisabled(false);
+ fActionSaveAs.setDisabled(false);
fLoading = false;
actionPlay();
}
diff --git a/debugger/QT/SkDebuggerGUI.h b/debugger/QT/SkDebuggerGUI.h
index fcbf3b7..3e4d319 100644
--- a/debugger/QT/SkDebuggerGUI.h
+++ b/debugger/QT/SkDebuggerGUI.h
@@ -117,6 +117,16 @@
void actionRewind();
/**
+ Saves the current SKP with all modifications.
+ */
+ void actionSave();
+
+ /**
+ Saves the current SKP under a different name and/or location.
+ */
+ void actionSaveAs();
+
+ /**
Sends the scale factor information to the settings widget.
*/
void actionScale(float scaleFactor);
@@ -199,6 +209,8 @@
QAction fActionPlay;
QAction fActionPause;
QAction fActionRewind;
+ QAction fActionSave;
+ QAction fActionSaveAs;
QAction fActionShowDeletes;
QAction fActionStepBack;
QAction fActionStepForward;
@@ -206,7 +218,7 @@
QAction fActionZoomOut;
QSignalMapper fMapper;
QWidget fCentralWidget;
-
+ QWidget fSpacer;
QComboBox fFilter;
QVBoxLayout fLeftColumnLayout;
@@ -251,6 +263,11 @@
void loadPicture(QString fileName);
/**
+ Creates a picture of the current canvas.
+ */
+ void saveToFile(QString filename);
+
+ /**
Populates the list widget with the vector of strings passed in.
*/
void setupListWidget(std::vector<std::string>* cv);
diff --git a/debugger/QT/moc_SkDebuggerGUI.cpp b/debugger/QT/moc_SkDebuggerGUI.cpp
index cb1e571..0d207aa 100644
--- a/debugger/QT/moc_SkDebuggerGUI.cpp
+++ b/debugger/QT/moc_SkDebuggerGUI.cpp
@@ -1,7 +1,7 @@
/****************************************************************************
** Meta object code from reading C++ file 'SkDebuggerGUI.h'
**
-** Created: Wed Jul 25 15:04:14 2012
+** Created: Thu Jul 26 16:33:10 2012
** by: The Qt Meta Object Compiler version 62 (Qt 4.6.2)
**
** WARNING! All changes made in this file will be lost!
@@ -23,7 +23,7 @@
4, // revision
0, // classname
0, 0, // classinfo
- 27, 14, // methods
+ 29, 14, // methods
0, 0, // properties
0, 0, // enums/sets
0, 0, // constructors
@@ -46,20 +46,22 @@
224, 14, 14, 14, 0x08,
237, 175, 14, 14, 0x08,
262, 14, 14, 14, 0x08,
- 289, 277, 14, 14, 0x08,
- 308, 14, 14, 14, 0x08,
- 325, 14, 14, 14, 0x08,
- 342, 14, 14, 14, 0x08,
- 367, 362, 14, 14, 0x08,
- 394, 14, 14, 14, 0x08,
- 414, 405, 14, 14, 0x08,
- 433, 14, 14, 14, 0x28,
- 448, 362, 14, 14, 0x08,
- 484, 15, 14, 14, 0x08,
- 503, 14, 14, 14, 0x08,
- 517, 14, 14, 14, 0x08,
- 536, 14, 14, 14, 0x08,
- 561, 554, 14, 14, 0x08,
+ 277, 14, 14, 14, 0x08,
+ 290, 14, 14, 14, 0x08,
+ 317, 305, 14, 14, 0x08,
+ 336, 14, 14, 14, 0x08,
+ 353, 14, 14, 14, 0x08,
+ 370, 14, 14, 14, 0x08,
+ 395, 390, 14, 14, 0x08,
+ 422, 14, 14, 14, 0x08,
+ 442, 433, 14, 14, 0x08,
+ 461, 14, 14, 14, 0x28,
+ 476, 390, 14, 14, 0x08,
+ 512, 15, 14, 14, 0x08,
+ 531, 14, 14, 14, 0x08,
+ 545, 14, 14, 14, 0x08,
+ 564, 14, 14, 14, 0x08,
+ 589, 582, 14, 14, 0x08,
0 // eod
};
@@ -69,15 +71,15 @@
"actionBreakpoints()\0actionCancel()\0"
"actionClearBreakpoints()\0actionClearDeletes()\0"
"actionCommandFilter()\0actionClose()\0"
- "actionDelete()\0setHidden\0actionGLWidget(bool)\0"
+ "actionDelete()\0isToggled\0actionGLWidget(bool)\0"
"actionInspector()\0actionPlay()\0"
"actionRasterWidget(bool)\0actionRewind()\0"
- "scaleFactor\0actionScale(float)\0"
- "actionSettings()\0actionStepBack()\0"
- "actionStepForward()\0item\0"
- "loadFile(QListWidgetItem*)\0openFile()\0"
- "isPaused\0pauseDrawing(bool)\0pauseDrawing()\0"
- "registerListClick(QListWidgetItem*)\0"
+ "actionSave()\0actionSaveAs()\0scaleFactor\0"
+ "actionScale(float)\0actionSettings()\0"
+ "actionStepBack()\0actionStepForward()\0"
+ "item\0loadFile(QListWidgetItem*)\0"
+ "openFile()\0isPaused\0pauseDrawing(bool)\0"
+ "pauseDrawing()\0registerListClick(QListWidgetItem*)\0"
"selectCommand(int)\0showDeletes()\0"
"toggleBreakpoint()\0toggleDirectory()\0"
"string\0toggleFilter(QString)\0"
@@ -125,23 +127,25 @@
case 10: actionPlay(); break;
case 11: actionRasterWidget((*reinterpret_cast< bool(*)>(_a[1]))); break;
case 12: actionRewind(); break;
- case 13: actionScale((*reinterpret_cast< float(*)>(_a[1]))); break;
- case 14: actionSettings(); break;
- case 15: actionStepBack(); break;
- case 16: actionStepForward(); break;
- case 17: loadFile((*reinterpret_cast< QListWidgetItem*(*)>(_a[1]))); break;
- case 18: openFile(); break;
- case 19: pauseDrawing((*reinterpret_cast< bool(*)>(_a[1]))); break;
- case 20: pauseDrawing(); break;
- case 21: registerListClick((*reinterpret_cast< QListWidgetItem*(*)>(_a[1]))); break;
- case 22: selectCommand((*reinterpret_cast< int(*)>(_a[1]))); break;
- case 23: showDeletes(); break;
- case 24: toggleBreakpoint(); break;
- case 25: toggleDirectory(); break;
- case 26: toggleFilter((*reinterpret_cast< QString(*)>(_a[1]))); break;
+ case 13: actionSave(); break;
+ case 14: actionSaveAs(); break;
+ case 15: actionScale((*reinterpret_cast< float(*)>(_a[1]))); break;
+ case 16: actionSettings(); break;
+ case 17: actionStepBack(); break;
+ case 18: actionStepForward(); break;
+ case 19: loadFile((*reinterpret_cast< QListWidgetItem*(*)>(_a[1]))); break;
+ case 20: openFile(); break;
+ case 21: pauseDrawing((*reinterpret_cast< bool(*)>(_a[1]))); break;
+ case 22: pauseDrawing(); break;
+ case 23: registerListClick((*reinterpret_cast< QListWidgetItem*(*)>(_a[1]))); break;
+ case 24: selectCommand((*reinterpret_cast< int(*)>(_a[1]))); break;
+ case 25: showDeletes(); break;
+ case 26: toggleBreakpoint(); break;
+ case 27: toggleDirectory(); break;
+ case 28: toggleFilter((*reinterpret_cast< QString(*)>(_a[1]))); break;
default: ;
}
- _id -= 27;
+ _id -= 29;
}
return _id;
}
diff --git a/debugger/SkDebugCanvas.cpp b/debugger/SkDebugCanvas.cpp
index c5f0c2d..9510e65 100644
--- a/debugger/SkDebugCanvas.cpp
+++ b/debugger/SkDebugCanvas.cpp
@@ -29,7 +29,9 @@
void SkDebugCanvas::draw(SkCanvas* canvas) {
if(!commandVector.empty()) {
for(it = commandVector.begin(); it != commandVector.end(); ++it) {
- (*it)->execute(canvas);
+ if ((*it)->getVisibility()) {
+ (*it)->execute(canvas);
+ }
}
}
}