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

Qt程序启动时的白屏问题

很早之前发现一个Qt启动时的白屏问题,新建一个Qt项目,在ui文件窗口中仅添加一个按钮,不做布局,编译并运行,窗口显示后会发现有个短暂的白屏过程。
Qt程序字体初始化引起的白屏问题_第1张图片
如果做个布局,把按钮放进去,则不会出现白屏,但窗口显示会有稍微的延迟。

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

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

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

优化:

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

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

QFont().defaultFamily();

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

又是个无用的知识……

你可能感兴趣的:(Qt,Bug,Qt常见问题,qt,白屏,QFont)