author | zecke <zecke> | 2004-04-08 00:42:01 (UTC) |
---|---|---|
committer | zecke <zecke> | 2004-04-08 00:42:01 (UTC) |
commit | 5afca2540a2d6bf733c89ea97748496a679bc576 (patch) (unidiff) | |
tree | 3e4e419ccc0e1b1cb71cc2cf7e75d36f9301de81 | |
parent | 8c54ad421c7bee65b2a1442ce85c09f2eff3efc6 (diff) | |
download | opie-5afca2540a2d6bf733c89ea97748496a679bc576.zip opie-5afca2540a2d6bf733c89ea97748496a679bc576.tar.gz opie-5afca2540a2d6bf733c89ea97748496a679bc576.tar.bz2 |
Import a QPixmap via QCOP
-rw-r--r-- | noncore/graphics/drawpad/drawpad.cpp | 19 | ||||
-rw-r--r-- | noncore/graphics/drawpad/drawpad.h | 2 | ||||
-rw-r--r-- | noncore/graphics/drawpad/drawpadcanvas.cpp | 20 | ||||
-rw-r--r-- | noncore/graphics/drawpad/drawpadcanvas.h | 5 |
4 files changed, 40 insertions, 6 deletions
diff --git a/noncore/graphics/drawpad/drawpad.cpp b/noncore/graphics/drawpad/drawpad.cpp index 3331193..d9d0ce0 100644 --- a/noncore/graphics/drawpad/drawpad.cpp +++ b/noncore/graphics/drawpad/drawpad.cpp | |||
@@ -45,24 +45,26 @@ | |||
45 | #include <qmessagebox.h> | 45 | #include <qmessagebox.h> |
46 | #include <qspinbox.h> | 46 | #include <qspinbox.h> |
47 | #include <qtoolbutton.h> | 47 | #include <qtoolbutton.h> |
48 | #include <qtooltip.h> | 48 | #include <qtooltip.h> |
49 | #include <qwhatsthis.h> | 49 | #include <qwhatsthis.h> |
50 | 50 | ||
51 | using namespace Opie::Ui; | 51 | using namespace Opie::Ui; |
52 | using namespace Opie::Ui; | 52 | using namespace Opie::Ui; |
53 | DrawPad::DrawPad(QWidget* parent, const char* name, WFlags /*fl*/ ) | 53 | DrawPad::DrawPad(QWidget* parent, const char* name, WFlags /*fl*/ ) |
54 | : QMainWindow(parent, name, WStyle_ContextHelp) | 54 | : QMainWindow(parent, name, WStyle_ContextHelp) |
55 | { | 55 | { |
56 | // init members | 56 | // init members |
57 | connect( qApp, SIGNAL(appMessage(const QCString&, const QByteArray&)), | ||
58 | this, SLOT(slotAppMessage(const QCString&, const QByteArray&)) ); | ||
57 | 59 | ||
58 | m_pDrawPadCanvas = new DrawPadCanvas(this, this); | 60 | m_pDrawPadCanvas = new DrawPadCanvas(this, this); |
59 | 61 | ||
60 | connect(m_pDrawPadCanvas, SIGNAL(pagesChanged()), this, SLOT(updateView())); | 62 | connect(m_pDrawPadCanvas, SIGNAL(pagesChanged()), this, SLOT(updateView())); |
61 | 63 | ||
62 | setCentralWidget(m_pDrawPadCanvas); | 64 | setCentralWidget(m_pDrawPadCanvas); |
63 | 65 | ||
64 | // init menu | 66 | // init menu |
65 | 67 | ||
66 | setToolBarsMovable(false); | 68 | setToolBarsMovable(false); |
67 | 69 | ||
68 | QToolBar* menuToolBar = new QToolBar(this); | 70 | QToolBar* menuToolBar = new QToolBar(this); |
@@ -654,12 +656,29 @@ void DrawPad::loadConfig() | |||
654 | 656 | ||
655 | void DrawPad::saveConfig() | 657 | void DrawPad::saveConfig() |
656 | { | 658 | { |
657 | Config config("drawpad"); | 659 | Config config("drawpad"); |
658 | config.setGroup("General"); | 660 | config.setGroup("General"); |
659 | 661 | ||
660 | config.writeEntry("PagePosition", (int)m_pDrawPadCanvas->pagePosition()); | 662 | config.writeEntry("PagePosition", (int)m_pDrawPadCanvas->pagePosition()); |
661 | config.writeEntry("AntiAliasing", antiAliasing()); | 663 | config.writeEntry("AntiAliasing", antiAliasing()); |
662 | config.writeEntry("PenWidth", (int)m_pen.width()); | 664 | config.writeEntry("PenWidth", (int)m_pen.width()); |
663 | config.writeEntry("PenColor", m_pen.color().name()); | 665 | config.writeEntry("PenColor", m_pen.color().name()); |
664 | config.writeEntry("BrushColor", m_brush.color().name()); | 666 | config.writeEntry("BrushColor", m_brush.color().name()); |
665 | } | 667 | } |
668 | |||
669 | |||
670 | /* | ||
671 | * Import a Thumbnail from SCAP or similiar | ||
672 | */ | ||
673 | void DrawPad::slotAppMessage( const QCString& str, const QByteArray& ar ) { | ||
674 | QDataStream stream(ar, IO_ReadOnly ); | ||
675 | /* | ||
676 | * import the pixmap | ||
677 | */ | ||
678 | if ( str == "importPixmap(QPixmap)" ) { | ||
679 | QPixmap pix; | ||
680 | stream >> pix;; | ||
681 | m_pDrawPadCanvas->importPixmap( pix ); | ||
682 | QPEApplication::setKeepRunning(); | ||
683 | } | ||
684 | } | ||
diff --git a/noncore/graphics/drawpad/drawpad.h b/noncore/graphics/drawpad/drawpad.h index 8ba6e58..ba9e47d 100644 --- a/noncore/graphics/drawpad/drawpad.h +++ b/noncore/graphics/drawpad/drawpad.h | |||
@@ -39,24 +39,26 @@ public: | |||
39 | Tool* tool() { return m_pTool; } | 39 | Tool* tool() { return m_pTool; } |
40 | QPen pen() { return m_pen; } | 40 | QPen pen() { return m_pen; } |
41 | QBrush brush() { return m_brush; } | 41 | QBrush brush() { return m_brush; } |
42 | 42 | ||
43 | bool antiAliasing(); | 43 | bool antiAliasing(); |
44 | void finishStartup(); | 44 | void finishStartup(); |
45 | 45 | ||
46 | private slots: | 46 | private slots: |
47 | void newPage(); | 47 | void newPage(); |
48 | void clearPage(); | 48 | void clearPage(); |
49 | void deletePage(); | 49 | void deletePage(); |
50 | 50 | ||
51 | void slotAppMessage( const QCString&, const QByteArray& ); | ||
52 | |||
51 | void setPointTool(); | 53 | void setPointTool(); |
52 | void setLineTool(); | 54 | void setLineTool(); |
53 | void setRectangleTool(); | 55 | void setRectangleTool(); |
54 | void setFilledRectangleTool(); | 56 | void setFilledRectangleTool(); |
55 | void setEllipseTool(); | 57 | void setEllipseTool(); |
56 | void setFilledEllipseTool(); | 58 | void setFilledEllipseTool(); |
57 | void setTextTool(); | 59 | void setTextTool(); |
58 | void setFillTool(); | 60 | void setFillTool(); |
59 | void setEraseTool(); | 61 | void setEraseTool(); |
60 | 62 | ||
61 | void changePenWidth(int value); | 63 | void changePenWidth(int value); |
62 | void changePenColor(const QColor& color); | 64 | void changePenColor(const QColor& color); |
diff --git a/noncore/graphics/drawpad/drawpadcanvas.cpp b/noncore/graphics/drawpad/drawpadcanvas.cpp index 446096c..423ef26 100644 --- a/noncore/graphics/drawpad/drawpadcanvas.cpp +++ b/noncore/graphics/drawpad/drawpadcanvas.cpp | |||
@@ -171,39 +171,39 @@ void DrawPadCanvas::load(QIODevice* ioDevice) | |||
171 | textStream.setCodec(QTextCodec::codecForName("UTF-8")); | 171 | textStream.setCodec(QTextCodec::codecForName("UTF-8")); |
172 | 172 | ||
173 | QXmlInputSource xmlInputSource(textStream); | 173 | QXmlInputSource xmlInputSource(textStream); |
174 | QXmlSimpleReader xmlSimpleReader; | 174 | QXmlSimpleReader xmlSimpleReader; |
175 | DrawPadCanvasXmlHandler drawPadCanvasXmlHandler; | 175 | DrawPadCanvasXmlHandler drawPadCanvasXmlHandler; |
176 | 176 | ||
177 | xmlSimpleReader.setContentHandler(&drawPadCanvasXmlHandler); | 177 | xmlSimpleReader.setContentHandler(&drawPadCanvasXmlHandler); |
178 | xmlSimpleReader.parse(xmlInputSource); | 178 | xmlSimpleReader.parse(xmlInputSource); |
179 | 179 | ||
180 | m_pages = drawPadCanvasXmlHandler.pages(); | 180 | m_pages = drawPadCanvasXmlHandler.pages(); |
181 | 181 | ||
182 | if (m_pages.isEmpty()) { | 182 | if (m_pages.isEmpty()) { |
183 | m_pages.append(new Page("", | 183 | m_pages.append(new Page("", |
184 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), | 184 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), |
185 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); | 185 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); |
186 | m_pages.current()->pixmap()->fill(Qt::white); | 186 | m_pages.current()->pixmap()->fill(Qt::white); |
187 | } | 187 | } |
188 | 188 | ||
189 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); | 189 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); |
190 | viewport()->update(); | 190 | viewport()->update(); |
191 | 191 | ||
192 | emit pagesChanged(); | 192 | emit pagesChanged(); |
193 | } | 193 | } |
194 | 194 | ||
195 | void DrawPadCanvas::initialPage() | 195 | void DrawPadCanvas::initialPage() |
196 | { | 196 | { |
197 | m_pages.append(new Page("", | 197 | m_pages.append(new Page("", |
198 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), | 198 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), |
199 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); | 199 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); |
200 | //236, 232)); no more fixed sizes | 200 | //236, 232)); no more fixed sizes |
201 | 201 | ||
202 | m_pages.current()->pixmap()->fill(Qt::white); | 202 | m_pages.current()->pixmap()->fill(Qt::white); |
203 | 203 | ||
204 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); | 204 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); |
205 | viewport()->update(); | 205 | viewport()->update(); |
206 | 206 | ||
207 | emit pagesChanged(); | 207 | emit pagesChanged(); |
208 | } | 208 | } |
209 | 209 | ||
@@ -256,24 +256,36 @@ void DrawPadCanvas::importPage(const QString& fileName) | |||
256 | { | 256 | { |
257 | Page* importedPage = new Page(); | 257 | Page* importedPage = new Page(); |
258 | 258 | ||
259 | importedPage->pixmap()->load(fileName); | 259 | importedPage->pixmap()->load(fileName); |
260 | m_pages.insert(m_pages.at() + 1, importedPage); | 260 | m_pages.insert(m_pages.at() + 1, importedPage); |
261 | 261 | ||
262 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); | 262 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); |
263 | viewport()->update(); | 263 | viewport()->update(); |
264 | 264 | ||
265 | emit pagesChanged(); | 265 | emit pagesChanged(); |
266 | } | 266 | } |
267 | 267 | ||
268 | void DrawPadCanvas::importPixmap( const QPixmap& pix ) { | ||
269 | Page* importedPage = new Page(); | ||
270 | |||
271 | (*importedPage->pixmap()) = pix; | ||
272 | m_pages.insert(m_pages.at()+1, importedPage ); | ||
273 | resizeContents(m_pages.current()->pixmap()->width(), | ||
274 | m_pages.current()->pixmap()->height() ); | ||
275 | viewport()->update(); | ||
276 | |||
277 | emit pagesChanged(); | ||
278 | } | ||
279 | |||
268 | void DrawPadCanvas::exportPage(uint fromPage, uint toPage, const QString& name,const QString& format) | 280 | void DrawPadCanvas::exportPage(uint fromPage, uint toPage, const QString& name,const QString& format) |
269 | { | 281 | { |
270 | if (fromPage == toPage) { | 282 | if (fromPage == toPage) { |
271 | DocLnk docLnk; | 283 | DocLnk docLnk; |
272 | MimeType mimeType(format); | 284 | MimeType mimeType(format); |
273 | 285 | ||
274 | docLnk.setName(name); | 286 | docLnk.setName(name); |
275 | docLnk.setType(mimeType.id()); | 287 | docLnk.setType(mimeType.id()); |
276 | 288 | ||
277 | FileManager fileManager; | 289 | FileManager fileManager; |
278 | QIODevice* ioDevice = fileManager.saveFile(docLnk); | 290 | QIODevice* ioDevice = fileManager.saveFile(docLnk); |
279 | QImageIO imageIO(ioDevice, format); | 291 | QImageIO imageIO(ioDevice, format); |
@@ -344,25 +356,25 @@ void DrawPadCanvas::selectPage(uint pagePosition) | |||
344 | m_pages.at(pagePosition - 1); | 356 | m_pages.at(pagePosition - 1); |
345 | 357 | ||
346 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); | 358 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); |
347 | viewport()->update(); | 359 | viewport()->update(); |
348 | 360 | ||
349 | emit pagesChanged(); | 361 | emit pagesChanged(); |
350 | } | 362 | } |
351 | 363 | ||
352 | void DrawPadCanvas::deleteAll() | 364 | void DrawPadCanvas::deleteAll() |
353 | { | 365 | { |
354 | m_pages.clear(); | 366 | m_pages.clear(); |
355 | 367 | ||
356 | m_pages.append(new Page("", | 368 | m_pages.append(new Page("", |
357 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), | 369 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), |
358 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); | 370 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); |
359 | 371 | ||
360 | m_pages.current()->pixmap()->fill(Qt::white); | 372 | m_pages.current()->pixmap()->fill(Qt::white); |
361 | 373 | ||
362 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); | 374 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); |
363 | viewport()->update(); | 375 | viewport()->update(); |
364 | 376 | ||
365 | emit pagesChanged(); | 377 | emit pagesChanged(); |
366 | } | 378 | } |
367 | 379 | ||
368 | void DrawPadCanvas::newPage(QString title, uint width, uint height, const QColor& color) | 380 | void DrawPadCanvas::newPage(QString title, uint width, uint height, const QColor& color) |
@@ -380,25 +392,25 @@ void DrawPadCanvas::clearPage() | |||
380 | { | 392 | { |
381 | m_pages.current()->pixmap()->fill(Qt::white); | 393 | m_pages.current()->pixmap()->fill(Qt::white); |
382 | 394 | ||
383 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); | 395 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); |
384 | viewport()->update(); | 396 | viewport()->update(); |
385 | } | 397 | } |
386 | 398 | ||
387 | void DrawPadCanvas::deletePage() | 399 | void DrawPadCanvas::deletePage() |
388 | { | 400 | { |
389 | m_pages.remove(m_pages.current()); | 401 | m_pages.remove(m_pages.current()); |
390 | 402 | ||
391 | if (m_pages.isEmpty()) { | 403 | if (m_pages.isEmpty()) { |
392 | m_pages.append(new Page("", | 404 | m_pages.append(new Page("", |
393 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), | 405 | clipper()->width()+(verticalScrollBar()->isVisible()?verticalScrollBar()->width():0), |
394 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); | 406 | clipper()->height()+(horizontalScrollBar()->isVisible()?horizontalScrollBar()->height():0))); |
395 | 407 | ||
396 | m_pages.current()->pixmap()->fill(Qt::white); | 408 | m_pages.current()->pixmap()->fill(Qt::white); |
397 | } | 409 | } |
398 | 410 | ||
399 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); | 411 | resizeContents(m_pages.current()->pixmap()->width(), m_pages.current()->pixmap()->height()); |
400 | viewport()->update(); | 412 | viewport()->update(); |
401 | 413 | ||
402 | emit pagesChanged(); | 414 | emit pagesChanged(); |
403 | } | 415 | } |
404 | 416 | ||
diff --git a/noncore/graphics/drawpad/drawpadcanvas.h b/noncore/graphics/drawpad/drawpadcanvas.h index 80a2a7e..2b3d4a5 100644 --- a/noncore/graphics/drawpad/drawpadcanvas.h +++ b/noncore/graphics/drawpad/drawpadcanvas.h | |||
@@ -14,58 +14,59 @@ | |||
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 | ||
22 | class DrawPad; | 22 | class DrawPad; |
23 | class Page; | 23 | class Page; |
24 | 24 | ||
25 | class DrawPadCanvas : public QScrollView | 25 | class DrawPadCanvas : public QScrollView |
26 | { | 26 | { |
27 | Q_OBJECT | 27 | Q_OBJECT |
28 | 28 | ||
29 | public: | 29 | public: |
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 | void importPixmap( const QPixmap& ); | ||
39 | 40 | ||
40 | bool goPreviousPageEnabled(); | 41 | bool goPreviousPageEnabled(); |
41 | bool goNextPageEnabled(); | 42 | bool goNextPageEnabled(); |
42 | 43 | ||
43 | Page* currentPage(); | 44 | Page* currentPage(); |
44 | QList<Page> pages(); | 45 | QList<Page> pages(); |
45 | uint pagePosition(); | 46 | uint pagePosition(); |
46 | uint pageCount(); | 47 | uint pageCount(); |
47 | 48 | ||
48 | void selectPage(Page* page); | 49 | void selectPage(Page* page); |
49 | void selectPage(uint pagePosition); | 50 | void selectPage(uint pagePosition); |
50 | void backupPage(); | 51 | void backupPage(); |
51 | 52 | ||
52 | public slots: | 53 | public slots: |
53 | void deleteAll(); | 54 | void deleteAll(); |
54 | void newPage(QString title, uint width, uint height, const QColor& color); | 55 | void newPage(QString title, uint width, uint height, const QColor& color); |
55 | void clearPage(); | 56 | void clearPage(); |
56 | void deletePage(); | 57 | void deletePage(); |
57 | void movePageUp(); | 58 | void movePageUp(); |
58 | void movePageDown(); | 59 | void movePageDown(); |
59 | 60 | ||
60 | void undo(); | 61 | void undo(); |
61 | void redo(); | 62 | void redo(); |
62 | 63 | ||
63 | void goFirstPage(); | 64 | void goFirstPage(); |
64 | void goPreviousPage(); | 65 | void goPreviousPage(); |
65 | void goNextPage(); | 66 | void goNextPage(); |
66 | void goLastPage(); | 67 | void goLastPage(); |
67 | 68 | ||
68 | signals: | 69 | signals: |
69 | void pagesChanged(); | 70 | void pagesChanged(); |
70 | 71 | ||
71 | protected: | 72 | protected: |