Qt程序字体初始化引起的白屏问题

博客讨论了Qt应用程序启动时可能出现的短暂白屏现象,原因是QPlatformFontDatabase的同步调用导致的延迟。使用布局能避免白屏,但可能增加窗口显示延迟。解决方法包括在程序开始时预加载字体信息,或者确保UI设计允许计算尺寸以提前触发字体初始化。对于不使用UI文件的情况,由于尺寸计算会触发初始化,因此没有白屏问题。
摘要由CSDN通过智能技术生成

Qt程序启动时的白屏问题

很早之前发现一个Qt启动时的白屏问题,新建一个Qt项目,在ui文件窗口中仅添加一个按钮,不做布局,编译并运行,窗口显示后会发现有个短暂的白屏过程。
在这里插入图片描述
如果做个布局,把按钮放进去,则不会出现白屏,但窗口显示会有稍微的延迟。

经过调试源码发现,第一次绘制按钮的堆栈里,QPlatformFontDatabase::fallbacksForFamily是一个比较耗时的同步调用,这个过程应该是获取系统里的字体信息。Qt5.15 + win10 + i7七代测试,大概350ms,也跟系统装了多少字体有关,不同版本Qt耗时也有差异。

而在使用布局的时候,需要通过QPushButton::sizeHint计算按钮的尺寸,也会触发初始化字体信息,由于窗口还未显示,看不到这个白屏过程。

但是,如果不使用ui文件,直接用代码创建按钮,Qt需要确定显示尺寸,仍会先调用QPushButton::sizeHint,同上,没有白屏过程。使用ui文件会有白屏是因为ui文件里总是有预设的尺寸,不需要调用QPushButton::sizeHint计算,从而延迟到了第一次绘制的时候。

优化:

实际大多数程序都有布局,几乎不会有这个问题,所以也不用管。

如果非常在意这几百毫秒的延迟,且在创建窗口前会有比较长的时间做一些读取配置的操作,可以开个线程执行:

QFont().defaultFamily();

这个也会触发初始化字体信息。

又是个无用的知识……

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值