Flutter国际化

一、依赖与预览

  • get: 4.1.4

预览
在这里插入图片描述

二、使用

1. 在main.dart内配置

Widget build(BuildContext context) {
    return GetMaterialApp(
      title: "GUGU国际社交",
      debugShowCheckedModeBanner: false,
      enableLog: true,
      logWriterCallback: Logger.write,
      initialRoute: AppPages.INITIAL,
      getPages: AppPages.pages,
      locale: TranslationService.locale, /// 设备当前语言
      fallbackLocale: TranslationService.fallbackLocale, /// 默认语言
      translations: TranslationService(), /// 翻译服务
    );
  }

2. 配置TranslationService方法

translation_service.dart

/// 第三方
import 'package:get/get.dart';
import 'package:flutter/material.dart';

/// 本地资源
import 'zh_Hans.dart';
import 'zh_HK.dart';
import 'en_US.dart';

class TranslationService extends Translations {
  static Locale? get locale => Get.deviceLocale; /// 对应:ui.window.locale
  static final fallbackLocale = Locale('zh', ''); /// 第一个参数为大分类,第二个为小分类,可不填
  @override
  Map<String, Map<String, String>> get keys => {
    'en': en_US,
    'zh': zh_Hans,
    'zh_HK': zh_HK,
    'zh_Hans_US': zh_HK,
    'zh_TW': zh_HK,
    'zh_MO': zh_HK,
  };
}

zh_Hans.dart(中文简体)

const Map<String, String> zh_Hans = {
  'InternationalSocial': '国际社交',
};

zh_HK.dart(中文繁体)

const Map<String, String> zh_HK = {
  'InternationalSocial': '國際交友',
};

en_US.dart

const Map<String, String> en_US = {
  'InternationalSocial': 'International Social',
};

3. 使用

GestureDetector(
  onTap: (){
    var locale = Locale("zh", "HK");
    Get.updateLocale(locale); /// 看了下源码,是需要先修改ui.window.locale,再刷新APP页面
  },
  child: Text(
    "InternationalSocial".tr,
  ),
);

附录:
1. 各个国家语言代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

倾云鹤

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值