【PYQT5】使用Spacer实现页面缩放自适应,元素总是铺满屏幕

概要

使用Qt Designer设计页面时,如果不加以处理,点击最大化窗口后,Main Window能够最大化显示,但是页面中的元素保持固定的大小,并不会跟随当前页面的大小自适应缩放,影响页面美观。

整体架构流程

使用PYQT进行页面设计时有两种方式,一种是直接写.py代码,一种是使用Qt Designer直接拖放元素完成ui设计,后再使用pyuic工具完成.ui文件到.py文件的转换。直接写代码的方式对qt元素组件的熟悉程度要求高于Qt Designer的方式,Qt Designer更加的形象,门槛较低。
基于pyqt5 UI设计需要的环境和工具:

  • python
    在这里插入图片描述

  • pyqt5库 --pip install 安装即可

  • Qt Designer --ui设计使用,pip install 安装pyqt5-tools库,需要添加External Tools
    安装后的Qt Designer在这里插入图片描述

    Qt Designer添加External Tools,注意红框中的文件路径
    在这里插入图片描述

  • pyuic --将.ui文件转换为python工程可调用的.py文件,pyqt5-tools中已包含,不需要单独安装,需要添加External Tools
    在这里插入图片描述
    Arguments:

F i l e N a m e FileName FileName -o F i l e N a m e W i t h o u t E x t e n s i o n FileNameWithoutExtension FileNameWithoutExtension.py -x

  • pyrcc5 --将.ui文件中包含的外部资源文件(图片,logo等),转换为python工程可调用的_rc.py文件,pyqt5-tools中已包含,不需要单独安装,需要添加External Tools
    在这里插入图片描述
    Arguments:

F i l e N a m e FileName FileName -o F i l e N a m e W i t h o u t E x t e n s i o n FileNameWithoutExtension FileNameWithoutExtension_rc.py

以上环境和工具的具体安装步骤可参考网络其他文档,已十分详尽

Qt Designer UI 设计步骤

  • 按需求拖放需要的组件,进行布局,完成设计,生成.ui文件,如下图mianui.ui文件
    在这里插入图片描述
  • 使用pyuic工具将.ui文件转换为同名.py文件,如上图mianui.py,如果ui文件中 包含外部引用的资源文件,需要使用pyrcc工具,生成_rc.py文件,该文件在mianui.py文件中引用
    在这里插入图片描述
  • mianui.py文件在python工程文件中引用,一般采用页面元素操作和逻辑分层的原则,具体方法可以参考其他资料
    在这里插入图片描述

技术细节

页面缩放自适应是想要实现当用户不想按照默认的窗口大小使用时,点击最大化或者拉动缩小放大工具,工具窗口里的所有元素,应该跟随窗口的变化,全部元素等比例或者部分元素等比例放大缩小,使页面整体协调。效果如下图:
默认页面大小:
在这里插入图片描述
最大化页面:
在这里插入图片描述
主要设置:

  • 两步布局,使用spacer与元素首先进行一次横向布局,再整体进行一次栅格布局,布局完成后整个 布局已经铺满了页面,会跟随页面的大小变化
    分别横向布局后的页面:
    这样的页面不会自适应缩放
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
  • 组件属性配置
    使用说明按钮属性,该元素大小不随页面放大缩小在这里插入图片描述
    使用说明按钮右侧spacer属性,设置为expanding后,该元素大小随页面放大缩小在这里插入图片描述
    开始按钮设置了水平延展,垂直方向固定,两侧的spacer设置与上个相同在这里插入图片描述

可能出现的问题

在最后保存文件的时候,可能会报错:
在这里插入图片描述
错误原因为有未放到布局中的spacer,实际上按照我们两步布局的方式操作,不会有未放到布局中的spacer,因此可以直接点击保存后关闭。保险起见,也可以另存为文件 ,另存为成功之后再关闭。

  • 21
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在PyQt5实现UI自适应屏幕大小且可缩放,可以通过调整布局使用相对大小实现。 首先,我们可以使用Qt的布局管理器来自动调整部件的大小和位置。常用的布局管理器有QHBoxLayout和QVBoxLayout,可以根据需要嵌套使用。通过将部件添加到布局管理器中,然后将布局管理器设置给窗口,窗口将自动根据窗口大小调整部件的大小和位置。 例如,可以使用QVBoxLayout来垂直排列部件,然后使用QHBoxLayout来水平排列部件。通过在布局管理器中添加部件,并将布局管理器设置给窗口,窗口将根据窗口大小调整部件的大小和位置。 其次,可以使用QSizePolicy来设置部件的大小策略。QSizePolicy有很多选项,例如设置部件在水平和垂直方向上的大小是否可伸缩、是否能够自动填充空间等。通过设置适当的大小策略,可以使部件根据窗口大小自动调整大小。 最后,可以实现窗口的缩放功能。可以通过重新实现窗口的resizeEvent()方法来捕捉窗口大小变化的事件,并在事件发生时根据窗口的大小来调整部件的大小。 综上所述,通过适当地使用布局管理器、大小策略和事件处理,可以实现PyQt5中的UI自适应屏幕大小且可缩放的效果。 ### 回答2: 要实现PyQt5的UI自适应屏幕大小且可缩放,可以使用QGridLayout和QHBoxLayout等布局管理器,并且根据窗口大小的变化进行动态调整。 首先,你可以创建一个主窗口,并设置它的布局管理器为QGridLayout。然后,在布局内添加各种控件,比如按钮、文本框等。然后使用setSizePolicy方法来设置控件的尺寸策略,使其在窗口大小变化时能够自动跟随调整。 接下来,可以重写主窗口类的resizeEvent方法,在窗口大小发生变化时进行布局的调整。在该方法中,可以使用QDesktopWidget类来获取屏幕的宽度和高度,并根据当前屏幕大小动态调整控件的尺寸和位置。 另外,还可以为主窗口添加一个滚动条,以便在窗口过小的情况下,用户可以通过滚动条来查看完整的内容。在布局管理器中添加一个QScrollArea,并将其作为子窗口添加到主窗口中。 此外,你还可以通过添加一个缩放功能来实现UI的缩放。可以使用QGraphicsView来展示界面,并使用QGraphicsView的scale方法来进行缩放。在主窗口中添加一个QGraphicsView,并在resizeEvent中根据窗口大小的变化来调整缩放比例。 通过上述方法,你可以实现PyQt5的UI自适应屏幕大小且可缩放的功能。当窗口大小发生变化时,控件会根据窗口的大小进行自动调整,并且当窗口过小时,可以通过滚动条进行查看。 ### 回答3: 使用PyQt5实现UI自适应屏幕大小并可缩放的方法如下: 1. 设置UI控件的相对大小:在设计UI界面时,使用相对大小来设置控件的尺寸,而不是使用固定的像素值。可以通过设置控件的大小策略(size policy)来实现,如设置为最小尺寸(QSizePolicy.Minimum),即可使控件根据可用空间自动调整大小。 2. 监听窗口大小变化事件:使用`resizeEvent`方法,可以在窗口大小发生变化时触发相应的事件。通过在该方法中重新计算并设置控件的大小,从而实现UI自适应。 ```python def resizeEvent(self, event): # 获取当前窗口大小 window_size = event.size() # 根据窗口大小重新计算并设置控件的大小 # ... # 调用父类的resizeEvent方法 super().resizeEvent(event) ``` 3. 支持缩放功能:可以使用QGraphicsView或QScrollArea等容器控件作为UI界面的根控件,从而实现缩放功能。在该容器控件上加入需要缩放的控件,并使用`setViewportUpdateMode`方法设置为自动更新视口模式,即可允许用户通过手势或鼠标滚轮来进行缩放操作。 ```python # 使用QGraphicsView作为根控件 self.view = QGraphicsView() # 设置自动更新视口模式 self.view.setViewportUpdateMode(QGraphicsView.FullViewportUpdate) # 加入需要缩放的控件 # ... # 设置根控件 self.setLayout(QVBoxLayout()) self.layout().addWidget(self.view) ``` 通过上述方法,可以实现PyQt5的UI自适应屏幕大小且可缩放的效果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值