【Qt Quick】Menu

说明

菜单栏通常由下拉菜单组成,菜单一般存在于窗口的顶部。

常用

1.菜单分离器

就是在菜单中两个菜单名之间的横线,用于分隔。

MenuSeparator { }

2.顶部菜单

在MenuBar中增加一个菜单选项。

MenuBar {
        id: menuBar
        anchors.fill: parent
        Menu {
            id: fileMenu
            title: qsTr("文件")
        }

增加菜单

直接在Menu中再加一个Menu,这个子Menu又会拥有一个可以下拉的选项,套娃一样。Menu的触发则需要加入MenuItem方法之后才能使用onTriggered。

MenuBar {
        id: menuBar
        anchors.fill: parent
	        Menu {
	            id: fileMenu
	            title: qsTr("文件")
	            Menu {
	            id: fileMenu
	            title: qsTr("文件")
	        }
        }

增加一个选项

1.在Menu中加一个Action方法。他自己就拥有触发选项,点击事件可以直接使用onTriggered进行触发,比如此处是打开网站;
2.也可以使用MenuItem,效果是一样的。

//1
 Action{
        id:m_LoadBtn
         text: qsTr("加载")
         onTriggered: Qt.openUrlExternally("https://www.bilibili.com/")
         }
//2
MenuItem{
        text: qsTr("打开网站")
        onTriggered: Qt.openUrlExternally("https://www.bilibili.com/")
         }

添加快捷键

和onTriggered的添加方式及要求一样,加入shortcut+自己定义的按键设置,即可定义快捷键功能。

Action{
                id:m_OpenUrlBtn
                text: qsTr("打开网站")
                onTriggered: Qt.openUrlExternally("https://www.bilibili.com/")
                shortcut: "Ctrl+O"
            }

3.右键菜单

需要注意的是此菜单包含了鼠标左键和右键,如果只需要右键的,就去掉Qt.LeftButton即可。

  MouseArea {
      anchors.fill: parent
      acceptedButtons: Qt.LeftButton | Qt.RightButton
      onClicked: {
          if (mouse.button === Qt.RightButton)
              contextMenu.popup()
      }
      onPressAndHold: {
          if (mouse.source === Qt.MouseEventNotSynthesized)
              contextMenu.popup()
      }

      Menu {
          id: contextMenu
          MenuItem { text: "Cut" }
          MenuItem { text: "Copy" }
          MenuItem { text: "Paste" }
      }
  }

a.左填充

右键菜单中的每一行选项默认左对齐,左填充可以进行位置的更改。

leftPadding: 20//左填充

b.修改菜单的背景颜色

background: Rectangle{
                color: "light gray"
            }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

非西昂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值