Avalonia怎么解决中文显示乱码问题 Avalonia字体设置方法

来源:这里教程网 时间:2026-02-21 17:35:23 作者:

中文乱码在Avalonia(尤其是Ursa.Avalonia)中,根本原因不是代码写错了,而是默认不打包中文字体——尤其在Browser/WebAssembly环境下,系统可用字体有限,又没 fallback 字体链,一碰到缺字就显示方块或乱码。解决关键就三点:用对字体、设对位置、适配环境。

直接切font分支(新手首选)

项目团队已维护好一个开箱即用的font分支,里面预置了微软雅黑、宋体、思源黑体等常用中文字体资源,无需改代码、不调配置,切过去就生效:

终端执行:
git clone https://gitcode.com/IRIHI_Technology/Ursa.Avalonia && cd Ursa.Avalonia && git checkout font
如果你是引用Ursa.Avalonia作为子模块或NuGet包,建议直接基于该分支构建本地包 适合新项目启动、Demo验证、快速交付,5分钟内搞定

控件级字体指定(灵活可控)

不换分支也能修,给具体控件加

FontFamily
属性,明确告诉它“该用什么字体”:

<button fontfamily="Microsoft YaHei, SimSun, sans-serif">登录</button>
<textblock fontfamily="Microsoft YaHei UI">欢迎使用</textblock>
推荐写成字体列表形式(逗号分隔),让系统按顺序 fallback,比如
"Microsoft YaHei, SimHei, SimSun, sans-serif"
注意:XAML里引号要匹配,别漏掉双引号;Browser环境下仅靠这个可能不够,需配合全局注册

全局字体资源定义(统一管理)

App.axaml
<application.resources></application.resources>
里声明一个可复用的字体资源,再用
{DynamicResource}
引用:

添加资源定义:

<Application.Resources><br>  <FontFamily x:Key="ChineseFont">Microsoft YaHei, SimHei, SimSun, sans-serif</FontFamily><br></Application.Resources>

在任意控件中使用:
<textblock fontfamily="{DynamicResource ChineseFont}" text="测试中文"></textblock>
Window级也可统一设:
<window fontfamily="{DynamicResource ChineseFont}"></window>
此方式便于后期统一替换品牌字体,但Browser环境仍需确保字体文件实际加载成功

自定义字体文件引入(企业/品牌需求)

要用思源黑体、阿里巴巴普惠体等开源字体,或公司定制字体,就得手动引入.ttf/.otf文件:

把字体文件放进
Assets/Fonts/
目录(如
Assets/Fonts/SourceHanSansCN-Regular.otf
App.axaml.cs
OnFrameworkInitializationCompleted
中注册:

FontManager.Current.AddFontResource(new Uri("avares://YourApp/Assets/Fonts/SourceHanSansCN-Regular.otf"));

再在
App.axaml
中定义资源:
<fontfamily x:key="BrandFont">avares://YourApp/Assets/Fonts/SourceHanSansCN-Regular.otf</fontfamily>
务必检查构建动作:字体文件的
Build Action
要设为
Content
,且
Copy to Output Directory
设为
Copy if newer

基本上就这些。核心逻辑很清晰:Browser环境靠预置或注册字体文件 + 合理fallback链;桌面端更宽松,但统一设置仍能避免平台差异。选哪种方案,取决于你用的是主分支还是font分支、是否需要定制字体、以及项目所处阶段。

相关推荐