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