Unity TMP 中文字体生成

1️⃣ 前提条件

  • 确认使用 TextMeshPro / TextMeshProUGUI 组件(Unity自带 Text 不支持 TMP 字体资产)

  • 确认下载的 字体文件支持中文 (例如 Source Han Sans SC

  • TMP 版本建议 ≥ 3.0 ,Unity 版本建议 2020+

2️⃣ Font Asset Creator 设置步骤

  1. Source Font File → 选择支持中文的字体(.ttf / .otf)

  2. Sampling Point Size → 90~120(中文字符多,建议 120 更清晰)

  3. Padding → 2~5

  4. Atlas Resolution4096 × 4096 (中文 Glyph 多,否则生成失败)踩坑点

  5. Character SetUnicode Range

    • 输入中文 Unicode 范围(16 进制 Hex):

      4E00-9FFF

    • 注意:TMP 只认 Hex,不要用十进制 19968-40959

  6. Render Mode → SDFAA(清晰、抗锯齿好)

  7. Auto Sizing → 关闭

  8. Get Kerning Pairs → 勾选(可选,提高字距精度)

  9. 点击 Generate Font Atlas → 等生成完成

3️⃣ Font Asset 使用步骤

  1. 在 Inspector 中确认 Character Table / Glyph Table

    • 应该能看到大量中文字符
  2. 绑定 TMP 文本组件:

    • Font Asset → 拖入刚生成的 Font Asset

    • Fallback Font Assets → 可以先清空,保证测试只用你生成的中文字体

  3. 文本组件里输入中文 → 应该直接显示


4️⃣ 动态模式备用方案

如果生成 Glyph 太多或 Atlas 太大,可使用 动态模式,TMP 会在运行时生成中文字符:

  1. Font Asset Inspector → Atlas Population ModeDynamic

  2. 绑定到 TMP 文本组件

  3. 运行游戏,TMP 会动态生成中文

  • 优点:不用手动指定 Unicode 范围

  • 缺点:首次渲染中文时稍慢


5️⃣ 常见踩坑总结

原因 解决方法
中文不显示 Font Asset 没生成中文 Glyph(Character Set 错或 Atlas 太小) Unicode Range → 4E00-9FFF Hex,Atlas 4096,Sampling 90~120
下划线 / 删除线不显示 Font Asset 没包含 TMP 特殊字符 生成 Font Asset 时勾选 Special Characters 或改 Dynamic 模式
生成十进制 Unicode TMP 只认 Hex 记得转换 16 进制(4E00-9FFF)
Atlas 太小 / Sampling 太低 中文 Glyph 多,生成失败 Atlas 4096×4096,Sampling ≥90
TMP 文本组件没绑定 Font Asset 即使生成了中文,也不显示 确认 TMP 组件 Font Asset 已替换为生成的中文 Font Asset
Fallback Font 导致显示错 TMP 会尝试回退到 fallback 测试阶段先清空 Fallback Font Assets
英文显示中文不显示 Character Set 只生成 ASCII 必须选择 Unicode / Custom Characters

6️⃣ 建议

  • 开发阶段:用 Dynamic 模式最稳妥,不用担心 Atlas 大小

  • 正式发布:如果要优化性能,可以生成 Static Font Asset,但要确保 Atlas 足够大(中文全部覆盖)

  • 输入特殊字符:下划线 / 删除线 / emoji 也需要加入 Font Asset 或 Dynamic 模式生成

相关推荐
weixin_409383122 小时前
godot y排序定位 sprite原点 等轴视角地图块测试 isometric 碰撞测试 初学godot
游戏引擎·godot
万兴丶3 小时前
Unity用C#完成抖音小游戏接入引力引擎(Gravity Engine)完整指南,一篇文章讲清楚!
unity·c#·游戏引擎·抖音
WarrenMondeville5 小时前
4.Unity面向对象-接口隔离原则
java·unity·接口隔离原则
WarrenMondeville7 小时前
3.Unity面向对象-里氏替换原则
unity·游戏引擎·里氏替换原则
WarrenMondeville8 小时前
5.Unity面向对象-依赖倒置原则
unity·设计模式·依赖倒置原则
万兴丶9 小时前
Unity 用AI自动开发游戏近一年----最新Cursor使用心得
人工智能·游戏·unity·cursor
张老师带你学20 小时前
UnityVR弯曲UI
科技·游戏·unity·游戏引擎·模型
张老师带你学1 天前
unity作业,街角小场景
科技·游戏·unity·游戏引擎·模型
mxwin1 天前
Unity Shader LOD:动态 Shader 等级切换技术详解
unity·游戏引擎·shader