Ensure that context menus show even if the window is not active on Mac
When using the mouse to show a context menu on Mac then even if the window is not active then it will show the menu for native applications. So this ensures that this is respected for context menus in Qt too. Task-number: QTBUG-31497 Change-Id: Ibfcb4b893b0e31d4ce36926a83c9214d130d8fa2 Reviewed-by: Gabriel de Dietrich <gabriel.dedietrich@digia.com> Reviewed-by: Shawn Rutledge <shawn.rutledge@digia.com>
This commit is contained in:
parent
66e3e1f75b
commit
b271ddebfc
@ -204,6 +204,7 @@ public: // for QNSView
|
|||||||
|
|
||||||
static const int NoAlertRequest;
|
static const int NoAlertRequest;
|
||||||
NSInteger m_alertRequest;
|
NSInteger m_alertRequest;
|
||||||
|
id monitor;
|
||||||
};
|
};
|
||||||
|
|
||||||
QT_END_NAMESPACE
|
QT_END_NAMESPACE
|
||||||
|
@ -213,6 +213,7 @@ QCocoaWindow::QCocoaWindow(QWindow *tlw)
|
|||||||
, m_registerTouchCount(0)
|
, m_registerTouchCount(0)
|
||||||
, m_resizableTransientParent(false)
|
, m_resizableTransientParent(false)
|
||||||
, m_alertRequest(NoAlertRequest)
|
, m_alertRequest(NoAlertRequest)
|
||||||
|
, monitor(nil)
|
||||||
{
|
{
|
||||||
#ifdef QT_COCOA_ENABLE_WINDOW_DEBUG
|
#ifdef QT_COCOA_ENABLE_WINDOW_DEBUG
|
||||||
qDebug() << "QCocoaWindow::QCocoaWindow" << this;
|
qDebug() << "QCocoaWindow::QCocoaWindow" << this;
|
||||||
@ -367,6 +368,11 @@ void QCocoaWindow::setVisible(bool visible)
|
|||||||
if ((window()->type() == Qt::Popup || window()->type() == Qt::Dialog || window()->type() == Qt::Tool)
|
if ((window()->type() == Qt::Popup || window()->type() == Qt::Dialog || window()->type() == Qt::Tool)
|
||||||
&& [m_nsWindow isKindOfClass:[NSPanel class]]) {
|
&& [m_nsWindow isKindOfClass:[NSPanel class]]) {
|
||||||
[(NSPanel *)m_nsWindow setWorksWhenModal:YES];
|
[(NSPanel *)m_nsWindow setWorksWhenModal:YES];
|
||||||
|
if (!(parentCocoaWindow && window()->transientParent()->isActive()) && window()->type() == Qt::Popup) {
|
||||||
|
monitor = [NSEvent addGlobalMonitorForEventsMatchingMask:NSLeftMouseDownMask|NSRightMouseDownMask|NSOtherMouseDown handler:^(NSEvent *) {
|
||||||
|
QWindowSystemInterface::handleMouseEvent(window(), QPointF(-1, -1), QPointF(window()->framePosition() - QPointF(1, 1)), Qt::LeftButton);
|
||||||
|
}];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -403,6 +409,10 @@ void QCocoaWindow::setVisible(bool visible)
|
|||||||
} else {
|
} else {
|
||||||
[m_contentView setHidden:YES];
|
[m_contentView setHidden:YES];
|
||||||
}
|
}
|
||||||
|
if (monitor && window()->type() == Qt::Popup) {
|
||||||
|
[NSEvent removeMonitor:monitor];
|
||||||
|
monitor = nil;
|
||||||
|
}
|
||||||
if (parentCocoaWindow && window()->type() == Qt::Popup) {
|
if (parentCocoaWindow && window()->type() == Qt::Popup) {
|
||||||
parentCocoaWindow->m_activePopupWindow = 0;
|
parentCocoaWindow->m_activePopupWindow = 0;
|
||||||
if (m_resizableTransientParent
|
if (m_resizableTransientParent
|
||||||
@ -849,10 +859,9 @@ NSWindow * QCocoaWindow::createNSWindow()
|
|||||||
// before the window is shown and needs a proper window.).
|
// before the window is shown and needs a proper window.).
|
||||||
if ((type & Qt::Popup) == Qt::Popup)
|
if ((type & Qt::Popup) == Qt::Popup)
|
||||||
[window setHasShadow:YES];
|
[window setHasShadow:YES];
|
||||||
else {
|
else
|
||||||
setWindowShadow(flags);
|
setWindowShadow(flags);
|
||||||
[window setHidesOnDeactivate: NO];
|
[window setHidesOnDeactivate: NO];
|
||||||
}
|
|
||||||
|
|
||||||
#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_7
|
#if MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_7
|
||||||
if (QSysInfo::QSysInfo::MacintoshVersion >= QSysInfo::MV_10_7) {
|
if (QSysInfo::QSysInfo::MacintoshVersion >= QSysInfo::MV_10_7) {
|
||||||
|
Loading…
Reference in New Issue
Block a user