C# Winform多语言切换

        实现这个需求,主要用到了Winform的本地化功能;用资源文件的方式来实现,真的是感觉简单方便。若是简单的页面,在词库备好的情况下,只需寥寥几笔即可完成。

下面介绍下详细步骤:

实现功能:

Winform中英文语言切换

开发环境:

开发工具: Visual Studio 2013

.NET Framework版本:4.5

实现步骤:

1.在项目下新建一个Resource文件夹,然后创建两个资源文件,分别命名为:Resource_en.resx和Resource_zh.resx

2.将窗体下面的控件以及Text(或者其他显示属性)分别对应到词库写入到资源文件中,如下图:

3.写一个本地化应用的公共类 LangUtil,内容如下:

public class LangUtil
    {
        static ComponentResourceManager res;
        public static void ApplyResource(Control control)
        {
            switch (Thread.CurrentThread.CurrentCulture.Name)
            {
                case "en-US":
                     res = new ComponentResourceManager(typeof(Resource.Resource_en));
                    break;
                case "zh-CN":
                    res = new ComponentResourceManager(typeof(Resource.Resource_zh));
                    break;
                default:
                    res = new ComponentResourceManager(typeof(Resource.Resource_zh));
                    break;
            }

            res.ApplyResources(control, control.Name, Thread.CurrentThread.CurrentCulture);
            applyControl(control.GetType().Name, control);
        }
		//递归应用到控件
        private static void applyControl(string topName, Control control)
        {
            foreach (Control ctl in control.Controls)
            {
                res.ApplyResources(ctl, topName + "." + ctl.Name, Thread.CurrentThread.CurrentCulture);
                if (ctl.HasChildren)
                {
                    applyControl(topName, ctl);
                }
            }
        }
    }

4.点击切换对应语言的时候,赋值到对应的数据

private void 英文ToolStripMenuItem_Click(object sender, EventArgs e)
 {
     Thread.CurrentThread.CurrentCulture = new CultureInfo("en-us");
       //直接应用到对应的form
     LangUtil.ApplyResource(this);
 }

 private void 中文ToolStripMenuItem_Click(object sender, EventArgs e)
 {
     Thread.CurrentThread.CurrentCulture = new CultureInfo("zh-cn");
      //直接应用到对应的form
      LangUtil.ApplyResource(this);
 }

5.完成

当然,以上是比较简单的实现,应用到项目中的话,就需要考虑到各种控件的不同属性的赋值问题了,所以需要对应的写代码来实现,但是都可以基于这一个原理去做。

若是动态数据的话,可以直接配置两套词库对应到数据库,根据选择加载不同的词库。

实现效果如下:

由简入繁,拿来即用

更多精彩,请关注微信公众号:

  • 2
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值