summaryrefslogtreecommitdiff
authorleseb <leseb>2002-06-19 07:02:19 (UTC)
committer leseb <leseb>2002-06-19 07:02:19 (UTC)
commitb1fd4450c70522551361c6138688777cb29e1e2f (patch) (unidiff)
tree6f7e09297fd103d4f7544f386083e90133bcfbdf
parent46e3484b8909ae6ab8ad1e72cfd91453c931fc8c (diff)
downloadopie-b1fd4450c70522551361c6138688777cb29e1e2f.zip
opie-b1fd4450c70522551361c6138688777cb29e1e2f.tar.gz
opie-b1fd4450c70522551361c6138688777cb29e1e2f.tar.bz2
Cleaner drawing method
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--noncore/graphics/drawpad/linetool.cpp12
1 files changed, 2 insertions, 10 deletions
diff --git a/noncore/graphics/drawpad/linetool.cpp b/noncore/graphics/drawpad/linetool.cpp
index 1480df2..99cd6de 100644
--- a/noncore/graphics/drawpad/linetool.cpp
+++ b/noncore/graphics/drawpad/linetool.cpp
@@ -11,75 +11,67 @@
11 * * 11 * *
12 ***************************************************************************/ 12 ***************************************************************************/
13 13
14#include "linetool.h" 14#include "linetool.h"
15 15
16#include "drawpad.h" 16#include "drawpad.h"
17#include "drawpadcanvas.h" 17#include "drawpadcanvas.h"
18 18
19#include <qimage.h> 19#include <qimage.h>
20#include <qpixmap.h> 20#include <qpixmap.h>
21 21
22LineTool::LineTool(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas) 22LineTool::LineTool(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas)
23 : ShapeTool(drawPad, drawPadCanvas) 23 : ShapeTool(drawPad, drawPadCanvas)
24{ 24{
25} 25}
26 26
27LineTool::~LineTool() 27LineTool::~LineTool()
28{ 28{
29} 29}
30 30
31void LineTool::drawFinalShape(QPainter& p) 31void LineTool::drawFinalShape(QPainter& p)
32{ 32{
33 p.setRasterOp(Qt::NotROP); 33 p.setRasterOp(Qt::NotROP);
34 p.drawLine(m_polyline[2], m_polyline[0]); 34 p.drawLine(m_polyline[2], m_polyline[0]);
35 35
36 QRect r = m_polyline.boundingRect(); 36 QRect r = m_polyline.boundingRect();
37 r = r.normalize(); 37 r = r.normalize();
38 r.setLeft(r.left() - m_pDrawPad->pen().width()); 38 r.setLeft(r.left() - m_pDrawPad->pen().width());
39 r.setTop(r.top() - m_pDrawPad->pen().width()); 39 r.setTop(r.top() - m_pDrawPad->pen().width());
40 r.setRight(r.right() + m_pDrawPad->pen().width()); 40 r.setRight(r.right() + m_pDrawPad->pen().width());
41 r.setBottom(r.bottom() + m_pDrawPad->pen().width()); 41 r.setBottom(r.bottom() + m_pDrawPad->pen().width());
42 42
43 QPixmap areaPixmap(r.width(), r.height()); 43 QPixmap areaPixmap(r.width(), r.height());
44 bitBlt(&areaPixmap, QPoint(0, 0), p.device(), r); 44 bitBlt(&areaPixmap, QPoint(0, 0), p.device(), r);
45 45
46 QImage areaImage = areaPixmap.convertToImage(); 46 QImage areaImage = areaPixmap.convertToImage();
47 QImage bigAreaImage = areaImage.smoothScale(areaImage.width() * 3, areaImage.height() * 3); 47 QImage bigAreaImage = areaImage.smoothScale(areaImage.width() * 3, areaImage.height() * 3);
48 48
49 QPixmap bigAreaPixmap; 49 QPixmap bigAreaPixmap;
50 bigAreaPixmap.convertFromImage(bigAreaImage); 50 bigAreaPixmap.convertFromImage(bigAreaImage);
51 51
52 QPen bigAreaPen = m_pDrawPad->pen(); 52 QPen bigAreaPen = m_pDrawPad->pen();
53 bigAreaPen.setWidth(bigAreaPen.width() * 3); 53 bigAreaPen.setWidth(bigAreaPen.width() * 3);
54 54
55 QPainter bigAreaPainter; 55 QPainter bigAreaPainter;
56 bigAreaPainter.begin(&bigAreaPixmap); 56 bigAreaPainter.begin(&bigAreaPixmap);
57 bigAreaPainter.setPen(bigAreaPen); 57 bigAreaPainter.setPen(bigAreaPen);
58 58
59 if (((m_polyline[2].x() < m_polyline[0].x()) && (m_polyline[2].y() < m_polyline[0].y())) 59 bigAreaPainter.drawLine((m_polyline[2].x() - r.x()) * 3 + 1, (m_polyline[2].y() - r.y()) * 3 + 1,
60 || ((m_polyline[2].x() > m_polyline[0].x()) && (m_polyline[2].y() > m_polyline[0].y()))) { 60 (m_polyline[0].x() - r.x()) * 3 + 1, (m_polyline[0].y() - r.y()) * 3 + 1);
61
62 bigAreaPainter.drawLine(bigAreaPen.width() + 1, bigAreaPen.width() + 1,
63 bigAreaPixmap.width() - bigAreaPen.width() - 2,
64 bigAreaPixmap.height() - bigAreaPen.width() - 2);
65 } else {
66 bigAreaPainter.drawLine(bigAreaPen.width() + 1, bigAreaPixmap.height() - bigAreaPen.width() - 2,
67 bigAreaPixmap.width() - bigAreaPen.width() - 2, bigAreaPen.width() + 1);
68 }
69 61
70 bigAreaPainter.end(); 62 bigAreaPainter.end();
71 63
72 bigAreaImage = bigAreaPixmap.convertToImage(); 64 bigAreaImage = bigAreaPixmap.convertToImage();
73 areaImage = bigAreaImage.smoothScale(bigAreaImage.width() / 3, bigAreaImage.height() / 3); 65 areaImage = bigAreaImage.smoothScale(bigAreaImage.width() / 3, bigAreaImage.height() / 3);
74 areaPixmap.convertFromImage(areaImage); 66 areaPixmap.convertFromImage(areaImage);
75 67
76 p.setRasterOp(Qt::CopyROP); 68 p.setRasterOp(Qt::CopyROP);
77 p.drawPixmap(r.x(), r.y(), areaPixmap); 69 p.drawPixmap(r.x(), r.y(), areaPixmap);
78} 70}
79 71
80void LineTool::drawTemporaryShape(QPainter& p) 72void LineTool::drawTemporaryShape(QPainter& p)
81{ 73{
82 p.setRasterOp(Qt::NotROP); 74 p.setRasterOp(Qt::NotROP);
83 p.drawLine(m_polyline[2], m_polyline[1]); 75 p.drawLine(m_polyline[2], m_polyline[1]);
84 p.drawLine(m_polyline[2], m_polyline[0]); 76 p.drawLine(m_polyline[2], m_polyline[0]);
85} 77}