summaryrefslogtreecommitdiff
path: root/noncore/graphics
authorleseb <leseb>2002-03-17 15:31:12 (UTC)
committer leseb <leseb>2002-03-17 15:31:12 (UTC)
commit378db8490c6c80ced939622605be1500fa126a2d (patch) (unidiff)
treeb39bbe287f70a1e867060eb14b86536e7d727d17 /noncore/graphics
parent31e0537b3406d3e89df6424cded2570d28d61df4 (diff)
downloadopie-378db8490c6c80ced939622605be1500fa126a2d.zip
opie-378db8490c6c80ced939622605be1500fa126a2d.tar.gz
opie-378db8490c6c80ced939622605be1500fa126a2d.tar.bz2
Basic undo/redo
Diffstat (limited to 'noncore/graphics') (more/less context) (show whitespace changes)
-rw-r--r--noncore/graphics/drawpad/drawmode.h6
-rw-r--r--noncore/graphics/drawpad/drawpad.cpp81
-rw-r--r--noncore/graphics/drawpad/drawpad.h17
-rw-r--r--noncore/graphics/drawpad/drawpadcanvas.cpp135
-rw-r--r--noncore/graphics/drawpad/drawpadcanvas.h12
5 files changed, 159 insertions, 92 deletions
diff --git a/noncore/graphics/drawpad/drawmode.h b/noncore/graphics/drawpad/drawmode.h
index d4ecadd..4e80fe2 100644
--- a/noncore/graphics/drawpad/drawmode.h
+++ b/noncore/graphics/drawpad/drawmode.h
@@ -18,15 +18,17 @@
18 18
19class DrawPad; 19class DrawPad;
20class DrawPadCanvas; 20class DrawPadCanvas;
21 21
22class DrawMode : QObject 22class DrawMode : QObject
23{ 23{
24public: 24protected:
25 DrawMode(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas); 25 DrawMode(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas);
26 ~DrawMode(); 26
27public:
28 virtual ~DrawMode();
27 29
28 virtual void mousePressEvent(QMouseEvent* e) = 0; 30 virtual void mousePressEvent(QMouseEvent* e) = 0;
29 virtual void mouseReleaseEvent(QMouseEvent* e) = 0; 31 virtual void mouseReleaseEvent(QMouseEvent* e) = 0;
30 virtual void mouseMoveEvent(QMouseEvent* e) = 0; 32 virtual void mouseMoveEvent(QMouseEvent* e) = 0;
31 33
32protected: 34protected:
diff --git a/noncore/graphics/drawpad/drawpad.cpp b/noncore/graphics/drawpad/drawpad.cpp
index 3c593b6..5cc2197 100644
--- a/noncore/graphics/drawpad/drawpad.cpp
+++ b/noncore/graphics/drawpad/drawpad.cpp
@@ -38,12 +38,14 @@ DrawPad::DrawPad(QWidget* parent, const char* name, WFlags f)
38{ 38{
39 setCaption(tr("DrawPad")); 39 setCaption(tr("DrawPad"));
40 40
41 // init members 41 // init members
42 42
43 m_pDrawPadCanvas = new DrawPadCanvas(this, this); 43 m_pDrawPadCanvas = new DrawPadCanvas(this, this);
44 connect(m_pDrawPadCanvas, SIGNAL(pagesChanged()), this, SLOT(updateNavigationToolButtons()));
45 connect(m_pDrawPadCanvas, SIGNAL(pageBackupsChanged()), this, SLOT(updateUndoRedoToolButtons()));
44 46
45 QFile file(Global::applicationFileName("drawpad", "drawpad.xml")); 47 QFile file(Global::applicationFileName("drawpad", "drawpad.xml"));
46 48
47 if (file.open(IO_ReadOnly)) { 49 if (file.open(IO_ReadOnly)) {
48 m_pDrawPadCanvas->load(&file); 50 m_pDrawPadCanvas->load(&file);
49 file.close(); 51 file.close();
@@ -68,13 +70,13 @@ DrawPad::DrawPad(QWidget* parent, const char* name, WFlags f)
68 QPEToolBar* menuToolBar = new QPEToolBar(this); 70 QPEToolBar* menuToolBar = new QPEToolBar(this);
69 QPEMenuBar* menuBar = new QPEMenuBar(menuToolBar); 71 QPEMenuBar* menuBar = new QPEMenuBar(menuToolBar);
70 72
71 QPopupMenu *toolsPopupMenu = new QPopupMenu(menuBar); 73 QPopupMenu *toolsPopupMenu = new QPopupMenu(menuBar);
72 74
73 QAction* clearAllAction = new QAction(tr("Clear All"), QString::null, 0, this); 75 QAction* clearAllAction = new QAction(tr("Clear All"), QString::null, 0, this);
74 connect(clearAllAction, SIGNAL(activated()), this, SLOT(clearAll())); 76 connect(clearAllAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(clearAll()));
75 clearAllAction->addTo(toolsPopupMenu); 77 clearAllAction->addTo(toolsPopupMenu);
76 78
77 toolsPopupMenu->insertSeparator(); 79 toolsPopupMenu->insertSeparator();
78 80
79 QAction* setOptionsAction = new QAction(tr("Options"), tr("Options..."), 0, this); 81 QAction* setOptionsAction = new QAction(tr("Options"), tr("Options..."), 0, this);
80 setOptionsAction->addTo(toolsPopupMenu); 82 setOptionsAction->addTo(toolsPopupMenu);
@@ -83,47 +85,57 @@ DrawPad::DrawPad(QWidget* parent, const char* name, WFlags f)
83 85
84 // init page toolbar 86 // init page toolbar
85 87
86 QPEToolBar* pageToolBar = new QPEToolBar(this); 88 QPEToolBar* pageToolBar = new QPEToolBar(this);
87 89
88 QAction* newPageAction = new QAction(tr("New Page"), Resource::loadIconSet("new"), QString::null, 0, this); 90 QAction* newPageAction = new QAction(tr("New Page"), Resource::loadIconSet("new"), QString::null, 0, this);
89 connect(newPageAction, SIGNAL(activated()), this, SLOT(newPage())); 91 connect(newPageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(newPage()));
90 newPageAction->addTo(pageToolBar); 92 newPageAction->addTo(pageToolBar);
91 93
92 QAction* clearPageAction = new QAction(tr("Clear Page"), Resource::loadIconSet("drawpad/clear"), QString::null, 0, this); 94 QAction* clearPageAction = new QAction(tr("Clear Page"), Resource::loadIconSet("drawpad/clear"), QString::null, 0, this);
93 connect(clearPageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(clearPage())); 95 connect(clearPageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(clearPage()));
94 clearPageAction->addTo(pageToolBar); 96 clearPageAction->addTo(pageToolBar);
95 97
96 QAction* deletePageAction = new QAction(tr("Delete Page"), Resource::loadIconSet("trash"), QString::null, 0, this); 98 QAction* deletePageAction = new QAction(tr("Delete Page"), Resource::loadIconSet("trash"), QString::null, 0, this);
97 connect(deletePageAction, SIGNAL(activated()), this, SLOT(deletePage())); 99 connect(deletePageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(deletePage()));
98 deletePageAction->addTo(pageToolBar); 100 deletePageAction->addTo(pageToolBar);
99 101
100 QPEToolBar* emptyToolBar = new QPEToolBar(this); 102 QPEToolBar* emptyToolBar = new QPEToolBar(this);
101 emptyToolBar->setHorizontalStretchable(true); 103 emptyToolBar->setHorizontalStretchable(true);
102 104
103 // init navigation toolbar 105 // init navigation toolbar
104 106
105 QPEToolBar* navigationToolBar = new QPEToolBar(this); 107 QPEToolBar* navigationToolBar = new QPEToolBar(this);
106 108
109 m_pUndoAction = new QAction(tr("Undo"), Resource::loadIconSet("drawpad/undo"), QString::null, 0, this);
110 connect(m_pUndoAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(undo()));
111 m_pUndoAction->addTo(navigationToolBar);
112
113 m_pRedoAction = new QAction(tr("Redo"), Resource::loadIconSet("drawpad/redo"), QString::null, 0, this);
114 connect(m_pRedoAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(redo()));
115 m_pRedoAction->addTo(navigationToolBar);
116
117 updateUndoRedoToolButtons();
118
107 m_pFirstPageAction = new QAction(tr("First Page"), Resource::loadIconSet("fastback"), QString::null, 0, this); 119 m_pFirstPageAction = new QAction(tr("First Page"), Resource::loadIconSet("fastback"), QString::null, 0, this);
108 connect(m_pFirstPageAction, SIGNAL(activated()), this, SLOT(goFirstPage())); 120 connect(m_pFirstPageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(goFirstPage()));
109 m_pFirstPageAction->addTo(navigationToolBar); 121 m_pFirstPageAction->addTo(navigationToolBar);
110 122
111 m_pPreviousPageAction = new QAction(tr("Previous Page"), Resource::loadIconSet("back"), QString::null, 0, this); 123 m_pPreviousPageAction = new QAction(tr("Previous Page"), Resource::loadIconSet("back"), QString::null, 0, this);
112 connect(m_pPreviousPageAction, SIGNAL(activated()), this, SLOT(goPreviousPage())); 124 connect(m_pPreviousPageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(goPreviousPage()));
113 m_pPreviousPageAction->addTo(navigationToolBar); 125 m_pPreviousPageAction->addTo(navigationToolBar);
114 126
115 m_pNextPageAction = new QAction(tr("Next Page"), Resource::loadIconSet("forward"), QString::null, 0, this); 127 m_pNextPageAction = new QAction(tr("Next Page"), Resource::loadIconSet("forward"), QString::null, 0, this);
116 connect(m_pNextPageAction, SIGNAL(activated()), this, SLOT(goNextPage())); 128 connect(m_pNextPageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(goNextPage()));
117 m_pNextPageAction->addTo(navigationToolBar); 129 m_pNextPageAction->addTo(navigationToolBar);
118 130
119 m_pLastPageAction = new QAction(tr("Last Page"), Resource::loadIconSet("fastforward"), QString::null, 0, this); 131 m_pLastPageAction = new QAction(tr("Last Page"), Resource::loadIconSet("fastforward"), QString::null, 0, this);
120 connect(m_pLastPageAction, SIGNAL(activated()), this, SLOT(goLastPage())); 132 connect(m_pLastPageAction, SIGNAL(activated()), m_pDrawPadCanvas, SLOT(goLastPage()));
121 m_pLastPageAction->addTo(navigationToolBar); 133 m_pLastPageAction->addTo(navigationToolBar);
122 134
123 updateNavigationToolBar(); 135 updateNavigationToolButtons();
124 136
125 // init draw mode toolbar 137 // init draw mode toolbar
126 138
127 QPEToolBar* drawModeToolBar = new QPEToolBar(this); 139 QPEToolBar* drawModeToolBar = new QPEToolBar(this);
128 140
129 m_pPointDrawModeAction = new QAction(tr("Draw Point"), Resource::loadIconSet("drawpad/point.png"), QString::null, 0, this); 141 m_pPointDrawModeAction = new QAction(tr("Draw Point"), Resource::loadIconSet("drawpad/point.png"), QString::null, 0, this);
@@ -158,12 +170,15 @@ DrawPad::DrawPad(QWidget* parent, const char* name, WFlags f)
158 170
159 m_pDrawMode = 0; 171 m_pDrawMode = 0;
160 setPointDrawMode(); 172 setPointDrawMode();
161 173
162 emptyToolBar = new QPEToolBar(this); 174 emptyToolBar = new QPEToolBar(this);
163 emptyToolBar->setHorizontalStretchable(true); 175 emptyToolBar->setHorizontalStretchable(true);
176 emptyToolBar->addSeparator();
177
178 // init draw parameters toolbar
164 179
165 QPEToolBar* drawParametersToolBar = new QPEToolBar(this); 180 QPEToolBar* drawParametersToolBar = new QPEToolBar(this);
166 181
167 QSpinBox* penWidthSpinBox = new QSpinBox(1, 9, 1, drawParametersToolBar); 182 QSpinBox* penWidthSpinBox = new QSpinBox(1, 9, 1, drawParametersToolBar);
168 connect(penWidthSpinBox, SIGNAL(valueChanged(int)), this, SLOT(changePenWidth(int))); 183 connect(penWidthSpinBox, SIGNAL(valueChanged(int)), this, SLOT(changePenWidth(int)));
169 184
@@ -215,54 +230,12 @@ DrawPad::~DrawPad()
215 if (file.open(IO_WriteOnly)) { 230 if (file.open(IO_WriteOnly)) {
216 m_pDrawPadCanvas->save(&file); 231 m_pDrawPadCanvas->save(&file);
217 file.close(); 232 file.close();
218 } 233 }
219} 234}
220 235
221void DrawPad::clearAll()
222{
223 m_pDrawPadCanvas->clearAll();
224 updateNavigationToolBar();
225}
226
227void DrawPad::newPage()
228{
229 m_pDrawPadCanvas->newPage();
230 updateNavigationToolBar();
231}
232
233void DrawPad::deletePage()
234{
235 m_pDrawPadCanvas->deletePage();
236 updateNavigationToolBar();
237}
238
239void DrawPad::goFirstPage()
240{
241 m_pDrawPadCanvas->goFirstPage();
242 updateNavigationToolBar();
243}
244
245void DrawPad::goPreviousPage()
246{
247 m_pDrawPadCanvas->goPreviousPage();
248 updateNavigationToolBar();
249}
250
251void DrawPad::goNextPage()
252{
253 m_pDrawPadCanvas->goNextPage();
254 updateNavigationToolBar();
255}
256
257void DrawPad::goLastPage()
258{
259 m_pDrawPadCanvas->goLastPage();
260 updateNavigationToolBar();
261}
262
263void DrawPad::setPointDrawMode() 236void DrawPad::setPointDrawMode()
264{ 237{
265 if (m_pDrawMode) { 238 if (m_pDrawMode) {
266 delete m_pDrawMode; 239 delete m_pDrawMode;
267 } 240 }
268 241
@@ -378,13 +351,19 @@ void DrawPad::changeBrushColor(int index)
378 QPainter painter; 351 QPainter painter;
379 painter.begin(m_pBrushColorToolButton->pixmap()); 352 painter.begin(m_pBrushColorToolButton->pixmap());
380 painter.fillRect(QRect(0, 12, 14, 2), m_brush.color()); 353 painter.fillRect(QRect(0, 12, 14, 2), m_brush.color());
381 painter.end(); 354 painter.end();
382} 355}
383 356
384void DrawPad::updateNavigationToolBar() 357void DrawPad::updateUndoRedoToolButtons()
358{
359 m_pUndoAction->setEnabled(m_pDrawPadCanvas->undoEnabled());
360 m_pRedoAction->setEnabled(m_pDrawPadCanvas->redoEnabled());
361}
362
363void DrawPad::updateNavigationToolButtons()
385{ 364{
386 m_pFirstPageAction->setEnabled(m_pDrawPadCanvas->goPreviousPageEnabled()); 365 m_pFirstPageAction->setEnabled(m_pDrawPadCanvas->goPreviousPageEnabled());
387 m_pPreviousPageAction->setEnabled(m_pDrawPadCanvas->goPreviousPageEnabled()); 366 m_pPreviousPageAction->setEnabled(m_pDrawPadCanvas->goPreviousPageEnabled());
388 m_pNextPageAction->setEnabled(m_pDrawPadCanvas->goNextPageEnabled()); 367 m_pNextPageAction->setEnabled(m_pDrawPadCanvas->goNextPageEnabled());
389 m_pLastPageAction->setEnabled(m_pDrawPadCanvas->goNextPageEnabled()); 368 m_pLastPageAction->setEnabled(m_pDrawPadCanvas->goNextPageEnabled());
390} 369}
diff --git a/noncore/graphics/drawpad/drawpad.h b/noncore/graphics/drawpad/drawpad.h
index 0ece408..ee81ddf 100644
--- a/noncore/graphics/drawpad/drawpad.h
+++ b/noncore/graphics/drawpad/drawpad.h
@@ -36,42 +36,37 @@ public:
36 36
37 DrawMode* drawMode() { return m_pDrawMode; } 37 DrawMode* drawMode() { return m_pDrawMode; }
38 QPen pen() { return m_pen; } 38 QPen pen() { return m_pen; }
39 QBrush brush() { return m_brush; } 39 QBrush brush() { return m_brush; }
40 40
41private slots: 41private slots:
42 void clearAll();
43 void newPage();
44 void deletePage();
45
46 void goFirstPage();
47 void goPreviousPage();
48 void goNextPage();
49 void goLastPage();
50
51 void setPointDrawMode(); 42 void setPointDrawMode();
52 void setLineDrawMode(); 43 void setLineDrawMode();
53 void setRectangleDrawMode(); 44 void setRectangleDrawMode();
54 void setEllipseDrawMode(); 45 void setEllipseDrawMode();
55 void setFillDrawMode(); 46 void setFillDrawMode();
56 void setEraseDrawMode(); 47 void setEraseDrawMode();
57 48
58 void changePenWidth(int value); 49 void changePenWidth(int value);
59 void changePenColor(int index); 50 void changePenColor(int index);
60 void changeBrushColor(int index); 51 void changeBrushColor(int index);
61 52
62private: 53 void updateUndoRedoToolButtons();
63 void updateNavigationToolBar(); 54 void updateNavigationToolButtons();
64 55
56private:
65 DrawPadCanvas* m_pDrawPadCanvas; 57 DrawPadCanvas* m_pDrawPadCanvas;
66 QArray<QColor> m_colors; 58 QArray<QColor> m_colors;
67 59
68 DrawMode* m_pDrawMode; 60 DrawMode* m_pDrawMode;
69 QPen m_pen; 61 QPen m_pen;
70 QBrush m_brush; 62 QBrush m_brush;
71 63
64 QAction* m_pUndoAction;
65 QAction* m_pRedoAction;
66
72 QAction* m_pFirstPageAction; 67 QAction* m_pFirstPageAction;
73 QAction* m_pPreviousPageAction; 68 QAction* m_pPreviousPageAction;
74 QAction* m_pNextPageAction; 69 QAction* m_pNextPageAction;
75 QAction* m_pLastPageAction; 70 QAction* m_pLastPageAction;
76 71
77 QAction* m_pPointDrawModeAction; 72 QAction* m_pPointDrawModeAction;
diff --git a/noncore/graphics/drawpad/drawpadcanvas.cpp b/noncore/graphics/drawpad/drawpadcanvas.cpp
index f02f478..08f7b66 100644
--- a/noncore/graphics/drawpad/drawpadcanvas.cpp
+++ b/noncore/graphics/drawpad/drawpadcanvas.cpp
@@ -140,15 +140,17 @@ bool DrawPadCanvasXmlHandler::characters(const QString& ch)
140DrawPadCanvas::DrawPadCanvas(DrawPad* drawPad, QWidget* parent, const char* name, WFlags f) 140DrawPadCanvas::DrawPadCanvas(DrawPad* drawPad, QWidget* parent, const char* name, WFlags f)
141 : QWidget(parent, name, f) 141 : QWidget(parent, name, f)
142{ 142{
143 setBackgroundMode(QWidget::PaletteBase); 143 setBackgroundMode(QWidget::PaletteBase);
144 144
145 m_pDrawPad = drawPad; 145 m_pDrawPad = drawPad;
146 m_buffers.setAutoDelete(true); 146 m_pages.setAutoDelete(true);
147 m_buffers.append(new QPixmap(width(), height())); 147 m_pages.append(new QPixmap(width(), height()));
148 m_buffers.current()->fill(Qt::white); 148 m_pages.current()->fill(Qt::white);
149 m_pageBackups.setAutoDelete(true);
150 m_pageBackups.append(new QPixmap(*(m_pages.current())));
149} 151}
150 152
151DrawPadCanvas::~DrawPadCanvas() 153DrawPadCanvas::~DrawPadCanvas()
152{ 154{
153} 155}
154 156
@@ -161,31 +163,34 @@ void DrawPadCanvas::load(QIODevice* ioDevice)
161 QXmlSimpleReader xmlSimpleReader; 163 QXmlSimpleReader xmlSimpleReader;
162 DrawPadCanvasXmlHandler drawPadCanvasXmlHandler; 164 DrawPadCanvasXmlHandler drawPadCanvasXmlHandler;
163 165
164 xmlSimpleReader.setContentHandler(&drawPadCanvasXmlHandler); 166 xmlSimpleReader.setContentHandler(&drawPadCanvasXmlHandler);
165 xmlSimpleReader.parse(xmlInputSource); 167 xmlSimpleReader.parse(xmlInputSource);
166 168
167 m_buffers = drawPadCanvasXmlHandler.pixmaps(); 169 m_pages = drawPadCanvasXmlHandler.pixmaps();
168 170
169 if (m_buffers.isEmpty()) { 171 if (m_pages.isEmpty()) {
170 m_buffers.append(new QPixmap(width(), height())); 172 m_pages.append(new QPixmap(width(), height()));
171 m_buffers.current()->fill(Qt::white); 173 m_pages.current()->fill(Qt::white);
172 } 174 }
173 175
176 m_pageBackups.clear();
177 m_pageBackups.append(new QPixmap(*(m_pages.current())));
178
174 repaint(); 179 repaint();
175} 180}
176 181
177void DrawPadCanvas::save(QIODevice* ioDevice) 182void DrawPadCanvas::save(QIODevice* ioDevice)
178{ 183{
179 QTextStream textStream(ioDevice); 184 QTextStream textStream(ioDevice);
180 textStream.setCodec(QTextCodec::codecForName("UTF-8")); 185 textStream.setCodec(QTextCodec::codecForName("UTF-8"));
181 186
182 textStream << "<drawpad>" << endl; 187 textStream << "<drawpad>" << endl;
183 textStream << " <images>" << endl; 188 textStream << " <images>" << endl;
184 189
185 QListIterator<QPixmap> bufferIterator(m_buffers); 190 QListIterator<QPixmap> bufferIterator(m_pages);
186 191
187 for (bufferIterator.toFirst(); bufferIterator.current() != 0; ++bufferIterator) { 192 for (bufferIterator.toFirst(); bufferIterator.current() != 0; ++bufferIterator) {
188 textStream << " <image>" << endl; 193 textStream << " <image>" << endl;
189 194
190 QImage image = bufferIterator.current()->convertToImage(); 195 QImage image = bufferIterator.current()->convertToImage();
191 QByteArray byteArray; 196 QByteArray byteArray;
@@ -218,104 +223,180 @@ void DrawPadCanvas::save(QIODevice* ioDevice)
218 textStream << " </images>" << endl; 223 textStream << " </images>" << endl;
219 textStream << "</drawpad>"; 224 textStream << "</drawpad>";
220} 225}
221 226
222QPixmap* DrawPadCanvas::currentPage() 227QPixmap* DrawPadCanvas::currentPage()
223{ 228{
224 return m_buffers.current(); 229 return m_pages.current();
225} 230}
226 231
227void DrawPadCanvas::clearAll() 232void DrawPadCanvas::clearAll()
228{ 233{
229 m_buffers.clear(); 234 m_pages.clear();
235
236 m_pages.append(new QPixmap(width(), height()));
237 m_pages.current()->fill(Qt::white);
230 238
231 m_buffers.append(new QPixmap(width(), height())); 239 m_pageBackups.clear();
232 m_buffers.current()->fill(Qt::white); 240 m_pageBackups.append(new QPixmap(*(m_pages.current())));
233 241
234 repaint(); 242 repaint();
243
244 emit pagesChanged();
245 emit pageBackupsChanged();
235} 246}
236 247
237void DrawPadCanvas::newPage() 248void DrawPadCanvas::newPage()
238{ 249{
239 m_buffers.insert(m_buffers.at() + 1, new QPixmap(width(), height())); 250 m_pages.insert(m_pages.at() + 1, new QPixmap(width(), height()));
240 m_buffers.current()->fill(Qt::white); 251 m_pages.current()->fill(Qt::white);
252 m_pageBackups.clear();
253 m_pageBackups.append(new QPixmap(*(m_pages.current())));
241 repaint(); 254 repaint();
255
256 emit pagesChanged();
257 emit pageBackupsChanged();
242} 258}
243 259
244void DrawPadCanvas::clearPage() 260void DrawPadCanvas::clearPage()
245{ 261{
246 m_buffers.current()->fill(Qt::white); 262 m_pages.current()->fill(Qt::white);
247 repaint(); 263 repaint();
248} 264}
249 265
250void DrawPadCanvas::deletePage() 266void DrawPadCanvas::deletePage()
251{ 267{
252 m_buffers.remove(m_buffers.current()); 268 m_pages.remove(m_pages.current());
253 269
254 if (m_buffers.isEmpty()) { 270 if (m_pages.isEmpty()) {
255 m_buffers.append(new QPixmap(width(), height())); 271 m_pages.append(new QPixmap(width(), height()));
256 m_buffers.current()->fill(Qt::white); 272 m_pages.current()->fill(Qt::white);
257 } 273 }
258 274
275 m_pageBackups.clear();
276 m_pageBackups.append(new QPixmap(*(m_pages.current())));
277
259 repaint(); 278 repaint();
279
280 emit pagesChanged();
281 emit pageBackupsChanged();
282}
283
284bool DrawPadCanvas::undoEnabled()
285{
286 return (m_pageBackups.current() != m_pageBackups.getFirst());
287}
288
289bool DrawPadCanvas::redoEnabled()
290{
291 return (m_pageBackups.current() != m_pageBackups.getLast());
260} 292}
261 293
262bool DrawPadCanvas::goPreviousPageEnabled() 294bool DrawPadCanvas::goPreviousPageEnabled()
263{ 295{
264 return (m_buffers.current() != m_buffers.getFirst()); 296 return (m_pages.current() != m_pages.getFirst());
265} 297}
266 298
267bool DrawPadCanvas::goNextPageEnabled() 299bool DrawPadCanvas::goNextPageEnabled()
268{ 300{
269 return (m_buffers.current() != m_buffers.getLast()); 301 return (m_pages.current() != m_pages.getLast());
302}
303
304void DrawPadCanvas::undo()
305{
306 *(m_pages.current()) = *(m_pageBackups.prev());
307 repaint();
308
309 emit pageBackupsChanged();
310}
311
312void DrawPadCanvas::redo()
313{
314 *(m_pages.current()) = *(m_pageBackups.next());
315 repaint();
316
317 emit pageBackupsChanged();
270} 318}
271 319
272void DrawPadCanvas::goFirstPage() 320void DrawPadCanvas::goFirstPage()
273{ 321{
274 m_buffers.first(); 322 m_pages.first();
323 m_pageBackups.clear();
324 m_pageBackups.append(new QPixmap(*(m_pages.current())));
275 repaint(); 325 repaint();
326
327 emit pagesChanged();
328 emit pageBackupsChanged();
276} 329}
277 330
278void DrawPadCanvas::goPreviousPage() 331void DrawPadCanvas::goPreviousPage()
279{ 332{
280 m_buffers.prev(); 333 m_pages.prev();
334 m_pageBackups.clear();
335 m_pageBackups.append(new QPixmap(*(m_pages.current())));
281 repaint(); 336 repaint();
337
338 emit pagesChanged();
339 emit pageBackupsChanged();
282} 340}
283 341
284void DrawPadCanvas::goNextPage() 342void DrawPadCanvas::goNextPage()
285{ 343{
286 m_buffers.next(); 344 m_pages.next();
345 m_pageBackups.clear();
346 m_pageBackups.append(new QPixmap(*(m_pages.current())));
287 repaint(); 347 repaint();
348
349 emit pagesChanged();
350 emit pageBackupsChanged();
288} 351}
289 352
290void DrawPadCanvas::goLastPage() 353void DrawPadCanvas::goLastPage()
291{ 354{
292 m_buffers.last(); 355 m_pages.last();
356 m_pageBackups.clear();
357 m_pageBackups.append(new QPixmap(*(m_pages.current())));
293 repaint(); 358 repaint();
359
360 emit pagesChanged();
361 emit pageBackupsChanged();
294} 362}
295 363
296void DrawPadCanvas::mousePressEvent(QMouseEvent* e) 364void DrawPadCanvas::mousePressEvent(QMouseEvent* e)
297{ 365{
298 m_pDrawPad->drawMode()->mousePressEvent(e); 366 m_pDrawPad->drawMode()->mousePressEvent(e);
299} 367}
300 368
301void DrawPadCanvas::mouseReleaseEvent(QMouseEvent* e) 369void DrawPadCanvas::mouseReleaseEvent(QMouseEvent* e)
302{ 370{
303 m_pDrawPad->drawMode()->mouseReleaseEvent(e); 371 m_pDrawPad->drawMode()->mouseReleaseEvent(e);
372
373 QPixmap* currentBackup = m_pageBackups.current();
374 while (m_pageBackups.last() != currentBackup) {
375 m_pageBackups.removeLast();
376 }
377
378 while (m_pageBackups.count() >= (5 + 1)) {
379 m_pageBackups.removeFirst();
380 }
381
382 m_pageBackups.append(new QPixmap(*(m_pages.current())));
383
384 emit pageBackupsChanged();
304} 385}
305 386
306void DrawPadCanvas::mouseMoveEvent(QMouseEvent* e) 387void DrawPadCanvas::mouseMoveEvent(QMouseEvent* e)
307{ 388{
308 m_pDrawPad->drawMode()->mouseMoveEvent(e); 389 m_pDrawPad->drawMode()->mouseMoveEvent(e);
309} 390}
310 391
311void DrawPadCanvas::resizeEvent(QResizeEvent* e) 392void DrawPadCanvas::resizeEvent(QResizeEvent* e)
312{ 393{
313 QWidget::resizeEvent(e); 394 QWidget::resizeEvent(e);
314 395
315 QListIterator<QPixmap> bufferIterator(m_buffers); 396 QListIterator<QPixmap> bufferIterator(m_pages);
316 397
317 for (bufferIterator.toFirst(); bufferIterator.current() != 0; ++bufferIterator) { 398 for (bufferIterator.toFirst(); bufferIterator.current() != 0; ++bufferIterator) {
318 int w = width() > bufferIterator.current()->width() ? width() : bufferIterator.current()->width(); 399 int w = width() > bufferIterator.current()->width() ? width() : bufferIterator.current()->width();
319 int h = height() > bufferIterator.current()->height() ? height() : bufferIterator.current()->height(); 400 int h = height() > bufferIterator.current()->height() ? height() : bufferIterator.current()->height();
320 401
321 QPixmap tmpPixmap(*(bufferIterator.current())); 402 QPixmap tmpPixmap(*(bufferIterator.current()));
@@ -331,9 +412,9 @@ void DrawPadCanvas::paintEvent(QPaintEvent* e)
331 QWidget::paintEvent(e); 412 QWidget::paintEvent(e);
332 413
333 QArray<QRect> rects = e->region().rects(); 414 QArray<QRect> rects = e->region().rects();
334 415
335 for (uint i = 0; i < rects.count(); i++) { 416 for (uint i = 0; i < rects.count(); i++) {
336 QRect r = rects[i]; 417 QRect r = rects[i];
337 bitBlt(this, r.x(), r.y(), m_buffers.current(), r.x(), r.y(), r.width(), r.height()); 418 bitBlt(this, r.x(), r.y(), m_pages.current(), r.x(), r.y(), r.width(), r.height());
338 } 419 }
339} 420}
diff --git a/noncore/graphics/drawpad/drawpadcanvas.h b/noncore/graphics/drawpad/drawpadcanvas.h
index 2ec9298..eddcb43 100644
--- a/noncore/graphics/drawpad/drawpadcanvas.h
+++ b/noncore/graphics/drawpad/drawpadcanvas.h
@@ -31,35 +31,45 @@ public:
31 DrawPadCanvas(DrawPad* drawPad, QWidget* parent = 0, const char* name = 0, WFlags f = 0); 31 DrawPadCanvas(DrawPad* drawPad, QWidget* parent = 0, const char* name = 0, WFlags f = 0);
32 ~DrawPadCanvas(); 32 ~DrawPadCanvas();
33 33
34 void load(QIODevice* ioDevice); 34 void load(QIODevice* ioDevice);
35 void save(QIODevice* ioDevice); 35 void save(QIODevice* ioDevice);
36 36
37 bool undoEnabled();
38 bool redoEnabled();
37 bool goPreviousPageEnabled(); 39 bool goPreviousPageEnabled();
38 bool goNextPageEnabled(); 40 bool goNextPageEnabled();
39 41
40 QPixmap* currentPage(); 42 QPixmap* currentPage();
41 43
42public slots: 44public slots:
43 void clearAll(); 45 void clearAll();
44 void newPage(); 46 void newPage();
45 void clearPage(); 47 void clearPage();
46 void deletePage(); 48 void deletePage();
47 49
50 void undo();
51 void redo();
52
48 void goFirstPage(); 53 void goFirstPage();
49 void goPreviousPage(); 54 void goPreviousPage();
50 void goNextPage(); 55 void goNextPage();
51 void goLastPage(); 56 void goLastPage();
52 57
58signals:
59 void pagesChanged();
60 void pageBackupsChanged();
61
53protected: 62protected:
54 void mousePressEvent(QMouseEvent* e); 63 void mousePressEvent(QMouseEvent* e);
55 void mouseReleaseEvent(QMouseEvent* e); 64 void mouseReleaseEvent(QMouseEvent* e);
56 void mouseMoveEvent(QMouseEvent* e); 65 void mouseMoveEvent(QMouseEvent* e);
57 void resizeEvent(QResizeEvent* e); 66 void resizeEvent(QResizeEvent* e);
58 void paintEvent(QPaintEvent* e); 67 void paintEvent(QPaintEvent* e);
59 68
60private: 69private:
61 DrawPad* m_pDrawPad; 70 DrawPad* m_pDrawPad;
62 QList<QPixmap> m_buffers; 71 QList<QPixmap> m_pages;
72 QList<QPixmap> m_pageBackups;
63}; 73};
64 74
65#endif // DRAWPADCANVAS_H 75#endif // DRAWPADCANVAS_H