Improved code for keyboard and mouse grabbing and releasing to avoid

unnecessary actions. This relates loosely to bug 2955.

Signed-off-by: Michele Calgaro <michele.calgaro@yahoo.it>
master
Michele Calgaro 4 years ago committed by Slávek Banko
parent 1c53644408
commit bc1b1fed7d
No known key found for this signature in database
GPG Key ID: 608F5293A04BE668

@ -1487,28 +1487,31 @@ void QWidget::grabMouse()
void QWidget::grabMouse( const QCursor &cursor ) void QWidget::grabMouse( const QCursor &cursor )
{ {
if ( !qt_nograb() ) { if ( !qt_nograb() ) {
if ( mouseGrb ) if ( mouseGrb != this ) {
mouseGrb->releaseMouse(); if ( mouseGrb ) {
mouseGrb->releaseMouse();
}
#if defined(QT_CHECK_STATE) #if defined(QT_CHECK_STATE)
int status = int status =
#endif #endif
XGrabPointer( x11Display(), winId(), False, XGrabPointer( x11Display(), winId(), False,
(uint)(ButtonPressMask | ButtonReleaseMask | (uint)(ButtonPressMask | ButtonReleaseMask |
PointerMotionMask | EnterWindowMask | LeaveWindowMask), PointerMotionMask | EnterWindowMask | LeaveWindowMask),
GrabModeAsync, GrabModeAsync, GrabModeAsync, GrabModeAsync,
None, cursor.handle(), qt_x_time ); None, cursor.handle(), qt_x_time );
#if defined(QT_CHECK_STATE) #if defined(QT_CHECK_STATE)
if ( status ) { if ( status ) {
const char *s = const char *s =
status == GrabNotViewable ? "\"GrabNotViewable\"" : status == GrabNotViewable ? "\"GrabNotViewable\"" :
status == AlreadyGrabbed ? "\"AlreadyGrabbed\"" : status == AlreadyGrabbed ? "\"AlreadyGrabbed\"" :
status == GrabFrozen ? "\"GrabFrozen\"" : status == GrabFrozen ? "\"GrabFrozen\"" :
status == GrabInvalidTime ? "\"GrabInvalidTime\"" : status == GrabInvalidTime ? "\"GrabInvalidTime\"" :
"<?>"; "<?>";
qWarning( "Grabbing the mouse failed with %s", s ); qWarning( "Grabbing the mouse failed with %s", s );
} }
#endif #endif
mouseGrb = this; mouseGrb = this;
}
} }
} }
@ -1548,11 +1551,13 @@ void QWidget::releaseMouse()
void QWidget::grabKeyboard() void QWidget::grabKeyboard()
{ {
if ( !qt_nograb() ) { if ( !qt_nograb() ) {
if ( keyboardGrb ) if ( keyboardGrb != this ) {
keyboardGrb->releaseKeyboard(); if ( keyboardGrb ) {
XGrabKeyboard( x11Display(), winid, False, GrabModeAsync, GrabModeAsync, keyboardGrb->releaseKeyboard();
qt_x_time ); }
keyboardGrb = this; XGrabKeyboard( x11Display(), winid, False, GrabModeAsync, GrabModeAsync, qt_x_time );
keyboardGrb = this;
}
} }
} }

Loading…
Cancel
Save