python GUI庫圖形界面開發(fā)之PyQt5布局控件QVBoxLayout詳細(xì)使用方法與實例
PyQt5布局控件QVBoxLayout簡介
采用QVBoxLayout類,按照從上到下的順序添加控件
本節(jié)內(nèi)容較少,演示兩個實例,便于明白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)
# 垂直布局按照從上到下的順序進(jìn)行添加按鈕部件。
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()函數(shù)的使用
在布局中要用到addStretch()函數(shù),設(shè)置stretch伸縮量后,按比例分配剩余的空間
| 函數(shù) | 描述 |
|---|---|
| QBoxLayout.addStretch(int stretch=0) | addStretch()函數(shù)在布局管理器中添加一個可伸縮的控件(QSpaceItem),0為最小值,并且將stretch作為伸縮量添加到布局末尾,stretch參數(shù)表示均分的比例,默認(rèn)為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()
# 設(shè)置伸縮量為1
hbox.addStretch(1)
hbox.addWidget( btn1 )
# 設(shè)置伸縮量為1
hbox.addStretch(1)
hbox.addWidget( btn2 )
# 設(shè)置伸縮量為1
hbox.addStretch(1)
hbox.addWidget( btn3 )
# 設(shè)置伸縮量為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()函數(shù)用于在按鈕間隨著伸縮量,伸縮量的比例為1:1:1:1,意思是將按鈕以外的空白地方等分為4分,并按照所設(shè)置的順序放入按鈕的布局管理器中,這樣在每一個控件之間都添加了伸縮量,所有控件之間的間距都會相同
思考:如果我們只添加一個addStretch()在第一個控件之前或者最后一個控件之后會怎樣呢,那么來試試看
探究:addStretch()函數(shù)放在第一個空間之前
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)
# 水平布局按照從左到右的順序進(jìn)行添加按鈕部件。
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_())
運行效果圖

結(jié)果顯示,這樣所有的控件都會向右顯示,
那么類似的放在最后一個控件之后,都會向左顯示,
本文主要介紹了PyQt5布局控件QVBoxLayout詳細(xì)使用方法與實例,更多關(guān)于PyQt5布局控件的使用知識請查看下面的相關(guān)鏈接
- python GUI庫圖形界面開發(fā)之PyQt5窗口布局控件QStackedWidget詳細(xì)使用方法
- python GUI庫圖形界面開發(fā)之PyQt5動態(tài)(可拖動控件大小)布局控件QSplitter詳細(xì)使用方法與實例
- python GUI庫圖形界面開發(fā)之PyQt5布局控件QGridLayout詳細(xì)使用方法與實例
- python GUI庫圖形界面開發(fā)之PyQt5表單布局控件QFormLayout詳細(xì)使用方法與實例
- Pyqt5自適應(yīng)布局實例
- Python深度學(xué)習(xí)實戰(zhàn)PyQt5布局管理項目示例詳解
- PyQt5的相對布局管理的實現(xiàn)
- Pyqt5中5種布局的實現(xiàn)示例
相關(guān)文章
python實現(xiàn)關(guān)鍵詞提取的示例講解
下面小編就為大家分享一篇python實現(xiàn)關(guān)鍵詞提取的示例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-04-04

