1、主窗口
QMainWindow
提供了主窗口的功能,使用它能创建一些简单的状态栏、工具栏和菜单栏。
主窗口是下面这些窗口的合称,教程在下方。
2、状态栏
状态栏是用来显示应用的状态信息的组件。
self.statusBar().showMessage('Ready')
状态栏是由QMainWindow
创建的。statusBar()
方法,创建状态栏。第一次调用会创建一个状态栏,而再次调用会返回一个状态栏对象。showMessage()
方法在状态栏上显示一条信息。
#!/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_())
3、菜单栏
菜单栏是非常常用的。是一组命令的集合(Mac OS下状态栏的显示不一样,为得到最相似的外观,我们可以增加一行语句
menubar.setNativeMenuBar(False)
)。
QAction
是菜单栏、工具栏或者快捷键的动作的组合。上面三行中,前两行创建了一个图标、一个exit的标签和一个快捷键组合,都执行了一个动作;第三行,创建了一个状态栏,当鼠标悬停在菜单栏的时候,能显示当前状态。
exitAct = QAction(QIcon('./Resources/images/icon.ico'), '&Exit', self)
图标、文字exitAct.setShortcut('Ctrl+Q')
快捷键exitAct.setStatusTip('退出应用')
状态栏提示exitAct.triggered.connect(qApp.quit)
当执行这个指定的动作时,就触发了一个事件。这个事件跟QApplication的quit()
行为相关联,所以这个动作就能终止这个应用。
self.menuBar()
创建菜单栏。这里创建了一个菜单栏,并用addMenu()在上面添加了一个file菜单,用addAction()关联了点击退出应用的事件。fileMenu = menubar.addMenu('&File')
添加了一个file菜单fileMenu.addAction(exitAct)
关联了点击退出应用的事件exitAct
#!/usr/bin/python3
# -*- coding: utf-8 -*-
import sys
from PyQt5.QtWidgets import QMainWindow, QAction, qApp, QApplication, QMenu
from PyQt5.QtGui import QIcon
class Example(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle('菜单栏')
icon = QIcon(":/images/logo")
self.setWindowIcon(icon)
self.setGeometry(300, 300, 300, 200)
self.initUI()
self.show()
def initUI(self):
exitAct = QAction(QIcon('./Resources/images/icon.ico'), '&Exit', self)
exitAct.setShortcut('Ctrl+Q')
exitAct.setStatusTip('退出应用')
exitAct.triggered.connect(qApp.quit)
self.statusBar()
menubar = self.menuBar()
fileMenu = menubar.addMenu('&File')
newMenu = menubar.addMenu('新建')
fileMenu.addAction(exitAct)
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())
3.1 子菜单
子菜单是嵌套在菜单里面的二级或者三级等的菜单。
#!/usr/bin/python3
# -*- coding: utf-8 -*-
import sys
from PyQt5.QtWidgets import QMainWindow, QAction, qApp, QApplication, QMenu
from PyQt5.QtGui import QIcon
class Example(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle('子单栏')
icon = QIcon("./Resources/images/icon.ico")
self.setWindowIcon(icon)
self.setGeometry(300, 300, 300, 200)
self.initUI()
self.show()
def initUI(self):
exitAct = QAction(QIcon('./Resources/images/icon.ico'), '&Exit', self)
exitAct.setShortcut('Ctrl+Q')
exitAct.setStatusTip('退出应用')
exitAct.triggered.connect(qApp.quit)
self.statusBar()
menubar = self.menuBar()
fileMenu = menubar.addMenu('&File')
newMenu = QMenu('新建', self)
impMenu = QMenu('Import', self)
impAct = QAction('Import mail', self)
impMenu.addAction(impAct)
fileMenu.addMenu(newMenu)
fileMenu.addMenu(impMenu)
fileMenu.addAction(exitAct)
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())
3.2 勾选菜单
viewStatAct = QAction('View statusbar', self, checkable=True)
用checkable
选项创建一个能选中的菜单。viewStatAct.setStatusTip('View statusbar')
状态栏提示viewStatAct.setChecked(True)
选中菜单viewStatAct.triggered.connect(self.toggleMenu)
当执行这个指定的动作时,就触发了一个事件self.toggleMenu
。- 事件
self.toggleMenu
中self.statusbar.show()、self.statusbar.hide()
状态栏提示显示/隐藏
import sys
from PyQt5.QtWidgets import QApplication, QAction, QMainWindow
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_())
3.3 右键菜单
右键菜单也叫弹出框,在应用中鼠标右键出现,是在某些场合下显示的一组命令。例如,Opera浏览器里,网页上的右键菜单里会有刷新,返回或者查看页面源代码。如果在工具栏上右键,会得到一个不同的用来管理工具栏的菜单。
- 使用
contextMenuEvent()
方法实现这个菜单action = cmenu.exec_(self.mapToGlobal(event.pos()))
使用exec_()
方法显示菜单。从鼠标右键事件对象中获得当前坐标。mapToGlobal()
方法把当前组件的相对坐标转换为窗口(window)的绝对坐标。if action == quitAct:
如果右键菜单里触发了quitAct
事件,执行关闭菜单行为qApp.quit()
#!/usr/bin/python3
# -*- coding: utf-8 -*-
import sys
from PyQt5.QtGui import QIcon
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('右键菜单')
icon = QIcon('./Resources/images/icon.ico')
self.setWindowIcon(icon)
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_())
4、工具栏
菜单栏包含了所有的命令,工具栏就是常用的命令的集合。
self.toolbar = self.addToolBar('Exit')
创建工具栏self.toolbar.addAction(exitAct)
将动作对象添加到工具栏