【Qt学习】Qlabel 的核心属性 与 代码实例

1. 介绍

在Qt学习的专题中,我们以及多次使用过QLabel,作用就是用于显示文本和图片;

QLabel有以下 核心属性:

好的,以下是QLabel的核心属性以表格形式列举出来:

属性描述
TextQLabel显示的文本内容。可以使用setText()方法设置文本。
PixmapQLabel显示的图片。可以使用setPixmap()方法设置图片。
Alignment文本或图片在QLabel中的对齐方式。可以使用setAlignment()方法设置对齐方式。
Word Wrap是否启用文本自动换行功能。可以使用setWordWrap()方法设置是否自动换行。
MarginQLabel的边距,即文本或图片与QLabel边框之间的距离。可以使用setMargin()方法设置边距。
Size ConstraintQLabel的尺寸约束。可以使用setSizePolicy()方法设置尺寸约束。
ToolTip鼠标悬停在QLabel上时显示的提示信息。可以使用setToolTip()方法设置提示信息。
Accessible NameQLabel的无障碍名称,用于辅助技术。可以使用setAccessibleName()方法设置无障碍名称。

2. 显示文本

我们用简单的代码展示QLabel:
代码示例

我们在ui界面创建3个Label控件:

在这里插入图片描述

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
	ui->label_1->setTextFormat(Qt::PlainText);
	ui->label_1->setText("这是一段纯文本");
	
	ui->label_2->setTextFormat(Qt::RichText);
	ui->label_2->setText("<b> 这是一段富文本 </b>");
	
	ui->label_3->setTextFormat(Qt::MarkdownText);
	ui->label_3->setText("## 这是一段 markdown 文本");}

效果如下:

在这里插入图片描述


3. 显示图片

此前我们使用过QPushButton设置图片,实际上并非最优解,QLabel设置图片的效果实际更上一层:

同理我们在ui界面添加一个Label控件,并添加资源文件,将图片导入到资源文件中:

在这里插入图片描述
代码示例

此时着手编写代码:

首先进行:加载图片+将图片设置到QLabel对象+将label铺满屏幕:

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

    // 将QLabel 铺满窗口(等大)
    QRect windowRect = this->geometry(); // 提取窗口geometry属性
    ui->label->setGeometry(0, 0, windowRect.width(), windowRect.height());
    // 加载图片
    QPixmap pixmap(":/Embarrass_smile.png");
    ui->label->setPixmap(pixmap);
    // 启动自动拉伸
    ui->label->setScaledContents(true);
}

随后在widget.h文件中声明resizeEvent函数(用于使图片跟随窗口变化而变化)

void resizeEvent(QResizeEvent *event);

后在widget.cpp文件中实现该函数:

// 当调整窗口大小时,Label跟随调整
void Widget::resizeEvent(QResizeEvent *event)
{
    qDebug() << event->size();
    ui->label->setGeometry(0, 0, event->size().width(), event->size().height());
}

效果展示:

请添加图片描述


4. 设置文本对齐方式

对于一个QLabel控件,我们可以直接在属性面板中在alignment进行文本对齐方式的设置:

在这里插入图片描述
也可以通过代码的方式进行设置:

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

5. 设置自动换行、边距、缩进

我们首先创建四个Label控件,并将其QFrame中的frameshape属性该位Box:

在这里插入图片描述
随后根据前面介绍提到的属性,进行换行、边距、缩进的设置:

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

    // QLabel设置 对齐方式
    ui->label->setText("一段测试文本");
    ui->label->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);

    // 设置自动换行
    ui->label_2->setText("一段长的测试文本:土豆,上帝赐予人类最宝贵的礼物,世界上最完美的食物,土豆丝好吃,土豆片好吃,土豆块好吃,土豆泥好吃,炸着吃,烤着吃,蒸着吃,煎着吃,都好吃,薯条好吃,薯饼好吃,加孜然好吃,蘸辣椒好吃,焗芝士好吃,怎么样都好吃,哪怕整个煮熟了撒盐都好吃,除了发芽不能吃,没有任何缺陷。");
    ui->label_2->setWordWrap(true);

    // 设置边距
    ui->label_3->setText("一段长的测试文本:(尖叫)(扭曲)(阴暗的爬行) (爬行)(扭动)(阴暗地蠕动)(翻滚)(激烈地爬动)(扭曲)(痉挛)(嘶吼)(蠕动)(阴森的低吼)(爬行)(分裂)(走上岸)(扭动)(痉挛)(蠕动)(扭曲的行走)(不分对象攻击)");
    ui->label_3->setIndent(50);

    // 设置缩进
    ui->label_4->setText("一段长的测试文本:正确的,直接的,中肯的,雅致的,客观的,完整的,立体的,全面的,合理的,辩证的,形而上学的,雅俗共赏的,一针见血的,直击要害的,批判性的,针对性的,创造性的,发散性的,具有独特意义的,客观的,合理的,明晰的,真实的,辩证的,深刻的,通达的,优美的,巧妙的,精辟的,雅正的,机智的,全面的,明白晓畅的,不偏不倚的,恰如其分的,滴水不漏的,不容质疑的,切中要害的,淋漓尽致的,深谙事理的,真知灼见的,发蒙振聩的,微言大义的,金声玉振的。");
    ui->label_4->setMargin(50);
}

效果如下:
在这里插入图片描述


6. 设置伙伴

如在介绍中所提到的butty属性,我们在ui界面创建:

在这里插入图片描述

这里我们将选项旁的label设置为 (文本)&A 的形式,后续通过代码设置伙伴后,&A就相当于设置了 alt + A的快捷键。

效果演示:
请添加图片描述
其中&后⾯跟着的字符,就是快捷键,但是呼出快捷键首先需要加上alt键

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值