当前位置: 首页 > article >正文

Qt常用控件——QLabel

文章目录

    • QLabel核心属性
    • 文本格式演示
    • 显示图片
    • 文本对齐
    • 自动换行、边距、缩进
    • 设置伙伴

QLabel核心属性

QLabel是显示类控件,可以用来显示文本和图片

属性说明
textQLabel中的文本
textFormat文本格式
Qt::PlainText纯文本
Qt::RichText富文本(支持html标签)
Qt::MarkdownTextmarkdown格式
Qt::AutoText根据文本内容自动决定文本格式
pixmapQLabel内部包含的图片
scaledContents设为 true 表示内容⾃动拉伸填充QLabel
设为 false 则不会⾃动拉伸
alignment对齐方式
可以设置水平和垂直方向如何对齐
wordWrap设为 true 内部的文本会自动换行
设为 false 则内部文本不会自动换行.
indent设置文本缩进;水平和垂直方向都生效.
margin内部文本和边框之间的边距
不同于于 indent, 但是是上下左右四个⽅向都同时有效
而 indent 最多只是两个方向有效(具体哪两个方向有效取决于 alignment )
openExternalLinks是否允许打开⼀个外部的链接
(当 QLabel ⽂本内容包含 url 的时候涉及到)
buddy给 QLabel 关联⼀个 “伙伴” , 这样点击 QLabel 时就能激活对应的伙伴
例如伙伴如果是⼀个 QCheckBox, 那么该 QCheckBox 就会被选中.

文本格式演示

图形化界面设置了3个Label控件

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    ui->label->setTextFormat(Qt::PlainText);
    ui->label->setText("纯文本");

    ui->label_2->setTextFormat(Qt::RichText);
    ui->label_2->setText("<b>富文本</b>");

    ui->label_3->setTextFormat(Qt::MarkdownText);
    ui->label_3->setText("## markdown文本");
}

Widget::~Widget()
{
    delete ui;
}

image-20240910193814057

显示图片

显示图片,先用qrc机制管理图片。

QLabel设置成和窗口一样大,并且把QLabel左上角设置到窗口左上角

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //获取窗口尺寸
    QRect windowRect = this->geometry();
    ui->label->setGeometry(0, 0, windowRect.width(), windowRect.height());

    //加载图片资源
    QPixmap pixmap(":/logo.jpg");

    ui->label->setPixmap(pixmap);
}

Widget::~Widget()
{
    delete ui;
}

image-20240910200906971

此时图片大小未填充满整个窗口,可以启动scaledContents,自动拉伸填充图片

image-20240910201032680

当我们拉动窗口大小的时候,图片还是固定大小,因为QLabel是固定大小。在初始化的时候,只是将QLabel尺寸设置成了和窗口一样,这个相当于是一次性的。

GIF 2024-9-10 20-13-38

如果想让窗口大小实时发送改变,这里要和“事件”结合:

  • Qt当中,表示用户的操作有两个概念,一个是信号,一个是事件
  • 当用户拖拽修改窗口大小的时候,就会触发resize事件(resizeEvent),我们拖拽的时候,是实时变化的,所有将窗口大小拖拽改变的时候,会触发一系列的resizeEvent

此时我们就可以Widget窗口类重写QWidgetresizeEvent虚函数,在鼠标拖动窗口尺寸的过程当中,这个函数就会反复调用执行。

void Widget::resizeEvent(QResizeEvent *event)
{}

此处的形参是非常有用的,里面包含了触发resize事件这一时刻,窗口尺寸的实时数值

GIF 2024-9-10 20-25-03

这里并未调用resizeEvent,是Qt自己调用,我们这里重写虚函数,相当于给Qt指定了一个回调函数

#include "widget.h"
#include "ui_widget.h"
#include<QDebug>
#include<QResizeEvent>
Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //获取窗口尺寸
    QRect windowRect = this->geometry();
    ui->label->setGeometry(0, 0, windowRect.width(), windowRect.height());

    //加载图片资源
    QPixmap pixmap(":/logo.jpg");
    //启动自动拉伸
    ui->label->setScaledContents(true);
    ui->label->setPixmap(pixmap);
}

Widget::~Widget()
{
    delete ui;
}

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

GIF 2024-9-10 20-39-24

文本对齐

在图形化界面,设置一个label,然后添加一下边框,方便观察

image-20240910204421160

这里面是按位或,通过位图的方式来进行设置:

image-20240910210129970

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //构造函数中, 给label设置不同的属性
    ui->label->setText("水平垂直居中对齐");
    ui->label->setAlignment(Qt::AlignCenter | Qt::AlignVCenter);

    ui->label_2->setText("水平靠右垂直居中");
    ui->label_2->setAlignment(Qt::AlignRight | Qt::AlignCenter);

    ui->label_3->setText("右上角对齐");
    ui->label_3->setAlignment(Qt::AlignRight | Qt::AlignTop);
}

Widget::~Widget()
{
    delete ui;
}

image-20240910210029347

自动换行、边距、缩进

此时文本的内容,并不是完整的

image-20240910210509473

可以采用setWordWrap设置自动换行:

image-20240910210615665

采用setIndent设置缩进,里面的参数表示缩进多少像素:

image-20240910210940667

如果采用缩进+换行,后面的换行,都会进行缩进

image-20240910211036282

采用setMargins设置边距

image-20240910211533598

设置伙伴

可以将QLabel和单选框或者复选框绑定为伙伴关系,然后通过QLabel触发选中操作

image-20240910212244803

绑定伙伴关系:

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //设置label和radioButton伙伴关系
    ui->label->setBuddy(ui->radioButton);
    ui->label_2->setBuddy(ui->radioButton_2);
}

Widget::~Widget()
{
    delete ui;
}

GIF 2024-9-10 21-23-22

  • Qt当中,QLabel中写的文本,可以指定快捷键,但是这个快捷键的规则功能比PushButton弱很多
  • 文本当中采用&跟上一个字符表示快捷键,比如说&A,然后可以通过键盘的alt + a来触发

http://www.kler.cn/a/299191.html

相关文章:

  • [数据集][目标检测]乱堆物料检测数据集VOC+YOLO格式1143张1类别
  • mqtt协议用于物联网数据传输协议,它与http协议有什么区别
  • 时间日期工具类
  • 亿发:信息化智能化需求大幅提升,企业信息化建设又迈出关键一步
  • 浏览器百科:网页存储篇-如何在Chrome中打开IndexedDB窗格(十一)
  • 【论文分享精炼版】 sNPU: Trusted Execution Environments on Integrated NPUs
  • Apache License 2.0 和 MIT License 区别
  • 安科瑞Acrelcloud-6000银行安全用电管理平台在湖南新盛业的应用
  • Android利用andserver库搭建本地https服务器
  • 《python语言程序设计》2018版第8章第14题金融:信用卡号合法性 利用6.29题
  • 万字长文解析:计算机视觉领域的目标检测与图像分割(不断更新)
  • Java开发常用软件下载地址
  • 类组件化websocket的方法(心跳机制)
  • 漫谈设计模式 [8]:装饰器模式
  • C语言:刷题日志(3)
  • 【QT】文件读写,文件对话框
  • 2024国赛数学建模预测算法-BP神经网络模型的预测精度分析(MATLAB 实现)
  • 寄存器间接寻址与寄存器直接寻址
  • 【32单片机篇】项目:智能台灯
  • 百易云资产管理运营系统 house.save.php SQL注入漏洞