iOS实现应用内切换本地化语言的方法实例
前言
当我们的应用仅仅面向国内用户群,一般仅支持一种语言--中文就可以了。当面向国外用户时就需要进行国际化了,不仅仅是语言的转变,也可能包括设计风格,页面布局、交互效果的转变,如微信,微博,qq这类应用都有着切换语言的功能。
最近因为工作的原因,遇到个需要在应用内部设置语言的需求,默认使用系统设置的语言,如果用户在app内设置了别的语言,以后则按照新设置的语言显示界面。
ios确定应用的语言
1.ios首先搜索用户的语言偏好设置(设置-通用-语言与地区)
2.检测你的应用是否支持用户的语言,先用偏好设置的第一个语言,检测应用是否包含该语言对应的文件夹(后缀是.lproj,文件名部分,英语为en,中文简体为zh-hans,日语为ja)如果存在,那就是该语言,否则用偏好设置第二个语言来匹配。重复该过程。
3.一旦系统为应用确定了语言,对应的.lproj文件夹就会用作本地化资源。
于是,写了个新*solocalization (本地下载),希望大家喜欢,其实代码很简单,有兴趣的可以直接去读源代码,有补充的可以直接向我提交 pull request。下面话不多说了,来一起看看详细的介绍吧。
方法如下:
1.创建本地化文件。
创建本地化字符串文件,文件名可以是默认的 infoplist.strings,也可以是别的,为这个文件设置好要支持的语言及内容。
2.导入 solocalization。
3.配置 solocalization。
设置支持的语言及默认语言,当系统设置的语言不属于支持的语言时会使用默认语言。
[solocalization configsupportregions:@[solocalizationenglish, solocalizationsimplifiedchinese] fallbackregion:solocalizationenglish];
4.设置 uikit 对象。
为 uikit 对象设置合适的属性,像下面这样简单,而且这样设置后,当语言切换时,这些 uikit 对象的文本内容会自动变为新设置的语言,不需要任何额外处理。
uibarbuttonitem *change = [[uibarbuttonitem alloc]initwithtitle:@"" style:uibarbuttonitemstyleplain target:self action:@selector(changelanguage:)]; // 这里的 @"setting" 就是 strings 文件中对应的那个 key,下同 change.sol_title = @"setting"; self.navigationitem.rightbarbuttonitem = change; self.label.sol_text = @"label"; [self.button sol_settitle:@"button" forstate:uicontrolstatenormal]; self.textfield.sol_placeholder = @"textfield placeholder"; self.navigationitem.sol_title = @"title";
对于 solocalization 暂不支持切换语言后自动修改文本内容的 uikit 对象,可以这样获取需要的本地化字符串:
// 其中 “title” 为 strings 文件中对应的 key,“infoplist”是本地化字符串文件名 nsstring *localizedstring = solocalizedstringfromtable(@"title", @"infoplist");
5.修改应用内使用的语言
// to use english [solocalization sharedlocalization].region = solocalizationenglish; // to use 简体中文 [solocalization sharedlocalization].region = solocalizationsimplifiedchinese;
6.自定义的本地化字符串文件名
solocalization 提供的 api 中,默认使用的本地化字符串文件名为 infoplist.strings 文件,如果使用其他文件名(比如使用这个文件名:local.strings),如下即可:
// 对于支持的 uikit 对象 label.sol_table = @"local"; // 使用 solocalizedstringfromtable 时 nsstring *localizedstring = solocalizedstringfromtable(@"title", @"local");
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。