summaryrefslogtreecommitdiffstats
path: root/tests/manual/qtabletevent
diff options
context:
space:
mode:
authorShawn Rutledge <shawn.rutledge@digia.com>2014-08-15 13:09:18 +0200
committerShawn Rutledge <shawn.rutledge@digia.com>2014-08-18 16:51:42 +0200
commit2f9c00d9a0e55500d0b182e584b07b11acddc18e (patch)
treea3b18d652155527b32467af4868695062a6ae41a /tests/manual/qtabletevent
parent74805930d1d3bc249edbd3aa07ab14c9ea28f26a (diff)
Tablet manual test: show rotated ellipse if the stylus has rotation
Followup to da9e02eb83ea6eecf3cdb16b11241c91f5029380: If the stylus is a Wacom Art Pen for example, the regular_widgets test will show a rotated ellipse with size proportional to pressure for each tablet point, instead of a circle. Task-number: QTBUG-39458 Change-Id: I4bbb5f8ceabf7006928d95df3ecd62378394f085 Reviewed-by: Allan Sandfeld Jensen <allan.jensen@digia.com>
Diffstat (limited to 'tests/manual/qtabletevent')
-rw-r--r--tests/manual/qtabletevent/regular_widgets/main.cpp24
1 files changed, 18 insertions, 6 deletions
diff --git a/tests/manual/qtabletevent/regular_widgets/main.cpp b/tests/manual/qtabletevent/regular_widgets/main.cpp
index 60bedbd8f4..2186b8a518 100644
--- a/tests/manual/qtabletevent/regular_widgets/main.cpp
+++ b/tests/manual/qtabletevent/regular_widgets/main.cpp
@@ -60,14 +60,15 @@ enum TabletPointType {
struct TabletPoint
{
TabletPoint(const QPointF &p = QPointF(), TabletPointType t = TabletMove,
- Qt::MouseButton b = Qt::LeftButton, QTabletEvent::PointerType pt = QTabletEvent::UnknownPointer, qreal prs = 0) :
- pos(p), type(t), button(b), ptype(pt), pressure(prs) {}
+ Qt::MouseButton b = Qt::LeftButton, QTabletEvent::PointerType pt = QTabletEvent::UnknownPointer, qreal prs = 0, qreal rotation = 0) :
+ pos(p), type(t), button(b), ptype(pt), pressure(prs), angle(rotation) {}
QPointF pos;
TabletPointType type;
Qt::MouseButton button;
QTabletEvent::PointerType ptype;
qreal pressure;
+ qreal angle;
};
class EventReportWidget : public QWidget
@@ -111,6 +112,8 @@ void EventReportWidget::paintEvent(QPaintEvent *)
p.fillRect(geom, Qt::white);
p.drawRect(QRectF(geom.topLeft(), geom.bottomRight() - QPointF(1,1)));
p.setPen(Qt::white);
+ QPainterPath ellipse;
+ ellipse.addEllipse(0, 0, 50, 10);
foreach (const TabletPoint &t, m_points) {
if (geom.contains(t.pos)) {
QPainterPath pp;
@@ -130,7 +133,16 @@ void EventReportWidget::paintEvent(QPaintEvent *)
case TabletMove:
if (t.pressure > 0.0) {
p.setPen(t.ptype == QTabletEvent::Eraser ? Qt::red : Qt::black);
- p.drawEllipse(t.pos, t.pressure * 10.0, t.pressure * 10.0);
+ if (t.angle != 0.0) {
+ p.save();
+ p.translate(t.pos);
+ p.scale(t.pressure, t.pressure);
+ p.rotate(t.angle);
+ p.drawPath(ellipse);
+ p.restore();
+ } else {
+ p.drawEllipse(t.pos, t.pressure * 10.0, t.pressure * 10.0);
+ }
p.setPen(Qt::white);
} else {
p.fillRect(t.pos.x() - 2, t.pos.y() - 2, 4, 4, Qt::black);
@@ -155,18 +167,18 @@ void EventReportWidget::tabletEvent(QTabletEvent *event)
break;
case QEvent::TabletMove:
type = QString::fromLatin1("TabletMove");
- m_points.push_back(TabletPoint(event->pos(), TabletMove, m_lastButton, event->pointerType(), event->pressure()));
+ m_points.push_back(TabletPoint(event->pos(), TabletMove, m_lastButton, event->pointerType(), event->pressure(), event->rotation()));
update();
break;
case QEvent::TabletPress:
type = QString::fromLatin1("TabletPress");
- m_points.push_back(TabletPoint(event->pos(), TabletButtonPress, event->button(), event->pointerType()));
+ m_points.push_back(TabletPoint(event->pos(), TabletButtonPress, event->button(), event->pointerType(), event->rotation()));
m_lastButton = event->button();
update();
break;
case QEvent::TabletRelease:
type = QString::fromLatin1("TabletRelease");
- m_points.push_back(TabletPoint(event->pos(), TabletButtonRelease, event->button(), event->pointerType()));
+ m_points.push_back(TabletPoint(event->pos(), TabletButtonRelease, event->button(), event->pointerType(), event->rotation()));
update();
break;
default: