PyQt5布局控件QVBoxLayout簡介
使用QVBoxLayout類,按照從上到下的順序添加控件
本節内容較少,示範兩個執行個體,便于明白QVBoxLayout(垂直布局)的使用
QVBoxLayout的正常使用執行個體
import sys
from PyQt5.QtWidgets import QApplication ,QWidget ,QVBoxLayout , QPushButton
class Winform(QWidget):
def __init__(self,parent=None):
super(Winform,self).__init__(parent)
self.setWindowTitle("垂直布局管理例子")
self.resize(330, 150)
# 垂直布局按照從上到下的順序進行添加按鈕部件。
vlayout = QVBoxLayout()
vlayout.addWidget( QPushButton(str(1)))
vlayout.addWidget( QPushButton(str(2)))
vlayout.addWidget( QPushButton(str(3)))
vlayout.addWidget( QPushButton(str(4)))
vlayout.addWidget( QPushButton(str(5)))
self.setLayout(vlayout)
if __name__ == "__main__":
app = QApplication(sys.argv)
form = Winform()
form.show()
sys.exit(app.exec_())
運作效果示意圖

addStretch()函數的使用
在布局中要用到addStretch()函數,設定stretch伸縮量後,按比例配置設定剩餘的空間
函數
描述
QBoxLayout.addStretch(int stretch=0)
addStretch()函數在布局管理器中添加一個可伸縮的控件(QSpaceItem),0為最小值,并且将stretch作為伸縮量添加到布局末尾,stretch參數表示均分的比例,預設為0
addStretch在QVBoxLayout的使用執行個體
一個布局管理器中,有三個按鈕,要求界面不随着父控件的伸縮而改變
from PyQt5.QtWidgets import QApplication ,QWidget, QVBoxLayout , QHBoxLayout ,QPushButton
import sys
class WindowDemo(QWidget):
def __init__(self ):
super().__init__()
btn1 = QPushButton(self)
btn2 = QPushButton(self)
btn3 = QPushButton(self)
btn1.setText('button 1')
btn2.setText('button 2')
btn3.setText('button 3')
hbox = QHBoxLayout()
# 設定伸縮量為1
hbox.addStretch(1)
hbox.addWidget( btn1 )
# 設定伸縮量為1
hbox.addStretch(1)
hbox.addWidget( btn2 )
# 設定伸縮量為1
hbox.addStretch(1)
hbox.addWidget( btn3 )
# 設定伸縮量為1
hbox.addStretch(1 )
self.setLayout(hbox)
self.setWindowTitle("addStretch 例子")
if __name__ == "__main__":
app = QApplication(sys.argv)
win = WindowDemo()
win.show()
sys.exit(app.exec_())
運作程式,初始效果圖如下
拉伸後效果圖如下
從上面的代碼可以看出,四個addStretch()函數用于在按鈕間随着伸縮量,伸縮量的比例為1:1:1:1,意思是将按鈕以外的空白地方等分為4分,并按照所設定的順序放入按鈕的布局管理器中,這樣在每一個控件之間都添加了伸縮量,所有控件之間的間距都會相同
思考:如果我們隻添加一個addStretch()在第一個控件之前或者最後一個控件之後會怎樣呢,那麼來試試看
探究:addStretch()函數放在第一個空間之前
import sys
from PyQt5.QtWidgets import QApplication ,QWidget ,QHBoxLayout , QPushButton
class Winform(QWidget):
def __init__(self,parent=None):
super(Winform,self).__init__(parent)
self.setWindowTitle("水準布局管理例子")
self.resize(800, 50)
# 水準布局按照從左到右的順序進行添加按鈕部件。
hlayout = QHBoxLayout()
# 添加伸縮
hlayout.addStretch(0)
hlayout.addWidget( QPushButton(str(1)) )
hlayout.addWidget( QPushButton(str(2)) )
hlayout.addWidget( QPushButton(str(3)))
hlayout.addWidget( QPushButton(str(4)) )
hlayout.addWidget( QPushButton(str(5)) )
# 添加伸縮
#hlayout.addStretch(1)
self.setLayout(hlayout)
if __name__ == "__main__":
app = QApplication(sys.argv)
form = Winform()
form.show()
sys.exit(app.exec_())
運作效果圖
結果顯示,這樣所有的控件都會向右顯示,
那麼類似的放在最後一個控件之後,都會向左顯示,
本文主要簡介了PyQt5布局控件QVBoxLayout具體使用方法與執行個體,更多關于PyQt5布局控件的使用知識請檢視下面的相關連結