当前位置:   article > 正文

python pyqt5 窗体自适应_Pyqt5自适应布局实例

python窗口自适应

pyqt5中要做到自适应布局,必须应用Layout类

下面列出类似于 html 中 float 功能的布局方法:

实现原理:PyQt5中的布局中,stretch 属性类似于一个可自适应的空白布局。会尽可能将周围的组件布局向外挤压

from PyQt5.QtWidgets import QVBoxLayout, QHBoxLayout

# 垂直居中

def vcenter_layout(*widgets):

vbox = QVBoxLayout()

vbox.addStretch()

for widget in widgets:

vbox.addWidget(widget)

vbox.addStretch()

return vbox

# 水平居中

def hcenter_layout(*widgets):

hbox = QHBoxLayout()

hbox.addStretch()

for widget in widgets:

hbox.addWidget(widget)

hbox.addStretch()

return hbox

# 垂直水平居中

def center_layout(widget):

hbox = QHBoxLayout()

hbox.addStretch()

hbox.addWidget(widget)

hbox.addStretch()

vbox = QVBoxLayout()

vbox.addStretch()

vbox.addLayout(hbox)

vbox.addStretch()

return vbox

# 居左

def left_layout(*widgets):

hbox = QHBoxLayout()

for widget in widgets:

hbox.addWidget(widget)

hbox.addStretch()

return hbox

# 居右

def right_layout(*widgets):

hbox = QHBoxLayout()

hbox.addStretch()

for widget in widgets:

hbox.addWidget(widget)

return hbox

# 向上靠齐

def top_layout(*widgets):

vbox = QVBoxLayout()

for widget in widgets:

vbox.addWidget(widget)

vbox.addStretch()

return vbox

# 向下靠齐

def bottom_layout(*widgets):

vbox = QVBoxLayout()

vbox.addStretch()

for widget in widgets:

vbox.addWidget(widget)

return vbox

# 正常垂直分布

def v_layout(*widgets):

vbox = QVBoxLayout()

for widget in widgets:

vbox.addWidget(widget)

return vbox

# 正常垂直分布

def h_layout(*widgets):

vbox = QHBoxLayout()

for widget in widgets:

vbox.addWidget(widget)

return vbox

基本上,大的布局通过上面的方法即可实现,细节可能还需要调整 margin 或者 spacing

以上这篇Pyqt5自适应布局实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/喵喵爱编程/article/detail/985383
推荐阅读
相关标签
  

闽ICP备14008679号