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

Qt 5.14.2 学习记录 —— 십 QLabel

文章目录

  • 1、属性
  • 2、文本格式
  • 3、设置图片
  • 4、文本对齐
  • 5、自动换行、边距、缩进
  • 5、伙伴


1、属性

QLabel用来显示文本和图片。


text:QLbael中的文本


textFormat:文本的格式

Qt::PlainText 纯文本
Qt::RichText 富文本(支持html标签)
Qt::MarkdownText markdown格式
Qt::AutoText(根据文本内容自动决定文本格式)


pixmap:QLabel内部包含的图片

scaledContents:true表示内容自动拉伸填充QLabel,false不自动拉伸,通常和图片一起使用

alignment:可设置水平和垂直方向的对齐方式

wordWrap:true表示内部的文本会自动换行,false表示内部文本不会自动换行

indent:设置文本缩进,水平和垂直方向都生效

margin:内部文本和边框之间的边距,对上下左右都生效

openExternalLinks:是否允许打开一个外部链接

buddy:给QLabel关联一个伙伴,点击QLabel时就会选中这个伙伴。

2、文本格式

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

    ui->label->setTextFormat(Qt::PlainText);
    ui->label->setText("<b>纯文本</b>"); // 纯文本没有什么标签

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

    ui->label_3->setTextFormat(Qt::MarkdownText);
    ui->label_3->setText("## Markdown文本"); // 二级标题
}

在这里插入图片描述

3、设置图片

在这里插入图片描述

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

    // 把QLabel设置成和窗口一样大, 并把这个QLabel左上角设置到窗口的左上角
    // 让QLable铺满整个窗口
    QRect windowRect = this->geometry();
    ui->label->setGeometry(0, 0, windowRect.width(), windowRect.height());

    QPixmap pixmap(":/img/ztk.jpg");
    ui->label->setPixmap(pixmap);
}

界面是这样的属性:

在这里插入图片描述

上述代码也让QLabel设定为这样的属性,但是图片可不一定是这样的,所以会出现图片没有占满界面

在这里插入图片描述

图片都没有加载完全部。改成自动拉伸:

    // 把QLabel设置成和窗口一样大, 并把这个QLabel左上角设置到窗口的左上角
    // 让QLable铺满整个窗口
    QRect windowRect = this->geometry();
    ui->label->setGeometry(0, 0, windowRect.width(), windowRect.height());

    QPixmap pixmap(":/img/ztk.jpg");
    ui->label->setPixmap(pixmap);
    // 自动拉伸
    ui->label->setScaledContents(true);

这样就行了

在这里插入图片描述

不过如果把窗口扩成全屏,这个图片并没有占满整个界面,因为程序运行后,QLabel是固定大小的,所以图片也固定了大小。

当用户拖拽修改窗口大小时,会触发resize事件,这个事件是连续的,因为在整个过程中,窗口尺寸一直在变化,直到达到目标尺寸。我们要让Widget窗口类重写父类QWidget的resizeEvent虚函数,每次触发事件就会调用以此resizeEvent虚函数。

// widget.h
class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();

    void resizeEvent(QResizeEvent *event);
private:
    Ui::Widget *ui;
};

// widget.cpp
// 形参event包含了触发resize事件时窗口的尺寸
void Widget::resizeEvent(QResizeEvent *event)
{
    // 终端查看尺寸变化
    qDebug() << event->size();

    // 实时改变QLabel
    ui->label->setGeometry(0, 0, event->size().width(), event->size().height());
}

4、文本对齐

在这里插入图片描述

为了方便查看,QLabel的frameShape改为Box,并复制多个来比较。

在这里插入图片描述

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

    ui->label->setText("第一段文本");
    // 垂直并且水平居中
    ui->label->setAlignment(Qt::AlignHCenter | Qt::AlignVCenter);

    ui->label_2->setText("第二段文本");
    // 右对齐并且水平居中
    ui->label_2->setAlignment(Qt::AlignRight | Qt::AlignVCenter);

    ui->label_3->setText("第三段文本");
    // 右并且上对齐
    ui->label_3->setAlignment(Qt::AlignRight | Qt::AlignTop);
}

5、自动换行、边距、缩进

还是标题4的界面


不用自动换行

在这里插入图片描述

    ui->label_2->setText("哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈");
    ui->label_2->setWordWrap(true);

在这里插入图片描述


缩进

    ui->label_3->setText("第三段文本");
    ui->label_3->setIndent(47);

在这里插入图片描述

长文本换行+缩进

    ui->label_3->setText("哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈哈");
    ui->label_3->setWordWrap(true);
    ui->label_3->setIndent(47);

在这里插入图片描述


边距

// 上下左右四个方向都有30边距
    ui->label_4->setText("第四段文本");
    ui->label_4->setMargin(30);

在这里插入图片描述

5、伙伴

在这里插入图片描述

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

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

运行后alt + a就选中选项1,alt + b就选中选项2,因为&b的意思就是alt + b。

伙伴关系的快捷键可以选中对应的单/复选按钮。快捷键功能比QPushButton弱。

结束。


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

相关文章:

  • 开发人员学习书籍推荐(C#、Python方向)
  • 【计算机网络】窥探计网全貌:说说计算机网络体系结构?
  • 超燃预告!Origin百图绘制系列即将登场
  • 【Web安全】SQL 注入攻击技巧详解:UNION 注入(UNION SQL Injection)
  • 腾讯云AI代码助手编程挑战赛——贪吃蛇小游戏
  • 【再谈设计模式】模板方法模式 - 算法骨架的构建者
  • 32单片机从入门到精通之安全性与可靠性——防护措施(十八)
  • C#中的常用集合
  • SQLite安装与使用图文详解
  • P3884 [JLOI2009] 二叉树问题
  • openssl编译
  • 论文解析 | 基于语言模型的自主代理调查
  • 如何理解机器学习中的向量 ?
  • Mac 启动docke报错 com.docker.vmnetd【解决方案】
  • 在 Safari 浏览器中,快速将页面恢复到 100% 缩放(也就是默认尺寸)Command (⌘) + 0 (零)
  • vue实现Nprogress进度条功能
  • 新版本的IDEA如何解决Git分支显示为警告⚠<unknown>的问题
  • Android ValueAnimator根据屏幕刷率动态出帧/刷新,Kotlin
  • NLP中的问答(Question answering)
  • C#中的类型转换以及异常处理--05
  • Python在Excel工作表中创建数据透视表
  • AI Agent:软件测试自动化的新纪元
  • C++中的条件变量(condition_variable)详解:小白版
  • 移动应用安全:保护用户隐私与数据的关键解决方案
  • 安全运营体系建设
  • 字符串 (算法十一)