菜单和工具栏简介
菜单是一组位于菜单栏的命令,工具栏是应用的一些常用工具按钮, 状态栏显示一些状态信息,通常在应用的底部
主窗口是下面这些窗口的合称
QMainWindow : 提供了主窗口的功能,使用它能创建一些简单的状态栏、 工具栏和菜单栏
一、状态栏
状态栏是用来显示应用的状态信息的组件,状态栏是QMainWindow创建的
代码实现:
import sys
from PyQt5.QtWidgets import QMainWindow, QApplication
"""
statusBar():创建状态栏,第一次 调用创建一个状态栏,返回一个状态栏对象
showMessage():在状 态栏上显示一条信息
"""
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_())
程序预览:
二、菜单栏
菜单栏是非常常用的,是一组命令的集合(Mac OS下状态栏的显示不 一样,为了得到最相似的外观,我们增加了一句menubar.setNativeMenuBar(False)
我们创建了只有一个命令的菜单栏,这个命令就是终止应用。同时也创 建了一个状态栏。而且还能使用快捷键 Ctrl+Q 退出应用
代码实现:
import sys
from PyQt5.QtWidgets import QMainWindow, QAction, qApp, QApplication
from PyQt5.QtGui import QIcon
"""
QAction :是菜单栏、工具栏或者快捷键的动作的组合
"""
class Example(QMainWindow):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
# 创建了一个图标、一个exit的标签
exitAct = QAction(QIcon('./default.png'), '&Exit', self)
# 创建快捷键
exitAct.setShortcut('Ctrl+Q')
# 创建了一个状态栏
exitAct.setStatusTip('Exit application')
# 跟 QApplication的quit() 行为相关联
exitAct.triggered.connect(qApp.quit)
self.statusBar()
# 创建菜单栏
menubar = self.menuBar()
# 添加了一个 file菜单
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_())
程序预览:
三、子菜单
子菜单是嵌套在菜单里面的二级或者三级等的菜单
这个例子里,有两个子菜单,一个在file菜单下面,一个在file的 import下面
代码实现:
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_())
程序预览:
四、勾选菜单
创建了一个行为菜单。这个行为/动作能切换状态栏显示或者隐藏
代码实现:
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_())
程序预览:
五、右键菜单
右键菜单也叫弹出框(!?),是在某些场合下显示的一组命令。例 如,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')
# 把当前组件的相对坐标转换为窗口(window)的绝对坐标
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_())
程序预览:
六、工具栏
菜单栏包含了所有的命令,工具栏就是常用的命令的集合
例子中,我们创建了一个工具栏。这个工具栏只有一个退出应用 的动作
代码实现:
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('default.png'), 'Exit', self)
exitAct.setShortcut('Ctrl+Q')
# 这些行为被触发的时候,会调用 QtGui.QMainWindow 的quit方法退出应用
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_())
程序预览:
七、主窗口
主窗口就是上面三种栏目的总称,现在我们把上面的三种栏在一个应用里展示出来
代码实现:
"""
主窗口是下面这些窗口的合称
QMainWindow : 提供了主窗口的功能,使用它能创建一些简单的状态栏、 工具栏和菜单栏
"""
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()
# 把它放在 QMainWindow 的中间区域
self.setCentralWidget(textEdit)
exitAct = QAction(QIcon('default.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_())
代码创建了一个很经典的菜单框架,有右键菜单,工具栏和状态栏
程序预览: