C# WinForm国际化实现的简单方法
软件行业发展到今天,国际化问题一直都占据非常重要的位置,而且应该越来越被重视。对于开发人员而言,在编写程序之前,国际化问题是首先要考虑的一个问题,也许有时候这个问题已经在设计者的考虑范围之内,但终归要开发人员去做实现的。因此,如何实现国际化,是开发人员必须掌握的一项基本技能。
今天,这里要讲的就是,在利用c#进行winform开发时,国际化是怎么实现的。鉴于时间及篇幅关系,这里仅仅介绍一种简单的国际化实现方法,可能这里提到的方法已经有非常多人提到过,但笔者还是不厌其烦地介绍一下。
要在c#中实现国际化,需要相关资源文件,比如要在一个软件中支持英文、中文两种语言,那么就必须有这两种语言的资源文件,这在c#中可以采用资源文件(后缀名为.resx)来实现,我们不妨定义英文资源文件名称为resource.en-us,中文资源文件名称为resource.zh-cn,两种资源文件所涉及的id都应该是一样的(这对于其他更多的资源文件均是一样的),只不过是展示的名称不同罢了。
有了这两种资源文件,接下来就要考虑如何做的问题了。为了适应多处使用的情形,这里笔者单独编写了一个类resourceculture,该类包含了一些静态方法,主要作用是用来设置当前语言及返回当前的语言的相关字符串。该类代码如下:
using system.reflection;
using system.resources;
using system.threading;
using system.globalization;
namespace globalizationtest
{
class resourceculture
{
/// <summary>
/// set current culture by name
/// </summary>
/// <param name="name">name</param>
public static void setcurrentculture(string name)
{
if (string.isnullorempty(name))
{
name = "en-us";
}
thread.currentthread.currentculture = new cultureinfo(name);
}
/// <summary>
/// get string by id
/// </summary>
/// <param name="id">id</param>
/// <returns>current language string</returns>
public static string getstring(string id)
{
string strcurlanguage = "";
try
{
resourcemanager rm = new resourcemanager("globalizationtest.resource", assembly.getexecutingassembly());
cultureinfo ci = thread.currentthread.currentculture;
strcurlanguage = rm.getstring(id, ci);
}
catch
{
strcurlanguage = "no id:" + id + ", please add.";
}
return strcurlanguage;
}
}
}
在form1中的代码如下:
/**
* this project is just a example to show how to do the globalization in c# winform.
* you and rebuild and/or modify it by yourself if you want.
* specially, this project was created in visual studio 2010.
*
* project name : globalizationtest
* create date : april 29th, 2010
* */
using system;
using system.windows.forms;
namespace globalizationtest
{
public partial class form1 : form
{
public form1()
{
initializecomponent();
}
/// <summary>
/// set the resource culture
/// </summary>
private void setresourceculture()
{
// set the form title text
this.text = resourceculture.getstring("form1_frmtext");
// set the groupbox text
this.gblanguageview.text = resourceculture.getstring("form1_gblanguageviewtext");
this.gblanguageselection.text = resourceculture.getstring("form1_gblanguageselectiontext");
// set the label text
this.lblcurlanguagetext.text = resourceculture.getstring("form1_lblcurlanguagetext");
this.lblnametext.text = resourceculture.getstring("form1_lblnametext");
this.lblphonetext.text = resourceculture.getstring("form1_lblphonetext");
// set the button text
this.btnmsgshow.text = resourceculture.getstring("form1_btnmsgshowtext");
// set radiobutton text
this.rbenglish.text = resourceculture.getstring("language_englishtext");
this.rbchinese.text = resourceculture.getstring("language_chinesetext");
// set the current language text
if (rbenglish.checked)
{
this.lblcurlanguage.text = resourceculture.getstring("language_englishtext");
}
else if (rbchinese.checked)
{
this.lblcurlanguage.text = resourceculture.getstring("language_chinesetext");
}
}
private void form1_load(object sender, eventargs e)
{
// set the default language
resourceculture.setcurrentculture("en-us");
this.setresourceculture();
}
private void btnmsgshow_click(object sender, eventargs e)
{
if(string.isnullorempty(txtname.text))
{
messagebox.show(resourceculture.getstring("form1_msgbox_nametext"), resourceculture.getstring("form1_msgbox_titletext"),
messageboxbuttons.ok, messageboxicon.exclamation);
return;
}
if (string.isnullorempty(txtphone.text))
{
messagebox.show(resourceculture.getstring("form1_msgbox_phonetext"), resourceculture.getstring("form1_msgbox_titletext"),
messageboxbuttons.ok, messageboxicon.exclamation);
return;
}
messagebox.show(resourceculture.getstring("form1_msgbox_infotext") + txtname.text + ", " + txtphone.text,
resourceculture.getstring("form1_msgbox_titletext"), messageboxbuttons.ok, messageboxicon.information);
}
private void rbenglish_checkedchanged(object sender, eventargs e)
{
resourceculture.setcurrentculture("en-us");
this.setresourceculture();
}
private void rbchinese_checkedchanged(object sender, eventargs e)
{
resourceculture.setcurrentculture("zh-cn");
this.setresourceculture();
}
}
}
最终的效果如下图1和图2所示:
图1
归结起来,要在c#的winform中实现国际化,至少需要做好以下几点:
(1)准备所需资源文件(如本文中提到的英文和中文资源文件);
(2)引入命名空间(包括:system.reflection、system.resources、system.threading和system.globalization);
(3)实例化资源管理器(即resourcemanager);
(4)设置当前进程的语言区域;
(5)通过资源管理器从指定的资源文件中获取所需值。
通过上述的方法即可简单实现国际化。