Send out an additional TabletMove event before TabletPress.
Sometimes when a user puts the pen down too fast a TabletPress event will get triggered before a TabletMove event can occur. The app then assumes the user moved the pen very fast to the new position. The old position is there either (0,0), which often triggers the menu, or the last position the app received, which triggers apps like Xournal++ and Krita to paint a line from the old to the new position.
This commit is contained in:
parent
147ee7726e
commit
3a85b57ec2
1 changed files with 5 additions and 1 deletions
|
@ -1714,9 +1714,13 @@ public:
|
||||||
} case QEvent::TabletLeaveProximity:
|
} case QEvent::TabletLeaveProximity:
|
||||||
tool->sendProximityOut();
|
tool->sendProximityOut();
|
||||||
break;
|
break;
|
||||||
case QEvent::TabletPress:
|
case QEvent::TabletPress: {
|
||||||
|
const auto pos = event->globalPosF() - toplevel->bufferGeometry().topLeft();
|
||||||
|
tool->sendMotion(pos);
|
||||||
|
m_cursorByTool[tool]->setPos(event->globalPos());
|
||||||
tool->sendDown();
|
tool->sendDown();
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case QEvent::TabletRelease:
|
case QEvent::TabletRelease:
|
||||||
tool->sendUp();
|
tool->sendUp();
|
||||||
break;
|
break;
|
||||||
|
|
Loading…
Reference in a new issue