【 Avalonia UI 语言国际化 I18n】图文结合教学,保姆级教学,语言国际化就是这么简单(.Net C#)

完整项目地址

github : https://github.com/Crazy-GrowUp/AvaloniaI18nTest/tree/master
gitee :https://gitee.com/jack_of_disco/avalonia-i18n-test

0.项目新建 Properties 文件夹

对应的项目配置文件里面就会增加 <Folder Include="Properties\" />

1.项目添加新建项目

在 Properties 里面添加资源文件,命名为 Resource.resx

2.将自定义工具设置为 PublicResXFileCodeGenerator(重要)

右键 Resource.resx 文件,打开属性,修改属性中自定义工具为 PublicResXFileCodeGenerator

3.添加文本资源


4.安装扩展 ResXManager(推荐)

安装完成后,可能需要重启VS

5.添加多国语言

方式一:右键 Resource.resx 使用 ResXManager 打开

Properties 文件夹下面就多了一个 Resource.en.resx

方式二:手动添加多国语言文件

比如我们要添加中文,那么就新建 Resource.zh.resx 资源文件

然后将对应的翻译填写到资源文件中

6.在 .axaml 文件中使用

  1. 在 MainWindow.axaml 中加上 xmlns:prop="using:AvaloniaI18nTest.Properties"
  2. 通过 {x:Static prop:Resource.Name} 进行使用

7.在代码中使用

  1. 在 MainWindowViewModel 中 使用 using AvaloniaI18nTest.Properties; 或者 using prop = AvaloniaI18nTest.Properties;

  2. 取出其中的值

    c# 复制代码
     public string ResxName { get; } = Resource.Name;
     public string ResxName2 { get; } = prop.Resource.Name;   
  1. 在 axaml 中显示

8.切换语言

切换需要需要在 App.axaml.cs 中的 Initialize() 方法中进行设置

c# 复制代码
 // 不写或者为空就是默认系统语言
 // Thread.CurrentThread.CurrentUICulture = new System.Globalization.CultureInfo(""); 
 // 修改语言
 // Thread.CurrentThread.CurrentUICulture = new System.Globalization.CultureInfo("zh"); 
 Thread.CurrentThread.CurrentUICulture = new System.Globalization.CultureInfo("en");
相关推荐
狼性书生几秒前
uniapp+vue3实现的简单吐司通知弹窗组件
前端·uni-app·vue·组件·插件
克里斯蒂亚诺更新4 分钟前
使用elementUI的表格报错ResizeObserver loop completed with undelivered notifications.
前端·javascript·elementui
陈随易4 分钟前
Vue-Router v5内置文件式路由,告别手写维护的恐惧
前端·后端·程序员
木卫二号Coding5 分钟前
Python-文件拷贝+文件重命名+shutil+记录
开发语言·python
yongui478346 分钟前
使用C#实现Excel实时读取并导入SQL数据库
数据库·c#·excel
C_心欲无痕12 分钟前
移动端 B 站弹幕功能实现
前端·javascript
Amumu1213813 分钟前
Redux介绍(二)
前端·react.js
菜鸟很沉14 分钟前
Vue 3 组件双向绑定完全指南:update:modelValue 与 defineModel
前端·javascript·vue.js
C_心欲无痕21 分钟前
使用 FNM (Fast Node Manager) 管理多个 Node.js 版本
前端·node.js
bubiyoushang88823 分钟前
基于Q-learning的路径规划MATLAB仿真程序实现
开发语言·matlab