summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/graphics/drawpad/drawpad.cpp6
-rw-r--r--noncore/graphics/drawpad/drawpadcanvas.cpp50
-rw-r--r--noncore/graphics/drawpad/drawpadcanvas.h2
-rw-r--r--noncore/graphics/drawpad/newpagedialog.cpp5
-rw-r--r--noncore/graphics/drawpad/newpagedialog.h1
-rw-r--r--noncore/graphics/drawpad/page.cpp6
-rw-r--r--noncore/graphics/drawpad/page.h4
-rw-r--r--noncore/graphics/drawpad/thumbnailview.cpp4
8 files changed, 57 insertions, 21 deletions
diff --git a/noncore/graphics/drawpad/drawpad.cpp b/noncore/graphics/drawpad/drawpad.cpp
index 369e7f0..45fb886 100644
--- a/noncore/graphics/drawpad/drawpad.cpp
+++ b/noncore/graphics/drawpad/drawpad.cpp
@@ -1,89 +1,90 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * DrawPad - a drawing program for Opie Environment * 3 * DrawPad - a drawing program for Opie Environment *
4 * * 4 * *
5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> * 5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> *
6 * * 6 * *
7 * This program is free software; you can redistribute it and/or modify * 7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by * 8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or * 9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. * 10 * (at your option) any later version. *
11 * * 11 * *
12 ***************************************************************************/ 12 ***************************************************************************/
13 13
14#include "drawpad.h" 14#include "drawpad.h"
15 15
16#include "drawpadcanvas.h" 16#include "drawpadcanvas.h"
17#include "ellipsetool.h" 17#include "ellipsetool.h"
18#include "erasetool.h" 18#include "erasetool.h"
19#include "exportdialog.h" 19#include "exportdialog.h"
20#include "filledellipsetool.h" 20#include "filledellipsetool.h"
21#include "filledrectangletool.h" 21#include "filledrectangletool.h"
22#include "filltool.h" 22#include "filltool.h"
23#include "importdialog.h" 23#include "importdialog.h"
24#include "linetool.h" 24#include "linetool.h"
25#include "newpagedialog.h" 25#include "newpagedialog.h"
26#include "page.h"
26#include "pageinformationdialog.h" 27#include "pageinformationdialog.h"
27#include "pointtool.h" 28#include "pointtool.h"
28#include "rectangletool.h" 29#include "rectangletool.h"
29#include "texttool.h" 30#include "texttool.h"
30#include "thumbnailview.h" 31#include "thumbnailview.h"
31 32
32#include <opie/colordialog.h> 33#include <opie/colordialog.h>
33#include <opie/colorpopupmenu.h> 34#include <opie/colorpopupmenu.h>
34 35
35#include <qpe/applnk.h> 36#include <qpe/applnk.h>
36#include <qpe/global.h> 37#include <qpe/global.h>
37#include <qpe/qpemenubar.h> 38#include <qpe/qpemenubar.h>
38#include <qpe/qpetoolbar.h> 39#include <qpe/qpetoolbar.h>
39#include <qpe/resource.h> 40#include <qpe/resource.h>
40 41
41#include <qaction.h> 42#include <qaction.h>
42#include <qfile.h> 43#include <qfile.h>
43#include <qmessagebox.h> 44#include <qmessagebox.h>
44#include <qpainter.h> 45#include <qpainter.h>
45#include <qspinbox.h> 46#include <qspinbox.h>
46#include <qtoolbutton.h> 47#include <qtoolbutton.h>
47#include <qtooltip.h> 48#include <qtooltip.h>
48 49
49DrawPad::DrawPad(QWidget* parent, const char* name) 50DrawPad::DrawPad(QWidget* parent, const char* name)
50 : QMainWindow(parent, name) 51 : QMainWindow(parent, name)
51{ 52{
52 // init members 53 // init members
53 54
54 m_pDrawPadCanvas = new DrawPadCanvas(this, this); 55 m_pDrawPadCanvas = new DrawPadCanvas(this, this);
55 56
56 connect(m_pDrawPadCanvas, SIGNAL(pagesChanged()), this, SLOT(updateNavigationToolButtons())); 57 connect(m_pDrawPadCanvas, SIGNAL(pagesChanged()), this, SLOT(updateNavigationToolButtons()));
57 connect(m_pDrawPadCanvas, SIGNAL(pagesChanged()), this, SLOT(updateCaption())); 58 connect(m_pDrawPadCanvas, SIGNAL(pagesChanged()), this, SLOT(updateCaption()));
58 connect(m_pDrawPadCanvas, SIGNAL(pageBackupsChanged()), this, SLOT(updateUndoRedoToolButtons())); 59 connect(m_pDrawPadCanvas, SIGNAL(pageBackupsChanged()), this, SLOT(updateUndoRedoToolButtons()));
59 60
60 setCentralWidget(m_pDrawPadCanvas); 61 setCentralWidget(m_pDrawPadCanvas);
61 62
62 // init menu 63 // init menu
63 64
64 setToolBarsMovable(false); 65 setToolBarsMovable(false);
65 66
66 QPEToolBar* menuToolBar = new QPEToolBar(this); 67 QPEToolBar* menuToolBar = new QPEToolBar(this);
67 QPEMenuBar* menuBar = new QPEMenuBar(menuToolBar); 68 QPEMenuBar* menuBar = new QPEMenuBar(menuToolBar);
68 69
69 QPopupMenu *toolsPopupMenu = new QPopupMenu(menuBar); 70 QPopupMenu *toolsPopupMenu = new QPopupMenu(menuBar);
70 71
71 QAction* deleteAllAction = new QAction(tr("Delete All"), QString::null, 0, this); 72 QAction* deleteAllAction = new QAction(tr("Delete All"), QString::null, 0, this);
72 connect(deleteAllAction, SIGNAL(activated()), this, SLOT(deleteAll())); 73 connect(deleteAllAction, SIGNAL(activated()), this, SLOT(deleteAll()));
73 deleteAllAction->addTo(toolsPopupMenu); 74 deleteAllAction->addTo(toolsPopupMenu);
74 75
75 toolsPopupMenu->insertSeparator(); 76 toolsPopupMenu->insertSeparator();
76 77
77 QAction* importPageAction = new QAction(tr("Import"), tr("Import..."), 0, this); 78 QAction* importPageAction = new QAction(tr("Import"), tr("Import..."), 0, this);
78 connect(importPageAction, SIGNAL(activated()), this, SLOT(importPage())); 79 connect(importPageAction, SIGNAL(activated()), this, SLOT(importPage()));
79 importPageAction->addTo(toolsPopupMenu); 80 importPageAction->addTo(toolsPopupMenu);
80 81
81 QAction* exportPageAction = new QAction(tr("Export"), tr("Export..."), 0, this); 82 QAction* exportPageAction = new QAction(tr("Export"), tr("Export..."), 0, this);
82 connect(exportPageAction, SIGNAL(activated()), this, SLOT(exportPage())); 83 connect(exportPageAction, SIGNAL(activated()), this, SLOT(exportPage()));
83 exportPageAction->addTo(toolsPopupMenu); 84 exportPageAction->addTo(toolsPopupMenu);
84 85
85 toolsPopupMenu->insertSeparator(); 86 toolsPopupMenu->insertSeparator();
86 87
87 QAction* thumbnailViewAction = new QAction(tr("Thumbnail View"), tr("Thumbnail View..."), 0, this); 88 QAction* thumbnailViewAction = new QAction(tr("Thumbnail View"), tr("Thumbnail View..."), 0, this);
88 connect(thumbnailViewAction, SIGNAL(activated()), this, SLOT(thumbnailView())); 89 connect(thumbnailViewAction, SIGNAL(activated()), this, SLOT(thumbnailView()));
89 thumbnailViewAction->addTo(toolsPopupMenu); 90 thumbnailViewAction->addTo(toolsPopupMenu);
@@ -220,130 +221,130 @@ DrawPad::DrawPad(QWidget* parent, const char* name)
220 // init draw parameters toolbar 221 // init draw parameters toolbar
221 222
222 QPEToolBar* drawParametersToolBar = new QPEToolBar(this); 223 QPEToolBar* drawParametersToolBar = new QPEToolBar(this);
223 224
224 QSpinBox* penWidthSpinBox = new QSpinBox(1, 9, 1, drawParametersToolBar); 225 QSpinBox* penWidthSpinBox = new QSpinBox(1, 9, 1, drawParametersToolBar);
225 connect(penWidthSpinBox, SIGNAL(valueChanged(int)), this, SLOT(changePenWidth(int))); 226 connect(penWidthSpinBox, SIGNAL(valueChanged(int)), this, SLOT(changePenWidth(int)));
226 227
227 QToolTip::add(penWidthSpinBox, tr("Pen Width")); 228 QToolTip::add(penWidthSpinBox, tr("Pen Width"));
228 penWidthSpinBox->setValue(1); 229 penWidthSpinBox->setValue(1);
229 penWidthSpinBox->setFocusPolicy(QWidget::NoFocus); 230 penWidthSpinBox->setFocusPolicy(QWidget::NoFocus);
230 231
231 m_pPenColorToolButton = new QToolButton(drawParametersToolBar); 232 m_pPenColorToolButton = new QToolButton(drawParametersToolBar);
232 m_pPenColorToolButton->setPixmap(Resource::loadPixmap("drawpad/pencolor.png")); 233 m_pPenColorToolButton->setPixmap(Resource::loadPixmap("drawpad/pencolor.png"));
233 234
234 ColorPopupMenu* penColorPopupMenu = new ColorPopupMenu(Qt::black, m_pPenColorToolButton); 235 ColorPopupMenu* penColorPopupMenu = new ColorPopupMenu(Qt::black, m_pPenColorToolButton);
235 connect(penColorPopupMenu, SIGNAL(colorSelected(const QColor&)), this, SLOT(changePenColor(const QColor&))); 236 connect(penColorPopupMenu, SIGNAL(colorSelected(const QColor&)), this, SLOT(changePenColor(const QColor&)));
236 237
237 QToolTip::add(m_pPenColorToolButton, tr("Pen Color")); 238 QToolTip::add(m_pPenColorToolButton, tr("Pen Color"));
238 m_pPenColorToolButton->setPopup(penColorPopupMenu); 239 m_pPenColorToolButton->setPopup(penColorPopupMenu);
239 m_pPenColorToolButton->setPopupDelay(0); 240 m_pPenColorToolButton->setPopupDelay(0);
240 241
241 changePenColor(Qt::black); 242 changePenColor(Qt::black);
242 243
243 m_pBrushColorToolButton = new QToolButton(drawParametersToolBar); 244 m_pBrushColorToolButton = new QToolButton(drawParametersToolBar);
244 m_pBrushColorToolButton->setPixmap(Resource::loadPixmap("drawpad/brushcolor.png")); 245 m_pBrushColorToolButton->setPixmap(Resource::loadPixmap("drawpad/brushcolor.png"));
245 246
246 ColorPopupMenu* brushColorPopupMenu = new ColorPopupMenu(Qt::white, m_pBrushColorToolButton); 247 ColorPopupMenu* brushColorPopupMenu = new ColorPopupMenu(Qt::white, m_pBrushColorToolButton);
247 connect(brushColorPopupMenu, SIGNAL(colorSelected(const QColor&)), this, SLOT(changeBrushColor(const QColor&))); 248 connect(brushColorPopupMenu, SIGNAL(colorSelected(const QColor&)), this, SLOT(changeBrushColor(const QColor&)));
248 249
249 QToolTip::add(m_pBrushColorToolButton, tr("Fill Color")); 250 QToolTip::add(m_pBrushColorToolButton, tr("Fill Color"));
250 m_pBrushColorToolButton->setPopup(brushColorPopupMenu); 251 m_pBrushColorToolButton->setPopup(brushColorPopupMenu);
251 m_pBrushColorToolButton->setPopupDelay(0); 252 m_pBrushColorToolButton->setPopupDelay(0);
252 253
253 changeBrushColor(Qt::white); 254 changeBrushColor(Qt::white);
254 255
255 // init pages 256 // init pages
256 257
257 QFile file(Global::applicationFileName("drawpad", "drawpad.xml")); 258 QFile file(Global::applicationFileName("drawpad", "drawpad.xml"));
258 259
259 if (file.open(IO_ReadOnly)) { 260 if (file.open(IO_ReadOnly)) {
260 m_pDrawPadCanvas->load(&file); 261 m_pDrawPadCanvas->load(&file);
261 file.close(); 262 file.close();
262 } else { 263 } else {
263 m_pDrawPadCanvas->initialPage(); 264 m_pDrawPadCanvas->initialPage();
264 } 265 }
265} 266}
266 267
267DrawPad::~DrawPad() 268DrawPad::~DrawPad()
268{ 269{
269 QFile file(Global::applicationFileName("drawpad", "drawpad.xml")); 270 QFile file(Global::applicationFileName("drawpad", "drawpad.xml"));
270 271
271 if (file.open(IO_WriteOnly)) { 272 if (file.open(IO_WriteOnly)) {
272 m_pDrawPadCanvas->save(&file); 273 m_pDrawPadCanvas->save(&file);
273 file.close(); 274 file.close();
274 } 275 }
275} 276}
276 277
277void DrawPad::newPage() 278void DrawPad::newPage()
278{ 279{
279 QRect rect = m_pDrawPadCanvas->contentsRect(); 280 QRect rect = m_pDrawPadCanvas->contentsRect();
280 281
281 NewPageDialog newPageDialog(rect.width(), rect.height(), m_pen.color(), m_brush.color(), this); 282 NewPageDialog newPageDialog(rect.width(), rect.height(), m_pen.color(), m_brush.color(), this);
282 283
283 if (newPageDialog.exec() == QDialog::Accepted) { 284 if (newPageDialog.exec() == QDialog::Accepted) {
284 m_pDrawPadCanvas->newPage(newPageDialog.selectedWidth(), newPageDialog.selectedHeight(), 285 m_pDrawPadCanvas->newPage(newPageDialog.selectedTitle(), newPageDialog.selectedWidth(),
285 newPageDialog.selectedColor()); 286 newPageDialog.selectedHeight(), newPageDialog.selectedColor());
286 } 287 }
287} 288}
288 289
289void DrawPad::clearPage() 290void DrawPad::clearPage()
290{ 291{
291 QMessageBox messageBox(tr("Clear Page"), tr("Do you want to clear\nthe current page?"), 292 QMessageBox messageBox(tr("Clear Page"), tr("Do you want to clear\nthe current page?"),
292 QMessageBox::Information, QMessageBox::Yes, 293 QMessageBox::Information, QMessageBox::Yes,
293 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default, 294 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default,
294 QMessageBox::NoButton, this); 295 QMessageBox::NoButton, this);
295 296
296 messageBox.setButtonText(QMessageBox::Yes, tr("Yes")); 297 messageBox.setButtonText(QMessageBox::Yes, tr("Yes"));
297 messageBox.setButtonText(QMessageBox::No, tr("No")); 298 messageBox.setButtonText(QMessageBox::No, tr("No"));
298 299
299 if (messageBox.exec() == QMessageBox::Yes) { 300 if (messageBox.exec() == QMessageBox::Yes) {
300 m_pDrawPadCanvas->clearPage(); 301 m_pDrawPadCanvas->clearPage();
301 } 302 }
302} 303}
303 304
304void DrawPad::deletePage() 305void DrawPad::deletePage()
305{ 306{
306 QMessageBox messageBox(tr("Delete Page"), tr("Do you want to delete\nthe current page?"), 307 QMessageBox messageBox(tr("Delete Page"), tr("Do you want to delete\nthe current page?"),
307 QMessageBox::Information, QMessageBox::Yes, 308 QMessageBox::Information, QMessageBox::Yes,
308 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default, 309 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default,
309 QMessageBox::NoButton, this); 310 QMessageBox::NoButton, this);
310 311
311 messageBox.setButtonText(QMessageBox::Yes, tr("Yes")); 312 messageBox.setButtonText(QMessageBox::Yes, tr("Yes"));
312 messageBox.setButtonText(QMessageBox::No, tr("No")); 313 messageBox.setButtonText(QMessageBox::No, tr("No"));
313 314
314 if (messageBox.exec() == QMessageBox::Yes) { 315 if (messageBox.exec() == QMessageBox::Yes) {
315 m_pDrawPadCanvas->deletePage(); 316 m_pDrawPadCanvas->deletePage();
316 } 317 }
317} 318}
318 319
319void DrawPad::setPointTool() 320void DrawPad::setPointTool()
320{ 321{
321 if (m_pTool) { 322 if (m_pTool) {
322 delete m_pTool; 323 delete m_pTool;
323 } 324 }
324 325
325 m_pTool = new PointTool(this, m_pDrawPadCanvas); 326 m_pTool = new PointTool(this, m_pDrawPadCanvas);
326 327
327 m_pLineToolButton->setIconSet(m_pPointToolAction->iconSet()); 328 m_pLineToolButton->setIconSet(m_pPointToolAction->iconSet());
328 QToolTip::add(m_pLineToolButton, m_pPointToolAction->text()); 329 QToolTip::add(m_pLineToolButton, m_pPointToolAction->text());
329 330
330 disconnect(m_pLineToolButton, SIGNAL(clicked()), 0, 0); 331 disconnect(m_pLineToolButton, SIGNAL(clicked()), 0, 0);
331 connect(m_pLineToolButton, SIGNAL(clicked()), m_pPointToolAction, SIGNAL(activated())); 332 connect(m_pLineToolButton, SIGNAL(clicked()), m_pPointToolAction, SIGNAL(activated()));
332 333
333 m_pLineToolButton->setOn(true); 334 m_pLineToolButton->setOn(true);
334 m_pRectangleToolButton->setOn(false); 335 m_pRectangleToolButton->setOn(false);
335 m_pEllipseToolButton->setOn(false); 336 m_pEllipseToolButton->setOn(false);
336 m_pTextToolAction->setOn(false); 337 m_pTextToolAction->setOn(false);
337 m_pFillToolAction->setOn(false); 338 m_pFillToolAction->setOn(false);
338 m_pEraseToolAction->setOn(false); 339 m_pEraseToolAction->setOn(false);
339} 340}
340 341
341void DrawPad::setLineTool() 342void DrawPad::setLineTool()
342{ 343{
343 if (m_pTool) { 344 if (m_pTool) {
344 delete m_pTool; 345 delete m_pTool;
345 } 346 }
346 347
347 m_pTool = new LineTool(this, m_pDrawPadCanvas); 348 m_pTool = new LineTool(this, m_pDrawPadCanvas);
348 349
349 m_pLineToolButton->setIconSet(m_pLineToolAction->iconSet()); 350 m_pLineToolButton->setIconSet(m_pLineToolAction->iconSet());
@@ -543,66 +544,67 @@ void DrawPad::updateCaption()
543{ 544{
544 uint pagePosition = m_pDrawPadCanvas->pagePosition(); 545 uint pagePosition = m_pDrawPadCanvas->pagePosition();
545 uint pageCount = m_pDrawPadCanvas->pageCount(); 546 uint pageCount = m_pDrawPadCanvas->pageCount();
546 547
547 setCaption(tr("DrawPad") + " - " + tr("Page") + " " 548 setCaption(tr("DrawPad") + " - " + tr("Page") + " "
548 + QString::number(pagePosition) + "/" + QString::number(pageCount)); 549 + QString::number(pagePosition) + "/" + QString::number(pageCount));
549} 550}
550 551
551void DrawPad::deleteAll() 552void DrawPad::deleteAll()
552{ 553{
553 QMessageBox messageBox(tr("Delete All"), tr("Do you want to delete\nall the pages?"), 554 QMessageBox messageBox(tr("Delete All"), tr("Do you want to delete\nall the pages?"),
554 QMessageBox::Information, QMessageBox::Yes, 555 QMessageBox::Information, QMessageBox::Yes,
555 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default, 556 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default,
556 QMessageBox::NoButton, this); 557 QMessageBox::NoButton, this);
557 558
558 messageBox.setButtonText(QMessageBox::Yes, tr("Yes")); 559 messageBox.setButtonText(QMessageBox::Yes, tr("Yes"));
559 messageBox.setButtonText(QMessageBox::No, tr("No")); 560 messageBox.setButtonText(QMessageBox::No, tr("No"));
560 561
561 if (messageBox.exec() == QMessageBox::Yes) { 562 if (messageBox.exec() == QMessageBox::Yes) {
562 m_pDrawPadCanvas->deleteAll(); 563 m_pDrawPadCanvas->deleteAll();
563 } 564 }
564} 565}
565 566
566void DrawPad::importPage() 567void DrawPad::importPage()
567{ 568{
568 ImportDialog importDialog(this); 569 ImportDialog importDialog(this);
569 570
570 importDialog.showMaximized(); 571 importDialog.showMaximized();
571 572
572 if (importDialog.exec() == QDialog::Accepted) { 573 if (importDialog.exec() == QDialog::Accepted) {
573 const DocLnk* docLnk = importDialog.selected(); 574 const DocLnk* docLnk = importDialog.selected();
574 575
575 if (docLnk) { 576 if (docLnk) {
576 m_pDrawPadCanvas->importPage(docLnk->file()); 577 m_pDrawPadCanvas->importPage(docLnk->file());
577 delete docLnk; 578 delete docLnk;
578 } 579 }
579 } 580 }
580} 581}
581 582
582void DrawPad::exportPage() 583void DrawPad::exportPage()
583{ 584{
584 ExportDialog exportDialog(m_pDrawPadCanvas->pagePosition(), m_pDrawPadCanvas->pageCount(), this); 585 ExportDialog exportDialog(m_pDrawPadCanvas->pagePosition(), m_pDrawPadCanvas->pageCount(), this);
585 586
586 exportDialog.showMaximized(); 587 exportDialog.showMaximized();
587 588
588 if (exportDialog.exec() == QDialog::Accepted) { 589 if (exportDialog.exec() == QDialog::Accepted) {
589 m_pDrawPadCanvas->exportPage(exportDialog.selectedFromPage(), exportDialog.selectedToPage(), 590 m_pDrawPadCanvas->exportPage(exportDialog.selectedFromPage(), exportDialog.selectedToPage(),
590 exportDialog.selectedName(), exportDialog.selectedFormat()); 591 exportDialog.selectedName(), exportDialog.selectedFormat());
591 } 592 }
592} 593}
593 594
594void DrawPad::thumbnailView() 595void DrawPad::thumbnailView()
595{ 596{
596 ThumbnailView thumbnailView(this, m_pDrawPadCanvas, this); 597 ThumbnailView thumbnailView(this, m_pDrawPadCanvas, this);
597 598
598 thumbnailView.showMaximized(); 599 thumbnailView.showMaximized();
599 thumbnailView.exec(); 600 thumbnailView.exec();
600} 601}
601 602
602void DrawPad::pageInformation() 603void DrawPad::pageInformation()
603{ 604{
604 PageInformationDialog pageInformationDialog(m_pDrawPadCanvas->currentPage()); 605 PageInformationDialog pageInformationDialog(m_pDrawPadCanvas->currentPage());
605 606
606 if (pageInformationDialog.exec() == QDialog::Accepted) { 607 if (pageInformationDialog.exec() == QDialog::Accepted) {
608 m_pDrawPadCanvas->currentPage()->setTitle(pageInformationDialog.selectedTitle());
607 } 609 }
608} 610}
diff --git a/noncore/graphics/drawpad/drawpadcanvas.cpp b/noncore/graphics/drawpad/drawpadcanvas.cpp
index bcb6877..dcf0871 100644
--- a/noncore/graphics/drawpad/drawpadcanvas.cpp
+++ b/noncore/graphics/drawpad/drawpadcanvas.cpp
@@ -1,472 +1,498 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * DrawPad - a drawing program for Opie Environment * 3 * DrawPad - a drawing program for Opie Environment *
4 * * 4 * *
5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> * 5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> *
6 * * 6 * *
7 * This program is free software; you can redistribute it and/or modify * 7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by * 8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or * 9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. * 10 * (at your option) any later version. *
11 * * 11 * *
12 ***************************************************************************/ 12 ***************************************************************************/
13 13
14#include "drawpadcanvas.h" 14#include "drawpadcanvas.h"
15 15
16#include "drawpad.h" 16#include "drawpad.h"
17#include "page.h" 17#include "page.h"
18#include "tool.h" 18#include "tool.h"
19 19
20#include <qpe/applnk.h> 20#include <qpe/applnk.h>
21#include <qpe/filemanager.h> 21#include <qpe/filemanager.h>
22#include <qpe/mimetype.h> 22#include <qpe/mimetype.h>
23 23
24#include <qbuffer.h> 24#include <qbuffer.h>
25#include <qimage.h> 25#include <qimage.h>
26#include <qpainter.h> 26#include <qpainter.h>
27#include <qtextcodec.h> 27#include <qtextcodec.h>
28#include <qtextstream.h> 28#include <qtextstream.h>
29#include <qxml.h> 29#include <qxml.h>
30 30
31#include <zlib.h> 31#include <zlib.h>
32 32
33class DrawPadCanvasXmlHandler: public QXmlDefaultHandler 33class DrawPadCanvasXmlHandler: public QXmlDefaultHandler
34{ 34{
35public: 35public:
36 DrawPadCanvasXmlHandler(); 36 DrawPadCanvasXmlHandler();
37 ~DrawPadCanvasXmlHandler(); 37 ~DrawPadCanvasXmlHandler();
38 38
39 QList<Page> pages(); 39 QList<Page> pages();
40 40
41 bool startElement(const QString& namespaceURI, const QString& localName, 41 bool startElement(const QString& namespaceURI, const QString& localName,
42 const QString& qName, const QXmlAttributes& atts); 42 const QString& qName, const QXmlAttributes& atts);
43 bool endElement(const QString& namespaceURI, const QString& localName, 43 bool endElement(const QString& namespaceURI, const QString& localName,
44 const QString& qName); 44 const QString& qName);
45 bool characters(const QString& ch); 45 bool characters(const QString& ch);
46 46
47private: 47private:
48 enum State { 48 enum State {
49 Unknown, 49 Unknown,
50 InTitle,
51 InDate,
50 InData 52 InData
51 }; 53 };
52 54
53 State m_state; 55 State m_state;
56 QString m_title;
57 QDateTime m_date;
54 ulong m_dataLenght; 58 ulong m_dataLenght;
55 QString m_dataFormat; 59 QString m_dataFormat;
56 QList<Page> m_pages; 60 QList<Page> m_pages;
57}; 61};
58 62
59DrawPadCanvasXmlHandler::DrawPadCanvasXmlHandler() 63DrawPadCanvasXmlHandler::DrawPadCanvasXmlHandler()
60{ 64{
61 m_state = Unknown; 65 m_state = Unknown;
62} 66}
63 67
64DrawPadCanvasXmlHandler::~DrawPadCanvasXmlHandler() 68DrawPadCanvasXmlHandler::~DrawPadCanvasXmlHandler()
65{ 69{
66} 70}
67 71
68QList<Page> DrawPadCanvasXmlHandler::pages() 72QList<Page> DrawPadCanvasXmlHandler::pages()
69{ 73{
70 return m_pages; 74 return m_pages;
71} 75}
72 76
73bool DrawPadCanvasXmlHandler::startElement(const QString& namespaceURI, const QString& localName, 77bool DrawPadCanvasXmlHandler::startElement(const QString& namespaceURI, const QString& localName,
74 const QString& qName, const QXmlAttributes& atts) 78 const QString& qName, const QXmlAttributes& atts)
75{ 79{
76 Q_CONST_UNUSED(namespaceURI) 80 Q_CONST_UNUSED(namespaceURI)
77 Q_CONST_UNUSED(localName) 81 Q_CONST_UNUSED(localName)
78 82
79 if (qName.compare("data") == 0) { 83 if (qName == "image") {
84 m_title = QString();
85 m_date = QDateTime(QDate(1970, 1, 1));
86 } else if (qName == "title") {
87 m_state = InTitle;
88 } else if (qName == "date") {
89 m_state = InDate;
90 } else if (qName == "data") {
80 m_state = InData; 91 m_state = InData;
81 m_dataLenght = atts.value("length").toULong(); 92 m_dataLenght = atts.value("length").toULong();
82 m_dataFormat = atts.value("format"); 93 m_dataFormat = atts.value("format");
83 94
84 if (m_dataFormat.isEmpty()) { 95 if (m_dataFormat.isEmpty()) {
85 m_dataFormat = "XPM"; 96 m_dataFormat = "XPM";
86 } 97 }
87 } 98 }
88 99
89 return true; 100 return true;
90} 101}
91 102
92bool DrawPadCanvasXmlHandler::endElement(const QString& namespaceURI, const QString& localName, 103bool DrawPadCanvasXmlHandler::endElement(const QString& namespaceURI, const QString& localName,
93 const QString& qName) 104 const QString& qName)
94{ 105{
95 Q_CONST_UNUSED(namespaceURI) 106 Q_CONST_UNUSED(namespaceURI)
96 Q_CONST_UNUSED(localName) 107 Q_CONST_UNUSED(localName)
97 108
98 if (qName.compare("data") == 0) { 109 if (qName == "title") {
110 m_state = Unknown;
111 } else if (qName == "date") {
112 m_state = Unknown;
113 } else if (qName == "data") {
99 m_state = Unknown; 114 m_state = Unknown;
100 } 115 }
101 116
102 return true; 117 return true;
103} 118}
104 119
105bool DrawPadCanvasXmlHandler::characters(const QString& ch) 120bool DrawPadCanvasXmlHandler::characters(const QString& ch)
106{ 121{
107 if (m_state == InData) { 122 if (m_state == InTitle) {
123 m_title = ch;
124 } else if (m_state == InDate) {
125 m_date = m_date.addSecs(ch.toInt());
126 } else if (m_state == InData) {
108 QByteArray byteArray(ch.length() / 2); 127 QByteArray byteArray(ch.length() / 2);
109 128
110 for (int i = 0; i < (int)ch.length() / 2; i++) { 129 for (int i = 0; i < (int)ch.length() / 2; i++) {
111 char h = ch[2 * i].latin1(); 130 char h = ch[2 * i].latin1();
112 char l = ch[2 * i + 1].latin1(); 131 char l = ch[2 * i + 1].latin1();
113 uchar r = 0; 132 uchar r = 0;
114 133
115 if (h <= '9') { 134 if (h <= '9') {
116 r += h - '0'; 135 r += h - '0';
117 } else { 136 } else {
118 r += h - 'a' + 10; 137 r += h - 'a' + 10;
119 } 138 }
120 139
121 r = r << 4; 140 r = r << 4;
122 141
123 if (l <= '9') { 142 if (l <= '9') {
124 r += l - '0'; 143 r += l - '0';
125 } else { 144 } else {
126 r += l - 'a' + 10; 145 r += l - 'a' + 10;
127 } 146 }
128 147
129 byteArray[i] = r; 148 byteArray[i] = r;
130 } 149 }
131 150
132 151
133 QImage image; 152 QImage image;
134 153
135 if (m_dataFormat == "XPM") { 154 if (m_dataFormat == "XPM") {
136 if (m_dataLenght < ch.length() * 5) { 155 if (m_dataLenght < ch.length() * 5) {
137 m_dataLenght = ch.length() * 5; 156 m_dataLenght = ch.length() * 5;
138 } 157 }
139 158
140 QByteArray byteArrayUnzipped(m_dataLenght); 159 QByteArray byteArrayUnzipped(m_dataLenght);
141 ::uncompress((uchar*)byteArrayUnzipped.data(), &m_dataLenght, (uchar*)byteArray.data(), byteArray.size()); 160 ::uncompress((uchar*)byteArrayUnzipped.data(), &m_dataLenght, (uchar*)byteArray.data(), byteArray.size());
142 161
143 image.loadFromData((const uchar*)byteArrayUnzipped.data(), m_dataLenght, m_dataFormat); 162 image.loadFromData((const uchar*)byteArrayUnzipped.data(), m_dataLenght, m_dataFormat);
144 } else { 163 } else {
145 image.loadFromData((const uchar*)byteArray.data(), m_dataLenght, m_dataFormat); 164 image.loadFromData((const uchar*)byteArray.data(), m_dataLenght, m_dataFormat);
146 } 165 }
147 166
148 Page* page = new Page(image.width(), image.height()); 167 Page* page = new Page(m_title, image.width(), image.height());
168 page->setLastModified(m_date);
149 page->convertFromImage(image); 169 page->convertFromImage(image);
150 m_pages.append(page); 170 m_pages.append(page);
151 } 171 }
152 172
153 return true; 173 return true;
154} 174}
155 175
156DrawPadCanvas::DrawPadCanvas(DrawPad* drawPad, QWidget* parent, const char* name) 176DrawPadCanvas::DrawPadCanvas(DrawPad* drawPad, QWidget* parent, const char* name)
157 : QScrollView(parent, name) 177 : QScrollView(parent, name)
158{ 178{
159 m_pDrawPad = drawPad; 179 m_pDrawPad = drawPad;
160 m_pages.setAutoDelete(true); 180 m_pages.setAutoDelete(true);
161 m_pageBackups.setAutoDelete(true); 181 m_pageBackups.setAutoDelete(true);
162 182
163 viewport()->setBackgroundMode(QWidget::NoBackground); 183 viewport()->setBackgroundMode(QWidget::NoBackground);
164} 184}
165 185
166DrawPadCanvas::~DrawPadCanvas() 186DrawPadCanvas::~DrawPadCanvas()
167{ 187{
168} 188}
169 189
170void DrawPadCanvas::load(QIODevice* ioDevice) 190void DrawPadCanvas::load(QIODevice* ioDevice)
171{ 191{
172 QTextStream textStream(ioDevice); 192 QTextStream textStream(ioDevice);
173 textStream.setCodec(QTextCodec::codecForName("UTF-8")); 193 textStream.setCodec(QTextCodec::codecForName("UTF-8"));
174 194
175 QXmlInputSource xmlInputSource(textStream); 195 QXmlInputSource xmlInputSource(textStream);
176 QXmlSimpleReader xmlSimpleReader; 196 QXmlSimpleReader xmlSimpleReader;
177 DrawPadCanvasXmlHandler drawPadCanvasXmlHandler; 197 DrawPadCanvasXmlHandler drawPadCanvasXmlHandler;
178 198
179 xmlSimpleReader.setContentHandler(&drawPadCanvasXmlHandler); 199 xmlSimpleReader.setContentHandler(&drawPadCanvasXmlHandler);
180 xmlSimpleReader.parse(xmlInputSource); 200 xmlSimpleReader.parse(xmlInputSource);
181 201
182 m_pages = drawPadCanvasXmlHandler.pages(); 202 m_pages = drawPadCanvasXmlHandler.pages();
183 203
184 if (m_pages.isEmpty()) { 204 if (m_pages.isEmpty()) {
185 m_pages.append(new Page(contentsRect().size())); 205 m_pages.append(new Page("", contentsRect().size()));
186 m_pages.current()->fill(Qt::white); 206 m_pages.current()->fill(Qt::white);
187 } 207 }
188 208
189 m_pageBackups.clear(); 209 m_pageBackups.clear();
190 m_pageBackups.append(new Page(*(m_pages.current()))); 210 m_pageBackups.append(new Page(*(m_pages.current())));
191 211
192 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 212 resizeContents(m_pages.current()->width(), m_pages.current()->height());
193 viewport()->update(); 213 viewport()->update();
194 214
195 emit pagesChanged(); 215 emit pagesChanged();
196 emit pageBackupsChanged(); 216 emit pageBackupsChanged();
197} 217}
198 218
199void DrawPadCanvas::initialPage() 219void DrawPadCanvas::initialPage()
200{ 220{
201 m_pages.append(new Page(236, 232)); 221 m_pages.append(new Page("", 236, 232));
202 m_pages.current()->fill(Qt::white); 222 m_pages.current()->fill(Qt::white);
203 223
204 m_pageBackups.clear(); 224 m_pageBackups.clear();
205 m_pageBackups.append(new Page(*(m_pages.current()))); 225 m_pageBackups.append(new Page(*(m_pages.current())));
206 226
207 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 227 resizeContents(m_pages.current()->width(), m_pages.current()->height());
208 viewport()->update(); 228 viewport()->update();
209 229
210 emit pagesChanged(); 230 emit pagesChanged();
211 emit pageBackupsChanged(); 231 emit pageBackupsChanged();
212} 232}
213 233
214void DrawPadCanvas::save(QIODevice* ioDevice) 234void DrawPadCanvas::save(QIODevice* ioDevice)
215{ 235{
216 QTextStream textStream(ioDevice); 236 QTextStream textStream(ioDevice);
217 textStream.setCodec(QTextCodec::codecForName("UTF-8")); 237 textStream.setCodec(QTextCodec::codecForName("UTF-8"));
218 238
219 textStream << "<drawpad>" << endl; 239 textStream << "<drawpad>" << endl;
220 textStream << " <images>" << endl; 240 textStream << " <images>" << endl;
221 241
222 QListIterator<Page> bufferIterator(m_pages); 242 QListIterator<Page> bufferIterator(m_pages);
223 243
224 for (bufferIterator.toFirst(); bufferIterator.current() != 0; ++bufferIterator) { 244 for (bufferIterator.toFirst(); bufferIterator.current() != 0; ++bufferIterator) {
225 textStream << " <image>" << endl; 245 textStream << " <image>" << endl;
246 textStream << " <title>" << bufferIterator.current()->title() << "</title>" << endl;
247
248 int intDate = QDateTime(QDate(1970, 1, 1)).secsTo(bufferIterator.current()->lastModified());
249 textStream << " <date>" << intDate << "</date>" << endl;
226 250
227 QImage image = bufferIterator.current()->convertToImage(); 251 QImage image = bufferIterator.current()->convertToImage();
228 QByteArray byteArray; 252 QByteArray byteArray;
229 QBuffer buffer(byteArray); 253 QBuffer buffer(byteArray);
230 QImageIO imageIO(&buffer, "PNG"); 254 QImageIO imageIO(&buffer, "PNG");
231 255
232 buffer.open(IO_WriteOnly); 256 buffer.open(IO_WriteOnly);
233 imageIO.setImage(image); 257 imageIO.setImage(image);
234 imageIO.write(); 258 imageIO.write();
235 buffer.close(); 259 buffer.close();
236 260
237 textStream << " <data length=\"" << byteArray.size() << "\" format=\"PNG\">"; 261 textStream << " <data length=\"" << byteArray.size() << "\" format=\"PNG\">";
238 262
239 static const char hexchars[] = "0123456789abcdef"; 263 static const char hexchars[] = "0123456789abcdef";
240 264
241 for (int i = 0; i < (int)byteArray.size(); i++ ) { 265 for (int i = 0; i < (int)byteArray.size(); i++ ) {
242 uchar s = (uchar)byteArray[i]; 266 uchar s = (uchar)byteArray[i];
243 textStream << hexchars[s >> 4]; 267 textStream << hexchars[s >> 4];
244 textStream << hexchars[s & 0x0f]; 268 textStream << hexchars[s & 0x0f];
245 } 269 }
246 270
247 textStream << "</data>" << endl; 271 textStream << "</data>" << endl;
248 textStream << " </image>" << endl; 272 textStream << " </image>" << endl;
249 } 273 }
250 274
251 textStream << " </images>" << endl; 275 textStream << " </images>" << endl;
252 textStream << "</drawpad>"; 276 textStream << "</drawpad>";
253} 277}
254 278
255void DrawPadCanvas::importPage(const QString& fileName) 279void DrawPadCanvas::importPage(const QString& fileName)
256{ 280{
257 Page* importedPage = new Page(); 281 Page* importedPage = new Page();
258 282
259 importedPage->load(fileName); 283 importedPage->load(fileName);
260 m_pages.insert(m_pages.at() + 1, importedPage); 284 m_pages.insert(m_pages.at() + 1, importedPage);
261 285
262 m_pageBackups.clear(); 286 m_pageBackups.clear();
263 m_pageBackups.append(new Page(*(m_pages.current()))); 287 m_pageBackups.append(new Page(*(m_pages.current())));
264 288
265 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 289 resizeContents(m_pages.current()->width(), m_pages.current()->height());
266 viewport()->update(); 290 viewport()->update();
267 291
268 emit pagesChanged(); 292 emit pagesChanged();
269 emit pageBackupsChanged(); 293 emit pageBackupsChanged();
270} 294}
271 295
272void DrawPadCanvas::exportPage(uint fromPage, uint toPage, const QString& name,const QString& format) 296void DrawPadCanvas::exportPage(uint fromPage, uint toPage, const QString& name,const QString& format)
273{ 297{
274 if (fromPage == toPage) { 298 if (fromPage == toPage) {
275 DocLnk docLnk; 299 DocLnk docLnk;
276 MimeType mimeType(format); 300 MimeType mimeType(format);
277 301
278 docLnk.setName(name); 302 docLnk.setName(name);
279 docLnk.setType(mimeType.id()); 303 docLnk.setType(mimeType.id());
280 304
281 FileManager fileManager; 305 FileManager fileManager;
282 QIODevice* ioDevice = fileManager.saveFile(docLnk); 306 QIODevice* ioDevice = fileManager.saveFile(docLnk);
283 QImageIO imageIO(ioDevice, format); 307 QImageIO imageIO(ioDevice, format);
284 308
285 QImage image = m_pages.current()->convertToImage(); 309 QImage image = m_pages.current()->convertToImage();
286 imageIO.setImage(image); 310 imageIO.setImage(image);
287 imageIO.write(); 311 imageIO.write();
288 delete ioDevice; 312 delete ioDevice;
289 } else { 313 } else {
290 for (uint i = fromPage; i <= toPage; i++) { 314 for (uint i = fromPage; i <= toPage; i++) {
291 DocLnk docLnk; 315 DocLnk docLnk;
292 MimeType mimeType(format); 316 MimeType mimeType(format);
293 317
294 docLnk.setName(name + QString::number(i)); 318 docLnk.setName(name + QString::number(i));
295 docLnk.setType(mimeType.id()); 319 docLnk.setType(mimeType.id());
296 320
297 FileManager fileManager; 321 FileManager fileManager;
298 QIODevice* ioDevice = fileManager.saveFile(docLnk); 322 QIODevice* ioDevice = fileManager.saveFile(docLnk);
299 QImageIO imageIO(ioDevice, format); 323 QImageIO imageIO(ioDevice, format);
300 324
301 QImage image = m_pages.at(i - 1)->convertToImage(); 325 QImage image = m_pages.at(i - 1)->convertToImage();
302 imageIO.setImage(image); 326 imageIO.setImage(image);
303 imageIO.write(); 327 imageIO.write();
304 delete ioDevice; 328 delete ioDevice;
305 } 329 }
306 } 330 }
307} 331}
308 332
309Page* DrawPadCanvas::currentPage() 333Page* DrawPadCanvas::currentPage()
310{ 334{
311 return m_pages.current(); 335 return m_pages.current();
312} 336}
313 337
314QList<Page> DrawPadCanvas::pages() 338QList<Page> DrawPadCanvas::pages()
315{ 339{
316 return m_pages; 340 return m_pages;
317} 341}
318 342
319uint DrawPadCanvas::pagePosition() 343uint DrawPadCanvas::pagePosition()
320{ 344{
321 return (m_pages.at() + 1); 345 return (m_pages.at() + 1);
322} 346}
323 347
324uint DrawPadCanvas::pageCount() 348uint DrawPadCanvas::pageCount()
325{ 349{
326 return m_pages.count(); 350 return m_pages.count();
327} 351}
328 352
329void DrawPadCanvas::selectPage(Page* page) 353void DrawPadCanvas::selectPage(Page* page)
330{ 354{
331 m_pages.findRef(page); 355 m_pages.findRef(page);
332 m_pageBackups.clear(); 356 m_pageBackups.clear();
333 m_pageBackups.append(new Page(*(m_pages.current()))); 357 m_pageBackups.append(new Page(*(m_pages.current())));
334 358
335 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 359 resizeContents(m_pages.current()->width(), m_pages.current()->height());
336 viewport()->update(); 360 viewport()->update();
337 361
338 emit pagesChanged(); 362 emit pagesChanged();
339 emit pageBackupsChanged(); 363 emit pageBackupsChanged();
340} 364}
341 365
342void DrawPadCanvas::backupPage() 366void DrawPadCanvas::backupPage()
343{ 367{
344 QPixmap* currentBackup = m_pageBackups.current(); 368 m_pages.current()->setLastModified(QDateTime::currentDateTime());
369
370 Page* currentBackup = m_pageBackups.current();
345 while (m_pageBackups.last() != currentBackup) { 371 while (m_pageBackups.last() != currentBackup) {
346 m_pageBackups.removeLast(); 372 m_pageBackups.removeLast();
347 } 373 }
348 374
349 while (m_pageBackups.count() >= (5 + 1)) { 375 while (m_pageBackups.count() >= (5 + 1)) {
350 m_pageBackups.removeFirst(); 376 m_pageBackups.removeFirst();
351 } 377 }
352 378
353 m_pageBackups.append(new Page(*(m_pages.current()))); 379 m_pageBackups.append(new Page(*(m_pages.current())));
354 380
355 emit pageBackupsChanged(); 381 emit pageBackupsChanged();
356} 382}
357 383
358void DrawPadCanvas::deleteAll() 384void DrawPadCanvas::deleteAll()
359{ 385{
360 m_pages.clear(); 386 m_pages.clear();
361 387
362 m_pages.append(new Page(contentsRect().size())); 388 m_pages.append(new Page("", contentsRect().size()));
363 m_pages.current()->fill(Qt::white); 389 m_pages.current()->fill(Qt::white);
364 390
365 m_pageBackups.clear(); 391 m_pageBackups.clear();
366 m_pageBackups.append(new Page(*(m_pages.current()))); 392 m_pageBackups.append(new Page(*(m_pages.current())));
367 393
368 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 394 resizeContents(m_pages.current()->width(), m_pages.current()->height());
369 viewport()->update(); 395 viewport()->update();
370 396
371 emit pagesChanged(); 397 emit pagesChanged();
372 emit pageBackupsChanged(); 398 emit pageBackupsChanged();
373} 399}
374 400
375void DrawPadCanvas::newPage(uint width, uint height, const QColor& color) 401void DrawPadCanvas::newPage(QString title, uint width, uint height, const QColor& color)
376{ 402{
377 m_pages.insert(m_pages.at() + 1, new Page(width, height)); 403 m_pages.insert(m_pages.at() + 1, new Page(title, width, height));
378 m_pages.current()->fill(color); 404 m_pages.current()->fill(color);
379 405
380 m_pageBackups.clear(); 406 m_pageBackups.clear();
381 m_pageBackups.append(new Page(*(m_pages.current()))); 407 m_pageBackups.append(new Page(*(m_pages.current())));
382 408
383 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 409 resizeContents(m_pages.current()->width(), m_pages.current()->height());
384 viewport()->update(); 410 viewport()->update();
385 411
386 emit pagesChanged(); 412 emit pagesChanged();
387 emit pageBackupsChanged(); 413 emit pageBackupsChanged();
388} 414}
389 415
390void DrawPadCanvas::clearPage() 416void DrawPadCanvas::clearPage()
391{ 417{
392 m_pages.current()->fill(Qt::white); 418 m_pages.current()->fill(Qt::white);
393 419
394 m_pageBackups.clear(); 420 m_pageBackups.clear();
395 m_pageBackups.append(new Page(*(m_pages.current()))); 421 m_pageBackups.append(new Page(*(m_pages.current())));
396 422
397 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 423 resizeContents(m_pages.current()->width(), m_pages.current()->height());
398 viewport()->update(); 424 viewport()->update();
399 425
400 emit pageBackupsChanged(); 426 emit pageBackupsChanged();
401} 427}
402 428
403void DrawPadCanvas::deletePage() 429void DrawPadCanvas::deletePage()
404{ 430{
405 m_pages.remove(m_pages.current()); 431 m_pages.remove(m_pages.current());
406 432
407 if (m_pages.isEmpty()) { 433 if (m_pages.isEmpty()) {
408 m_pages.append(new Page(contentsRect().size())); 434 m_pages.append(new Page("", contentsRect().size()));
409 m_pages.current()->fill(Qt::white); 435 m_pages.current()->fill(Qt::white);
410 } 436 }
411 437
412 m_pageBackups.clear(); 438 m_pageBackups.clear();
413 m_pageBackups.append(new Page(*(m_pages.current()))); 439 m_pageBackups.append(new Page(*(m_pages.current())));
414 440
415 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 441 resizeContents(m_pages.current()->width(), m_pages.current()->height());
416 viewport()->update(); 442 viewport()->update();
417 443
418 emit pagesChanged(); 444 emit pagesChanged();
419 emit pageBackupsChanged(); 445 emit pageBackupsChanged();
420} 446}
421 447
422void DrawPadCanvas::movePageUp() 448void DrawPadCanvas::movePageUp()
423{ 449{
424 int index = m_pages.at(); 450 int index = m_pages.at();
425 Page* page = m_pages.take(); 451 Page* page = m_pages.take();
426 m_pages.insert(index - 1, page); 452 m_pages.insert(index - 1, page);
427 453
428 emit pagesChanged(); 454 emit pagesChanged();
429} 455}
430 456
431void DrawPadCanvas::movePageDown() 457void DrawPadCanvas::movePageDown()
432{ 458{
433 int index = m_pages.at(); 459 int index = m_pages.at();
434 Page* page = m_pages.take(); 460 Page* page = m_pages.take();
435 m_pages.insert(index + 1, page); 461 m_pages.insert(index + 1, page);
436 462
437 emit pagesChanged(); 463 emit pagesChanged();
438} 464}
439 465
440bool DrawPadCanvas::undoEnabled() 466bool DrawPadCanvas::undoEnabled()
441{ 467{
442 return (m_pageBackups.current() != m_pageBackups.getFirst()); 468 return (m_pageBackups.current() != m_pageBackups.getFirst());
443} 469}
444 470
445bool DrawPadCanvas::redoEnabled() 471bool DrawPadCanvas::redoEnabled()
446{ 472{
447 return (m_pageBackups.current() != m_pageBackups.getLast()); 473 return (m_pageBackups.current() != m_pageBackups.getLast());
448} 474}
449 475
450bool DrawPadCanvas::goPreviousPageEnabled() 476bool DrawPadCanvas::goPreviousPageEnabled()
451{ 477{
452 return (m_pages.current() != m_pages.getFirst()); 478 return (m_pages.current() != m_pages.getFirst());
453} 479}
454 480
455bool DrawPadCanvas::goNextPageEnabled() 481bool DrawPadCanvas::goNextPageEnabled()
456{ 482{
457 return (m_pages.current() != m_pages.getLast()); 483 return (m_pages.current() != m_pages.getLast());
458} 484}
459 485
460void DrawPadCanvas::undo() 486void DrawPadCanvas::undo()
461{ 487{
462 *(m_pages.current()) = *(m_pageBackups.prev()); 488 *(m_pages.current()) = *(m_pageBackups.prev());
463 489
464 viewport()->update(); 490 viewport()->update();
465 491
466 emit pageBackupsChanged(); 492 emit pageBackupsChanged();
467} 493}
468 494
469void DrawPadCanvas::redo() 495void DrawPadCanvas::redo()
470{ 496{
471 *(m_pages.current()) = *(m_pageBackups.next()); 497 *(m_pages.current()) = *(m_pageBackups.next());
472 498
diff --git a/noncore/graphics/drawpad/drawpadcanvas.h b/noncore/graphics/drawpad/drawpadcanvas.h
index 39cf752..dcaff5c 100644
--- a/noncore/graphics/drawpad/drawpadcanvas.h
+++ b/noncore/graphics/drawpad/drawpadcanvas.h
@@ -1,85 +1,85 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * DrawPad - a drawing program for Opie Environment * 3 * DrawPad - a drawing program for Opie Environment *
4 * * 4 * *
5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> * 5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> *
6 * * 6 * *
7 * This program is free software; you can redistribute it and/or modify * 7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by * 8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or * 9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. * 10 * (at your option) any later version. *
11 * * 11 * *
12 ***************************************************************************/ 12 ***************************************************************************/
13 13
14#ifndef DRAWPADCANVAS_H 14#ifndef DRAWPADCANVAS_H
15#define DRAWPADCANVAS_H 15#define DRAWPADCANVAS_H
16 16
17#include <qscrollview.h> 17#include <qscrollview.h>
18 18
19#include <qlist.h> 19#include <qlist.h>
20#include <qpointarray.h> 20#include <qpointarray.h>
21 21
22class DrawPad; 22class DrawPad;
23class Page; 23class Page;
24 24
25class DrawPadCanvas : public QScrollView 25class DrawPadCanvas : public QScrollView
26{ 26{
27 Q_OBJECT 27 Q_OBJECT
28 28
29public: 29public:
30 DrawPadCanvas(DrawPad* drawPad, QWidget* parent = 0, const char* name = 0); 30 DrawPadCanvas(DrawPad* drawPad, QWidget* parent = 0, const char* name = 0);
31 ~DrawPadCanvas(); 31 ~DrawPadCanvas();
32 32
33 void load(QIODevice* ioDevice); 33 void load(QIODevice* ioDevice);
34 void initialPage(); 34 void initialPage();
35 void save(QIODevice* ioDevice); 35 void save(QIODevice* ioDevice);
36 36
37 void importPage(const QString& fileName); 37 void importPage(const QString& fileName);
38 void exportPage(uint fromPage, uint toPage, const QString& name, const QString& format); 38 void exportPage(uint fromPage, uint toPage, const QString& name, const QString& format);
39 39
40 bool undoEnabled(); 40 bool undoEnabled();
41 bool redoEnabled(); 41 bool redoEnabled();
42 bool goPreviousPageEnabled(); 42 bool goPreviousPageEnabled();
43 bool goNextPageEnabled(); 43 bool goNextPageEnabled();
44 44
45 Page* currentPage(); 45 Page* currentPage();
46 QList<Page> pages(); 46 QList<Page> pages();
47 uint pagePosition(); 47 uint pagePosition();
48 uint pageCount(); 48 uint pageCount();
49 49
50 void selectPage(Page* page); 50 void selectPage(Page* page);
51 void backupPage(); 51 void backupPage();
52 52
53public slots: 53public slots:
54 void deleteAll(); 54 void deleteAll();
55 void newPage(uint width, uint height, const QColor& color); 55 void newPage(QString title, uint width, uint height, const QColor& color);
56 void clearPage(); 56 void clearPage();
57 void deletePage(); 57 void deletePage();
58 void movePageUp(); 58 void movePageUp();
59 void movePageDown(); 59 void movePageDown();
60 60
61 void undo(); 61 void undo();
62 void redo(); 62 void redo();
63 63
64 void goFirstPage(); 64 void goFirstPage();
65 void goPreviousPage(); 65 void goPreviousPage();
66 void goNextPage(); 66 void goNextPage();
67 void goLastPage(); 67 void goLastPage();
68 68
69signals: 69signals:
70 void pagesChanged(); 70 void pagesChanged();
71 void pageBackupsChanged(); 71 void pageBackupsChanged();
72 72
73protected: 73protected:
74 void contentsMousePressEvent(QMouseEvent* e); 74 void contentsMousePressEvent(QMouseEvent* e);
75 void contentsMouseReleaseEvent(QMouseEvent* e); 75 void contentsMouseReleaseEvent(QMouseEvent* e);
76 void contentsMouseMoveEvent(QMouseEvent* e); 76 void contentsMouseMoveEvent(QMouseEvent* e);
77 void drawContents(QPainter* p, int cx, int cy, int cw, int ch); 77 void drawContents(QPainter* p, int cx, int cy, int cw, int ch);
78 78
79private: 79private:
80 DrawPad* m_pDrawPad; 80 DrawPad* m_pDrawPad;
81 QList<Page> m_pages; 81 QList<Page> m_pages;
82 QList<Page> m_pageBackups; 82 QList<Page> m_pageBackups;
83}; 83};
84 84
85#endif // DRAWPADCANVAS_H 85#endif // DRAWPADCANVAS_H
diff --git a/noncore/graphics/drawpad/newpagedialog.cpp b/noncore/graphics/drawpad/newpagedialog.cpp
index ff31aad..e6e7fcb 100644
--- a/noncore/graphics/drawpad/newpagedialog.cpp
+++ b/noncore/graphics/drawpad/newpagedialog.cpp
@@ -24,91 +24,96 @@
24NewPageDialog::NewPageDialog(uint width, uint height, const QColor& penColor, 24NewPageDialog::NewPageDialog(uint width, uint height, const QColor& penColor,
25 const QColor& brushColor, QWidget* parent, const char* name) 25 const QColor& brushColor, QWidget* parent, const char* name)
26 : QDialog(parent, name, true) 26 : QDialog(parent, name, true)
27{ 27{
28 setCaption(tr("New Page")); 28 setCaption(tr("New Page"));
29 29
30 m_penColor = penColor; 30 m_penColor = penColor;
31 m_brushColor = brushColor; 31 m_brushColor = brushColor;
32 32
33 QGroupBox* generalGroupBox = new QGroupBox(0, Qt::Vertical, tr("General"), this); 33 QGroupBox* generalGroupBox = new QGroupBox(0, Qt::Vertical, tr("General"), this);
34 34
35 QLabel* titleLabel = new QLabel(tr("Title:"), generalGroupBox); 35 QLabel* titleLabel = new QLabel(tr("Title:"), generalGroupBox);
36 m_pTitleLineEdit = new QLineEdit(generalGroupBox); 36 m_pTitleLineEdit = new QLineEdit(generalGroupBox);
37 37
38 QGroupBox* sizeGroupBox = new QGroupBox(0, Qt::Vertical, tr("Size"), this); 38 QGroupBox* sizeGroupBox = new QGroupBox(0, Qt::Vertical, tr("Size"), this);
39 39
40 QLabel* widthLabel = new QLabel(tr("Width:"), sizeGroupBox); 40 QLabel* widthLabel = new QLabel(tr("Width:"), sizeGroupBox);
41 QLabel* heightLabel = new QLabel(tr("Height:"), sizeGroupBox); 41 QLabel* heightLabel = new QLabel(tr("Height:"), sizeGroupBox);
42 42
43 m_pWidthSpinBox = new QSpinBox(1, 1024, 1, sizeGroupBox); 43 m_pWidthSpinBox = new QSpinBox(1, 1024, 1, sizeGroupBox);
44 m_pHeightSpinBox = new QSpinBox(1, 1024, 1, sizeGroupBox); 44 m_pHeightSpinBox = new QSpinBox(1, 1024, 1, sizeGroupBox);
45 45
46 m_pWidthSpinBox->setValue(width); 46 m_pWidthSpinBox->setValue(width);
47 m_pHeightSpinBox->setValue(height); 47 m_pHeightSpinBox->setValue(height);
48 48
49 m_pContentButtonGroup = new QButtonGroup(0, Qt::Vertical, tr("Background"), this); 49 m_pContentButtonGroup = new QButtonGroup(0, Qt::Vertical, tr("Background"), this);
50 50
51 QRadioButton* whiteColorRadioButton = new QRadioButton(tr("White"), m_pContentButtonGroup); 51 QRadioButton* whiteColorRadioButton = new QRadioButton(tr("White"), m_pContentButtonGroup);
52 QRadioButton* penColorRadioButton = new QRadioButton(tr("Pen Color"), m_pContentButtonGroup); 52 QRadioButton* penColorRadioButton = new QRadioButton(tr("Pen Color"), m_pContentButtonGroup);
53 QRadioButton* brushColorRadioButton = new QRadioButton(tr("Fill Color"), m_pContentButtonGroup); 53 QRadioButton* brushColorRadioButton = new QRadioButton(tr("Fill Color"), m_pContentButtonGroup);
54 54
55 m_pContentButtonGroup->setButton(0); 55 m_pContentButtonGroup->setButton(0);
56 56
57 QVBoxLayout* mainLayout = new QVBoxLayout(this, 4, 4); 57 QVBoxLayout* mainLayout = new QVBoxLayout(this, 4, 4);
58 generalGroupBox->layout()->setSpacing(4); 58 generalGroupBox->layout()->setSpacing(4);
59 sizeGroupBox->layout()->setSpacing(4); 59 sizeGroupBox->layout()->setSpacing(4);
60 m_pContentButtonGroup->layout()->setSpacing(4); 60 m_pContentButtonGroup->layout()->setSpacing(4);
61 QGridLayout* generalLayout = new QGridLayout(generalGroupBox->layout(), 1, 1); 61 QGridLayout* generalLayout = new QGridLayout(generalGroupBox->layout(), 1, 1);
62 QGridLayout* sizeLayout = new QGridLayout(sizeGroupBox->layout(), 2, 2); 62 QGridLayout* sizeLayout = new QGridLayout(sizeGroupBox->layout(), 2, 2);
63 QVBoxLayout* contentLayout = new QVBoxLayout(m_pContentButtonGroup->layout()); 63 QVBoxLayout* contentLayout = new QVBoxLayout(m_pContentButtonGroup->layout());
64 64
65 generalLayout->addWidget(titleLabel, 0, 0); 65 generalLayout->addWidget(titleLabel, 0, 0);
66 generalLayout->addWidget(m_pTitleLineEdit, 0, 1); 66 generalLayout->addWidget(m_pTitleLineEdit, 0, 1);
67 67
68 sizeLayout->addWidget(widthLabel, 0, 0); 68 sizeLayout->addWidget(widthLabel, 0, 0);
69 sizeLayout->addWidget(heightLabel, 1, 0); 69 sizeLayout->addWidget(heightLabel, 1, 0);
70 sizeLayout->addWidget(m_pWidthSpinBox, 0, 1); 70 sizeLayout->addWidget(m_pWidthSpinBox, 0, 1);
71 sizeLayout->addWidget(m_pHeightSpinBox, 1, 1); 71 sizeLayout->addWidget(m_pHeightSpinBox, 1, 1);
72 72
73 sizeLayout->setColStretch(1, 1); 73 sizeLayout->setColStretch(1, 1);
74 74
75 contentLayout->addWidget(whiteColorRadioButton); 75 contentLayout->addWidget(whiteColorRadioButton);
76 contentLayout->addWidget(penColorRadioButton); 76 contentLayout->addWidget(penColorRadioButton);
77 contentLayout->addWidget(brushColorRadioButton); 77 contentLayout->addWidget(brushColorRadioButton);
78 78
79 mainLayout->addWidget(generalGroupBox); 79 mainLayout->addWidget(generalGroupBox);
80 mainLayout->addWidget(sizeGroupBox); 80 mainLayout->addWidget(sizeGroupBox);
81 mainLayout->addWidget(m_pContentButtonGroup); 81 mainLayout->addWidget(m_pContentButtonGroup);
82} 82}
83 83
84NewPageDialog::~NewPageDialog() 84NewPageDialog::~NewPageDialog()
85{ 85{
86} 86}
87 87
88QString NewPageDialog::selectedTitle()
89{
90 return (m_pTitleLineEdit->text());
91}
92
88uint NewPageDialog::selectedWidth() 93uint NewPageDialog::selectedWidth()
89{ 94{
90 return (m_pWidthSpinBox->value()); 95 return (m_pWidthSpinBox->value());
91} 96}
92 97
93uint NewPageDialog::selectedHeight() 98uint NewPageDialog::selectedHeight()
94{ 99{
95 return (m_pHeightSpinBox->value()); 100 return (m_pHeightSpinBox->value());
96} 101}
97 102
98const QColor& NewPageDialog::selectedColor() 103const QColor& NewPageDialog::selectedColor()
99{ 104{
100 switch (m_pContentButtonGroup->id(m_pContentButtonGroup->selected())) { 105 switch (m_pContentButtonGroup->id(m_pContentButtonGroup->selected())) {
101 case 0: 106 case 0:
102 return (Qt::white); 107 return (Qt::white);
103 break; 108 break;
104 case 1: 109 case 1:
105 return (m_penColor); 110 return (m_penColor);
106 break; 111 break;
107 case 2: 112 case 2:
108 return (m_brushColor); 113 return (m_brushColor);
109 break; 114 break;
110 default: 115 default:
111 return (Qt::white); 116 return (Qt::white);
112 break; 117 break;
113 } 118 }
114} 119}
diff --git a/noncore/graphics/drawpad/newpagedialog.h b/noncore/graphics/drawpad/newpagedialog.h
index fe8f562..c8f84b8 100644
--- a/noncore/graphics/drawpad/newpagedialog.h
+++ b/noncore/graphics/drawpad/newpagedialog.h
@@ -1,48 +1,49 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * DrawPad - a drawing program for Opie Environment * 3 * DrawPad - a drawing program for Opie Environment *
4 * * 4 * *
5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> * 5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> *
6 * * 6 * *
7 * This program is free software; you can redistribute it and/or modify * 7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by * 8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or * 9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. * 10 * (at your option) any later version. *
11 * * 11 * *
12 ***************************************************************************/ 12 ***************************************************************************/
13 13
14#ifndef NEWPAGEDIALOG_H 14#ifndef NEWPAGEDIALOG_H
15#define NEWPAGEDIALOG_H 15#define NEWPAGEDIALOG_H
16 16
17#include <qdialog.h> 17#include <qdialog.h>
18 18
19class QButtonGroup; 19class QButtonGroup;
20class QLineEdit; 20class QLineEdit;
21class QSpinBox; 21class QSpinBox;
22 22
23class NewPageDialog : public QDialog 23class NewPageDialog : public QDialog
24{ 24{
25 Q_OBJECT 25 Q_OBJECT
26 26
27public: 27public:
28 NewPageDialog(uint width, uint height, const QColor& foregroundColor, 28 NewPageDialog(uint width, uint height, const QColor& foregroundColor,
29 const QColor& backgroundColor, QWidget* parent = 0, const char* name = 0); 29 const QColor& backgroundColor, QWidget* parent = 0, const char* name = 0);
30 ~NewPageDialog(); 30 ~NewPageDialog();
31 31
32 QString selectedTitle();
32 uint selectedWidth(); 33 uint selectedWidth();
33 uint selectedHeight(); 34 uint selectedHeight();
34 const QColor& selectedColor(); 35 const QColor& selectedColor();
35 36
36private: 37private:
37 QLineEdit* m_pTitleLineEdit; 38 QLineEdit* m_pTitleLineEdit;
38 39
39 QSpinBox* m_pWidthSpinBox; 40 QSpinBox* m_pWidthSpinBox;
40 QSpinBox* m_pHeightSpinBox; 41 QSpinBox* m_pHeightSpinBox;
41 42
42 QColor m_penColor; 43 QColor m_penColor;
43 QColor m_brushColor; 44 QColor m_brushColor;
44 45
45 QButtonGroup* m_pContentButtonGroup; 46 QButtonGroup* m_pContentButtonGroup;
46}; 47};
47 48
48#endif // NEWPAGEDIALOG_H 49#endif // NEWPAGEDIALOG_H
diff --git a/noncore/graphics/drawpad/page.cpp b/noncore/graphics/drawpad/page.cpp
index 7034a20..601d1c3 100644
--- a/noncore/graphics/drawpad/page.cpp
+++ b/noncore/graphics/drawpad/page.cpp
@@ -1,57 +1,59 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * DrawPad - a drawing program for Opie Environment * 3 * DrawPad - a drawing program for Opie Environment *
4 * * 4 * *
5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> * 5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> *
6 * * 6 * *
7 * This program is free software; you can redistribute it and/or modify * 7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by * 8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or * 9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. * 10 * (at your option) any later version. *
11 * * 11 * *
12 ***************************************************************************/ 12 ***************************************************************************/
13 13
14#include "page.h" 14#include "page.h"
15 15
16Page::Page() 16Page::Page()
17 : QPixmap() 17 : QPixmap()
18{ 18{
19 m_lastModified = QDateTime::currentDateTime(); 19 m_lastModified = QDateTime::currentDateTime();
20} 20}
21 21
22Page::Page(int w, int h) 22Page::Page(QString title, int w, int h)
23 : QPixmap(w, h) 23 : QPixmap(w, h)
24{ 24{
25 m_title = title;
25 m_lastModified = QDateTime::currentDateTime(); 26 m_lastModified = QDateTime::currentDateTime();
26} 27}
27 28
28Page::Page(const QSize& size) 29Page::Page(QString title, const QSize& size)
29 : QPixmap(size) 30 : QPixmap(size)
30{ 31{
32 m_title = title;
31 m_lastModified = QDateTime::currentDateTime(); 33 m_lastModified = QDateTime::currentDateTime();
32} 34}
33 35
34Page::~Page() 36Page::~Page()
35{ 37{
36} 38}
37 39
38QString Page::title() const 40QString Page::title() const
39{ 41{
40 return m_title; 42 return m_title;
41} 43}
42 44
43QDateTime Page::lastModified() const 45QDateTime Page::lastModified() const
44{ 46{
45 return m_lastModified; 47 return m_lastModified;
46} 48}
47 49
48void Page::setTitle(QString title) 50void Page::setTitle(QString title)
49{ 51{
50 m_title = title; 52 m_title = title;
51} 53}
52 54
53void Page::setLastModified(QDateTime lastModified) 55void Page::setLastModified(QDateTime lastModified)
54{ 56{
55 m_lastModified = lastModified; 57 m_lastModified = lastModified;
56} 58}
57 59
diff --git a/noncore/graphics/drawpad/page.h b/noncore/graphics/drawpad/page.h
index 020ab1f..20a37b5 100644
--- a/noncore/graphics/drawpad/page.h
+++ b/noncore/graphics/drawpad/page.h
@@ -1,41 +1,41 @@
1/*************************************************************************** 1/***************************************************************************
2 * * 2 * *
3 * DrawPad - a drawing program for Opie Environment * 3 * DrawPad - a drawing program for Opie Environment *
4 * * 4 * *
5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> * 5 * (C) 2002 by S. Prud'homme <prudhomme@laposte.net> *
6 * * 6 * *
7 * This program is free software; you can redistribute it and/or modify * 7 * This program is free software; you can redistribute it and/or modify *
8 * it under the terms of the GNU General Public License as published by * 8 * it under the terms of the GNU General Public License as published by *
9 * the Free Software Foundation; either version 2 of the License, or * 9 * the Free Software Foundation; either version 2 of the License, or *
10 * (at your option) any later version. * 10 * (at your option) any later version. *
11 * * 11 * *
12 ***************************************************************************/ 12 ***************************************************************************/
13 13
14#ifndef PAGE_H 14#ifndef PAGE_H
15#define PAGE_H 15#define PAGE_H
16 16
17#include <qpixmap.h> 17#include <qpixmap.h>
18 18
19#include <qdatetime.h> 19#include <qdatetime.h>
20 20
21class Page : public QPixmap 21class Page : public QPixmap
22{ 22{
23public: 23public:
24 Page(); 24 Page();
25 Page(int w, int h); 25 Page(QString title, int w, int h);
26 Page(const QSize& size); 26 Page(QString title, const QSize& size);
27 27
28 ~Page(); 28 ~Page();
29 29
30 QString title() const; 30 QString title() const;
31 QDateTime lastModified() const; 31 QDateTime lastModified() const;
32 32
33 void setTitle(QString title); 33 void setTitle(QString title);
34 void setLastModified(QDateTime lastModified); 34 void setLastModified(QDateTime lastModified);
35 35
36private: 36private:
37 QString m_title; 37 QString m_title;
38 QDateTime m_lastModified; 38 QDateTime m_lastModified;
39}; 39};
40 40
41#endif // PAGE_H 41#endif // PAGE_H
diff --git a/noncore/graphics/drawpad/thumbnailview.cpp b/noncore/graphics/drawpad/thumbnailview.cpp
index 35955e8..81ec79f 100644
--- a/noncore/graphics/drawpad/thumbnailview.cpp
+++ b/noncore/graphics/drawpad/thumbnailview.cpp
@@ -260,123 +260,123 @@ ThumbnailView::ThumbnailView(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas, QWi
260 260
261 m_pMovePageDownButton = new QToolButton(this); 261 m_pMovePageDownButton = new QToolButton(this);
262 m_pMovePageDownButton->setIconSet(Resource::loadIconSet("down")); 262 m_pMovePageDownButton->setIconSet(Resource::loadIconSet("down"));
263 m_pMovePageDownButton->setAutoRaise(true); 263 m_pMovePageDownButton->setAutoRaise(true);
264 connect(m_pMovePageDownButton, SIGNAL(clicked()), this, SLOT(movePageDown())); 264 connect(m_pMovePageDownButton, SIGNAL(clicked()), this, SLOT(movePageDown()));
265 265
266 m_pPageListBox = new PageListBox(m_pDrawPadCanvas, this); 266 m_pPageListBox = new PageListBox(m_pDrawPadCanvas, this);
267 connect(m_pPageListBox, SIGNAL(selectionChanged()), this, SLOT(changePage())); 267 connect(m_pPageListBox, SIGNAL(selectionChanged()), this, SLOT(changePage()));
268 268
269 QVBoxLayout* mainLayout = new QVBoxLayout(this, 4, 4); 269 QVBoxLayout* mainLayout = new QVBoxLayout(this, 4, 4);
270 QHBoxLayout* buttonLayout = new QHBoxLayout(0); 270 QHBoxLayout* buttonLayout = new QHBoxLayout(0);
271 271
272 buttonLayout->addWidget(newPageButton); 272 buttonLayout->addWidget(newPageButton);
273 buttonLayout->addWidget(clearPageButton); 273 buttonLayout->addWidget(clearPageButton);
274 buttonLayout->addWidget(deletePageButton); 274 buttonLayout->addWidget(deletePageButton);
275 buttonLayout->addStretch(); 275 buttonLayout->addStretch();
276 buttonLayout->addWidget(m_pMovePageUpButton); 276 buttonLayout->addWidget(m_pMovePageUpButton);
277 buttonLayout->addWidget(m_pMovePageDownButton); 277 buttonLayout->addWidget(m_pMovePageDownButton);
278 278
279 mainLayout->addLayout(buttonLayout); 279 mainLayout->addLayout(buttonLayout);
280 mainLayout->addWidget(m_pPageListBox); 280 mainLayout->addWidget(m_pPageListBox);
281 281
282 updateView(); 282 updateView();
283} 283}
284 284
285ThumbnailView::~ThumbnailView() 285ThumbnailView::~ThumbnailView()
286{ 286{
287 hide(); 287 hide();
288} 288}
289 289
290void ThumbnailView::updateView() 290void ThumbnailView::updateView()
291{ 291{
292 m_pMovePageUpButton->setEnabled(m_pDrawPadCanvas->goPreviousPageEnabled()); 292 m_pMovePageUpButton->setEnabled(m_pDrawPadCanvas->goPreviousPageEnabled());
293 m_pMovePageDownButton->setEnabled(m_pDrawPadCanvas->goNextPageEnabled()); 293 m_pMovePageDownButton->setEnabled(m_pDrawPadCanvas->goNextPageEnabled());
294} 294}
295 295
296void ThumbnailView::hide() 296void ThumbnailView::hide()
297{ 297{
298 QWidget::hide(); 298 QWidget::hide();
299 299
300 if (inLoop) { 300 if (inLoop) {
301 inLoop = false; 301 inLoop = false;
302 qApp->exit_loop(); 302 qApp->exit_loop();
303 } 303 }
304} 304}
305 305
306void ThumbnailView::exec() 306void ThumbnailView::exec()
307{ 307{
308 show(); 308 show();
309 309
310 if (!inLoop) { 310 if (!inLoop) {
311 inLoop = true; 311 inLoop = true;
312 qApp->enter_loop(); 312 qApp->enter_loop();
313 } 313 }
314} 314}
315 315
316void ThumbnailView::newPage() 316void ThumbnailView::newPage()
317{ 317{
318 QRect rect = m_pDrawPadCanvas->contentsRect(); 318 QRect rect = m_pDrawPadCanvas->contentsRect();
319 319
320 NewPageDialog newPageDialog(rect.width(), rect.height(), m_pDrawPad->pen().color(), 320 NewPageDialog newPageDialog(rect.width(), rect.height(), m_pDrawPad->pen().color(),
321 m_pDrawPad->brush().color(), this); 321 m_pDrawPad->brush().color(), this);
322 322
323 if (newPageDialog.exec() == QDialog::Accepted) { 323 if (newPageDialog.exec() == QDialog::Accepted) {
324 m_pDrawPadCanvas->newPage(newPageDialog.selectedWidth(), newPageDialog.selectedHeight(), 324 m_pDrawPadCanvas->newPage(newPageDialog.selectedTitle(), newPageDialog.selectedWidth(),
325 newPageDialog.selectedColor()); 325 newPageDialog.selectedHeight(), newPageDialog.selectedColor());
326 m_pPageListBox->updateView(); 326 m_pPageListBox->updateView();
327 updateView(); 327 updateView();
328 } 328 }
329} 329}
330 330
331void ThumbnailView::clearPage() 331void ThumbnailView::clearPage()
332{ 332{
333 QMessageBox messageBox(tr("Clear Page"), tr("Do you want to clear\nthe selected page?"), 333 QMessageBox messageBox(tr("Clear Page"), tr("Do you want to clear\nthe selected page?"),
334 QMessageBox::Information, QMessageBox::Yes, 334 QMessageBox::Information, QMessageBox::Yes,
335 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default, 335 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default,
336 QMessageBox::NoButton, this); 336 QMessageBox::NoButton, this);
337 337
338 messageBox.setButtonText(QMessageBox::Yes, tr("Yes")); 338 messageBox.setButtonText(QMessageBox::Yes, tr("Yes"));
339 messageBox.setButtonText(QMessageBox::No, tr("No")); 339 messageBox.setButtonText(QMessageBox::No, tr("No"));
340 340
341 if (messageBox.exec() == QMessageBox::Yes) { 341 if (messageBox.exec() == QMessageBox::Yes) {
342 m_pDrawPadCanvas->clearPage(); 342 m_pDrawPadCanvas->clearPage();
343 m_pPageListBox->updateView(); 343 m_pPageListBox->updateView();
344 } 344 }
345} 345}
346 346
347void ThumbnailView::deletePage() 347void ThumbnailView::deletePage()
348{ 348{
349 QMessageBox messageBox(tr("Delete Page"), tr("Do you want to delete\nthe selected page?"), 349 QMessageBox messageBox(tr("Delete Page"), tr("Do you want to delete\nthe selected page?"),
350 QMessageBox::Information, QMessageBox::Yes, 350 QMessageBox::Information, QMessageBox::Yes,
351 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default, 351 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default,
352 QMessageBox::NoButton, this); 352 QMessageBox::NoButton, this);
353 353
354 messageBox.setButtonText(QMessageBox::Yes, tr("Yes")); 354 messageBox.setButtonText(QMessageBox::Yes, tr("Yes"));
355 messageBox.setButtonText(QMessageBox::No, tr("No")); 355 messageBox.setButtonText(QMessageBox::No, tr("No"));
356 356
357 if (messageBox.exec() == QMessageBox::Yes) { 357 if (messageBox.exec() == QMessageBox::Yes) {
358 m_pDrawPadCanvas->deletePage(); 358 m_pDrawPadCanvas->deletePage();
359 m_pPageListBox->updateView(); 359 m_pPageListBox->updateView();
360 updateView(); 360 updateView();
361 } 361 }
362} 362}
363 363
364void ThumbnailView::movePageUp() 364void ThumbnailView::movePageUp()
365{ 365{
366 m_pDrawPadCanvas->movePageUp(); 366 m_pDrawPadCanvas->movePageUp();
367 m_pPageListBox->updateView(); 367 m_pPageListBox->updateView();
368 updateView(); 368 updateView();
369} 369}
370 370
371void ThumbnailView::movePageDown() 371void ThumbnailView::movePageDown()
372{ 372{
373 m_pDrawPadCanvas->movePageDown(); 373 m_pDrawPadCanvas->movePageDown();
374 m_pPageListBox->updateView(); 374 m_pPageListBox->updateView();
375 updateView(); 375 updateView();
376} 376}
377 377
378void ThumbnailView::changePage() 378void ThumbnailView::changePage()
379{ 379{
380 m_pDrawPadCanvas->selectPage(m_pPageListBox->selected()); 380 m_pDrawPadCanvas->selectPage(m_pPageListBox->selected());
381 updateView(); 381 updateView();
382} 382}