WPF 多语言 多资源 多皮肤 处理方案
同时兼容这么多需求的解决方案 我想到的 只有通过 动态切换加载资源字典 前端用绑定的模式 达到托管最大化
多语言举例
我编辑了 两个 语言包 一个中文 一个英文 (语言包这个最好用T4 写个模板,这样添加新语言接口的时候不会遗漏,只是建议)
en-us.xaml
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:s="clr-namespace:System;assembly=mscorlib">
<s:String x:Key="Menu">Menu</s:String>
<s:String x:Key="MenuClass">Class</s:String>
<s:String x:Key="MenuGun">Gun</s:String>
<s:String x:Key="LanguageType">en-us</s:String>
</ResourceDictionary>
zh-cn.xaml
<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:s="clr-namespace:System;assembly=mscorlib">
<s:String x:Key="Menu">菜单</s:String>
<s:String x:Key="MenuClass">种类</s:String>
<s:String x:Key="MenuGun">装备</s:String>
<s:String x:Key="LanguageType">zh-cn</s:String>
</ResourceDictionary>
这两个资源文件 我放到新建的文件夹 Languages 里
然后在 App.xaml 里手动绑定一个默认加载的语言方案 目的是为了 写代码的时候 绑定 可以使用 键值联想 再一个也可以直接在设计视图界面 直接查看绑定效果 方便修改和 调试
<Application.Resources>
<ResourceDictionary>
<ResourceDictionary.MergedDictionaries>
<ResourceDictionary Source="/Languages/en-us.xaml" />
</ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
</Application.Resources>
添加个全局静态变量来维护记录当前使用的语言,为了方便配置启动的默认语言,我单独又在一个txt里 写了个值.我之所以没放到config里,是因为不想在给客户更新的时候把客户的个性配置方案个覆盖掉,打包发布程序必须得打包config,否则编译失败,目前我没找到更好的解决方案.
public class GlobalSettings
{
private static string _CurrentLanguage;
public static string CurrentLanguage
{
get
{
if (string.IsNullOrEmpty(_CurrentLanguage))
{
string languageFilePath = Environment.CurrentDirectory + "\\language.txt";
string strLanguage = string.Empty;
string strDefaultLanguage = "zh-cn";
using (FileStream fs = new FileStream(languageFilePath, FileMode.OpenOrCreate,FileAccess.ReadWrite,FileShare.ReadWrite))
{
using (StreamReader sr = new StreamReader(fs))
{
strLanguage = sr.ReadToEnd().Trim().ToLower();
}
}
if (string.IsNullOrEmpty(strLanguage))
{
using (FileStream fs = new FileStream(languageFilePath, FileMode.OpenOrCreate, FileAccess.ReadWrite, FileShare.ReadWrite))
{
strLanguage = strDefaultLanguage;
using (StreamWriter sw = new StreamWriter(fs))
{
sw.Write(strLanguage);
}
}
}
_CurrentLanguage = strLanguage;
}
return _CurrentLanguage;
}
set { _CurrentLanguage = value; }
}
}
程序入口窗体 随便放两个按钮 "中文" "英文" 用来切换系统的语言
<Grid>
<Button Content="中文"
Height="23"
HorizontalAlignment="Left"
Margin="78,139,0,0"
Name="button1"
VerticalAlignment="Top"
Width="75"
Click="button1_Click" />
<Button Content="英文"
Height="23"
HorizontalAlignment="Right"
Margin="0,139,153,0"
Name="button2"
VerticalAlignment="Top"
Width="75"
Click="button2_Click" />
</Grid>
private void ShowWindow()
{
];
if (merged!=null)
{
merged.Source = new Uri(string.Format("pack://application:,,,/Languages/{0}.xaml", GlobalSettings.CurrentLanguage));
App.Current.Resources.MergedDictionaries[] = merged;
}
Window1 w1 = new Window1();
w1.ShowDialog();
w1 = null;
}
private void button1_Click(object sender, RoutedEventArgs e)
{
GlobalSettings.CurrentLanguage = "zh-cn";
ShowWindow();
}
private void button2_Click(object sender, RoutedEventArgs e)
{
GlobalSettings.CurrentLanguage = "en-us";
ShowWindow();
}
使用语言的绑定窗体 Window1.xaml
<Grid>
<TextBlock Height="37"
HorizontalAlignment="Left"
Margin="31,33,0,0"
Name="textBlock1"
VerticalAlignment="Top"
Width="83"
Text="{DynamicResource Menu }"
/>
<TextBlock Height="37"
HorizontalAlignment="Left"
Margin="159,33,0,0"
Name="textBlock2"
Text="{DynamicResource MenuClass }"
VerticalAlignment="Top"
Width="83" />
<TextBlock Height="37"
HorizontalAlignment="Left"
Margin="31,104,0,0"
Name="textBlock3"
Text="{DynamicResource MenuGun }"
VerticalAlignment="Top"
Width="83" />
<TextBlock Height="37"
HorizontalAlignment="Left"
Margin="149,104,0,0"
Name="textBlock4"
Text="{DynamicResource LanguageType }"
VerticalAlignment="Top"
Width="83" />
</Grid>
这样只需要动态切换加载资源字典就好了
这样是直接编译到程序集里了 扩展性还差很多
可以把 一套资源字典编译到 一个单独的dll里 这种做法就比较类似 *.skin的做法 这种就是把动态加载资源 替换成 动态加载 dll
只是做了个简单的例子 提供个思路
WPF 多语言 多资源 多皮肤 处理方案的更多相关文章
- 项目笔记---WPF多语言方案
近期由于朋友邀请帮忙给一个开源的游戏“外挂”做一个I18N的解决方案,恰好也是WPF做的,之前有过相关经验,就忙了一个星期终于搞定了,已经提交给作者了,现在这里做一个分享. 这里分享下我个人Fork的 ...
- 一份关于Swift语言学习资源的整理文件
一份关于Swift语言学习资源的整理文件 周银辉 在这里下载 https://github.com/ipader/SwiftGuide
- (转)WPF控件开源资源
(转)WPF控件开源资源 Textbox Drag/Drop in WPFhttp://www.codeproject.com/Articles/42696/Textbox-Drag-Drop-in- ...
- Go语言学习资源
Go语言学习资源 下载:http://www.golangtc.com/downloadhttp://www.golangtc.com/download/liteide 安装及开发工具http://j ...
- WPF笔记(1.8 资源与映射)——Hello,WPF!
原文:WPF笔记(1.8 资源与映射)--Hello,WPF! 终于,看明白了,已经是凌晨1:39分.这本书这一节写得实在是不好,一个local搞得我糊里糊涂,于是,准备按照他的思路,按照我的理解,改 ...
- WPF中静态引用资源与动态引用资源的区别
WPF中静态引用资源与动态引用资源的区别 WPF中引用资源分为静态引用与动态引用,两者的区别在哪里呢?我们通过一个小的例子来理解. 点击“Update”按钮,第2个按钮的文字会变成“更上一层楼”, ...
- WPF 多语言解决方案 - Multilingual App Toolkit
1.首先安装Multilingual App Toolkit 2.新建项目,在VS中点击"工具" -> "Multilingual App Toolkit&qu ...
- WPF控件开源资源
(转)WPF控件开源资源 Textbox Drag/Drop in WPFhttp://www.codeproject.com/Articles/42696/Textbox-Drag-Drop-in- ...
- WPF中引入外部资源
有时候需要在WPF中引入外部资源,比如图片.音频.视频等,所以这个常见的技能还是需要GET到. 第一步:在VS中创建一个WPF窗口程序 第二步:从外部引入资源,这里以引入图片资源为例 1)新建Reso ...
随机推荐
- windows win7 win10 多系统启动菜单 多系统引导设置
win键+R 输入msconfig 根据显示的程序设置(除非你看不懂文字)
- 使用java实现持续移动的小球
原创作品,可以转载,但是请标注出处地址http://www.cnblogs.com/V1haoge/p/5559829.html 仅为自己学习作品,使用java的JFrame框架实现持续移动的小球. ...
- IE6文字溢出BUG(多出来的猪问题)
在IE6下使用浮动可能会出现文字重复的情况. 在IE6下,浮动层之间有注释文字的话,之前那个浮动层的内容文字就有可能遭遇一个“隐形”的复制,但是代码里查看文字可并没有多出来. 看个例子: HTML & ...
- BZOJ 1083: [SCOI2005]繁忙的都市 kruskal
1083: [SCOI2005]繁忙的都市 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=1083 Description 城市C是一个非 ...
- C++ Code_StatusBar
主题 1. 创建状态栏 并显示 2. 在状态栏中显示进度条 3. MDI文档显示和隐藏状态栏 4. 5. 代码::创建状态栏 并显示 //手动添加3个ICON //////////////// ...
- 怎样用JS来添加CSS样式
方法: document.getElementById("xx").style.xxx中的全部属性是什么 盒子标签和属性对比 CSS语法(不区分大写和小写) JavaScript语 ...
- css常用知识
1.基本语法规范p {color:#ff0000;background:#ffffff}a.其中"p"称为"选择器"(selectors),指明我们要给&quo ...
- iOS系统控件显示中文
App中使用系统控件,一般默认会显示英文,即便系统的语言环境设置的是简体中文.这需要在App的工程中加入中文支持,这样在中文的系统环境下,调用的系统控件,比如“返回”而不是“Back”.步骤如下: 为 ...
- C#开源项目
原文: http://alance.iteye.com/blog/693987 一.AOP框架 Encase 是C#编写开发的为.NET平台提供的AOP框架.Encase 独特的提供了 ...
- QStyle 新风格的实现
摸索了很久,实际实现才发现很简单. 利用qt助手搜style可以发现style的实现和qapplication有关,在Qapplication里面搜到函数: void QApplication:: ...