PyQt5 教程 《菜单和工具栏》

65 篇文章 4 订阅
24 篇文章 0 订阅

目录

导读

PyQt5中的菜单和工具栏

QMainWindow的

状态栏

简单的菜单

子菜单

检查菜单

上下文菜单

工具栏

把它放在一起


PyQt5中的菜单和工具栏

在PyQt5教程的这一部分中,我们创建了一个状态栏,菜单栏和工具栏。菜单是位于菜单栏中的一组命令。工具栏上的按钮包含应用程序中的一些常用命令。状态栏显示状态信息,通常位于应用程序窗口的底部。

QMainWindow的

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

状态栏

状态栏是用于显示状态信息的小组件。

statusbar.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-


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()


if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

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

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

要获取状态栏,我们调用类的statusBar()方法QtGui.QMainWindow。该方法的第一次调用创建一个状态栏。后续调用将返回状态栏对象。在showMessage()显示在状态栏的消息。

简单的菜单

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

simplemenu.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-


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()
        
        
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

在上面的示例中,我们使用一个菜单创建菜单栏。此菜单将包含一个操作,如果选择该操作将终止该应用程序。还会创建状态栏。可以使用Ctrl+ Q快捷方式访问该操作。

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

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

exitAct.triggered.connect(qApp.quit)

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

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

menuBar()方法创建一个菜单栏。我们创建一个文件菜单,addMenu()并添加动作addAction()

 

子菜单

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

submenu.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-


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()
        
        
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

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

impMenu = QMenu('Import', self)

新菜单由QMenu创建.

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

一个动作添加到子菜单中addAction()

Submenu

图: Submenu

检查菜单

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

checkmenu.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-

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()
       
        
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

代码示例使用一个操作创建一个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()

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

Check menu

图: Check menu

上下文菜单

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

contextmenu.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-


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")
           opnAct = cmenu.addAction("Open")
           quitAct = cmenu.addAction("Quit")
           action = cmenu.exec_(self.mapToGlobal(event.pos()))
           
           if action == quitAct:
               qApp.quit()
       
        
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

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

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

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

if action == quitAct:
    qApp.quit()

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

工具栏

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

toolbar.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-


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()
        
        
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

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

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

与上面的菜单栏示例类似,我们创建了一个操作对象。该对象具有标签,图标和shorcut。一种quit()方法 QtGui.QMainWindow连接到触发信号。

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

使用该addToolBar()方法创建工具栏。我们用工具栏添加一个动作对象addAction()

工具栏

图:工具栏

把它放在一起

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

mainwindow.py
#!/usr/bin/python3
# -*- coding: utf-8 -*-


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()
        
        
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

此代码示例使用菜单栏,工具栏和状态栏创建经典GUI应用程序的框架。

textEdit = QTextEdit()
self.setCentralWidget(textEdit)

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

主窗口

图:主窗口

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值