-rw-r--r-- | noncore/graphics/drawpad/drawpad.cpp | 11 | ||||
-rw-r--r-- | noncore/graphics/drawpad/drawpad.h | 4 | ||||
-rw-r--r-- | noncore/graphics/drawpad/ellipsetool.cpp | 7 | ||||
-rw-r--r-- | noncore/graphics/drawpad/filledellipsetool.cpp | 8 | ||||
-rw-r--r-- | noncore/graphics/drawpad/linetool.cpp | 7 | ||||
-rw-r--r-- | noncore/graphics/drawpad/pointtool.cpp | 12 |
6 files changed, 43 insertions, 6 deletions
diff --git a/noncore/graphics/drawpad/drawpad.cpp b/noncore/graphics/drawpad/drawpad.cpp index 45fb886..b29f5ba 100644 --- a/noncore/graphics/drawpad/drawpad.cpp +++ b/noncore/graphics/drawpad/drawpad.cpp @@ -94,4 +94,10 @@ DrawPad::DrawPad(QWidget* parent, const char* name) pageInformationAction->addTo(toolsPopupMenu); + toolsPopupMenu->insertSeparator(); + + m_pAntiAliasingAction = new QAction(tr("Anti-Aliasing"), QString::null, 0, this); + m_pAntiAliasingAction->setToggleAction(true); + m_pAntiAliasingAction->addTo(toolsPopupMenu); + menuBar->insertItem(tr("Tools"), toolsPopupMenu); @@ -276,4 +282,9 @@ DrawPad::~DrawPad() } +bool DrawPad::antiAliasing() +{ + return (m_pAntiAliasingAction->isOn()); +} + void DrawPad::newPage() { diff --git a/noncore/graphics/drawpad/drawpad.h b/noncore/graphics/drawpad/drawpad.h index ce62802..8e29c61 100644 --- a/noncore/graphics/drawpad/drawpad.h +++ b/noncore/graphics/drawpad/drawpad.h @@ -39,4 +39,6 @@ public: QBrush brush() { return m_brush; } + bool antiAliasing(); + private slots: void newPage(); @@ -75,4 +77,6 @@ private: QBrush m_brush; + QAction* m_pAntiAliasingAction; + QAction* m_pUndoAction; QAction* m_pRedoAction; diff --git a/noncore/graphics/drawpad/ellipsetool.cpp b/noncore/graphics/drawpad/ellipsetool.cpp index 733bade..0cdb731 100644 --- a/noncore/graphics/drawpad/ellipsetool.cpp +++ b/noncore/graphics/drawpad/ellipsetool.cpp @@ -33,5 +33,7 @@ void EllipseTool::drawFinalShape(QPainter& p) p.setRasterOp(Qt::NotROP); p.drawRect(QRect(m_polyline[2], m_polyline[0])); + p.setRasterOp(Qt::CopyROP); + if (m_pDrawPad->antiAliasing()) { QRect r = m_polyline.boundingRect(); r = r.normalize(); @@ -65,6 +67,9 @@ void EllipseTool::drawFinalShape(QPainter& p) areaPixmap.convertFromImage(areaImage); - p.setRasterOp(Qt::CopyROP); p.drawPixmap(r.x(), r.y(), areaPixmap); + } else { + p.setPen(m_pDrawPad->pen()); + p.drawEllipse(QRect(m_polyline[2], m_polyline[0])); + } } diff --git a/noncore/graphics/drawpad/filledellipsetool.cpp b/noncore/graphics/drawpad/filledellipsetool.cpp index 2f7ec8f..6b5bbc6 100644 --- a/noncore/graphics/drawpad/filledellipsetool.cpp +++ b/noncore/graphics/drawpad/filledellipsetool.cpp @@ -33,5 +33,7 @@ void FilledEllipseTool::drawFinalShape(QPainter& p) p.setRasterOp(Qt::NotROP); p.drawRect(QRect(m_polyline[2], m_polyline[0])); + p.setRasterOp(Qt::CopyROP); + if (m_pDrawPad->antiAliasing()) { QRect r = m_polyline.boundingRect(); r = r.normalize(); @@ -66,6 +68,10 @@ void FilledEllipseTool::drawFinalShape(QPainter& p) areaPixmap.convertFromImage(areaImage); - p.setRasterOp(Qt::CopyROP); p.drawPixmap(r.x(), r.y(), areaPixmap); + } else { + p.setPen(m_pDrawPad->pen()); + p.setBrush(m_pDrawPad->brush()); + p.drawEllipse(QRect(m_polyline[2], m_polyline[0])); + } } diff --git a/noncore/graphics/drawpad/linetool.cpp b/noncore/graphics/drawpad/linetool.cpp index 99cd6de..b6baa2a 100644 --- a/noncore/graphics/drawpad/linetool.cpp +++ b/noncore/graphics/drawpad/linetool.cpp @@ -33,5 +33,7 @@ void LineTool::drawFinalShape(QPainter& p) p.setRasterOp(Qt::NotROP); p.drawLine(m_polyline[2], m_polyline[0]); + p.setRasterOp(Qt::CopyROP); + if (m_pDrawPad->antiAliasing()) { QRect r = m_polyline.boundingRect(); r = r.normalize(); @@ -66,6 +68,9 @@ void LineTool::drawFinalShape(QPainter& p) areaPixmap.convertFromImage(areaImage); - p.setRasterOp(Qt::CopyROP); p.drawPixmap(r.x(), r.y(), areaPixmap); + } else { + p.setPen(m_pDrawPad->pen()); + p.drawLine(m_polyline[2], m_polyline[0]); + } } diff --git a/noncore/graphics/drawpad/pointtool.cpp b/noncore/graphics/drawpad/pointtool.cpp index 22bb089..a4f846e 100644 --- a/noncore/graphics/drawpad/pointtool.cpp +++ b/noncore/graphics/drawpad/pointtool.cpp @@ -54,7 +54,4 @@ void PointTool::mouseMoveEvent(QMouseEvent* e) m_polyline[0] = e->pos(); - QPainter painter; - painter.begin(m_pDrawPadCanvas->currentPage()); - QRect r = m_polyline.boundingRect(); r = r.normalize(); @@ -64,4 +61,8 @@ void PointTool::mouseMoveEvent(QMouseEvent* e) r.setBottom(r.bottom() + m_pDrawPad->pen().width()); + QPainter painter; + painter.begin(m_pDrawPadCanvas->currentPage()); + + if (m_pDrawPad->antiAliasing()) { QPixmap areaPixmap(r.width(), r.height()); bitBlt(&areaPixmap, QPoint(0, 0), painter.device(), r); @@ -93,4 +94,9 @@ void PointTool::mouseMoveEvent(QMouseEvent* e) painter.drawPixmap(r.x(), r.y(), areaPixmap); + } else { + painter.setPen(m_pDrawPad->pen()); + painter.drawPolyline(m_polyline); + } + painter.end(); |