【Qt 常用控件】显示类控件——QLabel

server/2025/1/23 19:20:32/

目录

1.QLabel

1.1 textFormat 文本类型

普通文本和富文本

Markdown格式

1.2 alignment 文本对齐方式

1.3 wordWrap 自动换行

1.4 indent 文本缩进

1.5 margin 边距

1.6 buddy,qlabel伙伴

 1.7 pixmap图片 和 scaledContents自动填充


1.QLabel

功能:显示图片和文本

属性:
 

textQLabel中的文本。
textFormat

文本格式

Qt::PlainText :纯文本

Qt::RichText: 富文本、支持html标签

Qt::MarkdownText:markdown格式

Qt::AutoText:根据文本内容自动分析文本格式

pixmap设置QLabel内部包含的图片。
scaledContents

label内部图片 是否自动拉伸填充。

alignment

文本对齐方式(水平/垂直居中对齐,左/右/上/下 对齐)

wordWrap

自动换行

文本长度超出Label显示范围,是否自动换行。

如果不自动换行,文本不能完全显示。

QLabel不提供滚动条,QTextEdit(多行编辑框)提供滚动条拖拽。

indent

设置文本缩进。设置后,对label内的所有行都缩进,不只是首行缩进。

水平方向和垂直方向都生效。

而indent最多只是两个方向有效(具体哪两个⽅向有效取决于alignment对齐方式)。

margin

内部⽂本和边框之间的边距。

不同于于indent文本缩进。

是上下左右四个方向都同时有效。

openExternalLinks

是否允许打开⼀个外部的链接.

(当QLabel⽂本内容包含url的时候涉及到)

buddy

给QLabel关联⼀个"伙伴"

这样点击QLabel时就能激活对应的伙伴

例如伙伴如果是⼀个QCheckBox

那么该QCheckBox就会被选中

1.1 textFormat 文本类型

文本格式

Qt::PlainText :纯文本

Qt::RichText: 富文本、支持html标签

Qt::MarkdownText:markdown格式

Qt::AutoText:根据文本内容自动分析文本格式

例:为label标签,设置不同的文本类型

观察<b>标签的对文本的修饰效果,和#在markdown类型中的显示效果

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);ui->label_plaintext->setTextFormat(Qt::PlainText);ui->label_plaintext->setText("<b>纯文本</b>");ui->label_richtext->setTextFormat(Qt::RichText);ui->label_richtext->setText("<b>富文本</b>");ui->label_markdown->setTextFormat(Qt::MarkdownText);ui->label_markdown->setText("# 带标题符的markdown");}Widget::~Widget()
{delete ui;
}

普通文本和富文本

1. 普通文本

仅由字符(字母、数字、标点符号等)组成,是最基本的文字信息载体。

2. 富文本

使用word工具编辑的文件、就可以认为是富文本

富文本除了文字外,还包含多种格式和多媒体元素。

在格式方面,可以有不同的字体、字号、字体颜色、加粗、倾斜、下划线等样式,

还能设置段落格式,如缩进、行距等。

并且可以插入多媒体元素,像图片、视频、音频,以及超链接、表格、图表等。

Markdown格式

Markdown是一种轻量级的「标记语言」,提供各种特殊符号,表示不同的样式/格式。

  • #表示标题

  • 设置文本样式的符号:

1.2 alignment 文本对齐方式

  • Qt::AlignLeft:左对齐。
  • Qt::AlignRight:右对齐。
  • Qt::AlignTop:顶部对齐
  • Qt::AlignBottom:底部对齐。

  • Qt::AlignVCenter:垂直居中。
  • Qt::AlignHCenter:水平居中
  • Qt::AlignCenter:水平和垂直都居中。
    ui->label->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);//水平居中 |垂直居中

1.3 wordWrap 自动换行

wordWrap 自动换行:文本长度超出Label显示范围,是否自动换行。

如果不自动换行,文本不能完全显示。

QLabel不提供滚动条,QTextEdit(多行编辑框)提供滚动条拖拽。

 //自动换行ui->label_2->setText("长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长");ui->label_2->setWordWrap(true);

1.4 indent 文本缩进

    //intdent文本缩进ui->label_3->setText("长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长");ui->label_3->setIndent(50);ui->label_3->setWordWrap(true);

1.5 margin 边距

    ui->label_3->setText("长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长长");ui->label_3->setIndent(50);//缩进50ui->label_3->setWordWrap(true);//自动换行ui->label_3->setMargin(50);//边距50

边距效果:设置label内上下左右空白部分的距离(边距),只有内部矩形部分能显示文本。

未设置边距的时:

设置边距后:

超出中间矩形区域的部分,不显示。

边距与缩进:

 有边距、有缩进

有边距、无缩进

缩进是,在边距的基础上,再缩进。

1.6 buddy,qlabel伙伴

给QLabel关联⼀个"伙伴",这样点击QLabel时就能激活对应的伙伴。

例如伙伴如果是⼀个按钮(单选或复选按钮),按下快捷键,按钮会被选中。

绑定伙伴关系后,利用QLabel文本中的&符,为伙伴设置快捷键。

快捷键为:alt+指定字符。该字符label文本中&符,后的第一个字符。

    ui->label->setBuddy(ui->radioButton);ui->label_2->setBuddy(ui->radioButton_2);

1.7 pixmap图片 和 scaledContents自动填充

此时图片自动拉伸,铺满label:

重写resizeEvent虚函数,实现拖拽改变窗口大小的同时,改变QLabel的大小

可当窗口大小发生改变时,QLabel大小并不会随之变化:

  • 原因:为QLabel设置大小,是在widget的构造函数中设置的,设置就只设置了这一次
  • 虽然已经设置了label内的图片自动填充,可是label大小并没有改变,填充也没用。

Qt中表示用户操作的两类概念:信号、事件。

当拖拽修改窗口大小时,会触发resize事件。

resize这种事件,是一个连续的过程(从a一点点到b的过程),就会触发一系列的resize事件。

每触发一次resizeEvent事件,都会调用一次对应的虚函数。

  • 解决方法:重写QWidget的resizeEvent虚函数。
  • 原理:多态调用,实际会调用到子类Widget重写的虚函数。

回调函数设置方法

1.函数指针

2.函数对象

3.lambda

4.重写父类虚函数(框架内部拿着父类指针、调用虚函数(只要传参传的子类对象地址,就会实现多态调用))

5.Qt的信号槽

void Widget::resizeEvent(QResizeEvent* event)
{qDebug()<< event->size();ui->label->setGeometry(0,0,event->size().width(),event->size().height());
}


http://www.ppmy.cn/server/160827.html

相关文章

Chrome 132 版本新特性

Chrome 132 版本新特性 一、Chrome 132 版本浏览器更新 1. 在 iOS 上使用 Google Lens 搜索 在 Chrome 132 版本中&#xff0c;开始在所有平台上推出这一功能。 1.1. 更新版本&#xff1a; Chrome 126 在 ChromeOS、Linux、Mac、Windows 上&#xff1a;在 1% 的稳定版用户…

linux CentOS 创建账号,并设置权限

1. 查看用户&#xff1a;cat /etc/passwd 2. 创建用户 sudo useradd username 3. 设置密码 sudo passwd username 4. 限制命令 sudo visudo 文件末尾添加 developer ALL(root) NOPASSWD: /bin/cd, /bin/ls, /usr/bin/cat, /usr/bin/git, /usr/bin/tail

npm、cnpm 、yarn、pnpm的优势点和缺点

他们都是干什么的&#xff1f; npm、cnpm 和 yarn 都是用于管理 JavaScript 项目依赖的工具。 npm (Node Package Manager) 官方性&#xff1a;由 Node.js 官方提供的默认包管理器。性能&#xff1a;在早期版本中&#xff0c;npm 的安装速度较慢&#xff0c;因为它是串行安装…

解决GB28181对接RTSP倍速播放导致FFmpeg缓冲区满导致花屏问题

在GB28181协议对接RTSP流时&#xff0c;倍速播放会导致FFmpeg缓冲区溢出&#xff0c;进而造成花屏问题。这是由于倍速播放增加了数据流的处理速度&#xff0c;而FFmpeg的缓冲区未能及时处理这些增量数据&#xff0c;导致视频帧丢失或渲染错误。为解决此问题&#xff0c;可能需要…

sentinel微服务保护

学习链接 SpringCloudRabbitMQDockerRedis搜索分布式 文章目录 学习链接1.初识Sentinel1.1.雪崩问题及解决方案1.1.1.雪崩问题1.1.2.超时处理1.1.3.仓壁模式1.1.4.断路器1.1.5.限流1.1.6.总结 1.2.服务保护技术对比1.3.Sentinel介绍和安装1.3.1.初识Sentinel官网地址github地址…

Python 电脑定时关机工具

Python 电脑定时关机工具 相关资源文件已经打包成EXE文件&#xff0c;可双击直接运行程序&#xff0c;且文章末尾已附上相关源码&#xff0c;以供大家学习交流&#xff0c;博主主页还有更多Python相关程序案例&#xff0c;秉着开源精神的想法&#xff0c;望大家喜欢&#xff0c…

【NLP高频面题】LSTM的前向计算如何进行加速?

【NLP高频面题】LSTM的前向计算如何进行加速&#xff1f; 重要性&#xff1a;★★★ 核心思想&#xff1a;将小矩阵合并成大矩阵再进行梯度分块&#xff08;Reduce → Map&#xff09;。 合并计算遗忘门、输入门、输出门和新增信息的仿射变换&#xff0c;使用“大矩阵”加速…

[Effective C++]条款48 模板元编程(TMP)

本文初发于 “天目中云的小站”&#xff0c;同步转载于此。 条款48 : 认识template元编程 在条款47我们主要了解了萃取器这种模板元编程, 也初步进入了模板元编程的世界. 在本条款中, 我们将继续认识模板元编程, 认识其必要性和应用场景, 相比于条款47讲的还算比较深入,本条款真…