前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >快速适配 Flutter 之语言国际化

快速适配 Flutter 之语言国际化

作者头像
出其东门
发布2020-05-13 13:38:27
2.3K0
发布2020-05-13 13:38:27
举报
文章被收录于专栏:01二进制

如果你希望你的APP走出海外,那么就需要你在编写代码时考虑支持不同的语言环境,设置一些“本地化”的值,例如文本/布局。Flutter本身是具备国际化的,在适配方面也较为简单,今天我将会介绍一个名为Flutter Intl的插件快速实现Flutter的语言国际化。

Flutter Intl

之前在学习适配国际化的时候,出现最多的一个组件叫做flutter_i18n[1],不过由于一些原因,这个插件已经停止维护了,后来无意中发现了一个名为Flutter Intl[2]的插件,我们只需要在VSCode/Android Studio中安装他即可。

添加依赖

默认情况下,Flutter仅提供美国英语本地化。要添加对其他语言的支持,应用程序必须指定其他MaterialApp属性,并包含一个名为的单独包-“flutter_localizations”。

pubspec.yaml中添加flutter_localizations依赖并执行packages get

代码语言:javascript
复制
# 国际化
flutter_localizations:
    sdk: flutter

如下图所示:

初始化项目

接下来我们选择Tools -> Flutter Intl -> Initialize for the Project就会对项目进行初始化

初始化结束后,pubspec.yaml中会自动增加以下字段

代码语言:javascript
复制
flutter_intl:
    enabled: true

表示国际化已经开启。与此同时,lib目录下会新增generatedl10n两个目录。

l10n目录下为arb文件•generated目录下为根据arb文件自动生成以下dart代码

ARB 文件

ARB文件扩展名为:Application Resource Bundle 意为应用程序资源包,并得到Google的支持,每个.arb文件都包含一个JSON表,该表从资源ID映射到本地化值,文件名包含已为其转换值的语言环境。

所以,如果我们想新增一门语言支持的话,只需要通过插件添加相应的arb文件即可。

新增语言

•通过插件新增arb文件

然后填入相应的local值生成arb文件,如zh表示中文。

之后便会在lib/generated/intl/目录下会生成新的messages_xx.dart文件

配置语言

arb文件生成成功后,剩下的便是在MaterialApp中配置supportedLocaleslocalizationsDelegates

代码语言:javascript
复制
MaterialApp(
…………
    // 设置语言
    localizationsDelegates: const [
    S.delegate,
    GlobalMaterialLocalizations.delegate,
    GlobalCupertinoLocalizations.delegate,
    GlobalWidgetsLocalizations.delegate
    ],
   // 将zh设置为第一项,没有适配语言时,英语为首选项
    supportedLocales: S.delegate.supportedLocales,
…………
)

我们来解释下上面这段代码出现的变量

localizationsDelegates列表中的元素是生成本地化值集合的工厂。

S.delegate 我们项目的本地化委托类,插件自动生成,他会根据你的arb文件自动生成对应的函数。

GlobalMaterialLocalizations.delegate 为Material Components库提供了本地化的字符串和其他值。•GlobalCupertinoLocalizations.delegate 为Cupertino Components库提供了本地化的字符串和其他值。•GlobalWidgetsLocalizations.delegate定义widget默认的文本方向,从左到右或从右到左。•supportedLocales支持的本地化。•S.delegate.supportedLocales我们项目支持的本地化,插件自动生成,它会在你添加arb文件时自动更新你的支持的本地化。

有关这些应用程序属性的更多信息,它们所依赖的类型以及如何国际化Flutter应用程序,可以查阅官方文档?《Flutter 应用里的国际化》[3]

使用

上文提到了,配置好该插件后,我们需要做的便是在arb文件中编辑相应的字段即可,这里给出示例。

如果有其他语言,只需要再添加一份arb文件即可。

接下来我么只需要将字符串部分替换掉即可。

然后保存文件,插件就会在message_xx.adart中自动添加对应的函数方便获取该字符串。

当然,arb还支持其他语法,这里说下最常见的占位符语法:

•arb文件

代码语言:javascript
复制
{
  "dialogTip":"Hello $name"
}

•使用

代码语言:javascript
复制
S.of(context).dialogTip("Rhyme");

更多使用方式见intl | Dart Package[4]

切换语言

上面说了这么多都只是告诉我们如何适配多种语言,上面这些操作均是跟随系统自动调整语言的,那么有什么办法可以让用户自定义切换语言呢?自然是可以的。

我们只需要在合适的地方调用以下代码即可。

代码语言:javascript
复制
S.load(Locale('zh', 'CN');

这里的zh/CN可以换成其他语言代码。

然后我们将选择好的语言用SharedPreference保存,每次启动App时检查用户设置的语言即可。效果如下图所示:

最后

以上就是本文的全部内容了,总的来说,有了Flutter Intl工具之后,开发者可以省去繁琐的代码配置,安心将精力花在文字适配(翻译)上。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-05-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 01二进制 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Flutter Intl
  • 添加依赖
  • 初始化项目
  • ARB 文件
  • 新增语言
  • 配置语言
  • 使用
  • 切换语言
  • 最后
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档