Cocoa: Make sure internal minimized state is up to date
Refactors some code from previous changes addressing the same issue for maximized and fullscreen states. Change-Id: I8a27274a90e6610b424ea7af3269369a1d724c48 Reviewed-by: Richard Moe Gustavsen <richard.gustavsen@digia.com>
This commit is contained in:
parent
b8c007ede0
commit
bfab741cb7
@ -81,6 +81,7 @@ QT_END_NAMESPACE
|
||||
- (void)invalidateWindowShadowIfNeeded;
|
||||
- (void)drawRect:(NSRect)dirtyRect;
|
||||
- (void)updateGeometry;
|
||||
- (void)notifyWindowStateChanged:(Qt::WindowState)newState;
|
||||
- (void)windowNotification : (NSNotification *) windowNotification;
|
||||
- (void)notifyWindowWillZoom:(BOOL)willZoom;
|
||||
- (void)viewDidHide;
|
||||
|
@ -251,6 +251,15 @@ static QTouchDevice *touchDevice = 0;
|
||||
}
|
||||
}
|
||||
|
||||
- (void)notifyWindowStateChanged:(Qt::WindowState)newState
|
||||
{
|
||||
QWindowSystemInterface::handleWindowStateChanged(m_window, newState);
|
||||
// We want to read the window state back from the window,
|
||||
// but the event we just sent may be asynchronous.
|
||||
QWindowSystemInterface::flushWindowSystemEvents();
|
||||
m_platformWindow->setSynchedWindowStateFromWindow();
|
||||
}
|
||||
|
||||
- (void)windowNotification : (NSNotification *) windowNotification
|
||||
{
|
||||
//qDebug() << "windowNotification" << QCFString::toQString([windowNotification name]);
|
||||
@ -269,10 +278,11 @@ static QTouchDevice *touchDevice = 0;
|
||||
if (!m_platformWindow->windowIsPopupType())
|
||||
QWindowSystemInterface::handleWindowActivated(0);
|
||||
}
|
||||
} else if (notificationName == NSWindowDidMiniaturizeNotification) {
|
||||
QWindowSystemInterface::handleWindowStateChanged(m_window, Qt::WindowMinimized);
|
||||
} else if (notificationName == NSWindowDidDeminiaturizeNotification) {
|
||||
QWindowSystemInterface::handleWindowStateChanged(m_window, Qt::WindowNoState);
|
||||
} else if (notificationName == NSWindowDidMiniaturizeNotification
|
||||
|| notificationName == NSWindowDidDeminiaturizeNotification) {
|
||||
Qt::WindowState newState = notificationName == NSWindowDidMiniaturizeNotification ?
|
||||
Qt::WindowMinimized : Qt::WindowNoState;
|
||||
[self notifyWindowStateChanged:newState];
|
||||
} else if ([notificationName isEqualToString: @"NSWindowDidOrderOffScreenNotification"]) {
|
||||
m_platformWindow->obscureWindow();
|
||||
} else if ([notificationName isEqualToString: @"NSWindowDidOrderOnScreenAndFinishAnimatingNotification"]) {
|
||||
@ -294,11 +304,7 @@ static QTouchDevice *touchDevice = 0;
|
||||
|| notificationName == NSWindowDidExitFullScreenNotification) {
|
||||
Qt::WindowState newState = notificationName == NSWindowDidEnterFullScreenNotification ?
|
||||
Qt::WindowFullScreen : Qt::WindowNoState;
|
||||
QWindowSystemInterface::handleWindowStateChanged(m_window, newState);
|
||||
// We want to read the window state back from the window,
|
||||
// but the event we just sent may be asynchronous.
|
||||
QWindowSystemInterface::flushWindowSystemEvents();
|
||||
m_platformWindow->setSynchedWindowStateFromWindow();
|
||||
[self notifyWindowStateChanged:newState];
|
||||
}
|
||||
}
|
||||
#endif
|
||||
@ -309,11 +315,7 @@ static QTouchDevice *touchDevice = 0;
|
||||
- (void)notifyWindowWillZoom:(BOOL)willZoom
|
||||
{
|
||||
Qt::WindowState newState = willZoom ? Qt::WindowMaximized : Qt::WindowNoState;
|
||||
QWindowSystemInterface::handleWindowStateChanged(m_window, newState);
|
||||
// We want to read the window state back from the window,
|
||||
// but the event we just sent may be asynchronous.
|
||||
QWindowSystemInterface::flushWindowSystemEvents();
|
||||
m_platformWindow->setSynchedWindowStateFromWindow();
|
||||
[self notifyWindowStateChanged:newState];
|
||||
}
|
||||
|
||||
- (void)viewDidHide
|
||||
|
Loading…
Reference in New Issue
Block a user