PyQt5中的菜单和工具栏

文章介绍了如何使用PyQt5库创建主应用程序窗口,包括设置状态栏、菜单栏、简单菜单、子菜单、可选菜单和工具栏。通过QMainWindow类,可以构建具有经典布局的应用,包括添加退出操作、显示状态提示以及响应快捷键。同时展示了如何添加和管理上下文菜单,以及创建具有中心小部件的主窗口。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

QMainWindow

QMainWindow类提供了一个主应用程序窗口。这样就可以创建一个带有状态栏、工具栏和菜单栏的经典应用程序框架。

状态栏

状态栏是一个用于显示状态信息的小部件。

statusbar.py

#!/usr/bin/python

"""
ZetCode PyQt5 tutorial

This program creates a statusbar.

Author: Jan Bodnar
Website: zetcode.com
"""

import sys
from PyQt5.QtWidgets import QMainWindow, QApplication


class Example(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):
        self.statusBar().showMessage('Ready')

        self.setGeometry(300, 300, 250, 150)
        self.setWindowTitle('Statusbar')
        self.show()


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

状态栏是在QMainWindow小部件的帮助下创建的。

self.statusBar().showMessage("Ready")

为了获得状态栏,我们调用QtGui.QMainWindow类的statusBar方法。该方法的第一次调用创建一个状态栏。后续调用返回statusbar对象。showMessage命令用于在状态栏上显示一条消息。

PyQt5简单菜单

菜单栏是GUI应用程序的常见部分。它是位于各种菜单中的一组命令。(Mac OS对菜单栏的处理方式不同。要获得类似的结果,我们可以添加以下行:menubar.setNativeMenuBar(False)

simple_menu.py

#!/usr/bin/python

"""
ZetCode PyQt5 tutorial

This program creates a menubar. The
menubar has one menu with an exit action.

Author: Jan Bodnar
Website: zetcode.com
"""

import sys
from PyQt5.QtWidgets import QMainWindow, QAction, qApp, QApplication
from PyQt5.QtGui import QIcon


class Example(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):

        exitAct = QAction(QIcon('exit.png'), '&Exit', self)
        exitAct.setShortcut('Ctrl+Q')
        exitAct.setStatusTip('Exit application')
        exitAct.triggered.connect(qApp.quit)

        self.statusBar()

        menubar = self.menuBar()
        fileMenu = menubar.addMenu('&File')
        fileMenu.addAction(exitAct)

        self.setGeometry(300, 300, 300, 200)
        self.setWindowTitle('Simple menu')
        self.show()


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

在上面的例子中,我们创建了一个菜单栏。这个菜单包含一个操作,如果被选中,它将终止应用程序。同时还创建了一个状态栏。可以通过快捷键Ctrl+Q访问该操作。

exitAct = QAction(QIcon('exit.png'), '&Exit', self)
exitAct.setShortcut('Ctrl+Q')
exitAct.setStatusTip('Exit application')

QAction是使用菜单栏、工具栏或自定义键盘快捷键执行的操作的抽象。在上面的三行代码中,我们创建了一个带有特定图标和“Exit”标签的操作。此外,还为此操作定义了一个快捷方式。第三行代码创建了一个状态提示,当我们将鼠标指针悬停在菜单项上时,该提示将显示在状态栏中。

exitAct.triggered.connect (qApp.quit)

当我们选择这个特定的动作时,就会发出一个触发信号。信号连接到QApplication小部件的quit方法。这将终止应用程序。

menubar = self.menuBar()
fileMenu = menubar.addMenu('&File')
fileMenu.addAction (exitAction)

menuBar方法创建一个菜单栏。我们使用addMenu创建一个文件菜单,并使用addAction添加操作。

PyQt5子菜单

子菜单是位于另一个菜单中的菜单。

submenu.py

#!/usr/bin/python

"""
ZetCode PyQt5 tutorial

This program creates a submenu.

Author: Jan Bodnar
Website: zetcode.com
"""

import sys
from PyQt5.QtWidgets import QMainWindow, QAction, QMenu, QApplication


class Example(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):

        menubar = self.menuBar()
        fileMenu = menubar.addMenu('File')

        impMenu = QMenu('Import', self)
        impAct = QAction('Import mail', self)
        impMenu.addAction(impAct)

        newAct = QAction('New', self)

        fileMenu.addAction(newAct)
        fileMenu.addMenu(impMenu)

        self.setGeometry(300, 300, 300, 200)
        self.setWindowTitle('Submenu')
        self.show()


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

在这个例子中,我们有两个菜单项;一个位于文件菜单中,另一个位于文件的导入子菜单中。

impMenu = QMenu('Import', self)

使用QMenu创建新菜单。

impAct = QAction('Import mail', self)
impMenu.addAction(impAct)

使用addAction将一个操作添加到子菜单中。

PyQt5检查菜单

在下面的示例中,我们创建了一个可以选中和不选中的菜单。

check_menu.py
#!/usr/bin/python

"""
ZetCode PyQt5 tutorial

This program creates a checkable menu.

Author: Jan Bodnar
Website: zetcode.com
"""

import sys
from PyQt5.QtWidgets import QMainWindow, QAction, QApplication


class Example(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()


    def initUI(self):

        self.statusbar = self.statusBar()
        self.statusbar.showMessage('Ready')

        menubar = self.menuBar()
        viewMenu = menubar.addMenu('View')

        viewStatAct = QAction('View statusbar', self, checkable=True)
        viewStatAct.setStatusTip('View statusbar')
        viewStatAct.setChecked(True)
        viewStatAct.triggered.connect(self.toggleMenu)

        viewMenu.addAction(viewStatAct)

        self.setGeometry(300, 300, 300, 200)
        self.setWindowTitle('Check menu')
        self.show()

    def toggleMenu(self, state):

        if state:
            self.statusbar.show()
        else:
            self.statusbar.hide()


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

代码示例创建一个带有一个操作的View菜单。该操作显示或隐藏状态栏。当状态栏可见时,选中菜单项。

viewStatAct = QAction('View statusbar', self, checkable=True)

使用checkable选项,我们创建了一个可检查菜单。

viewStatAct.setChecked(True)

因为状态栏从一开始就是可见的,所以我们用setChecked方法检查动作。

def toggleMenu(self, state):

    if state:
        self.statusbar.show()
    else:
        self.statusbar.hide()

根据操作的状态,我们显示或隐藏状态栏。

PyQt5上下文菜单

上下文菜单,也称为弹出式菜单,是在某些上下文中显示的命令列表。例如,在Opera浏览器中,当我们右键单击网页时,我们会得到一个上下文菜单。在这里,我们可以重新加载页面、返回或查看页面源。如果我们右键单击工具栏,我们会得到另一个管理工具栏的上下文菜单。

context_menu.py

#!/usr/bin/python

"""
ZetCode PyQt5 tutorial

This program creates a context menu.

Author: Jan Bodnar
Website: zetcode.com
"""

import sys
from PyQt5.QtWidgets import QMainWindow, qApp, QMenu, QApplication


class Example(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):
        self.setGeometry(300, 300, 300, 200)
        self.setWindowTitle('Context menu')
        self.show()

    def contextMenuEvent(self, event):
        cmenu = QMenu(self)

        newAct = cmenu.addAction("New")
        openAct = cmenu.addAction("Open")
        quitAct = cmenu.addAction("Quit")
        action = cmenu.exec_(self.mapToGlobal(event.pos()))

        if action == quitAct:
            qApp.quit()


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

要使用上下文菜单,我们必须重新实现contextMenuEvent方法。

action = cmenu.exec_(self.mapToGlobal(event.pos()))

上下文菜单用exec_方法显示。从事件对象获取鼠标指针的坐标。mapToGlobal方法将小部件坐标转换为全局屏幕坐标。

if action == quitAct:
    qApp.quit()

如果从上下文菜单返回的操作等于退出操作,则终止应用程序。

PyQt5工具栏

菜单将我们可以在应用程序中使用的所有命令分组。工具栏提供了对最常用命令的快速访问。

toolbar.py

#!/usr/bin/python

"""
ZetCode PyQt5 tutorial

This program creates a toolbar.
The toolbar has one action, which
terminates the application, if triggered.

Author: Jan Bodnar
Website: zetcode.com
"""

import sys
from PyQt5.QtWidgets import QMainWindow, QAction, qApp, QApplication
from PyQt5.QtGui import QIcon


class Example(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()


    def initUI(self):

        exitAct = QAction(QIcon('exit24.png'), 'Exit', self)
        exitAct.setShortcut('Ctrl+Q')
        exitAct.triggered.connect(qApp.quit)

        self.toolbar = self.addToolBar('Exit')
        self.toolbar.addAction(exitAct)

        self.setGeometry(300, 300, 300, 200)
        self.setWindowTitle('Toolbar')
        self.show()


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

在上面的示例中,我们创建了一个简单的工具栏。工具栏有一个工具动作,即在触发时终止应用程序的退出动作。

exitAct = QAction(QIcon('exit24.png')'Exit', self)
exitAct.setShortcut (Ctrl + Q)
exitAct.triggered.connect (qApp.quit)

与上面的菜单栏示例类似,我们创建一个操作对象。该对象具有标签、图标和快捷方式。QtGui.QMainWindowquit方法已连接到触发信号。

self.toolbar = self.addToolBar('Exit')
self.toolbar.addAction(exitAction)

工具栏是用addToolBar方法创建的。我们使用addAction向工具栏添加一个操作对象。

PyQt5主窗口

在本节的最后一个示例中,我们创建了菜单栏、工具栏和状态栏。我们还创建了一个中心小部件。

main_window.py

#!/usr/bin/python

"""
ZetCode PyQt5 tutorial

This program creates a skeleton of
a classic GUI application with a menubar,
toolbar, statusbar, and a central widget.

Author: Jan Bodnar
Website: zetcode.com
"""

import sys
from PyQt5.QtWidgets import QMainWindow, QTextEdit, QAction, QApplication
from PyQt5.QtGui import QIcon


class Example(QMainWindow):

    def __init__(self):
        super().__init__()

        self.initUI()


    def initUI(self):

        textEdit = QTextEdit()
        self.setCentralWidget(textEdit)

        exitAct = QAction(QIcon('exit24.png'), 'Exit', self)
        exitAct.setShortcut('Ctrl+Q')
        exitAct.setStatusTip('Exit application')
        exitAct.triggered.connect(self.close)

        self.statusBar()

        menubar = self.menuBar()
        fileMenu = menubar.addMenu('&File')
        fileMenu.addAction(exitAct)

        toolbar = self.addToolBar('Exit')
        toolbar.addAction(exitAct)

        self.setGeometry(300, 300, 350, 250)
        self.setWindowTitle('Main window')
        self.show()


def main():
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())


if __name__ == '__main__':
    main()

这个代码示例创建了一个带有菜单栏、工具栏和状态栏的经典GUI应用程序的框架。

textEdit = QTextEdit()
self.setCentralWidget(textEdit)

这里我们创建了一个文本编辑小部件。我们将其设置为QMainWindow的中心小部件。中央小部件占用了剩余的所有空间。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值