菜单和工具栏

菜单和工具栏

在这部分教程中,将会创建状态栏、菜单和工具栏。菜单中的一个菜单项是一组命令。工具栏中包含一些执行常见的功能按键。状态栏一般位于应用窗口的底部,用来显示状态信息

QMainWindow

QMainWindow 类提供应用的主窗口。它创建一个包含状态栏、工具栏和菜单的经典的应用视图轮廓

状态栏

状态栏控件用来形式状态信息

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

调用QtGui.QMainWindow类的statusBar()方法来获得窗口的状态栏。
首先创建状态栏,随后返回状态栏对象,showMessage()方法设置状态栏要显示的文本信息。

一般的菜单

菜单栏是桌面应用常见部分,他是一组命令(mac os 的菜单栏有些不同,添加menubar.setNativeMenuBar(False)这一行来获得相同的效果)

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)

当选中该动作,信号会被触发,该信号与QApplication控件的quit()连接,该方法会结束应用

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

menuBar()方法创建一个菜单栏,addMenu()创建一个菜单,并用addAction为菜单添加动作

子菜单

子菜单在一个菜单的里面

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

例子中,有两个菜单项,一个在位于名为file的菜单,另一个位于file菜单的子import菜单项
submenu

impMenu = QMenu('Import', self)

QMenu创建一个新的菜单

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

addAction()给子菜单添加动作

可选择菜单

下面的例子,创建一个可选择的菜单

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的菜单并包含一个动作,该动作可以显示或者隐藏状态栏。但菜单项被选中时,显示状态栏
checkmunu

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

创建一个可选择的菜单

viewStatAct.setChecked(True)

由于状态栏开始是可见的,用setChecked()方法选中动作

def toggleMenu(self, state):

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

根据动作的状态,显示或者隐藏状态栏

上下文菜单

上下文菜单也叫作popup菜单,是一个在一些上下文上显示的命令列表。
例如,在opera浏览器中,当在在网页中右键,就会显示上下文菜单,该菜单可以重载网页、返回、或者查看网页源码。如果在该浏览器的工具栏中右键,会显示另一个用来管理工具栏的上下文菜单。

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

如果上下文返回的动作等于名为quit的动作,就结束应用

工具栏

菜单组织应用中所有的命令。工具栏提供常用命令的快捷入口

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

上例中,创建了一个简单的工具栏,该工具栏有一个工具动作,该动作触发时结束应用
toolbar

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

与菜单栏类似,创建了一个动作对象,该动作有标签、图标和快捷方式,QtGui.QMainWindow的quit连接到该动作的触发信号

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

addToolBat()方法创建工具栏,用addAction()方法给工具栏添加动作对象

一起使用

这一部分,我们会创建菜单栏、工具栏和状态栏,并且创建一个中心控件

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

该代码创建了一个显示菜单栏、工具栏、状态栏的典型应用框架
mainwindow

textEdit = QTextEdit()
self.setCentralWidget(textEdit)

这里创建了一个可编辑文本控件,把它放到QMainWindow的中间,并占据所有控件

原文地址:http://zetcode.com/gui/pyqt5/menustoolbars/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值