百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Qt for Python—Qt Designer 概览

off999 2024-10-18 08:09 71 浏览 0 评论

前言

本系列第三篇文章(Qt for Python学习笔记—应用程序初探 )、第四篇文章(Qt for Python学习笔记—应用程序再探 )中均是使用纯代码方式来开发 PySide6 GUI 应用程序的。

本文是本系列第五篇文章,图文方式介绍可视化界面设计工具——Qt Designer



1. 简介

Qt 提供了一款名叫 Qt Designer 的工具,该工具提供了 Qt 基本的可绘制窗口部件(如 QLabelQPushButton 等)或布局(如:QVBoxLayoutQGridLayout 等),通过鼠标直接拖曳这些窗口部件,放置在窗体的相关位置,按所见即所得的方式,来进行窗体设计,并可以设计的窗体效果进行快速预览。

借助 Qt Designer 工具,能够高效、快速地以可视化方式完成窗体 UI 的设计,界面直观形象,所见所得。

文中会涉及到如下术语,简介如下:

  • Widget:部件(也称组件、控件),用于 GUI 的图形界面元素,如按钮、标签等。
  • Form:窗体,本文用于指 GUI 窗口的统称。


2 启动 Qt Designer

在本系列第二篇文章(Qt for Python学习笔记—搭建开发环境 )中有介绍到在安装完成 PySide6 模块后,会在安装路径(如: C:\Develop\Python\Lib\site-packages )下新增 PySide6 模块,其中就有一组可执行文件(如:designer.exeuic.exercc.exe 等),其中 designer.exe 就是 Qt Designer 工具的可执行文件。通常为了便于后续启动 Qt Designer,我们会将 designer.exe 创建为桌面快捷方式(可通过鼠标右键,点【发送到】–>【桌面快捷方式】完成)。

单击桌面上的 Qt Designer 快捷方式,然后启动 Qt Designer。在 Qt Designer 窗口出现后,通常会自动弹出一个【新建窗体】的对话框窗口,在该窗口中选择一个窗体模板(如:Main Window),然后点击【创建】按钮,即可进入 Qt Designer 设计窗口。



3. Qt Designer 简介

3.0 窗口界面概览

下图为 Qt Designer 6.0.0 的一个典型设计窗口界面:

整个设计窗口除了窗体标题栏和边框外,可以划分为8个区域:

  • 第1个区域:顶部的菜单栏
  • 第2个区域:顶部菜单栏下方的工具栏(也称菜单快捷选项)
  • 第3个区域:底部的状态栏
  • 第4个区域:左侧的窗口部件盒
  • 第5个区域:中间的窗体编辑器
  • 第6个区域:右侧上方的对象检查器
  • 第7个区域:右侧中部的属性编辑器
  • 第8个区域:右侧下方的区域,该区域实际上包含3个Tab区域(信号/槽 编辑器资源浏览器动作编辑器

3.1 菜单栏(Menu Bar)

菜单栏提供了 Qt Designer 设计窗口的大多数功能入口,共包括7组主菜单(如下图示)。


3.1.1【文件】主菜单项

该主菜单项下的子菜单项如下图示:


其中常用子菜单项介绍如下:

  • 点击【新建…】子菜单项(或按快捷键 Ctrl + N)后,弹出【新建窗体】对话框。
  • 点击【打开】子菜单项(或按快捷键 Ctrl + O)后,弹出【打开窗体】对话框,从相关路径中选择要打开的窗体文件(后缀名为 .ui
  • 点击【保存】子菜单项(或按快捷键 Ctrl + S)后,弹出【窗体另存为】对话框,选择保存路径,将当前窗体保存为指定文件名的窗体文件(后缀名为 .ui

注1:通常情况,保存的窗体文件名与窗体的 objectName 保持一致(这样通过文件名就可以直接知道窗体的名称)。

注2:窗体文件(.ui)实际上一个 xml 文件,它记录了窗体上各部件的属性和位置分布。


扩展:【新建窗体】对话框中提供有三种类型(5种模板)的窗体供选择:

1) Main Window类型的窗体模板:该模板是一个基于 QMainWindow 类的窗体,具有主窗口的特性,顶部通常显示标题栏和边框,窗口上有主菜单栏、工具栏、状态栏等。

2) Widget 类型的窗体模板:该模板是一个基于 QWidget 类的窗体。QWidget 类是所有界面组件的基类,如 QLabelQPushButton 等界面组件都是从 QWidget 类继承而来的。QWidget 类也是 QDialogQMainWindow 的父类,基于 QWidget 类创建的窗体可以作为独立的窗口运行,也可以嵌入到其他界面组件内显示。

3) Dialog 类型的窗体模板:该模板是一个基于 QDialog 类的窗体,具有一般对话框的特性,如可以模态显示、具有返回值等。可以设置不同的标题栏外观,主要用于通知或收集输入窗口,如颜色对话框、字体对话框等,具体以下有3种:,

——(1) 底部带有对话框按钮的对话框

——(2) 右侧带有对话框按钮的对话框

——(3) 不带对话框按钮的对话框


3.1.2【编辑】主菜单项

该主菜单项下的子菜单项如下图示:


其中前9个子菜单项意思很容易理解,就不作介绍了。

最后4个子菜单项表示4种 GUI 窗口部件编辑模式:

  • 编辑窗口部件】子菜单项:对应部件编辑模式,此模式下可以在 Qt Designer 中添加 GUI 窗口部件,以及修改它们的属性和外观。
  • 编辑信号/槽】子菜单项:对应信号和槽编辑模式,此模式下可以在 Qt Designer 中的窗口部件上关联 Qt 已经定义好的信号和槽。
  • 编辑伙伴】子菜单项:对应伙伴编辑模式,此模式下可以在 Qt Designer 中的窗口部件上建立某个部件和其他窗口部件的伙伴关系。
  • 编辑 Tab 顺序】子菜单项:对应 Tab 编辑模式,此模式下可以在 Qt Designer 中的窗口部件上设置 Tab 键在窗口部件上的焦点顺序。

3.1.3【窗体】主菜单项

该主菜单项下的子菜单项如下图示:


其中:

  • 前9个子菜单项,均为布局相关的,会在后续文章中详细介绍。
  • 点击【预览于】子菜单项,会显示3个下级子菜单项(【windowsvista 风格】、【Windows 风格】、【Fusion 风格】),在预览时分别对应三种风格的窗体。
  • 点击【预览…】子菜单项(或按快捷键 Ctrl + R)后,可以对所创建的窗体进行预览。
  • 点击【View C++ Code…】子菜单项后,可以查看该窗体对应的 C++ 代码。
  • 点击【View Python Code…】子菜单项后,可以查看该窗体对应的 Python 代码。
  • 点击【窗体设定…】子菜单项后,弹出【窗体设定】对话框窗口。

3.1.4【视图】主菜单项

该主菜单项下的子菜单项如下图示:


其中:

  • 勾选【窗口部件盒】子菜单项后,在主窗口的停靠区出现【窗口部件盒
  • 勾选【对象检查器】子菜单项后,在主窗口的停靠区出现【对象检查器
  • 勾选【属性编辑器】子菜单项后,在主窗口的停靠区出现【属性编辑器
  • 勾选【资源浏览器】子菜单项后,在主窗口的停靠区出现【资源浏览器
  • 勾选【动作编辑器】子菜单项后,在主窗口的停靠区出现【动作编辑器
  • 勾选【信号/槽 编辑器】子菜单项后,在主窗口的停靠区出现【信号/槽 编辑器
  • 工具栏】子菜单项,可以对启用哪些快捷按钮进行设置。

3.1.5【设置】主菜单项

该主菜单项下的子菜单项如下图示:


其中:

  • 点击【首选项…】子菜单项后,出现【首选项】对话框(如下图示),可根据需要进行相关设置。
  • 其他字体】子菜单项



3.1.6【窗口】主菜单项

该主菜单项下的子菜单项如下图示:


其中:

  • 点击【最小化】子菜单项后,将当前窗体设置为最小化。
  • 下面列示出 Qt Designer 中已经打开的窗体(当前正在编辑的窗体名前会有个圆点)

3.1.7【帮助】主菜单项

该主菜单项下的子菜单项如下图示:


各子菜单项功能一目了然,就不作进一步介绍了。



3.2 工具栏(Tool Bar)

在编辑窗体时经常会用到工具栏上的快捷按钮,实际上所有工具栏上的快捷按钮均可以通过菜单栏获得。

下图是缺省配置的工具栏:


共分为四组:

  • 第一组(3个):依次对应主菜单项【文件】下的【新建】、【打开】、【保存】子菜单项。
  • 第二组(2个):依次对应主菜单项【编辑】下的【放到后面】、【放到前面】子菜单项。
  • 第三组(4个):依次对应主菜单项【编辑】下的【编辑窗口部件】、【编辑信号/槽】、【编辑伙伴】、【编辑 Tab 顺序】子菜单项。
  • 第四组(8个):依次对应主菜单项【窗体】下的【水平布局】、【垂直布局】、【使用拆分器水平布局】、【使用拆分器垂直布局】、【网格布局】、【在窗体布局中布局】、【分拆布局】、【调整大小】子菜单项。

因工具栏上的按钮均对应菜单栏下的各子菜单项,其功能就请参见菜单栏部分了。



3.3 状态栏(Status Bar)

在状态栏中通常会显示一些跟当前操作相关的信息。



3.4 窗口部件盒(Widget Box)

窗口部件盒提供了用于设计窗体的一些标准的通用部件和布局。窗口部件盒中提供了8个分组类别,每个分组类别都包含具有相似用途或相关功能的部件。

通过单击窗口部件盒中的分组类别标签旁边的手柄,可以显示该分组类别中的所有可用对象(组件或布局)。当窗口处于【编辑部件模式】时,可以从窗口部件盒中选择适当的部件拖动到窗体编辑器中,然后将其拖放到所需的位置来将该组件添加设计到窗体。


3.4.1 布局分组类别(Layouts)


3.4.2 间隔分组类别(Spacers)


3.4.3 按钮分组类别(Buttons)


3.4.4 项目视图分组类别(Item Views)

Item Views 基于模型/视图(Model/View)结构,视图(View)与模型数据(Model Data)关联实现数据的显示和编辑。


3.4.5 项目部件分组类别(Item Widgets )

Item Widgets 直接将数据存储在每一个项里。一个项存储了文字、文字的格式、自定义数据等。


3.4.6 容器分组类别(Containers)


3.4.7 输入部件分组类别(Input Widgets)


3.4.8 显示部件分组类别(Display Widgets)



3.5 窗体编辑器

窗体编辑器中可以对窗体进行可视化设计,选择左侧窗口部件盒中的相应组件(或布局),通过鼠标拖曳至此区域,放置在相应位置。


上面示例图中分别从左侧窗口部件盒中的【Dispaly Widgets】分组类别中选择了2个 QLabel 部件,从【Input Widgets】分组类别中选择了2个 QLineEdit 部件,从【Buttons】分组类别中选择了2个 QPushButton 部件,通过鼠标拖曳至此区域(主窗体),并进行排列放置。

注1:顶部显示的“Main Window - untitled*” 表示该窗体尚未命名。

注2:此区域也可以通过快捷按钮(Ctrl + R)来对设计后的窗体的效果进行预览。

注3:更多信息会在后续文章中加以介绍。



3.6 对象检查器(Object Inspector)

对象检查器中用树形视图列示出了窗体上所有部件、以及各部件之间的布局和包含关系。

树形视图有两列,分别显示各部件的对象名称(objectName)和对应的类名称。

注:更多信息会在后续文章中加以介绍。



3.7 属性编辑器(Property Editor)

属性编辑器中列出了被选中的窗体或部件的各种属性和对应的值,可以在属性编辑器里修改这些属性的值。

属性编辑器的内容分为两列,其中左侧列是属性的名称,右侧列是该属性对应的值。

属性自上而下分为多个组,实际上代表了类的继承关系。


简单示例介绍:

——上部的 MainWindow : QMainWindow 表示这是一个 QMainWindow 窗体;

——objectName 属性:表示窗体/部件的对象名称,窗体中的每一个部件都需要一个唯一的对象名称,以便在代码中被引用。本例中 objectName 属性的值为“MainWindow”,表示窗体的对象名称为:MainWindow。该值可以进行修改。

——上图可以看出 QMainWindow 类的继承关系为: QObject 类 <– QWidget 类 <- QMainWindow 类。

——其他众多属性本文就不一一说明了,会在后续文章中陆续加以介绍。

注:更多信息会在后续文章中加以介绍。



3.8 信号与槽编辑器(Signal/Slot Editor)

信号与槽编辑器中列出了在 Qt Designer 中关联的信号和槽,通过双击列中的对象或信号/槽,可以进行对象和信号/槽的选择。

注:更多信息会在后续文章中加以介绍。



3.9 资源浏览器(Resource Browser)

资源浏览器中列出了程序使用的资源文件(*.qrc)以及相应的资源。

在该编辑器中可以创建或删除资源文件,也可以添加或取消资源。

注:更多信息会在后续文章中加以介绍。



3.10 动作编辑器(Action Eidtor)

动作编辑器中列出了为窗口部件设计的动作(QAction),并可以创建新动作和删除动作。


动作编辑器提供了一组快捷工具按钮:

  • 新建】按钮

点击该按钮,弹出一个【新建动作】对话框(如下图示),完成相关信息设置,点击【OK】按钮后即可完成创建一个新动作。

注:创建动作后,可以在任何适用的动作处使用它。


  • 删除】按钮

点击该按钮,即可删除被选中的动作。

  • 复制】、【粘贴】按钮

动作编辑器可以在菜单栏、工具栏和窗体之间复制和粘贴动作。

  • 配置动作编辑器】按钮

动作编辑器提供两种视图:图标视图 和 细节视图,点击该按钮,可进行这两种视图的切换。


要将动作添加到菜单栏或工具栏,只需在动作编辑器中在动作上按下鼠标左键,然后将其拖动到首选位置即可。


注:更多信息会在后续文章中加以介绍。



结束语

本系列介绍如何在 Python 中使用 Qt for Python 进行 GUI 应用程序开发。

本文是《Qt for Python 学习笔记》系列第五篇,对可视化设计工具 Qt Designer 进行了一个概览介绍,让读者对 Qt Designer 工具有个初步的认识。

接下来会介绍如何借助 Qt Designer 工具进行可视化界面设计并完成一个 PySide6 GUI 应用程序开发的过程,敬请期待!

希望本文能对您有所帮助!若文中存在疏忽不足或错误,还请不吝赐教!

相关推荐

怎么把win7电脑恢复出厂设置

1.首先我们打开电脑找到“计算机”点击打开。2.进入页面然后我们点击“Windows7(C:)”打开C盘。3.我们在C盘界面找到Windows7并点击打开。4.进入到Win7文件夹中找到并双击“Sys...

ctrl c 和 ctrl v 怎么按(一键复制粘贴)

左手小指按Ctrl键,食指按C键或者V键具体在按Ctrl+C的时候,无名指放在Z键上,中指放在X键上,食指按C键如果你也用这种方式的话,可能和我一样,第一次按的时候不习惯手指这样去分工的感觉,但是你...

u盘格式转换为fat32(U盘格式转换为FAT32)
  • u盘格式转换为fat32(U盘格式转换为FAT32)
  • u盘格式转换为fat32(U盘格式转换为FAT32)
  • u盘格式转换为fat32(U盘格式转换为FAT32)
  • u盘格式转换为fat32(U盘格式转换为FAT32)
玩游戏cpu温度多少正常(玩游戏cpu温度多少正常 贴吧)

在游戏过程中,CPU温度的正常范围通常在40°C至80°C之间。然而,具体的正常温度取决于CPU型号、散热系统和环境条件等因素。一般来说,如果CPU温度超过80°C,就可能存在过热的风险,需要采取措施...

idm下载器(如何卸载idm下载器)

截至2023年9月3日,IDM(InternetDownloadManager)是一款非常受欢迎的下载工具,但它并没有被禁用。IDM可以帮助用户更快速、稳定地下载文件,提供了多线程下载、断点续传等...

电脑按f8后无法开机,三个键搞定

电脑开机按F8没有反应可能有多种原因,以下是一些可能的解决方法:尝试重启电脑:有时候,系统会出现临时问题,重启可能有助于解决。检查键盘连接和状态:确保键盘连接正常,没有故障。如果在其他地方测试过键盘是...

重装win7系统不能正常启动(win7重装系统后进不了系统)

1、点击Win10正式版桌面找到“此电脑”图标,右击并从弹出的右键菜单中选择“属性”项。2、此时将打开“控制”窗口,在左侧找到“高级系统设置”按钮点击进入详细设置界面。3、待打开“系统属性”窗口后,切...

win7professional是什么版本

Windows7Professional是专业版。Windows7包含6个版本,分别为Windows7Starter(初级版)、Windows7HomeBasic(家庭普通版)、Win...

tplink路由器怎么管理(tplink路由器管理app叫什么)

1、进入到路由器的管理界面,点击设置向导然后点下一步。2、选择工作模式,选择AP:接入点模式,点击下一步1.AP是WirelessAccessPoint的简称,中文名称:无线接入点;AP模式也...

怎样把wifi网速调到最快(怎样把wifi网速调到最快速度)

解决的方式很多,试试以下方法: 一、路由器摆放位置不正确  为了让自家的房间显得干净、整洁,很多人会选择将路由器放在不显眼的地方,比如门后、墙角、电脑桌下面,这样确实不影响美观,但是网络信号容易被...

360系统重装大师装win7(360重装大师怎么装win7)
  • 360系统重装大师装win7(360重装大师怎么装win7)
  • 360系统重装大师装win7(360重装大师怎么装win7)
  • 360系统重装大师装win7(360重装大师怎么装win7)
  • 360系统重装大师装win7(360重装大师怎么装win7)
十大口碑最好的台式电脑(目前最好的台式)

一:联想电脑联想公司是全世界500强公司,也是全世界最大的pc电脑生产商之一。目前在点信息科技产业内全方位发展,是一家具有创造力的科技大公司,在全世界也就具有极高的品牌价值。二:戴尔电脑戴尔也是PC电...

显卡天梯图3050ti(显卡天梯图快科技)

RTX3050Ti的最新跑分达到了71803。根据Geekbench的信息,RTX3050Ti搭载20组CU,也就是2560个CUDA核心,GPU频率为1.49GH...

office完整版下载(office2019完整版下载)

word是office软件中的一部份,完全的安装了office软件就等于安装了word。安装具体步骤如下:1、搜索,下载Office安装包。2、下载完成后,将Office安装包解压。选中Offic...

qq邮箱网页登陆(qq邮箱网页登陆提示安全风险要验证码)

qq邮箱的登录方法:1登录QQ后,正常情况下头像旁边有一个邮箱图标,点击直接登录QQ邮箱2如果没有在主面板上显示的话,可以点击界面管理器添加3在界面管理的右侧,找到QQ邮箱并设置为选状态这样就可直接从...

取消回复欢迎 发表评论: