summaryrefslogtreecommitdiffstats
path: root/src/widgets/widgets/qsizegrip.cpp
diff options
context:
space:
mode:
authorFriedemann Kleint <Friedemann.Kleint@nokia.com>2012-06-12 10:47:42 +0200
committerQt by Nokia <qt-info@nokia.com>2012-06-14 03:05:41 +0200
commit0137f092af12110c427f05358f7b207ea95ea341 (patch)
treef314b8d0f744c4822af8f0d8890ecd9983a284d7 /src/widgets/widgets/qsizegrip.cpp
parent1539e8e310ee3da8ae44a4b5b28d0f72b1345eb4 (diff)
Introduce QPA API for size grip handling.
- Introduce API to do size grip handling (mouse press and move). - Move Windows code to Windows plugin. - Move X11 code to XCB plugin and activate it. Change-Id: I2f61d6ddc1fa07447e668554d41ecc820efca23f Reviewed-by: Samuel Rødal <samuel.rodal@nokia.com>
Diffstat (limited to 'src/widgets/widgets/qsizegrip.cpp')
-rw-r--r--src/widgets/widgets/qsizegrip.cpp98
1 files changed, 27 insertions, 71 deletions
diff --git a/src/widgets/widgets/qsizegrip.cpp b/src/widgets/widgets/qsizegrip.cpp
index c9860f20ff..16c2656be0 100644
--- a/src/widgets/widgets/qsizegrip.cpp
+++ b/src/widgets/widgets/qsizegrip.cpp
@@ -46,6 +46,8 @@
#include "qapplication.h"
#include "qevent.h"
#include "qpainter.h"
+#include "qwindow.h"
+#include <qpa/qplatformwindow.h>
#include "qstyle.h"
#include "qstyleoption.h"
#include "qlayout.h"
@@ -59,23 +61,8 @@
#include <private/qwidget_p.h>
#include <QtWidgets/qabstractscrollarea.h>
-#ifdef Q_OS_WIN
-# include <QtCore/qt_windows.h>
-# include "private/qapplication_p.h"
-#endif
-
QT_BEGIN_NAMESPACE
-#if defined (Q_OS_WIN)
-# define SZ_SIZEBOTTOMRIGHT 0xf008
-# define SZ_SIZEBOTTOMLEFT 0xf007
-# define SZ_SIZETOPLEFT 0xf004
-# define SZ_SIZETOPRIGHT 0xf005
-
-HMENU qt_getWindowsSystemMenu(const QWidget *w);
-
-#endif
-
static QWidget *qt_sizegrip_topLevelWidget(QWidget* w)
{
while (w && !w->isWindow() && w->windowType() != Qt::SubWindow)
@@ -87,6 +74,7 @@ class QSizeGripPrivate : public QWidgetPrivate
{
Q_DECLARE_PUBLIC(QSizeGrip)
public:
+ QSizeGripPrivate();
void init();
QPoint p;
QRect r;
@@ -143,8 +131,19 @@ public:
if (showSizeGrip)
q->setVisible(true);
}
+
+ bool m_platformSizeGrip;
};
+QSizeGripPrivate::QSizeGripPrivate()
+ : dxMax(0)
+ , dyMax(0)
+ , gotMousePress(false)
+ , tlw(0)
+ , m_platformSizeGrip(false)
+{
+}
+
#ifdef Q_WS_MAC
void QSizeGripPrivate::updateMacSizer(bool hide) const
{
@@ -226,11 +225,7 @@ QSizeGrip::QSizeGrip(QWidget * parent)
void QSizeGripPrivate::init()
{
Q_Q(QSizeGrip);
- dxMax = 0;
- dyMax = 0;
- tlw = 0;
m_corner = q->isLeftToRight() ? Qt::BottomRightCorner : Qt::BottomLeftCorner;
- gotMousePress = false;
#if !defined(QT_NO_CURSOR) && !defined(Q_WS_MAC)
q->setCursor(m_corner == Qt::TopLeftCorner || m_corner == Qt::BottomRightCorner
@@ -284,6 +279,7 @@ void QSizeGrip::paintEvent(QPaintEvent *event)
resize operation. The mouse press event is passed in the \a event
parameter.
*/
+
void QSizeGrip::mousePressEvent(QMouseEvent * e)
{
if (e->button() != Qt::LeftButton) {
@@ -297,44 +293,20 @@ void QSizeGrip::mousePressEvent(QMouseEvent * e)
d->gotMousePress = true;
d->r = tlw->geometry();
-#ifdef Q_WS_X11
- // Use a native X11 sizegrip for "real" top-level windows if supported.
- if (tlw->isWindow() && X11->isSupportedByWM(ATOM(_NET_WM_MOVERESIZE))
+ // Does the platform provide size grip support?
+ d->m_platformSizeGrip = false;
+ if (tlw->isWindow()
+ && tlw->windowHandle()
&& !(tlw->windowFlags() & Qt::X11BypassWindowManagerHint)
- && !tlw->testAttribute(Qt::WA_DontShowOnScreen) && !tlw->hasHeightForWidth()) {
- XEvent xev;
- xev.xclient.type = ClientMessage;
- xev.xclient.message_type = ATOM(_NET_WM_MOVERESIZE);
- xev.xclient.display = X11->display;
- xev.xclient.window = tlw->winId();
- xev.xclient.format = 32;
- xev.xclient.data.l[0] = e->globalPos().x();
- xev.xclient.data.l[1] = e->globalPos().y();
- if (d->atBottom())
- xev.xclient.data.l[2] = d->atLeft() ? 6 : 4; // bottomleft/bottomright
- else
- xev.xclient.data.l[2] = d->atLeft() ? 0 : 2; // topleft/topright
- xev.xclient.data.l[3] = Button1;
- xev.xclient.data.l[4] = 0;
- XUngrabPointer(X11->display, X11->time);
- XSendEvent(X11->display, QX11Info::appRootWindow(x11Info().screen()), False,
- SubstructureRedirectMask | SubstructureNotifyMask, &xev);
- return;
+ && !tlw->testAttribute(Qt::WA_DontShowOnScreen)
+ && !tlw->hasHeightForWidth()) {
+ QPlatformWindow *platformWindow = tlw->windowHandle()->handle();
+ const QPoint topLevelPos = mapTo(tlw, e->pos());
+ d->m_platformSizeGrip = platformWindow && platformWindow->startSystemResize(topLevelPos, d->m_corner);
}
-#endif // Q_WS_X11
-#ifdef Q_OS_WIN
- if (tlw->isWindow() && !tlw->testAttribute(Qt::WA_DontShowOnScreen) && !tlw->hasHeightForWidth()) {
- uint orientation = 0;
- if (d->atBottom())
- orientation = d->atLeft() ? SZ_SIZEBOTTOMLEFT : SZ_SIZEBOTTOMRIGHT;
- else
- orientation = d->atLeft() ? SZ_SIZETOPLEFT : SZ_SIZETOPRIGHT;
- ReleaseCapture();
- PostMessage(QApplicationPrivate::getHWNDForWidget(tlw), WM_SYSCOMMAND, orientation, 0);
+ if (d->m_platformSizeGrip)
return;
- }
-#endif // Q_OS_WIN
// Find available desktop/workspace geometry.
QRect availableGeometry;
@@ -400,32 +372,16 @@ void QSizeGrip::mousePressEvent(QMouseEvent * e)
*/
void QSizeGrip::mouseMoveEvent(QMouseEvent * e)
{
- if (e->buttons() != Qt::LeftButton) {
+ Q_D(QSizeGrip);
+ if (e->buttons() != Qt::LeftButton || d->m_platformSizeGrip) {
QWidget::mouseMoveEvent(e);
return;
}
- Q_D(QSizeGrip);
QWidget* tlw = qt_sizegrip_topLevelWidget(this);
if (!d->gotMousePress || tlw->testAttribute(Qt::WA_WState_ConfigPending))
return;
-#ifdef Q_WS_X11
- if (tlw->isWindow() && X11->isSupportedByWM(ATOM(_NET_WM_MOVERESIZE))
- && tlw->isTopLevel() && !(tlw->windowFlags() & Qt::X11BypassWindowManagerHint)
- && !tlw->testAttribute(Qt::WA_DontShowOnScreen) && !tlw->hasHeightForWidth())
- return;
-#endif
-#ifdef Q_OS_WIN
- if (tlw->isWindow() && qt_getWindowsSystemMenu(tlw) && !tlw->testAttribute(Qt::WA_DontShowOnScreen) && !tlw->hasHeightForWidth()) {
- if (const HWND hwnd = QApplicationPrivate::getHWNDForWidget(tlw)) {
- MSG msg;
- while (PeekMessage(&msg, hwnd, WM_MOUSEMOVE, WM_MOUSEMOVE, PM_REMOVE)) ;
- return;
- }
- }
-#endif
-
QPoint np(e->globalPos());
// Don't extend beyond the available geometry; bound to dyMax and dxMax.