summaryrefslogtreecommitdiff
path: root/noncore/graphics/drawpad/drawpad.cpp
Unidiff
Diffstat (limited to 'noncore/graphics/drawpad/drawpad.cpp') (more/less context) (show whitespace changes)
-rw-r--r--noncore/graphics/drawpad/drawpad.cpp64
1 files changed, 38 insertions, 26 deletions
diff --git a/noncore/graphics/drawpad/drawpad.cpp b/noncore/graphics/drawpad/drawpad.cpp
index 5cc2197..f67bef8 100644
--- a/noncore/graphics/drawpad/drawpad.cpp
+++ b/noncore/graphics/drawpad/drawpad.cpp
@@ -15,2 +15,4 @@
15 15
16#include "colordialog.h"
17#include "colorpanel.h"
16#include "drawpadcanvas.h" 18#include "drawpadcanvas.h"
@@ -55,12 +57,2 @@ DrawPad::DrawPad(QWidget* parent, const char* name, WFlags f)
55 57
56 m_colors.resize(8);
57 m_colors.at(0) = Qt::black;
58 m_colors.at(1) = Qt::white;
59 m_colors.at(2) = Qt::red;
60 m_colors.at(3) = Qt::green;
61 m_colors.at(4) = Qt::blue;
62 m_colors.at(5) = Qt::cyan;
63 m_colors.at(6) = Qt::magenta;
64 m_colors.at(7) = Qt::yellow;
65
66 // init menu 58 // init menu
@@ -190,10 +182,12 @@ DrawPad::DrawPad(QWidget* parent, const char* name, WFlags f)
190 QPopupMenu* penColorPopupMenu = new QPopupMenu(m_pPenColorToolButton); 182 QPopupMenu* penColorPopupMenu = new QPopupMenu(m_pPenColorToolButton);
191 connect(penColorPopupMenu, SIGNAL(activated(int)), this, SLOT(changePenColor(int)));
192 183
193 QPixmap penColorPixmap(14, 14); 184 ColorPanel* penColorPanel = new ColorPanel(penColorPopupMenu);
185 connect(penColorPanel, SIGNAL(colorSelected(const QColor&)), this, SLOT(changePenColor(const QColor&)));
186 penColorPopupMenu->insertItem(penColorPanel);
194 187
195 for (uint i = 0; i < m_colors.size(); i++) { 188 penColorPopupMenu->insertSeparator();
196 penColorPixmap.fill(m_colors.at(i)); 189
197 penColorPopupMenu->insertItem(penColorPixmap, i); 190 QAction* choosePenColorAction = new QAction(tr("More"), tr("More..."), 0, this);
198 } 191 connect(choosePenColorAction, SIGNAL(activated()), this, SLOT(choosePenColor()));
192 choosePenColorAction->addTo(penColorPopupMenu);
199 193
@@ -209,10 +203,12 @@ DrawPad::DrawPad(QWidget* parent, const char* name, WFlags f)
209 QPopupMenu* brushColorPopupMenu = new QPopupMenu(m_pBrushColorToolButton); 203 QPopupMenu* brushColorPopupMenu = new QPopupMenu(m_pBrushColorToolButton);
210 connect(brushColorPopupMenu, SIGNAL(activated(int)), this, SLOT(changeBrushColor(int)));
211 204
212 QPixmap brushColorPixmap(14, 14); 205 ColorPanel* brushColorPanel = new ColorPanel(brushColorPopupMenu);
206 connect(brushColorPanel, SIGNAL(colorSelected(const QColor&)), this, SLOT(changeBrushColor(const QColor&)));
207 brushColorPopupMenu->insertItem(brushColorPanel);
213 208
214 for (uint i = 0; i < m_colors.size(); i++) { 209 brushColorPopupMenu->insertSeparator();
215 brushColorPixmap.fill(m_colors.at(i)); 210
216 brushColorPopupMenu->insertItem(brushColorPixmap, i); 211 QAction* chooseBrushColorAction = new QAction(tr("More"), tr("More..."), 0, this);
217 } 212 connect(chooseBrushColorAction, SIGNAL(activated()), this, SLOT(chooseBrushColor()));
213 chooseBrushColorAction->addTo(brushColorPopupMenu);
218 214
@@ -336,5 +332,5 @@ void DrawPad::changePenWidth(int value)
336 332
337void DrawPad::changePenColor(int index) 333void DrawPad::changePenColor(const QColor& color)
338{ 334{
339 m_pen.setColor(m_colors.at(index)); 335 m_pen.setColor(color);
340 336
@@ -344,7 +340,9 @@ void DrawPad::changePenColor(int index)
344 painter.end(); 340 painter.end();
341
342 m_pPenColorToolButton->popup()->hide();
345} 343}
346 344
347void DrawPad::changeBrushColor(int index) 345void DrawPad::changeBrushColor(const QColor& color)
348{ 346{
349 m_brush = QBrush(m_colors.at(index)); 347 m_brush = QBrush(color);
350 348
@@ -354,2 +352,16 @@ void DrawPad::changeBrushColor(int index)
354 painter.end(); 352 painter.end();
353
354 m_pBrushColorToolButton->popup()->hide();
355}
356
357void DrawPad::choosePenColor()
358{
359 QColor newPenColor = QColorDialog::getColor(m_pen.color());
360 changePenColor(newPenColor);
361}
362
363void DrawPad::chooseBrushColor()
364{
365 QColor newBrushColor = QColorDialog::getColor(m_brush.color());
366 changeBrushColor(newBrushColor);
355} 367}