鸿蒙Qt字体实战:消灭“豆腐块“乱码与自定义字体加载

1. 满屏的"豆腐块"

在将Qt应用移植到鸿蒙初期,我们经常遇到一个尴尬的问题:

英文字符显示正常,但中文字符全部变成了方框(俗称"豆腐块" / Tofu)。

或者,设计师提供的精美 ttf 字体,在代码里加载成功了,但界面上死活不显示。

2. 原因一:系统字体回退失败

Qt依赖 fontconfig 或底层系统的字体API来查找默认字体。

在鸿蒙精简版(Standard System)或某些开发板上,可能预装的字体有限,或者Qt无法自动映射到系统的HarmonyOS Sans

临时方案:

在代码中显式指定一个存在的字体家族。

cpp 复制代码
QApplication app(argc, argv);
QFont font = app.font();
font.setFamily("HarmonyOS Sans SC"); // 尝试系统默认字体名
app.setFont(font);

3. 原因二:自定义字体加载路径错误

更多情况是应用自带了字体文件(如 OpenSans.ttf),但加载失败。

错误代码:

cpp 复制代码
int id = QFontDatabase::addApplicationFont(":/fonts/OpenSans.ttf"); // qrc路径
if (id == -1) {
    qWarning() << "Failed to load font"; // 鸿蒙上这里可能返回-1
}

虽然Qt通常支持从qrc加载字体,但在某些嵌入式或移动平台配置下,Qt需要一个物理文件路径来创建FreeType引擎的句柄。

解决方案:拷贝+加载

策略与Rawfile资源类似,先将字体文件拷贝到沙箱可写目录,再加载。

cpp 复制代码
QString fontPath = copyRawFileToSandbox("myfont.ttf");
int id = QFontDatabase::addApplicationFont(fontPath);

if (id != -1) {
    QString family = QFontDatabase::applicationFontFamilies(id).at(0);
    QFont font(family);
    app.setFont(font);
}

4. 进阶:Qt Quick 中文字体失效

在QML中,你可能设置了:

qml 复制代码
Text {
    font.family: "MyCustomFont"
    text: "你好"
}

但显示依然是默认字体。

这通常是因为 FontLoader 的使用方式不对。

正确姿势:

qml 复制代码
FontLoader {
    id: localFont
    source: "file:///data/storage/.../myfont.ttf" // 使用绝对路径
}

Text {
    font.family: localFont.name // 必须引用FontLoader的name属性
    text: "Hello"
}

最佳实践:

尽量使用 qrc:/ 加载 QML 中的字体资源,如果遇到平台兼容性问题(FreeType报错),再回退到本地文件方案。

5. 字体渲染模糊?High DPI适配

如果字体加载出来了,但是边缘锯齿严重或者模糊。

检查 main.cpp 是否开启了High DPI支持。

cpp 复制代码
// Qt 6 默认开启,但在某些鸿蒙设备上可能获取的DPR不对
app.setAttribute(Qt::AA_UseHighDpiPixmaps);

// 手动强制DPR(如果系统识别错误)
qputenv("QT_SCALE_FACTOR", "2"); 

6. 总结

  1. 中文乱码 :通常是系统字体映射失败,建议打包开源的中文字体(如 Source Han Sans 的精简版)随App发布。
  2. 加载失败addApplicationFontqrc 支持不稳定时,拷贝到临时目录再加载。
  3. QML字体 :使用 FontLoader 并正确引用 .name 属性。

字体是UI的门面,解决好字体问题,应用的质感瞬间提升一个档次。

相关推荐
Goway_Hui2 小时前
【鸿蒙原生应用开发--ArkUI--015】File-manager 文件管理器应用开发教程
华为·harmonyos
不羁的木木4 小时前
《HarmonyOS底部页签-沉浸光感组件实战》基础入门:认识HdsTabs容器与核心配置
华为·harmonyos
不羁的木木4 小时前
《HarmonyOS技术精讲》三:记忆链接 ── 跨场景数据融合
pytorch·华为·harmonyos
2501_919749034 小时前
鸿蒙 Flutter 实战:image_crop 0.4.1 适配 3.27-ohos 全流程
flutter·华为·harmonyos
祭曦念4 小时前
鸿蒙应用的生命周期与页面跳转:从入门到实战
华为·harmonyos
轻口味5 小时前
HarmonyOS 6.1.1 全栈实战录 - 88 实战 Ability Kit 启动生命周期预热与快照恢复机
华为·harmonyos·鸿蒙
Goway_Hui5 小时前
【鸿蒙原生应用开发--ArkUI--013】Exercise-tracker 运动记录应用开发教程
华为·harmonyos
想你依然心痛6 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“图谱智脑“——PC端AI智能体沉浸式知识图谱构建工作台
人工智能·ar·知识图谱·harmonyos·智能体
想你依然心痛6 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与HMAF的“律界智脑“——PC端AI智能体沉浸式法律文档智能审查工作台
人工智能·华为·ar·harmonyos·智能体
特立独行的猫a6 小时前
鸿蒙 PC 平台 Python 第三方库移植全景指南
python·华为·harmonyos·三方库移植·鸿蒙pc