diff options
Diffstat (limited to 'src/gui/kernel')
| -rw-r--r-- | src/gui/kernel/qguiapplication.cpp | 10 | ||||
| -rw-r--r-- | src/gui/kernel/qwindow.cpp | 6 | 
2 files changed, 9 insertions, 7 deletions
| diff --git a/src/gui/kernel/qguiapplication.cpp b/src/gui/kernel/qguiapplication.cpp index e44d9b1468b..518843ffcbd 100644 --- a/src/gui/kernel/qguiapplication.cpp +++ b/src/gui/kernel/qguiapplication.cpp @@ -2626,7 +2626,6 @@ void QGuiApplicationPrivate::processEnterEvent(QWindowSystemInterfacePrivate::En      }      currentMouseWindow = e->enter; -    lastCursorPosition = e->globalPos;      // TODO later: EnterEvent must report _which_ mouse entered the window; for now we assume primaryPointingDevice()      QEnterEvent event(e->localPos, e->localPos, e->globalPos); @@ -3408,6 +3407,15 @@ void QGuiApplicationPrivate::processExposeEvent(QWindowSystemInterfacePrivate::E          return;      QWindowPrivate *p = qt_window_private(window); +    if (e->isExposed) { +        // If the window has been automatically positioned or resized by the +        // window manager, we now assume those have taken effect, even for +        // asynchronous window managers. From this point on we want the window +        // to keep its geometry, even when recreated. +        p->positionAutomatic = false; +        p->resizeAutomatic = false; +    } +      if (!p->receivedExpose) {          if (p->resizeEventPending) {              // as a convenience for plugins, send a resize event before the first expose event if they haven't done so diff --git a/src/gui/kernel/qwindow.cpp b/src/gui/kernel/qwindow.cpp index c23be8eb3ad..bad5932c457 100644 --- a/src/gui/kernel/qwindow.cpp +++ b/src/gui/kernel/qwindow.cpp @@ -582,12 +582,6 @@ void QWindowPrivate::create(bool recursive)      platformWindow->initialize(); -    // Now that the window is created and initialized the platform has had -    // a chance to position and size it automatically. From this point on -    // we want the window to keep its geometry, even when recreated. -    positionAutomatic = false; -    resizeAutomatic = false; -      QObjectList childObjects = q->children();      for (int i = 0; i < childObjects.size(); i ++) {          QObject *object = childObjects.at(i); | 
