Details
-
Bug
-
Resolution: Unresolved
-
P2: Important
-
None
-
5.11.0
-
None
Description
After a37785ec7638e7485112b87dd7e767881fecc114 it become apparent that we don't get mouse release event from X server when system move/resize ends (because WM is grabbing the pointer). The old code (before a37785ec) would wrongly deduce mouse move as mouse release, which is why the issue was not seen before. Even with the old code it had user experience issues. It can be tested by running qtbase/examples/widgets/mainwindows/mainwindow with QT_QPA_DISABLE_ENHANCED_MOUSE=1. Try shrinking the window until the cursor moves out of QSizeGrip widget's area, release the mouse. Cursor will not be restored until mouse gets moved (which gets deduced into release event as described above).
The other platform that uses system move/resize feature via QSizeGrip is Windows. There the window system also does not send mouse events in this case. It has been worked around by https://codereview.qt-project.org/#/c/230827/ Any solution that requires making fake mouse events is sub-optimal and usually is a source of other bugs down the road.
This should really be fixed at widget-level. Probably inside QWidgetWindow::handleEnterLeaveEvent(), where it should detect that if qt_last_mouse_receiver == QSizeGrip (where d->m_platformSizeGrip==true) and then properly dispatch enter/leave, which should take care of restoring the cursor.
Note: When somebody will try to fix this at widget layer, set QT_XCB_NO_XI2=1 on X11 for testing. There seem to be some other unrelated enter/leave handling issues with XI2 code path. Those will be fixed in a separate patch once this issue has been resolved.
Attachments
Issue Links
- relates to
-
QTBUG-91077 startSystemMove/startSystemResize causing mouse events to be lost on X11(MATE)
- Closed