qtdesigner页面布局

本文介绍使用qtdesigner工具通过PyQt5实现GUI界面设计的过程,包括四大基本布局的应用及控件随窗口缩放的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


前言

最近学习pyqt5来编写GUI界面,发现qtdesigner这个工具是在是太好用了,不仅能很方便的设计页面,还能很快捷的将设计出来的界面转换成代码。下面做一下学习笔记。


一、四大布局

打开qtdesigner工具,界面大致如下,左边是存放各种控件的控件库;中间是设计GUI界面的窗口;右边是设置各种控件参数的窗口。
在这里,首先做一个简易的登录界面。
在这里插入图片描述
然后快捷键ctrl+R就能够预览实际运行的效果
在这里插入图片描述
但这时候你会发现里面的控件不能随窗口的拉大而改变位置,这时候就要用到布局了。先介绍一下四大布局

水平布局(HorizontalLayout)

顾名思义,就是把控件水平排列
在这里插入图片描述

垂直布局(VerticalLayout)

顾名思义,就是把控件垂直排列
在这里插入图片描述

栅格布局(GridLayout)

大致排列好控件位置,设置布局之后会把控件更规范的排列,大小也会自动适配,缩放布局的时候里面的控件也会跟着缩放。
在这里插入图片描述

表单布局(FromLayout)

跟栅格布局差不多。
在这里插入图片描述
设置布局方法:
选中要进行布局的控件,然后点击布局即可
在这里插入图片描述

延伸

一、使得控件随窗口缩放而缩放的方法

需要给整个窗口加布局,点击窗口类,在选择布局
在这里插入图片描述

二、布局之上再设置布局

布局不仅可以给控件设置,也可以给布局设置。下面页面的布局是:先给每一行的两个控件设置为水平布局,然后给上水平布局设置垂直布局。这样也能达到表格布局的效果。
在这里插入图片描述

二、布局参数

点击布局之后会看到下面参数
在这里插入图片描述
layoutName:布局名
layoutLeftMargin:左间距,跟css里面的margin一样是外边距的意思
layoutRighttMargin:右间距
layoutTopMargin:顶部间距
layoutBottomMargin:底板间距
layoutHorizontalSpacing:控件之间的间距
分别对应下面位置的间距
在这里插入图片描述

layoutRowStretch:每一行的高度比
layoutColumnStretch:每一列的宽度比
如layoutColunmStretch设置为1,4,那么就相当于把布局的宽度分为5份,第一列占1份。第二列占4份
在这里插入图片描述
layoutRowStretch的设置也是同样的道理。

因为当前布局行方向和列方向都是只分成了两个部分,所以只有两个参数(a,b),如果是分成3部分的话会有三个参数(a,b,c),分成4部分就会有四个参数,以此类推。

三、ui文件转换成py文件

布局完之后,保存文件会发现是ui文件而不是py文件,它们之间要怎么转换呢?
这个不难,只要输入下面命令就可以了

pyuic5 -o demo.py demo.ui

demo.py
在这里插入图片描述
但生成的代码只是构建页面的代码,不能直接运行,在这里新建一个py文件引用界面代码并运行
demo_main.py

import sys
from PyQt5.QtWidgets import QMainWindow, QApplication

from demo import Ui_Form


class DemoMain(QMainWindow, Ui_Form):

    def __init__(self):
        # 初始化父类
        super().__init__()
        # 调用Ui_Form的setupUi()方法构建页面
        self.setupUi(self)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    # 实例化页面并展示
    demo_win = DemoMain()
    demo_win.show()

    sys.exit(app.exec_())

这样就可以运行了。

不过这里可能会有人有疑问:为什么不直接在生成的py文件里面写执行显示页面的代码呢?
因为一个界面可能会经过很多次修改,每次修改页面后生成的代码会覆盖之前的代码,那么其中的一些逻辑函数和执行函数又要根据新代码来重新编写。相信我,你并不希望这样。
ui对应的代码和逻辑代码分开的好处是,无论你如何修改ui,逻辑代码那边因为只是引入了ui代码,所以无需重新编写,只需要添加新的逻辑代码就好


总结

qtdesigner是个很强大的工具,可以帮助我们快速方便开发GUI界面。有什么问题欢迎在评论区留言。

<think>好的,我现在需要回答用户关于在Qt Designer中设置布局控件大小和位置的问题。首先,用户提到了引用中的内容,特别是引用[2]中提到的horizontalLayoutWidget和horizontalLayout_2的关系,这说明用户可能对如何在Qt Designer中通过布局控件管理子控件的位置和尺寸有疑问。 首先,我需要回忆一下Qt Designer的基本操作。布局控件(如QHBoxLayout、QVBoxLayout)用于自动管理其子控件的排列和尺寸调整。在Qt Designer中,用户通常会将控件放入布局中,这样当窗口大小改变时,布局会自动调整控件的位置和大小。但有时候用户可能希望手动调整布局控件本身的大小或位置,这时候需要注意一些方法。 根据引用[2],horizontalLayoutWidget是一个承载布局的控件,而horizontalLayout_2是该布局对象。这说明在Qt Designer中,布局需要一个容器控件来放置,布局本身并不是一个可视化的控件,而是依附于这个容器控件存在的。因此,设置布局的位置和尺寸实际上是设置容器控件的位置和尺寸。 接下来,我需要考虑用户可能的具体操作步骤。比如,在Qt Designer中,用户可能拖拽一个Widget控件到窗口中,然后对该Widget应用布局。这时候,这个Widget就成为布局的容器,调整它的位置和大小可以通过属性编辑器设置geometry属性,包括x、y坐标以及宽度和高度。同时,布局的属性可能需要调整边距和间距来控制内部控件的位置和间隔。 另外,用户可能需要了解如何通过代码来动态调整布局控件的大小和位置。例如,在引用[1]中提到的gLayout.addWidget方法,以及引用[2]中的horizontalLayoutWidget的初始化和布局设置。这时候可能需要解释如何在代码中设置父控件的位置和尺寸,进而影响布局的位置和尺寸。 还需要注意,Qt布局系统有自动调整的机制,手动设置可能会与布局的自动调整产生冲突。因此,建议用户尽量使用布局的属性(如边距、拉伸因子)来控制,而不是直接设置固定尺寸,除非有特殊需求。 最后,要确保回答结构清晰,分步骤说明,并涵盖用户可能遇到的问题,比如布局与容器控件的关系、如何在设计时和代码中设置大小位置,以及注意事项等。同时,生成的相关问题要围绕用户可能进一步想了解的内容,例如动态调整、布局嵌套、边距设置等。</think>在Qt Designer中设置布局控件的大小和位置需要结合容器控件和布局属性进行操作,具体步骤如下: ### 1. 布局与容器控件的关系 - 布局本身不直接设置位置和尺寸,而是依附于父级容器控件(如`QWidget`)。如引用[2]所述,`horizontalLayout_2`布局对象需要依托`horizontalLayoutWidget`控件存在,两者共同构成布局体系。 - 操作流程: 1. 在Qt Designer中拖入一个`QWidget`控件作为容器 2. 右键容器控件选择布局类型(水平/垂直/网格等) 3. 向布局中添加子控件 ### 2. 设置容器控件属性 在属性编辑器中调整容器控件的几何属性: ```python # 对应C++/Python代码示例 container_widget.setGeometry(QtCore.QRect(x, y, width, height)) ``` ![Qt Designer属性编辑器示意图](https://example.com/qt-property-editor.png)[^3] ### 3. 布局参数配置 通过布局属性控制内部元素: - **边距调整**:设置`layoutMargin`(整体外边距) - **间距控制**:设置`spacing`(内部元素间隔) - **拉伸因子**:使用`QSpacerItem`或设置`stretch`比例 ### 4. 混合布局策略 对于复杂界面: 1. 主窗口使用顶级布局 2. 嵌套子布局容器 3. 通过`sizePolicy`属性设置控件的扩展特性 ```python widget.setSizePolicy( QtWidgets.QSizePolicy.Policy.Expanding, QtWidgets.QSizePolicy.Policy.Fixed ) ``` ### 5. 注意事项 - 避免直接设置固定尺寸,优先使用布局的自动调整特性 - 容器控件的`minimumSize`/`maximumSize`会约束布局效果 - 使用布局后,子控件的几何属性将由布局自动管理[^2]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值