PyQt5每天必学之布局管理

作者:我的世界你曾经来过 时间:2022-11-19 08:14:00 

在GUI编程中有一个不容忽视的部分,那就是布局管理。布局管理掌控着我们的控件在应用程序窗口如何摆放。布局管理可以通过两种方式来完成。我们可以使用绝对定位或布局类两种方法控制程序窗口中的控件位置。

绝对定位

每个控件按程序员指定的位置放置。当您使用绝对定位,我们要了解以下限制:

  • 如果我们调整窗口的大小控件的大小和位置保持不变

  • 在不同平台上应用程序看起来可能会不同

  • 更改字体可能会破坏应用程序的布局

  • 如果决定改变布局,我们必须每个控件彻底的加以修改,这是繁琐和耗时的

下面的例子就是控件的绝对坐标定位方式。


#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

这个例子显示了在窗口中使用绝对定位的三个标签。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QLabel

class Example(QWidget):

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

self.initUI()

def initUI(self):

lbl1 = QLabel('我的世界你曾经来过', self)
lbl1.move(15, 10)

lbl2 = QLabel('CSND博客', self)
lbl2.move(35, 40)

lbl3 = QLabel('程序员', self)
lbl3.move(55, 70)

self.setGeometry(300, 300, 250, 150)
self.setWindowTitle('绝对定位')
self.show()

if __name__ == '__main__':

app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())

在我们的例子中使用的都是标签(Label)。我们通过提供x和y坐标值定位它们。坐标系的原点是控件的左上角。 x值增长是由左到右。 y值增长是从上到下。


lbl1 = QLabel('我的世界你曾经来过', self)
lbl1.move(15, 10)

标签控件被放置在 x=15 和 y=10。

程序执行后

PyQt5每天必学之布局管理

Box layout盒子布局

布局管理使用布局类的方式更加灵活、实用。它是将一个控件放在窗口中的首选方式。QHBoxLayout和QVBoxLayout分别是水平和垂直对齐控件的基本布局类。

试想一下,我们希望把两个按钮在程序的右下角。要创建这样一个布局,我们可以使用一横一纵两个框。要创造必要的空余空间,我们将增加一个拉伸因子(stretch factor)。


#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

在这个例子中,我们在窗口的右下角放置两个按钮。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import (QApplication, QWidget,
QPushButton, QVBoxLayout, QHBoxLayout)

class Example(QWidget):

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

self.initUI()

def initUI(self):

okButton = QPushButton('确定')
cancelButton = QPushButton('取消')

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, 350, 150)
self.setWindowTitle('Box布局')
self.show()

if __name__ == '__main__':

app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())

该示例将两个按钮放在窗口的右下角。当我们调整应用程序窗口的大小时,他们是固定在右下角的。我们同时使用HBoxLayout 和QVBoxLayout布局。


okButton = QPushButton('确定')
cancelButton = QPushButton('取消')

这里我们创建了两个按钮。


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

我们创建了一个水平box布局,增加拉伸因子(addStretch),添加(addWidget)两个按钮。在添加两个按钮之前增加了一个拉伸因子,这会将两个按钮推到窗口右侧。


vbox = QVBoxLayout()
vbox.addStretch(1)
vbox.addLayout(hbox)

要得到我们想要的布局,还需将横向布局放入垂直的布局中。在垂直框上的拉伸因子会将水平框包括里面的控件推至窗口的底部。


self.setLayout(vbox)

最后,我们设置窗口的主布局。

程序执行后

PyQt5每天必学之布局管理

QGridLayout网格布局

最经常使用的布局类是网格布局。这种布局将该空间分成行和列。要创建一个网格布局,我们使用QGridLayout 的类。


#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

在这个例子中,我们使用网格布局创建一个计算器的框架。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import (QApplication, QWidget,
QPushButton, QGridLayout)

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('计算器')
self.show()

if __name__ == '__main__':

app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())

在我们的例子中,我们将创建的按钮控件放在网格中。


grid = QGridLayout()
self.setLayout(grid)

实例化 QGridLayout 并设置应用程序窗口的布局。


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)]

x我们创建了网格位置的列表。


for position, name in zip(positions, names):

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

创建按钮并添加(addWidget)到布局中。

程序执行后

PyQt5每天必学之布局管理

扩展网格布局

窗口中的控件可以跨越网格中的多个列或行。在下面的例子中,我们说明这一点。


#!/usr/bin/python3
# -*- coding: utf-8 -*-

"""
PyQt5 教程

在这个例子中,我们使用GridLayout的跨行创建了一个更复杂的窗口布局。

作者:我的世界你曾经来过
博客:http://blog.csdn.net/weiaitaowang
最后编辑:2016年7月31日
"""

import sys
from PyQt5.QtWidgets import (QApplication, QWidget, QLabel,
QTextEdit, QLineEdit, QGridLayout)

class Example(QWidget):

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

self.initUI()

def initUI(self):

title = QLabel('标题')
author = QLabel('作者')
review = QLabel('评论')

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('评论')
self.show()

if __name__ == '__main__':

app = QApplication(sys.argv)
ex = Example()
sys.exit(app.exec_())

我们创建的程序中包含三个标签,两个单行文本输入框和一个文本编辑控件,使用QGridLayout布局。


grid =QGridLayout()
grid.setSpacing(10)

实例化网格布局和并设置设置间距。


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

添加一个控件到网格布局中,我们可以为这个控件使用行跨度或列跨度。在我们的例子中,我们要求reviewEdit控件跨度5行。

程序执行后

PyQt5每天必学之布局管理

在PyQt5教程的这一部分专门介绍了布局管理。后面将会介绍PyQt5的事件相关内容。

来源:https://blog.csdn.net/weiaitaowang/article/details/52078704

标签:PyQt5,布局管理
0
投稿

猜你喜欢

  • numpy.sum()的使用详解

    2023-01-04 15:19:24
  • 详解Opentelemetry Collector采集器

    2024-04-27 15:31:02
  • 使用递归删除树形结构的所有子节点(java和mysql实现)

    2024-01-12 23:22:16
  • Golang实现带优先级的select

    2024-04-26 17:36:41
  • Python深度学习之FastText实现文本分类详解

    2022-09-03 10:35:28
  • JavaScript高级程序设计 阅读笔记(十五) 浏览器中的JavaScript

    2024-04-10 10:57:11
  • pytorch模型的保存和加载、checkpoint操作

    2022-07-14 00:36:20
  • Ubuntu20下MySQL 8.0.28 安装卸载方法图文教程

    2024-01-13 23:43:11
  • Python计算点到直线距离、直线间交点夹角

    2022-09-05 10:27:04
  • FLASH 全屏播放

    2008-07-19 11:36:00
  • python3.6.4安装opencv3.4.2的实现

    2021-08-07 22:48:56
  • Asp包含文件include动态包含方法(含变量)

    2010-01-14 20:12:00
  • 30行Python代码实现高分辨率图像导航的方法

    2021-03-23 04:11:37
  • pytest-sugar 执行过程中显示进度条的脚本分享

    2023-01-26 13:20:40
  • 如何用CSS实现图像替换链接文本显示并保证链接可点击

    2011-03-03 12:37:00
  • vue缓存的keepalive页面刷新数据的方法

    2023-07-02 17:01:00
  • server application error--IIS故障

    2009-06-11 12:50:00
  • 用书的概念理解小网站结构

    2007-10-31 18:08:00
  • Python中最常用的操作列表的几种方法归纳

    2021-01-11 22:06:05
  • vue源码之批量异步更新策略的深入解析

    2024-05-09 15:21:30
  • asp之家 网络编程 m.aspxhome.com