在实际开发中,也许我们需要做这样的界面,可分为两种情况: 1、应用程序具备多语言版本(如中文简体,中文繁体,英文等),用户界面上显示的文本会根据系统 的情况自动套用资源,比如我的系统是简体中文版的,那就使用简体中文的资源文件中的内容。 2、用户可以选择语言如简体中文、繁体中文。根据用户选择的语言,动态加载资源文件中的字符串。 就像我为本文做的这个例子,运行后,默认选中“简体中文”,即页面中的文本显示为简体中文。 然后,选择“繁體中文”,这时候,界面上的文本也相应地进行变化。 嗯,大致效果就是这样了。 接下来,我们一起来做一做这个实例,通过实例来理解其中的奥妙吧。 1、启动VS 2012,新建一个空页面的应用程序项目(此处省略47个字)。 2、在项目中新建一个文件夹,名为“Strings”,再在这个新文件夹下再建两个文件夹,分别名为 “zh-Hans”和“zh-Hant”,注意,语言限定名不要输错,前者是简体中文,后者是繁体中文。 3、分别在上面建的两个文件夹中各建一个资源文件,文件名按默认即可,Resources.resw。 这方便在代码中引用。(操作方法是在文件夹上右击,从菜单中选择“新建项”,找到“资源文件”)。 如果您的操作无误,现在您的项目资源目录结构就像下图那样。 记住,不管你用的是法语,日语,中文还是鸟语,资源文件的名字必须一样,只是放在不同文 件夹下,而文件夹以语言标记命名(如zh-CN),就这么简单, 不要弄错就行了。 4、先打开简体中文zh-Hans下面的资源文件,输入三个项,再打开zh-Hant下面的资源文件, 也输入三个项,记着,键名必须相同,只是值不同罢了,该用什么语言就用什么,牛语言的资 源就输入牛语,用作鸟语的资源就输入鸟语,就像翻译一样。 如下图所示。 5、打开MainPage.xaml,布局代码我直接贴,也不解释了。
- <Page
- x:Class="App2.MainPage"
- xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
- xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
- xmlns:local="using:App2"
- xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
- xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
- mc:Ignorable="d">
-
- <Page.Resources>
- <Style x:Key="tbTitle" TargetType="TextBlock">
- <Setter Property="FontSize" Value="20"/>
- <Setter Property="Margin" Value="4,20,0,3"/>
- </Style>
- <Style x:Key="strdisplaytb" TargetType="TextBlock">
- <Setter Property="FontSize" Value="28"/>
- <Setter Property="TextWrapping" Value="Wrap"/>
- </Style>
- </Page.Resources>
-
- <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">
- <StackPanel Margin="25">
- <ComboBox x:Name="cbSelectLang" Width="235" HorizontalAlignment="Left">
- <ComboBoxItem>简体中文</ComboBoxItem>
- <ComboBoxItem>繁體中文</ComboBoxItem>
- </ComboBox>
- <TextBlock Text="第一项文本:" Style="{StaticResource tbTitle}"/>
- <TextBlock x:Name="txtbText1" Style="{StaticResource strdisplaytb}"/>
- <TextBlock Text="第二项文本:" Style="{StaticResource tbTitle}"/>
- <TextBlock x:Name="txtbText2" Style="{StaticResource strdisplaytb}"/>
- <TextBlock Text="第三项文本:" Style="{StaticResource tbTitle}" />
- <TextBlock x:Name="txtbText3" Style="{StaticResource strdisplaytb}" />
- </StackPanel>
- </Grid>
- </Page>
上面的XAML我相信你能看懂的,如果看不懂,说明你很有必要复习一下WPF。 6、打开代码视图(MainPage.xaml.cs),在构造函数中为ComboBox绑定一个事件处理程序。
- public MainPage()
- {
- this.InitializeComponent();
- this.cbSelectLang.SelectionChanged += cbSelectLang_SelectionChanged;
- }
7、cbSelectLang_SelectionChanged方法的代码如下:
- void cbSelectLang_SelectionChanged(object sender, SelectionChangedEventArgs e)
- {
- ComboBox cb = sender as ComboBox;
- if (cb != null)
- {
- string appLanguage = string.Empty;
- switch (cb.SelectedIndex)
- {
- case 0:
- appLanguage = "zh-Hans";
- break;
- case 1:
- appLanguage = "zh-Hant";
- break;
- default:
- appLanguage = "zh-Hans";
- break;
- }
- //更改语言
- ResourceContext rsContext = ResourceManager.Current.DefaultContext;
- rsContext.Languages = new List<string>(new string[] { appLanguage });
- //rsContext.QualifierValues["Language"] = appLanguage;
- //加载资源
- ResourceLoader loader = new ResourceLoader();
- this.txtbText1.Text = loader.GetString("item1");
- this.txtbText2.Text = loader.GetString("item2");
- this.txtbText3.Text = loader.GetString("item3");
- }
- }
设置应用程序的语言可以用上面代码中的 ResourceContext rsContext = ResourceManager.Current.DefaultContext; rsContext.Languages = new List<string>(new string[] { appLanguage }); 同时,下面有一行我给注释了。 //rsContext.QualifierValues["Language"] = appLanguage; 也就是说,两种方法都可以修改首选语言。 一是设置ResourceContext的Languages属性; 二是ResourceContext的QualifierValues是一个字典集合,我们修改其中键为Language的值 也能达到同样效果。 那么,应用程序的资源的URI和结构以及引用资源的标识符是如何分布的呢?且听下回分解。88 |