详解Qt中的布局管理器

Qt中的布局管理是用于组织用户界面中控件(如按钮、文本框、标签等)位置和尺寸调整的一种机制。说白了就是创建了一种规则,随着窗口变化其中的控件大小位置跟着变化。Qt提供了多种布局管理器,每种都有其特定用途和特点。以下是对Qt布局管理的详细说明,以及对应的示例代码:

布局管理器分类与示例

基础布局管理器

  • QHBoxLayout:水平布局,将控件按从左到右的顺序排列。
    示例代码:
QHBoxLayout *horizontalLayout = new QHBoxLayout();
QPushButton *button1 = new QPushButton("Button 1");
QPushButton *button2 = new QPushButton("Button 2");horizontalLayout->addWidget(button1);
horizontalLayout->addWidget(button2);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(horizontalLayout);
  • QVBoxLayout:垂直布局,将控件按从上到下的顺序排列。
    示例代码:
QVBoxLayout *verticalLayout = new QVBoxLayout();
QLabel *label = new QLabel("A Label");
QPushButton *button = new QPushButton("A Button");verticalLayout->addWidget(label);
verticalLayout->addWidget(button);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(verticalLayout);

高级布局管理器

  • QGridLayout:网格布局,将控件放置在二维网格中,可以根据行列位置和跨度来精确控制控件的位置。
    示例代码:
QGridLayout *gridLayout = new QGridLayout();
QLabel *label1 = new QLabel("Label 1");
QLabel *label2 = new QLabel("Label 2");
QPushButton *button = new QPushButton("Button");gridLayout->addWidget(label1, 0, 0);
gridLayout->addWidget(label2, 0, 1, 1, 2); // 跨两列
gridLayout->addWidget(button, 1, 0, 1, 3); // 跨三列QWidget *containerWidget = new QWidget();
containerWidget->setLayout(gridLayout);
  • QFormLayout:表单布局,特别适合创建具有标签-输入字段对齐的表单界面。它可以自动对齐相邻的控件,并支持行间的垂直间隔控制。
    示例代码:
QFormLayout *formLayout = new QFormLayout();
QLabel *nameLabel = new QLabel("Name:");
QLineEdit *nameEdit = new QLineEdit();
QLabel *ageLabel = new QLabel("Age:");
QSpinBox *ageSpinBox = new QSpinBox();formLayout->addRow(nameLabel, nameEdit);
formLayout->addRow(ageLabel, ageSpinBox);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(formLayout);
  • QStackedLayout:堆叠布局,允许在多个子布局或控件之间切换显示,类似于页面切换,只有一个子项在任何时候是可见的。
    示例代码:
QStackedLayout *stackedLayout = new QStackedLayout();
QWidget *page1 = new QWidget();
QWidget *page2 = new QWidget();stackedLayout->addWidget(page1);
stackedLayout->addWidget(page2);QPushButton *button = new QPushButton("Switch Page");
connect(button, &QPushButton::clicked, [stackedLayout](){stackedLayout->setCurrentIndex((stackedLayout->currentIndex() + 1) % stackedLayout->count());
});QVBoxLayout *mainLayout = new QVBoxLayout();
mainLayout->addWidget(button);
mainLayout->addLayout(stackedLayout);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(mainLayout);

动态布局

  • QScrollArea:虽然不是严格意义上的布局管理器,但QScrollArea提供了一个可以容纳任何布局或控件的滚动区域,当内容超出其边界时,会自动显示滚动条。
    示例代码:
QScrollArea *scrollArea = new QScrollArea();
QWidget *contentWidget = new QWidget();
QVBoxLayout *contentLayout = new QVBoxLayout(contentWidget);for (int i = 0; i < 20; ++i) {QLabel *label = new QLabel(QString("Label %1").arg(i));contentLayout->addWidget(label);
}scrollArea->setWidgetResizable(true);
scrollArea->setWidget(contentWidget);QVBoxLayout *mainLayout = new QVBoxLayout();
mainLayout->addWidget(scrollArea);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(mainLayout);
  • QSplitter:分割器,可以将界面划分为多个可调整大小的部分,每个部分可以包含自己的布局或控件。用户可以通过拖动分割线来改变各部分的相对大小。
    示例代码:
QSplitter *splitter = new QSplitter(Qt::Horizontal);
QWidget *leftWidget = new QWidget();
QWidget *rightWidget = new QWidget();QVBoxLayout *leftLayout = new QVBoxLayout(leftWidget);
leftLayout->addWidget(new QLabel("Left Content"));QVBoxLayout *rightLayout = new QVBoxLayout(rightWidget);
rightLayout->addWidget(new QLabel("Right Content"));splitter->addWidget(leftWidget);
splitter->addWidget(rightWidget);QVBoxLayout *mainLayout = new QVBoxLayout();
mainLayout->addWidget(splitter);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(mainLayout);

布局管理器属性与功能

除了上述的基本使用方法,布局管理器还提供了丰富的属性和功能以实现更精细的布局控制:

  • 对齐与间距: 可以设置布局内部控件的对齐方式(如居中、左对齐、顶部对齐等)以及控件之间的水平和垂直间距。
    示例代码(设置水平和垂直间距):
QVBoxLayout *layout = new QVBoxLayout();
layout->setSpacing(10); // 设置垂直间距为10像素
layout->setContentsMargins(5, 5, 5, 5); // 设置四周边距为5像素
  • 伸展因子(Stretch Factors)
    通过设置布局项的伸展因子,可以控制当布局有多余空间时,各控件如何分配额外空间。高伸展因子的控件将获得更大比例的空间。
    示例代码(设置伸展因子):
QHBoxLayout *layout = new QHBoxLayout();
QPushButton *button1 = new QPushButton("Button 1");
QPushButton *button2 = new QPushButton("Button 2");layout->addWidget(button1, 1); // 设置伸展因子为1
layout->addWidget(button2, 2); // 设置伸展因子为2,button2将占据更多水平空间QWidget *containerWidget = new QWidget();
containerWidget->setLayout(layout);
  • 大小约束: 可以设置控件的最大和最小尺寸限制,以确保布局在调整时不会违反这些限制。
    示例代码(设置最大宽度):
QLabel *label = new QLabel("A Label");
label->setMaximumWidth(200); // 设置最大宽度为200像素QVBoxLayout *layout = new QVBoxLayout();
layout->addWidget(label);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(layout);
  • 嵌套布局: 一个布局可以作为另一个布局的子布局,通过嵌套布局可以创建复杂的界面布局。
    示例代码(嵌套布局):
QVBoxLayout *mainLayout = new QVBoxLayout();
QHBoxLayout *topRow = new QHBoxLayout();
QVBoxLayout *bottomRow = new QVBoxLayout();QPushButton *button1 = new QPushButton("Button 1");
QPushButton *button2 = new QPushButton("Button 2");
QLabel *label = new QLabel("A Label");topRow->addWidget(button1);
topRow->addWidget(button2);
bottomRow->addWidget(label);mainLayout->addLayout(topRow);
mainLayout->addLayout(bottomRow);QWidget *containerWidget = new QWidget();
containerWidget->setLayout(mainLayout);

布局管理器使用技巧

  • 避免绝对定位: 都使用布局管理器了,别在手动设置控件的位置和大小,以提高界面的适应性和可维护性。
  • 混合使用布局: 根据界面需求,合理组合使用不同类型的布局,如在一个主垂直布局中嵌套多个水平布局,或者使用网格布局来精确控制复杂表格的布局。
  • 测试不同分辨率与窗口大小: 在多种屏幕分辨率和窗口尺寸下测试布局,确保其在各种情况下都能良好呈现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/796139.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用open3d分离背景和物体点云(二)

一、代码 Python import cv2 import open3d as o3d import matplotlib.pyplot as plt import numpy as npdef thPlaneSeg(pointcloud):pcd_np = np.asarray(pointcloud.points)# 设置深度阈值 (假设Z轴是深度轴)depth_threshold = 0.196 # 1.0米# 应用深度阈值,移除远于阈值…

自定义实现shell/bash

文章目录 函数和进程之间的相似性shell打印提示符&#xff0c;以及获取用户输入分割用户的输入判断是否是内建命令执行相关的命令 全部代码 正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的 人工智能学习网站&#xff0c; 通俗易懂&#xff0c;风趣幽默&#…

vue项目打包

Vue项目打包的步骤如下&#xff1a; 确保环境配置正确&#xff1a;首先&#xff0c;确保你的开发环境已经安装了Node.js和npm&#xff08;Node.js的包管理器&#xff09;。Vue项目通常使用npm或yarn作为包管理器来安装依赖。 安装项目依赖&#xff1a;在项目根目录下&#xff…

Day30 线程安全之窗口售票问题(含代码)

Day30 线程安全之窗口售票问题&#xff08;含代码&#xff09; 一、需求&#xff1a; 铁道部发布了一个售票任务&#xff0c;要求销售1000张票&#xff0c;要求有3个窗口来进行销售&#xff0c; 请编写多线程程序来模拟这个效果&#xff08; 注意&#xff1a;使用线程类的方式…

【Qt 学习笔记】详解Qt中的信号和槽

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 详解Qt中的信号与槽 文章编号&#xff1a;Qt 学习笔记 / 12 文章目录…

红黑树的平衡之道:深入解析右旋操作的原理与实践

红黑树的平衡之道&#xff1a;深入解析右旋操作的原理与实践 一、 红黑树旋转的背景二、右旋&#xff08;RIGHT-ROTATE&#xff09;的原理三、右旋&#xff08;RIGHT-ROTATE&#xff09;的算法步骤四、右旋&#xff08;RIGHT-ROTATE&#xff09;的伪代码五、右旋&#xff08;RI…

C语言-角谷步数

题目描述 你听说过角谷猜想吗&#xff1f; 任意的正整数&#xff0c;比如 5&#xff0c;我们从它开始&#xff0c;如下规则计算&#xff1a; 如果是偶数&#xff0c;则除以2&#xff1b;如果是奇数&#xff0c;则乘以 3 再加 1。 如此循环&#xff0c;最终必会得到 1&#xff…

ctf_show笔记篇(web入门---jwt)

目录 jwt简介 web345&#xff1a; web346&#xff1a; web347&#xff1a; web348: web349&#xff1a; web350&#xff1a; jwt简介 JSON Web Token&#xff08;JWT&#xff09;通常由三部分组成 Header&#xff08;头部&#xff09;&#xff1a;包含了两部分信息&…

蓝桥杯备考3

P8196 [传智杯 #4 决赛] 三元组 题目描述 给定一个长度为 n 的数列 a&#xff0c;对于一个有序整数三元组 (i,j,k)&#xff0c;若其满足 1≤i≤j≤k≤n 并且&#xff0c;则我们称这个三元组是「传智的」。 现在请你计算&#xff0c;有多少有序整数三元组是传智的。 输入格式…

LRU的原理与实现(java)

介绍 LRU的英文全称为Least Recently Used&#xff0c;即最近最少使用。它是一种内存数据淘汰算法&#xff0c;当添加想要添加数据而内存不足时&#xff0c;它会优先将最近一段时间内使用最少的数据淘汰掉&#xff0c;再将数据添加进来。 原理 LRU的原理在介绍中就已经基本说…

机器学习模型——逻辑回归

https://blog.csdn.net/qq_41682922/article/details/85013008 https://blog.csdn.net/guoziqing506/article/details/81328402 https://www.cnblogs.com/cymx66688/p/11363163.html 参数详解 逻辑回归的引出&#xff1a; 数据线性可分可以使用线性分类器&#xff0c;如果…

蓝桥真题--路径之谜DFS解法

路径之谜 思路 前置知识&#xff1a;深度搜索模板搜索所有可以找的路径&#xff0c;将走过的靶子减去一走到最后一个格子的时候&#xff0c;直接去判断所有的靶子只有除最后一个位置的靶子&#xff0c;其余靶子都归零的时候&#xff0c;判断一个最后一个位置横坐标和纵坐标的靶…

[深度学习]yolox训练参数含义

yolox训练数据的入口为YOLOX-main/tools/train.py。main函数中通过get_exp获取训练过程相关的超参数。 其中train.py中的make_parser函数的参数解析如下&#xff1a; -expn: 训练过程数据保存的位置&#xff0c;默认位置是tools/YOLOX_outputs中的目录&#xff0c;如果指定-e…

尚硅谷html5+css3(1)

1.基本标签&#xff1a; <h1>最大的标题字号 <h2>二号标题字号 <p>换行 2.根标签<html> 包括<head>和<body> <html><head><title>title</title><body>body</body></head> </html> 3…

MATLAB - 用命令行设计 MPC 控制器

系列文章目录 前言 本例演示如何通过命令行创建和测试模型预测控制器。 一、定义工厂模型 本示例使用《使用 MPC Designer 设计控制器》中描述的工厂模型。创建工厂的状态空间模型&#xff0c;并设置一些可选的模型属性&#xff0c;如输入、状态和输出变量的名称和单位。 % co…

正确使用@Resource

目录 1 怎么使用Resource&#xff1f;1.0 实验环境1.1 通过字段注入依赖1.2 bean property setter methods &#xff08;setter方法&#xff09; 2 打破岁月静好&#xff08;Resource takes a name attribute&#xff09;2.1 结论2.2 那我不指定呢&#xff1f;【结论&#xff1…

Seata(分布式事务集成测试和总结)

文章目录 1.集成测试1.集成测试正常下单1.步骤2.浏览器访问 http://localhost:10008/order/save?userId666&productId1&nums1&money1003.注意事项和细节 2.集成测试模拟异常1.步骤1.com/sun/springcloud/controller/StorageController.java 休眠12s&#xff0c;模…

自动驾驶执行层 - 线控底盘基础原理(非常详细)

自动驾驶执行层 - 线控底盘基础原理(非常详细) 附赠自动驾驶学习资料和量产经验&#xff1a;链接 1. 前言 1.1 线控的对象 在自动驾驶行业所谓的“感知-定位-决策-执行”的过程中&#xff0c;在末端的执行层&#xff0c;车辆需要自主执行决策层所给出的指令&#xff0c;具体…

leetcode(HOT100)——链表篇

1、相交链表 本题思路就是定义两指针&#xff0c;指向两链表的同一起跑线&#xff0c;然后共同往前走&#xff0c;边走边判断两链表的节点是否相等&#xff0c; 代码如下&#xff1a; /*** Definition for singly-linked list.* public class ListNode {* int val;* L…

Android14应用启动流程(源码+Trace)

1.简介 应用启动过程快的都不需要一秒钟&#xff0c;但这整个过程的执行是比较复杂的&#xff0c;无论是对手机厂商、应用开发来说启动速度也是核心用户体验指标之一&#xff0c;本文采用Android14源码与perfetto工具进行解析。 源码参考地址&#xff1a;Search trace分析工…