forked from pool/breeze
164 lines
5.7 KiB
Diff
164 lines
5.7 KiB
Diff
From: David Rosca <nowrep@gmail.com>
|
|
Date: Thu, 08 Oct 2015 18:46:45 +0000
|
|
Subject: Use NETRootInfo to initiate wm move operation
|
|
X-Git-Url: http://quickgit.kde.org/?p=breeze.git&a=commitdiff&h=ca72ca904f7fb8872667322bf5143e2b81eaf2f3
|
|
---
|
|
Use NETRootInfo to initiate wm move operation
|
|
|
|
Also remove hack that messes with cursor position, which results in
|
|
window sometimes rendered in wrong position for a moment after starting
|
|
window move.
|
|
|
|
REVIEW: 125522
|
|
BUG: 353749
|
|
---
|
|
|
|
|
|
--- a/kstyle/breezewindowmanager.cpp
|
|
+++ b/kstyle/breezewindowmanager.cpp
|
|
@@ -83,6 +83,14 @@
|
|
|
|
#if BREEZE_HAVE_X11
|
|
#include <QX11Info>
|
|
+#include <xcb/xcb.h>
|
|
+
|
|
+#if BREEZE_USE_KDE4
|
|
+#include <NETRootInfo>
|
|
+#else
|
|
+#include <NETWM>
|
|
+#endif
|
|
+
|
|
#endif
|
|
|
|
namespace Breeze
|
|
@@ -139,11 +147,8 @@
|
|
|
|
//* application-wise event.
|
|
/** needed to catch end of XMoveResize events */
|
|
- bool appMouseEvent( QObject*, QEvent* event )
|
|
- {
|
|
-
|
|
- // store target window (see later)
|
|
- QWidget* window( _parent->_target.data()->window() );
|
|
+ bool appMouseEvent( QObject*, QEvent* )
|
|
+ {
|
|
|
|
/*
|
|
post some mouseRelease event to the target, in order to counter balance
|
|
@@ -151,19 +156,6 @@
|
|
*/
|
|
QMouseEvent mouseEvent( QEvent::MouseButtonRelease, _parent->_dragPoint, Qt::LeftButton, Qt::LeftButton, Qt::NoModifier );
|
|
qApp->sendEvent( _parent->_target.data(), &mouseEvent );
|
|
-
|
|
- if( event->type() == QEvent::MouseMove )
|
|
- {
|
|
- /*
|
|
- HACK: quickly move the main cursor out of the window and back
|
|
- this is needed to get the focus right for the window children
|
|
- the origin of this issue is unknown at the moment
|
|
- */
|
|
- const QPoint cursor = QCursor::pos();
|
|
- QCursor::setPos(window->mapToGlobal( window->rect().topRight() ) + QPoint(1, 0) );
|
|
- QCursor::setPos(cursor);
|
|
-
|
|
- }
|
|
|
|
return false;
|
|
|
|
@@ -194,19 +186,6 @@
|
|
_appEventFilter = new AppEventFilter( this );
|
|
qApp->installEventFilter( _appEventFilter );
|
|
|
|
- #if BREEZE_HAVE_X11
|
|
- _moveResizeAtom = 0;
|
|
- if( Helper::isX11() )
|
|
- {
|
|
- // create move-resize atom
|
|
- xcb_connection_t* connection( Helper::connection() );
|
|
- const QString atomName( QStringLiteral( "_NET_WM_MOVERESIZE" ) );
|
|
- xcb_intern_atom_cookie_t cookie( xcb_intern_atom( connection, false, atomName.size(), qPrintable( atomName ) ) );
|
|
- ScopedPointer<xcb_intern_atom_reply_t> reply( xcb_intern_atom_reply( connection, cookie, nullptr) );
|
|
- _moveResizeAtom = reply ? reply->atom:0;
|
|
- }
|
|
- #endif
|
|
-
|
|
}
|
|
|
|
//_____________________________________________________________
|
|
@@ -755,43 +734,15 @@
|
|
const qreal dpiRatio = 1;
|
|
#endif
|
|
|
|
- // from bespin/virtuality
|
|
- xcb_button_release_event_t releaseEvent;
|
|
- memset(&releaseEvent, 0, sizeof(releaseEvent));
|
|
-
|
|
- releaseEvent.response_type = XCB_BUTTON_RELEASE;
|
|
- releaseEvent.event = window;
|
|
- releaseEvent.child = XCB_WINDOW_NONE;
|
|
- releaseEvent.root = QX11Info::appRootWindow();
|
|
- releaseEvent.event_x = _dragPoint.x()*dpiRatio;
|
|
- releaseEvent.event_y = _dragPoint.y()*dpiRatio;
|
|
- releaseEvent.root_x = position.x()*dpiRatio;
|
|
- releaseEvent.root_y = position.y()*dpiRatio;
|
|
- releaseEvent.detail = XCB_BUTTON_INDEX_1;
|
|
- releaseEvent.state = XCB_BUTTON_MASK_1;
|
|
- releaseEvent.time = XCB_CURRENT_TIME;
|
|
- releaseEvent.same_screen = true;
|
|
- xcb_send_event( connection, false, window, XCB_EVENT_MASK_BUTTON_RELEASE, reinterpret_cast<const char*>(&releaseEvent));
|
|
+ #if BREEZE_USE_KDE4
|
|
+ Display* net_connection = QX11Info::display();
|
|
+ #else
|
|
+ xcb_connection_t* net_connection = connection;
|
|
+ #endif
|
|
|
|
xcb_ungrab_pointer( connection, XCB_TIME_CURRENT_TIME );
|
|
-
|
|
- // from QtCurve
|
|
- xcb_client_message_event_t clientMessageEvent;
|
|
- memset(&clientMessageEvent, 0, sizeof(clientMessageEvent));
|
|
-
|
|
- clientMessageEvent.response_type = XCB_CLIENT_MESSAGE;
|
|
- clientMessageEvent.format = 32;
|
|
- clientMessageEvent.window = window;
|
|
- clientMessageEvent.type = _moveResizeAtom;
|
|
- clientMessageEvent.data.data32[0] = position.x()*dpiRatio;
|
|
- clientMessageEvent.data.data32[1] = position.y()*dpiRatio;
|
|
- clientMessageEvent.data.data32[2] = 8; // NET::Move
|
|
- clientMessageEvent.data.data32[3] = XCB_KEY_BUT_MASK_BUTTON_1;
|
|
- xcb_send_event( connection, false, QX11Info::appRootWindow(),
|
|
- XCB_EVENT_MASK_SUBSTRUCTURE_NOTIFY |
|
|
- XCB_EVENT_MASK_SUBSTRUCTURE_REDIRECT, reinterpret_cast<const char*>(&clientMessageEvent) );
|
|
-
|
|
- xcb_flush( connection );
|
|
+ NETRootInfo rootInfo( net_connection, NET::WMMoveResize );
|
|
+ rootInfo.moveResizeRequest( window, position.x() * dpiRatio, position.y() * dpiRatio, NET::Move );
|
|
|
|
#else
|
|
|
|
|
|
--- a/kstyle/breezewindowmanager.h
|
|
+++ b/kstyle/breezewindowmanager.h
|
|
@@ -31,10 +31,6 @@
|
|
#include <QString>
|
|
#include <QWidget>
|
|
|
|
-#if BREEZE_HAVE_X11
|
|
-#include <xcb/xcb.h>
|
|
-#endif
|
|
-
|
|
namespace Breeze
|
|
{
|
|
|
|
@@ -260,10 +256,6 @@
|
|
//* application event filter
|
|
QObject* _appEventFilter;
|
|
|
|
- #if BREEZE_HAVE_X11
|
|
- xcb_atom_t _moveResizeAtom;
|
|
- #endif
|
|
-
|
|
//* allow access of all private members to the app event filter
|
|
friend class AppEventFilter;
|
|
|