Qt 无法识别某些字体导致程序启动失败

有用户反馈启动程序时,没有出现 UI 界面,程序跟 “闪退了一样”,查看日志,没有发现闪退或者报错异常,后面远程用户电脑并尝试解决

研究分析:在用户电脑上运行 debug 包,会出现 qt.qpa.fonts:Unable to enumerate family... 错误

初步怀疑是 windows 字体的问题,程序使用的 Qt 框架可能无法识别这些字体,后面进一步定位问题,发现程序主界面在调用 show() 函数时卡住并闪退,这一步在网络连接之前,故先排除网络方面的问题

网络搜索相关 bug 反馈,查看到类似帖子:https://bugreports.qt.io/browse/QTBUG-85683

当前程序使用的也是 Qt 5.15.0 版本,与该问题一样,因升级 Qt 版本需要时间并要通过验证和测试,所以可以先清除 Qt 无法识别的字体,后续再升级 Qt 版本

解决方案:将用户的字体包(C:/Windows/Fonts)暂时拷贝到我们的电脑上以备复现,再将用户的字体库删除了一遍,仅保留 windows 默认的字体,再启动程序,可以启动成功,因用户反馈这些字体现在用不到了,所以目前没有什么问题

后续:在现有的 windows 10 和 windows 11 上安装了用户的字体包,没有复现 :(

posted @ 2022-12-09 15:37  strive-sun  阅读(759)  评论(0编辑  收藏  举报