summaryrefslogtreecommitdiff
Unidiff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/graphics/drawpad/drawpadcanvas.cpp18
-rw-r--r--noncore/graphics/drawpad/drawpadcanvas.h2
-rw-r--r--noncore/graphics/drawpad/thumbnailview.cpp43
-rw-r--r--noncore/graphics/drawpad/thumbnailview.h11
4 files changed, 65 insertions, 9 deletions
diff --git a/noncore/graphics/drawpad/drawpadcanvas.cpp b/noncore/graphics/drawpad/drawpadcanvas.cpp
index c23ee34..bcb6877 100644
--- a/noncore/graphics/drawpad/drawpadcanvas.cpp
+++ b/noncore/graphics/drawpad/drawpadcanvas.cpp
@@ -294,249 +294,267 @@ void DrawPadCanvas::exportPage(uint fromPage, uint toPage, const QString& name,c
294 docLnk.setName(name + QString::number(i)); 294 docLnk.setName(name + QString::number(i));
295 docLnk.setType(mimeType.id()); 295 docLnk.setType(mimeType.id());
296 296
297 FileManager fileManager; 297 FileManager fileManager;
298 QIODevice* ioDevice = fileManager.saveFile(docLnk); 298 QIODevice* ioDevice = fileManager.saveFile(docLnk);
299 QImageIO imageIO(ioDevice, format); 299 QImageIO imageIO(ioDevice, format);
300 300
301 QImage image = m_pages.at(i - 1)->convertToImage(); 301 QImage image = m_pages.at(i - 1)->convertToImage();
302 imageIO.setImage(image); 302 imageIO.setImage(image);
303 imageIO.write(); 303 imageIO.write();
304 delete ioDevice; 304 delete ioDevice;
305 } 305 }
306 } 306 }
307} 307}
308 308
309Page* DrawPadCanvas::currentPage() 309Page* DrawPadCanvas::currentPage()
310{ 310{
311 return m_pages.current(); 311 return m_pages.current();
312} 312}
313 313
314QList<Page> DrawPadCanvas::pages() 314QList<Page> DrawPadCanvas::pages()
315{ 315{
316 return m_pages; 316 return m_pages;
317} 317}
318 318
319uint DrawPadCanvas::pagePosition() 319uint DrawPadCanvas::pagePosition()
320{ 320{
321 return (m_pages.at() + 1); 321 return (m_pages.at() + 1);
322} 322}
323 323
324uint DrawPadCanvas::pageCount() 324uint DrawPadCanvas::pageCount()
325{ 325{
326 return m_pages.count(); 326 return m_pages.count();
327} 327}
328 328
329void DrawPadCanvas::selectPage(Page* page) 329void DrawPadCanvas::selectPage(Page* page)
330{ 330{
331 m_pages.findRef(page); 331 m_pages.findRef(page);
332 m_pageBackups.clear(); 332 m_pageBackups.clear();
333 m_pageBackups.append(new Page(*(m_pages.current()))); 333 m_pageBackups.append(new Page(*(m_pages.current())));
334 334
335 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 335 resizeContents(m_pages.current()->width(), m_pages.current()->height());
336 viewport()->update(); 336 viewport()->update();
337 337
338 emit pagesChanged(); 338 emit pagesChanged();
339 emit pageBackupsChanged(); 339 emit pageBackupsChanged();
340} 340}
341 341
342void DrawPadCanvas::backupPage() 342void DrawPadCanvas::backupPage()
343{ 343{
344 QPixmap* currentBackup = m_pageBackups.current(); 344 QPixmap* currentBackup = m_pageBackups.current();
345 while (m_pageBackups.last() != currentBackup) { 345 while (m_pageBackups.last() != currentBackup) {
346 m_pageBackups.removeLast(); 346 m_pageBackups.removeLast();
347 } 347 }
348 348
349 while (m_pageBackups.count() >= (5 + 1)) { 349 while (m_pageBackups.count() >= (5 + 1)) {
350 m_pageBackups.removeFirst(); 350 m_pageBackups.removeFirst();
351 } 351 }
352 352
353 m_pageBackups.append(new Page(*(m_pages.current()))); 353 m_pageBackups.append(new Page(*(m_pages.current())));
354 354
355 emit pageBackupsChanged(); 355 emit pageBackupsChanged();
356} 356}
357 357
358void DrawPadCanvas::deleteAll() 358void DrawPadCanvas::deleteAll()
359{ 359{
360 m_pages.clear(); 360 m_pages.clear();
361 361
362 m_pages.append(new Page(contentsRect().size())); 362 m_pages.append(new Page(contentsRect().size()));
363 m_pages.current()->fill(Qt::white); 363 m_pages.current()->fill(Qt::white);
364 364
365 m_pageBackups.clear(); 365 m_pageBackups.clear();
366 m_pageBackups.append(new Page(*(m_pages.current()))); 366 m_pageBackups.append(new Page(*(m_pages.current())));
367 367
368 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 368 resizeContents(m_pages.current()->width(), m_pages.current()->height());
369 viewport()->update(); 369 viewport()->update();
370 370
371 emit pagesChanged(); 371 emit pagesChanged();
372 emit pageBackupsChanged(); 372 emit pageBackupsChanged();
373} 373}
374 374
375void DrawPadCanvas::newPage(uint width, uint height, const QColor& color) 375void DrawPadCanvas::newPage(uint width, uint height, const QColor& color)
376{ 376{
377 m_pages.insert(m_pages.at() + 1, new Page(width, height)); 377 m_pages.insert(m_pages.at() + 1, new Page(width, height));
378 m_pages.current()->fill(color); 378 m_pages.current()->fill(color);
379 379
380 m_pageBackups.clear(); 380 m_pageBackups.clear();
381 m_pageBackups.append(new Page(*(m_pages.current()))); 381 m_pageBackups.append(new Page(*(m_pages.current())));
382 382
383 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 383 resizeContents(m_pages.current()->width(), m_pages.current()->height());
384 viewport()->update(); 384 viewport()->update();
385 385
386 emit pagesChanged(); 386 emit pagesChanged();
387 emit pageBackupsChanged(); 387 emit pageBackupsChanged();
388} 388}
389 389
390void DrawPadCanvas::clearPage() 390void DrawPadCanvas::clearPage()
391{ 391{
392 m_pages.current()->fill(Qt::white); 392 m_pages.current()->fill(Qt::white);
393 393
394 m_pageBackups.clear(); 394 m_pageBackups.clear();
395 m_pageBackups.append(new Page(*(m_pages.current()))); 395 m_pageBackups.append(new Page(*(m_pages.current())));
396 396
397 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 397 resizeContents(m_pages.current()->width(), m_pages.current()->height());
398 viewport()->update(); 398 viewport()->update();
399 399
400 emit pageBackupsChanged(); 400 emit pageBackupsChanged();
401} 401}
402 402
403void DrawPadCanvas::deletePage() 403void DrawPadCanvas::deletePage()
404{ 404{
405 m_pages.remove(m_pages.current()); 405 m_pages.remove(m_pages.current());
406 406
407 if (m_pages.isEmpty()) { 407 if (m_pages.isEmpty()) {
408 m_pages.append(new Page(contentsRect().size())); 408 m_pages.append(new Page(contentsRect().size()));
409 m_pages.current()->fill(Qt::white); 409 m_pages.current()->fill(Qt::white);
410 } 410 }
411 411
412 m_pageBackups.clear(); 412 m_pageBackups.clear();
413 m_pageBackups.append(new Page(*(m_pages.current()))); 413 m_pageBackups.append(new Page(*(m_pages.current())));
414 414
415 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 415 resizeContents(m_pages.current()->width(), m_pages.current()->height());
416 viewport()->update(); 416 viewport()->update();
417 417
418 emit pagesChanged(); 418 emit pagesChanged();
419 emit pageBackupsChanged(); 419 emit pageBackupsChanged();
420} 420}
421 421
422void DrawPadCanvas::movePageUp()
423{
424 int index = m_pages.at();
425 Page* page = m_pages.take();
426 m_pages.insert(index - 1, page);
427
428 emit pagesChanged();
429}
430
431void DrawPadCanvas::movePageDown()
432{
433 int index = m_pages.at();
434 Page* page = m_pages.take();
435 m_pages.insert(index + 1, page);
436
437 emit pagesChanged();
438}
439
422bool DrawPadCanvas::undoEnabled() 440bool DrawPadCanvas::undoEnabled()
423{ 441{
424 return (m_pageBackups.current() != m_pageBackups.getFirst()); 442 return (m_pageBackups.current() != m_pageBackups.getFirst());
425} 443}
426 444
427bool DrawPadCanvas::redoEnabled() 445bool DrawPadCanvas::redoEnabled()
428{ 446{
429 return (m_pageBackups.current() != m_pageBackups.getLast()); 447 return (m_pageBackups.current() != m_pageBackups.getLast());
430} 448}
431 449
432bool DrawPadCanvas::goPreviousPageEnabled() 450bool DrawPadCanvas::goPreviousPageEnabled()
433{ 451{
434 return (m_pages.current() != m_pages.getFirst()); 452 return (m_pages.current() != m_pages.getFirst());
435} 453}
436 454
437bool DrawPadCanvas::goNextPageEnabled() 455bool DrawPadCanvas::goNextPageEnabled()
438{ 456{
439 return (m_pages.current() != m_pages.getLast()); 457 return (m_pages.current() != m_pages.getLast());
440} 458}
441 459
442void DrawPadCanvas::undo() 460void DrawPadCanvas::undo()
443{ 461{
444 *(m_pages.current()) = *(m_pageBackups.prev()); 462 *(m_pages.current()) = *(m_pageBackups.prev());
445 463
446 viewport()->update(); 464 viewport()->update();
447 465
448 emit pageBackupsChanged(); 466 emit pageBackupsChanged();
449} 467}
450 468
451void DrawPadCanvas::redo() 469void DrawPadCanvas::redo()
452{ 470{
453 *(m_pages.current()) = *(m_pageBackups.next()); 471 *(m_pages.current()) = *(m_pageBackups.next());
454 472
455 viewport()->update(); 473 viewport()->update();
456 474
457 emit pageBackupsChanged(); 475 emit pageBackupsChanged();
458} 476}
459 477
460void DrawPadCanvas::goFirstPage() 478void DrawPadCanvas::goFirstPage()
461{ 479{
462 m_pages.first(); 480 m_pages.first();
463 m_pageBackups.clear(); 481 m_pageBackups.clear();
464 m_pageBackups.append(new Page(*(m_pages.current()))); 482 m_pageBackups.append(new Page(*(m_pages.current())));
465 483
466 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 484 resizeContents(m_pages.current()->width(), m_pages.current()->height());
467 viewport()->update(); 485 viewport()->update();
468 486
469 emit pagesChanged(); 487 emit pagesChanged();
470 emit pageBackupsChanged(); 488 emit pageBackupsChanged();
471} 489}
472 490
473void DrawPadCanvas::goPreviousPage() 491void DrawPadCanvas::goPreviousPage()
474{ 492{
475 m_pages.prev(); 493 m_pages.prev();
476 m_pageBackups.clear(); 494 m_pageBackups.clear();
477 m_pageBackups.append(new Page(*(m_pages.current()))); 495 m_pageBackups.append(new Page(*(m_pages.current())));
478 496
479 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 497 resizeContents(m_pages.current()->width(), m_pages.current()->height());
480 viewport()->update(); 498 viewport()->update();
481 499
482 emit pagesChanged(); 500 emit pagesChanged();
483 emit pageBackupsChanged(); 501 emit pageBackupsChanged();
484} 502}
485 503
486void DrawPadCanvas::goNextPage() 504void DrawPadCanvas::goNextPage()
487{ 505{
488 m_pages.next(); 506 m_pages.next();
489 m_pageBackups.clear(); 507 m_pageBackups.clear();
490 m_pageBackups.append(new Page(*(m_pages.current()))); 508 m_pageBackups.append(new Page(*(m_pages.current())));
491 509
492 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 510 resizeContents(m_pages.current()->width(), m_pages.current()->height());
493 viewport()->update(); 511 viewport()->update();
494 512
495 emit pagesChanged(); 513 emit pagesChanged();
496 emit pageBackupsChanged(); 514 emit pageBackupsChanged();
497} 515}
498 516
499void DrawPadCanvas::goLastPage() 517void DrawPadCanvas::goLastPage()
500{ 518{
501 m_pages.last(); 519 m_pages.last();
502 m_pageBackups.clear(); 520 m_pageBackups.clear();
503 m_pageBackups.append(new Page(*(m_pages.current()))); 521 m_pageBackups.append(new Page(*(m_pages.current())));
504 522
505 resizeContents(m_pages.current()->width(), m_pages.current()->height()); 523 resizeContents(m_pages.current()->width(), m_pages.current()->height());
506 viewport()->update(); 524 viewport()->update();
507 525
508 emit pagesChanged(); 526 emit pagesChanged();
509 emit pageBackupsChanged(); 527 emit pageBackupsChanged();
510} 528}
511 529
512void DrawPadCanvas::contentsMousePressEvent(QMouseEvent* e) 530void DrawPadCanvas::contentsMousePressEvent(QMouseEvent* e)
513{ 531{
514 m_pDrawPad->tool()->mousePressEvent(e); 532 m_pDrawPad->tool()->mousePressEvent(e);
515} 533}
516 534
517void DrawPadCanvas::contentsMouseReleaseEvent(QMouseEvent* e) 535void DrawPadCanvas::contentsMouseReleaseEvent(QMouseEvent* e)
518{ 536{
519 m_pDrawPad->tool()->mouseReleaseEvent(e); 537 m_pDrawPad->tool()->mouseReleaseEvent(e);
520} 538}
521 539
522void DrawPadCanvas::contentsMouseMoveEvent(QMouseEvent* e) 540void DrawPadCanvas::contentsMouseMoveEvent(QMouseEvent* e)
523{ 541{
524 m_pDrawPad->tool()->mouseMoveEvent(e); 542 m_pDrawPad->tool()->mouseMoveEvent(e);
525} 543}
526 544
527void DrawPadCanvas::drawContents(QPainter* p, int cx, int cy, int cw, int ch) 545void DrawPadCanvas::drawContents(QPainter* p, int cx, int cy, int cw, int ch)
528{ 546{
529 QRect clipRect(cx, cy, cw, ch); 547 QRect clipRect(cx, cy, cw, ch);
530 QRect pixmapRect(0, 0, m_pages.current()->width(), m_pages.current()->height()); 548 QRect pixmapRect(0, 0, m_pages.current()->width(), m_pages.current()->height());
531 QRect drawRect = pixmapRect.intersect(clipRect); 549 QRect drawRect = pixmapRect.intersect(clipRect);
532 550
533 p->drawPixmap(drawRect.topLeft(), *(m_pages.current()), drawRect); 551 p->drawPixmap(drawRect.topLeft(), *(m_pages.current()), drawRect);
534 552
535 if (drawRect.right() < clipRect.right()) { 553 if (drawRect.right() < clipRect.right()) {
536 p->fillRect(drawRect.right() + 1, cy, cw - drawRect.width(), ch, colorGroup().dark()); 554 p->fillRect(drawRect.right() + 1, cy, cw - drawRect.width(), ch, colorGroup().dark());
537 } 555 }
538 556
539 if (drawRect.bottom() < clipRect.bottom()) { 557 if (drawRect.bottom() < clipRect.bottom()) {
540 p->fillRect(cx, drawRect.bottom() + 1, cw, ch - drawRect.height(), colorGroup().dark()); 558 p->fillRect(cx, drawRect.bottom() + 1, cw, ch - drawRect.height(), colorGroup().dark());
541 } 559 }
542} 560}
diff --git a/noncore/graphics/drawpad/drawpadcanvas.h b/noncore/graphics/drawpad/drawpadcanvas.h
index d74d425..39cf752 100644
--- a/noncore/graphics/drawpad/drawpadcanvas.h
+++ b/noncore/graphics/drawpad/drawpadcanvas.h
@@ -1,83 +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(uint width, uint height, const QColor& color);
56 void clearPage(); 56 void clearPage();
57 void deletePage(); 57 void deletePage();
58 void movePageUp();
59 void movePageDown();
58 60
59 void undo(); 61 void undo();
60 void redo(); 62 void redo();
61 63
62 void goFirstPage(); 64 void goFirstPage();
63 void goPreviousPage(); 65 void goPreviousPage();
64 void goNextPage(); 66 void goNextPage();
65 void goLastPage(); 67 void goLastPage();
66 68
67signals: 69signals:
68 void pagesChanged(); 70 void pagesChanged();
69 void pageBackupsChanged(); 71 void pageBackupsChanged();
70 72
71protected: 73protected:
72 void contentsMousePressEvent(QMouseEvent* e); 74 void contentsMousePressEvent(QMouseEvent* e);
73 void contentsMouseReleaseEvent(QMouseEvent* e); 75 void contentsMouseReleaseEvent(QMouseEvent* e);
74 void contentsMouseMoveEvent(QMouseEvent* e); 76 void contentsMouseMoveEvent(QMouseEvent* e);
75 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);
76 78
77private: 79private:
78 DrawPad* m_pDrawPad; 80 DrawPad* m_pDrawPad;
79 QList<Page> m_pages; 81 QList<Page> m_pages;
80 QList<Page> m_pageBackups; 82 QList<Page> m_pageBackups;
81}; 83};
82 84
83#endif // DRAWPADCANVAS_H 85#endif // DRAWPADCANVAS_H
diff --git a/noncore/graphics/drawpad/thumbnailview.cpp b/noncore/graphics/drawpad/thumbnailview.cpp
index 0c7934e..428e008 100644
--- a/noncore/graphics/drawpad/thumbnailview.cpp
+++ b/noncore/graphics/drawpad/thumbnailview.cpp
@@ -45,228 +45,255 @@ PageListViewItem::PageListViewItem(Page* page, QListView* parent)
45 } 45 }
46 46
47 if (previewHeight < image.height()) { 47 if (previewHeight < image.height()) {
48 heightScale = (float)previewHeight / float(image.height()); 48 heightScale = (float)previewHeight / float(image.height());
49 } 49 }
50 50
51 float scale = (widthScale < heightScale ? widthScale : heightScale); 51 float scale = (widthScale < heightScale ? widthScale : heightScale);
52 QImage previewImage = image.smoothScale((int)(image.width() * scale) , (int)(image.height() * scale)); 52 QImage previewImage = image.smoothScale((int)(image.width() * scale) , (int)(image.height() * scale));
53 53
54 QPixmap previewPixmap; 54 QPixmap previewPixmap;
55 previewPixmap.convertFromImage(previewImage); 55 previewPixmap.convertFromImage(previewImage);
56 56
57 QPixmap pixmap(64, 64); 57 QPixmap pixmap(64, 64);
58 58
59 pixmap.fill(listView()->colorGroup().mid()); 59 pixmap.fill(listView()->colorGroup().mid());
60 bitBlt(&pixmap, (pixmap.width() - previewPixmap.width()) / 2, 60 bitBlt(&pixmap, (pixmap.width() - previewPixmap.width()) / 2,
61 (pixmap.height() - previewPixmap.height()) / 2, &previewPixmap); 61 (pixmap.height() - previewPixmap.height()) / 2, &previewPixmap);
62 62
63 setPixmap(0, pixmap); 63 setPixmap(0, pixmap);
64} 64}
65 65
66PageListViewItem::~PageListViewItem() 66PageListViewItem::~PageListViewItem()
67{ 67{
68} 68}
69 69
70Page* PageListViewItem::page() const 70Page* PageListViewItem::page() const
71{ 71{
72 return m_pPage; 72 return m_pPage;
73} 73}
74 74
75PageListView::PageListView(DrawPadCanvas* drawPadCanvas, QWidget* parent, const char* name) 75PageListView::PageListView(DrawPadCanvas* drawPadCanvas, QWidget* parent, const char* name)
76 : QListView(parent, name) 76 : QListView(parent, name)
77{ 77{
78 m_pDrawPadCanvas = drawPadCanvas; 78 m_pDrawPadCanvas = drawPadCanvas;
79 79
80 header()->hide(); 80 header()->hide();
81 setVScrollBarMode(QScrollView::AlwaysOn); 81 setVScrollBarMode(QScrollView::AlwaysOn);
82 setAllColumnsShowFocus(true); 82 setAllColumnsShowFocus(true);
83 83
84 addColumn(tr("Thumbnail")); 84 addColumn(tr("Thumbnail"));
85 addColumn(tr("Information")); 85 addColumn(tr("Information"));
86 86
87 updateView(); 87 updateView();
88} 88}
89 89
90PageListView::~PageListView() 90PageListView::~PageListView()
91{ 91{
92} 92}
93 93
94void PageListView::updateView() 94void PageListView::updateView()
95{ 95{
96 clear(); 96 clear();
97 97
98 if (m_pDrawPadCanvas) { 98 if (m_pDrawPadCanvas) {
99 QList<Page> pageList = m_pDrawPadCanvas->pages(); 99 QList<Page> pageList = m_pDrawPadCanvas->pages();
100 QListIterator<Page> it(pageList); 100 QListIterator<Page> it(pageList);
101 101
102 for (; it.current(); ++it) { 102 for (; it.current(); ++it) {
103 new PageListViewItem(it.current(), this); 103 new PageListViewItem(it.current(), this);
104 } 104 }
105 105
106 setSorting(0, false); 106 setSorting(0, false);
107 select(m_pDrawPadCanvas->currentPage()); 107 select(m_pDrawPadCanvas->currentPage());
108 } 108 }
109} 109}
110 110
111void PageListView::resizeEvent(QResizeEvent* e) 111void PageListView::resizeEvent(QResizeEvent* e)
112{ 112{
113 Q_UNUSED(e); 113 Q_UNUSED(e);
114 114
115 setColumnWidth(1, contentsRect().width() - columnWidth(0) - verticalScrollBar()->width()); 115 setColumnWidth(1, contentsRect().width() - columnWidth(0) - verticalScrollBar()->width());
116} 116}
117 117
118void PageListView::select(Page* page) 118void PageListView::select(Page* page)
119{ 119{
120 PageListViewItem* item = (PageListViewItem*)firstChild(); 120 PageListViewItem* item = (PageListViewItem*)firstChild();
121 121
122 while (item) { 122 while (item) {
123 if (item->page() == page) { 123 if (item->page() == page) {
124 setSelected(item, true); 124 setSelected(item, true);
125 ensureItemVisible(item); 125 ensureItemVisible(item);
126 break; 126 break;
127 } 127 }
128 128
129 item = (PageListViewItem*)(item->nextSibling()); 129 item = (PageListViewItem*)(item->nextSibling());
130 } 130 }
131} 131}
132 132
133Page* PageListView::selected() const 133Page* PageListView::selected() const
134{ 134{
135 Page* page; 135 Page* page;
136 136
137 PageListViewItem* item = (PageListViewItem*)selectedItem(); 137 PageListViewItem* item = (PageListViewItem*)selectedItem();
138 138
139 if (item) { 139 if (item) {
140 page = item->page(); 140 page = item->page();
141 } else { 141 } else {
142 page = NULL; 142 page = NULL;
143 } 143 }
144 144
145 return page; 145 return page;
146} 146}
147 147
148ThumbnailView::ThumbnailView(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas, QWidget* parent, const char* name) 148ThumbnailView::ThumbnailView(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas, QWidget* parent, const char* name)
149 : QWidget(parent, name, Qt::WType_Modal | Qt::WType_TopLevel) 149 : QWidget(parent, name, Qt::WType_Modal | Qt::WType_TopLevel)
150{ 150{
151 inLoop = false; 151 inLoop = false;
152 152
153 m_pDrawPad = drawPad; 153 m_pDrawPad = drawPad;
154 m_pDrawPadCanvas = drawPadCanvas; 154 m_pDrawPadCanvas = drawPadCanvas;
155 155
156 setCaption(tr("DrawPad - Thumbnail View")); 156 setCaption(tr("DrawPad - Thumbnail View"));
157 157
158 QToolButton* newPageButton = new QToolButton(this); 158 QToolButton* newPageButton = new QToolButton(this);
159 newPageButton->setIconSet(Resource::loadIconSet("new")); 159 newPageButton->setIconSet(Resource::loadIconSet("new"));
160 newPageButton->setAutoRaise(true); 160 newPageButton->setAutoRaise(true);
161 connect(newPageButton, SIGNAL(clicked()), this, SLOT(newPage())); 161 connect(newPageButton, SIGNAL(clicked()), this, SLOT(newPage()));
162 162
163 QToolButton* clearPageButton = new QToolButton(this); 163 QToolButton* clearPageButton = new QToolButton(this);
164 clearPageButton->setIconSet(Resource::loadIconSet("drawpad/clear")); 164 clearPageButton->setIconSet(Resource::loadIconSet("drawpad/clear"));
165 clearPageButton->setAutoRaise(true); 165 clearPageButton->setAutoRaise(true);
166 connect(clearPageButton, SIGNAL(clicked()), this, SLOT(clearPage())); 166 connect(clearPageButton, SIGNAL(clicked()), this, SLOT(clearPage()));
167 167
168 QToolButton* deletePageButton = new QToolButton(this); 168 QToolButton* deletePageButton = new QToolButton(this);
169 deletePageButton->setIconSet(Resource::loadIconSet("trash")); 169 deletePageButton->setIconSet(Resource::loadIconSet("trash"));
170 deletePageButton->setAutoRaise(true); 170 deletePageButton->setAutoRaise(true);
171 connect(deletePageButton, SIGNAL(clicked()), this, SLOT(deletePage())); 171 connect(deletePageButton, SIGNAL(clicked()), this, SLOT(deletePage()));
172 172
173 QToolButton* movePageUpButton = new QToolButton(this); 173 m_pMovePageUpButton = new QToolButton(this);
174 movePageUpButton->setIconSet(Resource::loadIconSet("up")); 174 m_pMovePageUpButton->setIconSet(Resource::loadIconSet("up"));
175 movePageUpButton->setAutoRaise(true); 175 m_pMovePageUpButton->setAutoRaise(true);
176 connect(m_pMovePageUpButton, SIGNAL(clicked()), this, SLOT(movePageUp()));
176 177
177 QToolButton* movePageDownButton = new QToolButton(this); 178 m_pMovePageDownButton = new QToolButton(this);
178 movePageDownButton->setIconSet(Resource::loadIconSet("down")); 179 m_pMovePageDownButton->setIconSet(Resource::loadIconSet("down"));
179 movePageDownButton->setAutoRaise(true); 180 m_pMovePageDownButton->setAutoRaise(true);
181 connect(m_pMovePageDownButton, SIGNAL(clicked()), this, SLOT(movePageDown()));
180 182
181 m_pPageListView = new PageListView(m_pDrawPadCanvas, this); 183 m_pPageListView = new PageListView(m_pDrawPadCanvas, this);
182 connect(m_pPageListView, SIGNAL(selectionChanged()), this, SLOT(changePage())); 184 connect(m_pPageListView, SIGNAL(selectionChanged()), this, SLOT(changePage()));
183 185
184 QVBoxLayout* mainLayout = new QVBoxLayout(this, 4, 4); 186 QVBoxLayout* mainLayout = new QVBoxLayout(this, 4, 4);
185 QHBoxLayout* buttonLayout = new QHBoxLayout(0); 187 QHBoxLayout* buttonLayout = new QHBoxLayout(0);
186 188
187 buttonLayout->addWidget(newPageButton); 189 buttonLayout->addWidget(newPageButton);
188 buttonLayout->addWidget(clearPageButton); 190 buttonLayout->addWidget(clearPageButton);
189 buttonLayout->addWidget(deletePageButton); 191 buttonLayout->addWidget(deletePageButton);
190 buttonLayout->addStretch(); 192 buttonLayout->addStretch();
191 buttonLayout->addWidget(movePageUpButton); 193 buttonLayout->addWidget(m_pMovePageUpButton);
192 buttonLayout->addWidget(movePageDownButton); 194 buttonLayout->addWidget(m_pMovePageDownButton);
193 195
194 mainLayout->addLayout(buttonLayout); 196 mainLayout->addLayout(buttonLayout);
195 mainLayout->addWidget(m_pPageListView); 197 mainLayout->addWidget(m_pPageListView);
198
199 updateView();
196} 200}
197 201
198ThumbnailView::~ThumbnailView() 202ThumbnailView::~ThumbnailView()
199{ 203{
200 hide(); 204 hide();
201} 205}
202 206
207void ThumbnailView::updateView()
208{
209 m_pMovePageUpButton->setEnabled(m_pDrawPadCanvas->goPreviousPageEnabled());
210 m_pMovePageDownButton->setEnabled(m_pDrawPadCanvas->goNextPageEnabled());
211}
212
203void ThumbnailView::hide() 213void ThumbnailView::hide()
204{ 214{
205 QWidget::hide(); 215 QWidget::hide();
206 216
207 if (inLoop) { 217 if (inLoop) {
208 inLoop = false; 218 inLoop = false;
209 qApp->exit_loop(); 219 qApp->exit_loop();
210 } 220 }
211} 221}
212 222
213void ThumbnailView::exec() 223void ThumbnailView::exec()
214{ 224{
215 show(); 225 show();
216 226
217 if (!inLoop) { 227 if (!inLoop) {
218 inLoop = true; 228 inLoop = true;
219 qApp->enter_loop(); 229 qApp->enter_loop();
220 } 230 }
221} 231}
222 232
223void ThumbnailView::newPage() 233void ThumbnailView::newPage()
224{ 234{
225 QRect rect = m_pDrawPadCanvas->contentsRect(); 235 QRect rect = m_pDrawPadCanvas->contentsRect();
226 236
227 NewPageDialog newPageDialog(rect.width(), rect.height(), m_pDrawPad->pen().color(), 237 NewPageDialog newPageDialog(rect.width(), rect.height(), m_pDrawPad->pen().color(),
228 m_pDrawPad->brush().color(), this); 238 m_pDrawPad->brush().color(), this);
229 239
230 if (newPageDialog.exec() == QDialog::Accepted) { 240 if (newPageDialog.exec() == QDialog::Accepted) {
231 m_pDrawPadCanvas->newPage(newPageDialog.selectedWidth(), newPageDialog.selectedHeight(), 241 m_pDrawPadCanvas->newPage(newPageDialog.selectedWidth(), newPageDialog.selectedHeight(),
232 newPageDialog.selectedColor()); 242 newPageDialog.selectedColor());
233 m_pPageListView->updateView(); 243 m_pPageListView->updateView();
244 updateView();
234 } 245 }
235} 246}
236 247
237void ThumbnailView::clearPage() 248void ThumbnailView::clearPage()
238{ 249{
239 QMessageBox messageBox(tr("Clear Page"), tr("Do you want to clear\nthe selected page?"), 250 QMessageBox messageBox(tr("Clear Page"), tr("Do you want to clear\nthe selected page?"),
240 QMessageBox::Information, QMessageBox::Yes, 251 QMessageBox::Information, QMessageBox::Yes,
241 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default, 252 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default,
242 QMessageBox::NoButton, this); 253 QMessageBox::NoButton, this);
243 254
244 messageBox.setButtonText(QMessageBox::Yes, tr("Yes")); 255 messageBox.setButtonText(QMessageBox::Yes, tr("Yes"));
245 messageBox.setButtonText(QMessageBox::No, tr("No")); 256 messageBox.setButtonText(QMessageBox::No, tr("No"));
246 257
247 if (messageBox.exec() == QMessageBox::Yes) { 258 if (messageBox.exec() == QMessageBox::Yes) {
248 m_pDrawPadCanvas->clearPage(); 259 m_pDrawPadCanvas->clearPage();
249 m_pPageListView->updateView(); 260 m_pPageListView->updateView();
250 } 261 }
251} 262}
252 263
253void ThumbnailView::deletePage() 264void ThumbnailView::deletePage()
254{ 265{
255 QMessageBox messageBox(tr("Delete Page"), tr("Do you want to delete\nthe selected page?"), 266 QMessageBox messageBox(tr("Delete Page"), tr("Do you want to delete\nthe selected page?"),
256 QMessageBox::Information, QMessageBox::Yes, 267 QMessageBox::Information, QMessageBox::Yes,
257 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default, 268 QMessageBox::No | QMessageBox::Escape | QMessageBox::Default,
258 QMessageBox::NoButton, this); 269 QMessageBox::NoButton, this);
259 270
260 messageBox.setButtonText(QMessageBox::Yes, tr("Yes")); 271 messageBox.setButtonText(QMessageBox::Yes, tr("Yes"));
261 messageBox.setButtonText(QMessageBox::No, tr("No")); 272 messageBox.setButtonText(QMessageBox::No, tr("No"));
262 273
263 if (messageBox.exec() == QMessageBox::Yes) { 274 if (messageBox.exec() == QMessageBox::Yes) {
264 m_pDrawPadCanvas->deletePage(); 275 m_pDrawPadCanvas->deletePage();
265 m_pPageListView->updateView(); 276 m_pPageListView->updateView();
277 updateView();
266 } 278 }
267} 279}
268 280
281void ThumbnailView::movePageUp()
282{
283 m_pDrawPadCanvas->movePageUp();
284 m_pPageListView->updateView();
285 updateView();
286}
287
288void ThumbnailView::movePageDown()
289{
290 m_pDrawPadCanvas->movePageDown();
291 m_pPageListView->updateView();
292 updateView();
293}
294
269void ThumbnailView::changePage() 295void ThumbnailView::changePage()
270{ 296{
271 m_pDrawPadCanvas->selectPage(m_pPageListView->selected()); 297 m_pDrawPadCanvas->selectPage(m_pPageListView->selected());
298 updateView();
272} 299}
diff --git a/noncore/graphics/drawpad/thumbnailview.h b/noncore/graphics/drawpad/thumbnailview.h
index 1fdb168..eb748fa 100644
--- a/noncore/graphics/drawpad/thumbnailview.h
+++ b/noncore/graphics/drawpad/thumbnailview.h
@@ -1,80 +1,89 @@
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 THUMBNAILVIEW_H 14#ifndef THUMBNAILVIEW_H
15#define THUMBNAILVIEW_H 15#define THUMBNAILVIEW_H
16 16
17#include <qwidget.h> 17#include <qwidget.h>
18#include <qlistview.h> 18#include <qlistview.h>
19 19
20class DrawPad; 20class DrawPad;
21class DrawPadCanvas; 21class DrawPadCanvas;
22class Page; 22class Page;
23 23
24class QToolButton;
25
24class PageListViewItem : public QListViewItem 26class PageListViewItem : public QListViewItem
25{ 27{
26public: 28public:
27 PageListViewItem(Page* page, QListView* parent); 29 PageListViewItem(Page* page, QListView* parent);
28 ~PageListViewItem(); 30 ~PageListViewItem();
29 31
30 Page* page() const; 32 Page* page() const;
31 33
32private: 34private:
33 Page* m_pPage; 35 Page* m_pPage;
34}; 36};
35 37
36class PageListView : public QListView 38class PageListView : public QListView
37{ 39{
38public: 40public:
39 PageListView(DrawPadCanvas* drawPadCanvas, QWidget* parent = 0, const char* name = 0); 41 PageListView(DrawPadCanvas* drawPadCanvas, QWidget* parent = 0, const char* name = 0);
40 ~PageListView(); 42 ~PageListView();
41 43
42 void updateView(); 44 void updateView();
43 45
44 void select(Page* page); 46 void select(Page* page);
45 Page* selected() const; 47 Page* selected() const;
46 48
47protected: 49protected:
48 void resizeEvent(QResizeEvent* e); 50 void resizeEvent(QResizeEvent* e);
49 51
50private: 52private:
51 DrawPadCanvas* m_pDrawPadCanvas; 53 DrawPadCanvas* m_pDrawPadCanvas;
52}; 54};
53 55
54class ThumbnailView : public QWidget 56class ThumbnailView : public QWidget
55{ 57{
56 Q_OBJECT 58 Q_OBJECT
57 59
58public: 60public:
59 ThumbnailView(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas, QWidget* parent = 0, const char* name = 0); 61 ThumbnailView(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas, QWidget* parent = 0, const char* name = 0);
60 ~ThumbnailView(); 62 ~ThumbnailView();
61 63
64 void updateView();
65
62 void hide(); 66 void hide();
63 void exec(); 67 void exec();
64 68
65public slots: 69public slots:
66 void newPage(); 70 void newPage();
67 void clearPage(); 71 void clearPage();
68 void deletePage(); 72 void deletePage();
73 void movePageUp();
74 void movePageDown();
69 void changePage(); 75 void changePage();
70 76
71private: 77private:
72 bool inLoop; 78 bool inLoop;
73 79
74 DrawPad* m_pDrawPad; 80 DrawPad* m_pDrawPad;
75 DrawPadCanvas* m_pDrawPadCanvas; 81 DrawPadCanvas* m_pDrawPadCanvas;
76 82
83 QToolButton* m_pMovePageUpButton;
84 QToolButton* m_pMovePageDownButton;
85
77 PageListView* m_pPageListView; 86 PageListView* m_pPageListView;
78}; 87};
79 88
80#endif // THUMBNAILVIEW_H 89#endif // THUMBNAILVIEW_H