Flutter本地化(国际化)之App名称

文章目录

Flutter开发的App,如果名称想要跟随着系统的语言自动改变,则必须同时配置Android和IOS原生。

Android国际化

  1. 打开android\app\src\main\res\values

  2. 创建strings.xml
    在values上右键,选择New>Values Resource File

    在新窗口中输入文件名strings.xml

    strings.xml文件中,输入以下内容

    xml 复制代码
    <?xml version="1.0" encoding="utf-8"?>
    <resources>
    <!--    appName是key,后面的值就是本地化实际的名称-->
        <string name="appName">App name default locale</string>
    </resources>
  3. 创建多个语言的strings.xml
    在res目录上右键,选择New>Android Resource Directory

    左侧Available Qualifiers选择Locale,点击中间的右箭头,然后在右边选择需要国际化的语言和地区,点击OK.

    会自动创建values前缀的文件夹,将之前的strings.xml复制进去.

    然后将值修改成对应语言.
    这里推荐使用Android Studio自带的国际化编辑器Translations Editor,在strings.xml的右上角,点击Open editor打开。

    在国际化编辑器,可以很方便地修改每一种语言定义的值,这样就不需要打开多个string.xml来修改了。

  4. 引用多语言的key
    打开Manifest.xml,将label的值替换为我们定义的资源id,引用方式为@string/id名

xml 复制代码
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
  package="com.example.flutter_app">
 <application
    android:label="@string/appName"
    android:name="${applicationName}"
    android:icon="@mipmap/ic_launcher">
      <!-- 其他省略... -->
  </application>
</manifest>

Android官方推荐资源的key命名方式全部小写,单词之间以下划线分开,例如app_name

最后重新运行App,当系统语言切换时,App的名称也会跟着改变。

当然了,如果切换的语言是不被App支持,会以默认的values文件下的资源值为主。

IOS国际化

  1. 首先要添加支持的语言。默认是en(英语)。如果已经设置过了,请看下一步。

    如果要设置其他语言为默认语言,选中语言后点击Set Default

  2. 创建InfoPlist文件。

    选中Runner,右键New File...

    在弹出的窗口中,选择Resouce中的String Catalog,点击Next

    保存名称为InfoPlist,点击Creat创建文件

  3. 定义多语言的key和value。

    打开InfoPlist,可以看到会自动有我们支持的语言。

    点击+号,创建一个字符串资源.

    将key的名称改为CFBundleDisplayName,后面的值就是本地化的app名称。

    对应的源码文件是ios/Runner/InfoPlist.xcstrings,看结构就是一个JSON。

    json 复制代码
    {
      "sourceLanguage" : "en",
      "strings" : {
        "CFBundleDisplayName" : {
          "extractionState" : "manual",
          "localizations" : {
            "en" : {
              "stringUnit" : {
                "state" : "translated",
                "value" : "App Name"
              }
            },
            "zh-Hans" : {
              "stringUnit" : {
                "state" : "translated",
                "value" : "App名称"
              }
            }
          }
        }
      },
      "version" : "1.0"
    }
  4. 最后在Info.plist中引用key。

    CFBundleDisplayNameCFBundleName的value都改为$(PRODUCT_NAME)

重新运行IOS App,只要支持当前系统的语言,就会显示对应的app名称。

相关推荐
世人万千丶3 小时前
Flutter 框架跨平台鸿蒙开发 - 鸿蒙版本五子棋游戏应用
学习·flutter·游戏·华为·harmonyos·鸿蒙
冬奇Lab4 小时前
相机拍照流程:从快门按下到JPEG存储的完整旅程
android·音视频开发·源码阅读
alexhilton4 小时前
在Compose中用Shader实现透明的粘稠元球效果
android·kotlin·android jetpack
autumn20054 小时前
Flutter 框架跨平台鸿蒙开发 - 连连看游戏应用
flutter·华为·harmonyos
程序员老刘5 小时前
AI时代我们是否还需要学编程?丨《Flutter跨平台开发核心技巧与应用》新书上市啦
flutter·ai编程·客户端
jwn9995 小时前
Laravel5.x核心特性全解析
android·php·laravel
浮芷.6 小时前
Flutter 框架跨平台鸿蒙开发 - flutter版本样式的美食菜谱应用
flutter·harmonyos·美食
Mr_CrazyPeter6 小时前
iONSPlayer 1.1.1版本发布
游戏·ios·模拟器
小雨天気.6 小时前
Flutter 框架跨平台鸿蒙开发 - 生活中的书法练习应用开发文档
flutter·生活·harmonyos
studyForMokey7 小时前
【Android面试】RecylerView专题
android·spring·面试