author | leseb <leseb> | 2002-06-19 07:02:19 (UTC) |
---|---|---|
committer | leseb <leseb> | 2002-06-19 07:02:19 (UTC) |
commit | b1fd4450c70522551361c6138688777cb29e1e2f (patch) (unidiff) | |
tree | 6f7e09297fd103d4f7544f386083e90133bcfbdf | |
parent | 46e3484b8909ae6ab8ad1e72cfd91453c931fc8c (diff) | |
download | opie-b1fd4450c70522551361c6138688777cb29e1e2f.zip opie-b1fd4450c70522551361c6138688777cb29e1e2f.tar.gz opie-b1fd4450c70522551361c6138688777cb29e1e2f.tar.bz2 |
Cleaner drawing method
-rw-r--r-- | noncore/graphics/drawpad/linetool.cpp | 12 |
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 | ||
22 | LineTool::LineTool(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas) | 22 | LineTool::LineTool(DrawPad* drawPad, DrawPadCanvas* drawPadCanvas) |
23 | : ShapeTool(drawPad, drawPadCanvas) | 23 | : ShapeTool(drawPad, drawPadCanvas) |
24 | { | 24 | { |
25 | } | 25 | } |
26 | 26 | ||
27 | LineTool::~LineTool() | 27 | LineTool::~LineTool() |
28 | { | 28 | { |
29 | } | 29 | } |
30 | 30 | ||
31 | void LineTool::drawFinalShape(QPainter& p) | 31 | void 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 | ||
80 | void LineTool::drawTemporaryShape(QPainter& p) | 72 | void 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 | } |