Qt控件的盒子模型,了解边距边线和内容区

这篇专门讲讲一个控件在绘制时的视觉样式。我们平常在对控件设置样式时,需要设置控件的一些外边距,内边距,边线,还有文字内容,贴上图片等。那么对于一个控件,到底怎么实现这些设置的呢?

先看下面这个图,这是一个标准的盒模型,也叫盒子模型。

这是一般控件的实际结构,比如QLabel,QPushbutton等,内部的结构实际都是这种样子。分为:外边距区域,边线区域,内边距区域,内容区域。

外边距区域:外边距区域通常是指标签内文本或图片与标签部件边界之间的空白区域。注意:一个控件的整个区域,是包含外边距区域的!

边线区域:边线区域,顾名思义,就是咱们平常看到的QLabel的边框占据的区域。边框可与是粗边框,可以是细边框,可以只有下边框或者其他某一边的边框线。都在这一区域绘制,当然你也可以将它设置为0px,就相当于取消了边框区域,给边框区域不留空间。

内边距区域:内边距区域‌是指控件内边线区域与内容之间的空间。你想要内容离上边框多点,离下边框近点,输了设置字体大小,就可以设置这个内边距区域。

内容区域:内容区就比较简单了,就是我们文字显示的区域。

再来说说,这块的样式设计。一般在样式表中,需要变哪些就设置哪些,比如你特意要文字左对齐,但又想离边线留个10px的距离,那么就可以设置左边内边距为10px;你想跟前面的另一个紧挨的控件留点距离,就可以设置外边距,当然,这种常见的需求,有很多中实现方式。下面贴一些常见的样式写法:

cpp 复制代码
QLabel{
//前景色
	color: qlineargradient(x1:0, y1:0, x2:1, y2:0,stop:0 rgb(20, 220, 60),stop:1 rgb(30, 40, 240));
	//顶部边线透明
		border-top-color: transparent;
		//右边线透明
		border-right-color: transparent;
		//左边线透明
		border-left-color: transparent;
		//文字左右居中,上下也居中
		text-align: center center;
		//字体组,加粗,雅黑
		font: bold normal 18pt "Microsoft YaHei";
}
相关推荐
云和数据.ChenGuang2 分钟前
Java装箱与拆箱(面试核心解析)
java·开发语言·面试
Evand J10 分钟前
【定位代码】复杂地磁环境下无人机自主导航增强技术研究——地磁匹配与多源数据融合方法,附matlab代码
开发语言·matlab·无人机
沛沛老爹11 分钟前
2025年java总结:缝缝补补又一年?
java·开发语言·人工智能·python·guava·总结·web转型ai
wadesir13 分钟前
高效计算欧拉函数(Rust语言实现详解)
开发语言·算法·rust
superman超哥14 分钟前
Rust 零拷贝技术应用:极致性能的内存操作艺术
开发语言·后端·rust·rust零拷贝技术·内存操作
superman超哥15 分钟前
Rust SIMD 指令优化:数据并行的极致性能
开发语言·后端·rust·数据并行·指令优化
千寻girling33 分钟前
面试官: “ 请你讲一下 package.json 文件 ? ”
前端·javascript·面试
如果你好36 分钟前
解决深拷贝循环引用痛点:一篇看懂 WeakMap 实现方案
前端·javascript
weixin_4784333238 分钟前
iluwatar 设计模式
java·开发语言·设计模式
han_39 分钟前
前端性能优化之性能指标篇
前端·javascript·性能优化