

新闻资讯
技术学院中文乱码主因是Avalonia(尤其Ursa.Avalonia)默认不打包中文字体,Browser/WebAssembly环境缺乏fallback字体链;解决关键为:用对字体、设对位置、适配环境,含切font分支、控件级指定、全局资源定义及自定义字体引入四方案。
中文乱码在Avalonia(尤其是Ursa.Avalonia)中,根本原因不是代码写错了,而是默认不打包中文字体——尤其在Browser/WebAssembly环境下,系统可用字体有限,又没 fallback 字体链,一碰到缺字就显示方块或乱码。解决关键就三点:用对字体、设对位置、适配环境。
项目团队已维护好一个开箱即用的font分支,里面预置了微软雅黑、宋体、思源黑体等常用中文字体资源,无
需改代码、不调配置,切过去就生效:
git clone https://gitcode.com/IRIHI_Technology/Ursa.Avalonia && cd Ursa.Avalonia && git checkout font
不换分支也能修,给具体控件加FontFamily属性,明确告诉它“该用什么字体”:
欢迎使用 "Microsoft YaHei, SimHei, SimSun, sans-serif"
在App.axaml的里声明一个可复用的字体资源,再用{DynamicResource}引用:
Microsoft YaHei, SimHei, SimSun, sans-serif
要用思源黑体、阿里巴巴普惠体等开源字体,或公司定制字体,就得手动引入.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中定义资源:avares://YourApp/Assets/Fonts/SourceHanSansCN-Regular.otf
Build Action要设为Content,且Copy to Output Directory设为Copy if newer
基本上就这些。核心逻辑很清晰:Browser环境靠预置或注册字体文件 + 合理fallback链;桌面端更宽松,但统一设置仍能避免平台差异。选哪种方案,取决于你用的是主分支还是font分支、是否需要定制字体、以及项目所处阶段。