布局管理==PYQT5

发布时间:2023-02-18 12:00

框布局Boxlayout

  • 我们使用QHBoxLayout和QVBoxLayout,来分别创建横向布局和纵向布局。
import sys
from PyQt5.QtWidgets import (QWidget, QPushButton,
                             QHBoxLayout, QVBoxLayout, QApplication)

class Example(QWidget):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):
        okButton = QPushButton(\"OK\")
        cancelButton = QPushButton(\"Cancel\")

        hbox = QHBoxLayout()
        hbox.addStretch(1)
        hbox.addWidget(okButton)
        hbox.addWidget(cancelButton)

        vbox = QVBoxLayout()
        vbox.addStretch(1)#伸展因子
        vbox.addLayout(hbox)

        self.setLayout(vbox)

        self.setGeometry(300, 300, 300, 150)
        self.setWindowTitle(\'Buttons\')
        self.show()

if __name__ == \'__main__\':
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

表格布局

  • 将空间划分为行和列。我们使用QGridLayout类创建一个网格布局。
import sys
from PyQt5.QtWidgets import (QWidget, QGridLayout,
                             QPushButton, QApplication)


class Example(QWidget):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):

        grid = QGridLayout()
        self.setLayout(grid)#我们创建一个网格的按钮。

        names = [\'Cls\', \'Bck\', \'\', \'Close\',#这些按钮标签
                 \'7\', \'8\', \'9\', \'/\',
                 \'4\', \'5\', \'6\', \'*\',
                 \'1\', \'2\', \'3\', \'-\',
                 \'0\', \'.\', \'=\', \'+\']

        positions = [(i, j) for i in range(5) for j in range(4)]

        for position, name in zip(positions, names):#我们创建一个网格中的位置的列表

            if name == \'\':
                continue
            button = QPushButton(name)
            grid.addWidget(button, *position)

        self.move(300, 150)
        self.setWindowTitle(\'Calculator\')
        self.show()
        
#控件可以在网格中跨越多个行列
import sys
from PyQt5.QtWidgets import (QWidget, QLabel, QLineEdit,
                             QTextEdit, QGridLayout, QApplication)

class Example(QWidget):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):
        title = QLabel(\'Title\')#标签文本
        author = QLabel(\'Author\')
        review = QLabel(\'Review\')

        titleEdit = QLineEdit()#文本编辑处
        authorEdit = QLineEdit()
        reviewEdit = QTextEdit()

        grid = QGridLayout()#表格布局
        grid.setSpacing(10)

        grid.addWidget(title, 1, 0)
        grid.addWidget(titleEdit, 1, 1)#创建一个网格布局和设置组件之间的间距。

        grid.addWidget(author, 2, 0)
        grid.addWidget(authorEdit, 2, 1)

        grid.addWidget(review, 3, 0)
        grid.addWidget(reviewEdit, 3, 1, 5, 1)

        self.setLayout(grid)

        self.setGeometry(300, 300, 350, 300)
        self.setWindowTitle(\'Review\')
        self.show()


if __name__ == \'__main__\':
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

绝对定位

  • 程序指定每个控件的位置和大小(以像素为单位)
  • 绝对定位有以下限制:
    - 如果我们调整窗口,控件的大小和位置不会改变
    - 在各种平台上应用程序看起来会不一样
    - 如果改变字体,我们的应用程序的布局就会改变
    - 如果我们决定改变我们的布局,我们必须完全重做我们的布局
import sys
from PyQt5.QtWidgets import QWidget, QLabel, QApplication
class Example(QWidget):

    def __init__(self):
        super().__init__()

        self.initUI()

    def initUI(self):
        lbl1 = QLabel(\'Zetcode\', self)
        lbl1.move(15, 10)#我们使用move()方法来控制控件的位置

        lbl2 = QLabel(\'tutorials\', self)
        lbl2.move(35, 40)

        lbl3 = QLabel(\'for programmers\', self)
        lbl3.move(55, 70)

        self.setGeometry(300, 300, 250, 150)
        self.setWindowTitle(\'Absolute\')
        self.show()


if __name__ == \'__main__\':
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

ItVuer - 免责声明 - 关于我们 - 联系我们

本网站信息来源于互联网,如有侵权请联系:561261067@qq.com

桂ICP备16001015号