Commit a238a5ad authored by Gabriel de Dietrich's avatar Gabriel de Dietrich Committed by The Qt Project
Browse files

MenuBar: Fix mouse interaction


Used the same pattern as earlier with Menu.

Change-Id: Id7a2d791516ba6d827e90c3b3e11f97dd326ccd5
Reviewed-by: default avatarJ-P Nurmi <jpnurmi@digia.com>
parent 658ea072
6.2 5.10 5.11 5.12 5.12.1 5.12.10 5.12.11 5.12.12 5.12.2 5.12.3 5.12.4 5.12.5 5.12.6 5.12.7 5.12.8 5.12.9 5.13 5.13.0 5.13.1 5.13.2 5.14 5.14.0 5.14.1 5.14.2 5.15 5.15.0 5.15.1 5.15.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 5.9.8 dev old/5.1 old/5.2 wip/calendar wip/tizen v5.15.0-alpha1 v5.14.1 v5.14.0 v5.14.0-rc2 v5.14.0-rc1 v5.14.0-beta3 v5.14.0-beta2 v5.14.0-beta1 v5.14.0-alpha1 v5.13.2 v5.13.1 v5.13.0 v5.13.0-rc3 v5.13.0-rc2 v5.13.0-rc1 v5.13.0-beta4 v5.13.0-beta3 v5.13.0-beta2 v5.13.0-beta1 v5.13.0-alpha1 v5.12.7 v5.12.6 v5.12.5 v5.12.4 v5.12.3 v5.12.2 v5.12.1 v5.12.0 v5.12.0-rc2 v5.12.0-rc1 v5.12.0-beta4 v5.12.0-beta3 v5.12.0-beta2 v5.12.0-beta1 v5.12.0-alpha1 v5.11.3 v5.11.2 v5.11.1 v5.11.0 v5.11.0-rc2 v5.11.0-rc1 v5.11.0-beta4 v5.11.0-beta3 v5.11.0-beta2 v5.11.0-beta1 v5.11.0-alpha1 v5.10.1 v5.10.0 v5.10.0-rc3 v5.10.0-rc2 v5.10.0-rc1 v5.10.0-beta4 v5.10.0-beta3 v5.10.0-beta2 v5.10.0-beta1 v5.10.0-alpha1 v5.9.9 v5.9.8 v5.9.7 v5.9.6 v5.9.5 v5.9.4 v5.9.3 v5.9.2 v5.9.1 v5.9.0 v5.9.0-rc2 v5.9.0-rc1 v5.9.0-beta4 v5.9.0-beta3 v5.9.0-beta2 v5.9.0-beta1 v5.9.0-alpha1 v5.8.0 v5.8.0-rc1 v5.8.0-beta1 v5.8.0-alpha1 v5.7.1 v5.7.0 v5.7.0-rc1 v5.7.0-beta1 v5.7.0-alpha1 v5.6.3 v5.6.2 v5.6.1 v5.6.1-1 v5.6.0 v5.6.0-rc1 v5.6.0-beta1 v5.6.0-alpha1 v5.5.1 v5.5.0 v5.5.0-rc1 v5.5.0-beta1 v5.5.0-alpha1 v5.4.2 v5.4.1 v5.4.0 v5.4.0-rc1 v5.4.0-beta1 v5.4.0-alpha1 v5.3.2 v5.3.1 v5.3.0 v5.3.0-rc1 v5.3.0-beta1 v5.3.0-alpha1 v5.2.1 v5.2.0 v5.2.0-rc1 v5.2.0-beta1 v5.2.0-alpha1 v5.1.1 v5.1.0 v5.1.0-rc2 v5.1.0-rc1 v5.1.0-beta1 v5.1.0-alpha1
No related merge requests found
Showing with 32 additions and 28 deletions
......@@ -219,7 +219,7 @@ MenuPrivate {
currentItem = column.childAt(pos.x, pos.y)
if (currentItem) {
root.__currentIndex = currentItem.menuItemIndex
if (currentItem.hasSubmenu && !currentItem.menuItem.popupVisible)
if (currentItem.hasSubmenu && !currentItem.menuItem.__popupVisible)
currentItem.showSubMenu(false)
} else {
root.__currentIndex = -1
......
......@@ -140,6 +140,27 @@ MenuBarPrivate {
anchors.fill: parent
hoverEnabled: true
onPositionChanged: updateCurrentItem(mouse)
onPressed: {
menuBarLoader.preselectMenuItem = false
menuBarLoader.openedMenuIndex = currentItem.menuItemIndex
}
property Item currentItem: null
function updateCurrentItem(mouse) {
var pos = mapToItem(row, mouse.x, mouse.y)
if (!currentItem || !currentItem.contains(Qt.point(pos.x - currentItem.x, pos.y - currentItem.y))) {
var newCurrentItem = row.childAt(pos.x, pos.y)
if (!newCurrentItem)
return;
currentItem = newCurrentItem
if (menuBarLoader.openedMenuIndex !== -1) {
menuBarLoader.preselectMenuItem = false
menuBarLoader.openedMenuIndex = currentItem.menuItemIndex
}
}
}
Row {
id: row
......@@ -150,27 +171,10 @@ MenuBarPrivate {
id: menuItemLoader
property var menuItem: modelData
property bool selected: menuItem.__popupVisible || itemMouseArea.pressed || menuBarLoader.openedMenuIndex === index
property bool selected: menuItem.__popupVisible || menuBarLoader.openedMenuIndex === index
sourceComponent: menuBarLoader.menuItemStyle
MouseArea {
id: itemMouseArea
anchors.fill:parent
hoverEnabled: true
onClicked: {
menuBarLoader.preselectMenuItem = false
menuBarLoader.openedMenuIndex = index
}
onPositionChanged: {
if ((pressed || menuMouseArea.pressed || menuBarLoader.openedMenuIndex !== -1)
&& menuBarLoader.openedMenuIndex !== index) {
menuBarLoader.openedMenuIndex = index
menuBarLoader.preselectMenuItem = false
}
}
}
property int menuItemIndex: index
Connections {
target: menuBarLoader
......
......@@ -134,14 +134,14 @@ void QtMenuPopupWindow::mouseReleaseEvent(QMouseEvent *e)
void QtMenuPopupWindow::forwardEventToTransientParent(QMouseEvent *e)
{
QWindow *parentMenuWindow = qobject_cast<QtMenuPopupWindow*>(transientParent());
if (!parentMenuWindow) {
if (m_mouseMoved && e->type() == QEvent::MouseButtonRelease)
dismissMenu();
} else {
QPoint parentPos = parentMenuWindow->mapFromGlobal(mapToGlobal(e->pos()));
if (!qobject_cast<QtMenuPopupWindow*>(transientParent())
&& m_mouseMoved && e->type() == QEvent::MouseButtonRelease) {
// Clicked outside any menu
dismissMenu();
} else if (transientParent()) {
QPoint parentPos = transientParent()->mapFromGlobal(mapToGlobal(e->pos()));
QMouseEvent pe = QMouseEvent(e->type(), parentPos, e->button(), e->buttons(), e->modifiers());
QGuiApplication::sendEvent(parentMenuWindow, &pe);
QGuiApplication::sendEvent(transientParent(), &pe);
}
}
......
......@@ -47,7 +47,7 @@ import QtQuick.Controls.Private 1.0
Style {
property Component frame: StyleItem {
elementType: "menubar"
width: control.width
width: control.__contentItem.width
height: parent ? parent.contentHeight : 0
// + 2 * (pixelMetric("menuvmargin") + pixelMetric("menupanelwidth"))
}
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment