Python Qt GUI设计:菜单栏、工具栏和状态栏的使用方法(拓展篇—2)

简介: Python Qt GUI设计:菜单栏、工具栏和状态栏的使用方法(拓展篇—2)

目录

1、菜单栏


1.1、Qt Creator创建菜单栏


1.2、 菜单栏类创建菜单栏


2、工具栏


2.1、Qt Creator创建工具栏


2.2、 工具栏类创建工具栏


3、状态栏


在使用Qt Creator创建UI文件时,MainWindow主窗口,主要包含:菜单栏、工具栏、状态栏等。


image.png


1、菜单栏

1.1、Qt Creator创建菜单栏

双击菜单栏上的“在这里输入”,输入文字,最后按回车键即可生成菜单。


image.png


例如,建立:文件、编辑两个一级菜单栏目,如下所示:


image.png


可以在一级目录下建二级目录,在文件栏目下建立打开栏目,如下所示:


image.png


在Qt Designer的属性编辑器中可以对动作进行编辑,设置快捷键、图标等信息,其详细信息如下图所示:


image.png

image.png


最后生成的UI文件可以再进行信号和槽的功能代码编写。


1.2、 菜单栏类创建菜单栏

在QMainWindow对象的标题栏下方,水平的QMenuBar被保留显示QMenu对象。QMenu类提供了一个可以添加到菜单栏的小控件,也用于创建上下文菜单和弹出菜单。每个QMenu对象都可以包含一个或多个QAction对象或级联的QMenu对象。


PyQt API提供了createPopupMenu()函数创建一个弹出菜单;menuBar()函数用于返回主窗口的QMenuBar对象; addMenu()函数可以将菜单添加到菜单栏中;通过addAction()函数可以在菜单中进行添加操作等。在设计菜单系统时使用的一些重要方法如下表所示:


image.png


通个示例了解QMenuBar、QMenu和QAction菜单栏类,示例效果如下所示:


image.png


示例中,顶层窗口必须是QMainWindow对象,才可以引用QMenuBar对象。通过addMenu()方法将“File"菜单添加到菜单栏中。菜单中的操作按钮可以是字符串或QAction对象。菜单发射triggered信号,将该信号连接到槽函数proecesstrigger(),该函数接收信号的QAction对象。单击任何QAction按钮时,QMenu对象都会发射triggered信号。


实现代码如下所示:


import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class MenuDemo(QMainWindow):
  def __init__(self, parent=None):
  super(MenuDemo, self).__init__(parent)
  layout = QHBoxLayout()
  bar = self.menuBar()
  file = bar.addMenu("File")
  file.addAction("New")
  save = QAction("Save",self)
  save.setShortcut("Ctrl+S")
  file.addAction(save)
  edit = file.addMenu("Edit")
  edit.addAction("copy")
  edit.addAction("paste")
  quit = QAction("Quit",self)
  file.addAction(quit)
  file.triggered[QAction].connect(self.processtrigger) 
  self.setLayout(layout)
  self.setWindowTitle("menu 例子")
  self.resize(350,300)
  def processtrigger(self,q):
  print( q.text()+" is triggered" )
if __name__ == '__main__':
  app = QApplication(sys.argv)
  demo = MenuDemo()
  demo.show()
  sys.exit(app.exec_())

2、工具栏

QToolBar控件是由文本按钮、图标或其他小控件按钮组成的可移动面板,通常位于菜单栏下方。


2.1、Qt Creator创建工具栏

使用Qt Designer默认生成的主窗口中不显示工具栏,可以通过单击鼠标右键来添加工具栏,如下图所示:


image.png


此时的工具栏是空的,没有组件,如下所示:


image.png


可以在Qt Designer的属性编辑器中新建addWinAction动作,并拖入添加到工具栏中,其详细信息如下图所示:



image.png

image.png





同菜单栏一样,最后生成的UI文件可以再进行信号和槽的功能代码编写。


2.2、 工具栏类创建工具栏

QToolBar类中的常用方法如下表所示:


image.png


每当单击工具栏中的按钮时,都将发射actionTriggered信号。另外,这个信号将关联的QAction对象的引用发送到连接的槽函数上。


通个示例了解QToolBar工具栏类,示例效果如下所示:


image.png


示例中,首先调用addToolBar()方法在工具栏区域添加文件工具栏。然后,添加具有文本标题的工具按钮,工具栏通常包含图形按钮,具有图标和名称的QAction对象将被添加到工具栏中。最后,将actionTriggered信号连接到槽函数toolbtnpressed()。


实现代码如下所示:


import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class ToolBarDemo( QMainWindow ):
  def __init__(self, parent=None):
  super(ToolBarDemo, self).__init__(parent)
  self.setWindowTitle("toolbar 例子")  
  self.resize(300, 200)
  layout = QVBoxLayout()
  tb = self.addToolBar("File")
  new = QAction(QIcon("./new.png"),"new",self)
  tb.addAction(new)
  open = QAction(QIcon("./open.png"),"open",self)
  tb.addAction(open)
  save = QAction(QIcon("./save.png"),"save",self)
  tb.addAction(save)
  tb.actionTriggered[QAction].connect(self.toolbtnpressed)
  self.setLayout(layout)
  def toolbtnpressed(self,a):
  print("pressed tool button is",a.text() )
if __name__ == '__main__':
  app = QApplication(sys.argv)
  demo = ToolBarDemo()
  demo.show()
  sys.exit(app.exec_())

3、状态栏

MainWindow对象在底部保留有一个水平条,作为状态栏(QStatusBar),用于显示永久的或临时的状态信息。


QStatusBar类中的常用方法如下表所示:


image.png


通个示例了解QStatusBar状态栏类,示例效果如下所示:


image.png


在这个例子中,顶层窗口MainWindow 有一个菜单栏和一个QTextEdit 对象,作为中心控件。当单击MenuBar的菜单时,将triggered信号与槽函数processTrigger()进行绑定。当单击"show"菜单选项时,会在状态栏显示提示信息,并在5秒后消失。


实现代码如下所示:


import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *
class StatusDemo(QMainWindow):
  def __init__(self, parent=None):
  super(StatusDemo, self).__init__(parent)
  bar = self.menuBar()
  file = bar.addMenu("File")
  file.addAction("show")
  file.triggered[QAction].connect(self.processTrigger)
  self.setCentralWidget(QTextEdit())
  self.statusBar= QStatusBar() 
  self.setWindowTitle("QStatusBar 例子")
  self.setStatusBar(self.statusBar)
  def processTrigger(self,q):
  if (q.text()=="show"):
    self.statusBar.showMessage(q.text()+" 菜单选项被点击了",5000)
if __name__ == '__main__':
  app = QApplication(sys.argv)
  demo = StatusDemo()
  demo.show()
  sys.exit(app.exec_())
相关文章
|
API C++ 开发者
PySide vs PyQt:Python GUI开发史诗级对决,谁才是王者?
PySide 和 PyQt 是 Python GUI 开发领域的两大利器,各有特色。PySide 采用 LGPL 协议,更灵活;PyQt 默认 GPL,商业使用需授权。两者背后团队实力雄厚,PySide 得到 Qt 官方支持,PyQt 由 Riverbank Computing 打造。API 设计上,PySide 简洁直观,贴近原生 Qt;PyQt 增加 Pythonic 接口,操作更高效。性能方面,两者表现优异,适合不同需求的项目开发。选择时可根据项目特点与开源要求决定。
1350 20
|
测试技术 开发者 Python
Python(GUI)之活动积分记录表
本文介绍了一套使用Python的Tkinter库构建的学生活动积分记录系统。该系统允许教师选择班级和学生,输入加分分数及原因,并将数据保存至文件,旨在简化学生积分管理流程,提升教学效率。
557 130
|
数据可视化 开发者 Python
Python GUI开发:Tkinter与PyQt的实战应用与对比分析
【10月更文挑战第26天】本文介绍了Python中两种常用的GUI工具包——Tkinter和PyQt。Tkinter内置于Python标准库,适合初学者快速上手,提供基本的GUI组件和方法。PyQt基于Qt库,功能强大且灵活,适用于创建复杂的GUI应用程序。通过实战示例和对比分析,帮助开发者选择合适的工具包以满足项目需求。
1265 7
|
前端开发 JavaScript 测试技术
Python中的GUI测试
【8月更文挑战第15天】本文探讨了Python中图形用户界面(GUI)测试的关键工具——Selenium与PyQt。Selenium专为Web应用测试设计,能模拟用户行为如点击和输入文本。PyQt则基于Qt框架,用于构建丰富的桌面应用程序及编写自动化测试脚本。
|
API UED
【Qt 学习笔记】Qt窗口 | 状态栏 | QStatusBar的使用及说明
【Qt 学习笔记】Qt窗口 | 状态栏 | QStatusBar的使用及说明
3057 4
|
Linux Android开发 开发者
【Python】GUI:Kivy库环境安装与示例
这篇文章介绍了 Kivy 库的安装与使用示例。Kivy 是一个开源的 Python 库,支持多平台开发,适用于多点触控应用。文章详细说明了 Kivy 的主要特点、环境安装方法,并提供了两个示例:一个简单的 Hello World 应用和一个 BMI 计算器界面。
809 0
|
机器学习/深度学习 算法框架/工具 Python
基于深度学习的手写数字识别项目GUI(Deep Learning Project – Handwritten Digit Recognition using Python)
基于深度学习的手写数字识别项目GUI(Deep Learning Project – Handwritten Digit Recognition using Python)
839 0
|
数据安全/隐私保护 C++ 计算机视觉
Qt(C++)开发一款图片防盗用水印制作小工具
文本水印是一种常用的防盗用手段,可以将文本信息嵌入到图片、视频等文件中,用于识别和证明文件的版权归属。在数字化和网络化的时代,大量的原创作品容易被不法分子盗用或侵犯版权,因此加入文本水印成为了保护原创作品和维护知识产权的必要手段。 通常情况下,文本水印可以包含版权声明、制作者姓名、日期、网址等信息,以帮助识别文件的来源和版权归属。同时,为了增强防盗用效果,文本水印通常会采用字体、颜色、角度等多种组合方式,使得水印难以被删除或篡改,有效地降低了盗用意愿和风险。 开发人员可以使用图像处理技术和编程语言实现文本水印的功能,例如使用Qt的QPainter类进行文本绘制操作,将文本信息嵌入到图片中,
660 1
Qt(C++)开发一款图片防盗用水印制作小工具
|
监控 C++ 容器
【qt】MDI多文档界面开发
【qt】MDI多文档界面开发
907 0

推荐镜像

更多