Qt 界面上字体自适应控件大小 - 随控件缩放

Qt 界面上字体自适应控件大小 - 随控件缩放

引言

在这里插入图片描述

Qt控件自适应字体大小可以用adjustSize()函数,但字体自适应控件大小并没有现成的函数可调. - 本文实现了按钮上的字体随按钮大小变化而变化 (如上图所示) - 其他控件同理。

  • 核心思路:根据控件的大小变化,同步调整字体的大小 - 重写resizeEvent函数

一、设计思路

本意是字体随按钮变化,实际上实现的是字体随窗体变化,由于按钮也随窗体变化,可以说是近似等价的实现 - 想变成随按钮变化也简单,将窗体高和宽换成按钮的即可:

    1. 在头文件声明高、宽和字体大小,并在构造函数中初始化 (记录,以便后续对比)
    this->width = this->size().width();
    this->height = this->size().height();
    this->fontsize = ui->pushButton->font().pointSize();
    1. 在窗体resizeEvent函数中,对比窗体高和宽的变化率,按照最小的变化率 (保证字体显示完整) 来控制字体大小。
void Widget::resizeEvent(QResizeEvent *event)
{
    int w = event->size().width();
    int h = event->size().height();
    double scale = 1.0;
    scale = 1.0 * w/this->width;
    if(scale < 1.0 * h/this->height){
        scale = 1.0 * h/this->height;
    }

    QFont font = ui->pushButton->font();
    int new_fontsize = scale * this->fontsize;
    if(new_fontsize != ui->pushButton->font().pointSize()){
        font.setPointSize(new_fontsize);
        ui->pushButton->setFont(font);
        qDebug()<< this->fontsize << " " << new_fontsize;
    }
}

二、进阶版大致思路

    1. 继承现有控件,重写每一个控件的resizeEvent函数,实现字体大小变换
      各个控件需保存自己的原始的大小和字体大小信息,根据原始信息和resize后的信息调整字体。 – 略繁琐,通用性较差
    1. 写一个函数或类 (推荐类,方便存储原始数据),遍历界面上的控件 (或将需要调整字体的控件提前加入类中的一个list中,在父窗体上resizeEvent函数中遍历list,调整其中控件字体大小即可)。-- 通用性强,较难实现

已经有大佬写了工具:QT界面自适应:https://blog.csdn.net/qq_45280097/article/details/134738567

三、参考链接

Qt 控件自适应字体大小:https://blog.csdn.net/lxj362343/article/details/108245226
Qt学习之路——字体跟随控件自适应(笔记):https://blog.csdn.net/qq_39020917/article/details/131911691
Qt Windows高清DPI自适应分辨率缩放,比较完美的解决方案:https://blog.csdn.net/startl/article/details/105862817

要实现Qt中UI界面中的控件随窗口的缩放而等比例缩放,可以使用布局管理器来自动调整控件大小和位置。布局管理器可以根据窗口的大小变化自动调整内部控件的尺寸和位置,从而实现自适应布局。 以下是一种常见的方法,可以让UI界面中的控件随窗口缩放等比例缩放: 1. 在Qt Designer中,选择主窗口或父容器窗口(例如QDialog),右键单击并选择"布局"->"布局管理器"->"垂直布局"(或水平布局)。 2. 将要自动缩放控件放置在布局管理器中。 3. 对于每个控件,您可以选择其大小策略(如保持原始大小、拉伸等)和拉伸因子。 - 对于保持原始大小控件,将其大小策略设置为"Preferred"(或不进行设置),这样它们将保持原始大小而不会缩放。 - 对于需要拉伸的控件,将其大小策略设置为"Expanding",并根据需要设置拉伸因子。 4. 保存并生成UI文件。 在运行时,当窗口的大小发生变化时,布局管理器将自动调整内部控件大小和位置,以使它们保持相对于窗口的比例。这样,UI界面中的控件就可以随窗口的缩放而等比例缩放了。 请注意,这种方法适用于使用Qt Designer创建的UI界面。如果您是通过编程方式创建UI界面,您可以使用QLayout类和其子类(如QVBoxLayout、QHBoxLayout等)来手动管理布局,并设置控件大小策略和拉伸因子。 希望对您有所帮助!如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大米粥哥哥

感谢认可!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值