PyQt5 有四種布局:水平(QHBoxLayout)、豎直(QVBoxLayout)、網格(QGridLayout)、表單(QFormLayout)
在窗體中單一的布局應該不難,但若是比較復雜的布局,一般涉及到布局的嵌套,這就頭疼了。
本文的四個知識點:
1. 布局不能直接嵌套(如果我錯了,歡迎指正!)
2. 內層的布局必須先“附着”在一個空 QWidget 上
3. 然后把這個“承載”着內層布局的空部件添加至外層布局
4. 最后,別忘記把全局布局“附着”到窗體本尊
0. 先看效果圖
下面對布局進行分析
1. 全局布局分析
全局布局使用了一個水平布局
wlayout = QtWidgets.QHBoxLayout()
2. 局部布局分析
四個局部布局分別使用了水平布局、豎直布局、網格布局、表單布局
hlayout = QtWidgets.QHBoxLayout() vlayout = QtWidgets.QVBoxLayout() glayout = QtWidgets.QGridLayout() flayout = QtWidgets.QFormLayout()
到這里,其實開始時我產生了一個很自然,但是錯誤的想法:把四個局部布局直接添加到全局布局內:
wlayout.addWidget(hlayout) wlayout.addWidget(vlayout) wlayout.addWidget(glayout) wlayout.addWidget(flayout)
報錯信息提示:addWidget() 參數必須為 QWidget 類型!
這給了我啟示:
先准備四個 QWidget: hwg, vwg, gwg, fwg
hwg = QtWidgets.QWidget() vwg = QtWidgets.QWidget() gwg = QtWidgets.QWidget() fwg = QtWidgets.QWidget()
然后用這四個 QWidget 分別去設置前面四個局部布局
hwg.setLayout(hlayout) vwg.setLayout(vlayout) gwg.setLayout(glayout) fwg.setLayout(flayout)
再把這四個 QWidget 部件添加至全局變量
wlayout.addWidget(hwg) wlayout.addWidget(vwg) wlayout.addWidget(gwg) wlayout.addWidget(fwg)
最后一步,把全局布局應用到窗體本尊
self.setLayout(wlayout)
3. 完整代碼
from PyQt5 import QtWidgets class MyWindow(QtWidgets.QWidget): def __init__(self): super().__init__() self.setWindowTitle('PyQt5布局示例') # 開始: wlayout = QtWidgets.QHBoxLayout() # 全局布局(1個):水平 hlayout = QtWidgets.QHBoxLayout() # 局部布局(4個):水平、豎直、網格、表單 vlayout = QtWidgets.QVBoxLayout() glayout = QtWidgets.QGridLayout() flayout = QtWidgets.QFormLayout() hlayout.addWidget(QtWidgets.QPushButton(str(1))) # 局部布局添加部件(例如:按鈕) hlayout.addWidget(QtWidgets.QPushButton(str(2))) vlayout.addWidget(QtWidgets.QPushButton(str(3))) vlayout.addWidget(QtWidgets.QPushButton(str(4))) glayout.addWidget(QtWidgets.QPushButton(str(5)),0,0) glayout.addWidget(QtWidgets.QPushButton(str(6)),0,1) glayout.addWidget(QtWidgets.QPushButton(str(7)),1,0) glayout.addWidget(QtWidgets.QPushButton(str(8)),1,1) flayout.addWidget(QtWidgets.QPushButton(str(9))) flayout.addWidget(QtWidgets.QPushButton(str(10))) flayout.addWidget(QtWidgets.QPushButton(str(11))) flayout.addWidget(QtWidgets.QPushButton(str(12))) hwg = QtWidgets.QWidget() # 准備四個部件 vwg = QtWidgets.QWidget() gwg = QtWidgets.QWidget() fwg = QtWidgets.QWidget() hwg.setLayout(hlayout) # 四個部件設置局部布局 vwg.setLayout(vlayout) gwg.setLayout(glayout) fwg.setLayout(flayout) wlayout.addWidget(hwg) # 四個部件加至全局布局 wlayout.addWidget(vwg) wlayout.addWidget(gwg) wlayout.addWidget(fwg) self.setLayout(wlayout) # 窗體本尊設置全局布局 if __name__=="__main__": import sys app = QtWidgets.QApplication(sys.argv) win = MyWindow() win.show() sys.exit(app.exec_())