effects: Set timestamp for input events
Set the time for mouse and touch events. This is especially important for the mouse is as the timestamp will be used to discriminate between single and double click. Previously this was always sending the double click event, making buttons work only every other click. BUG: 454275 BUG: 449907
This commit is contained in:
parent
66d1278794
commit
66a54d38d4
2 changed files with 4 additions and 2 deletions
|
@ -63,6 +63,7 @@ bool EffectsMouseInterceptionX11Filter::event(xcb_generic_event_t *event)
|
||||||
}
|
}
|
||||||
|
|
||||||
QWheelEvent ev(QPoint(me->event_x, me->event_y), QCursor::pos(), QPoint(), angleDelta, buttons, modifiers, Qt::NoScrollPhase, false);
|
QWheelEvent ev(QPoint(me->event_x, me->event_y), QCursor::pos(), QPoint(), angleDelta, buttons, modifiers, Qt::NoScrollPhase, false);
|
||||||
|
ev.setTimestamp(me->time);
|
||||||
return m_effects->checkInputWindowEvent(&ev);
|
return m_effects->checkInputWindowEvent(&ev);
|
||||||
}
|
}
|
||||||
const Qt::MouseButton button = x11ToQtMouseButton(me->detail);
|
const Qt::MouseButton button = x11ToQtMouseButton(me->detail);
|
||||||
|
@ -75,6 +76,7 @@ bool EffectsMouseInterceptionX11Filter::event(xcb_generic_event_t *event)
|
||||||
}
|
}
|
||||||
QMouseEvent ev(type, QPoint(me->event_x, me->event_y), QPoint(me->root_x, me->root_y),
|
QMouseEvent ev(type, QPoint(me->event_x, me->event_y), QPoint(me->root_x, me->root_y),
|
||||||
button, buttons, x11ToQtKeyboardModifiers(me->state));
|
button, buttons, x11ToQtKeyboardModifiers(me->state));
|
||||||
|
ev.setTimestamp(me->time);
|
||||||
return m_effects->checkInputWindowEvent(&ev);
|
return m_effects->checkInputWindowEvent(&ev);
|
||||||
}
|
}
|
||||||
} else if (eventType == XCB_MOTION_NOTIFY) {
|
} else if (eventType == XCB_MOTION_NOTIFY) {
|
||||||
|
@ -82,6 +84,7 @@ bool EffectsMouseInterceptionX11Filter::event(xcb_generic_event_t *event)
|
||||||
if (m_window == me->event) {
|
if (m_window == me->event) {
|
||||||
QMouseEvent ev(QEvent::MouseMove, QPoint(me->event_x, me->event_y), QPoint(me->root_x, me->root_y),
|
QMouseEvent ev(QEvent::MouseMove, QPoint(me->event_x, me->event_y), QPoint(me->root_x, me->root_y),
|
||||||
Qt::NoButton, x11ToQtMouseButtons(me->state), x11ToQtKeyboardModifiers(me->state));
|
Qt::NoButton, x11ToQtMouseButtons(me->state), x11ToQtKeyboardModifiers(me->state));
|
||||||
|
ev.setTimestamp(me->time);
|
||||||
return m_effects->checkInputWindowEvent(&ev);
|
return m_effects->checkInputWindowEvent(&ev);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -369,8 +369,6 @@ void OffscreenQuickView::forwardKeyEvent(QKeyEvent *keyEvent)
|
||||||
|
|
||||||
bool OffscreenQuickView::forwardTouchDown(qint32 id, const QPointF &pos, quint32 time)
|
bool OffscreenQuickView::forwardTouchDown(qint32 id, const QPointF &pos, quint32 time)
|
||||||
{
|
{
|
||||||
Q_UNUSED(time)
|
|
||||||
|
|
||||||
d->updateTouchState(Qt::TouchPointPressed, id, pos);
|
d->updateTouchState(Qt::TouchPointPressed, id, pos);
|
||||||
|
|
||||||
#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
|
#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
|
||||||
|
@ -378,6 +376,7 @@ bool OffscreenQuickView::forwardTouchDown(qint32 id, const QPointF &pos, quint32
|
||||||
#else
|
#else
|
||||||
QTouchEvent event(QEvent::TouchBegin, d->touchDevice, Qt::NoModifier, d->touchPoints);
|
QTouchEvent event(QEvent::TouchBegin, d->touchDevice, Qt::NoModifier, d->touchPoints);
|
||||||
#endif
|
#endif
|
||||||
|
event.setTimestamp(time);
|
||||||
QCoreApplication::sendEvent(d->m_view, &event);
|
QCoreApplication::sendEvent(d->m_view, &event);
|
||||||
|
|
||||||
return event.isAccepted();
|
return event.isAccepted();
|
||||||
|
|
Loading…
Reference in a new issue