【Flutter】多语言适配-波斯语RTL从右到左

前言

在多语言适配的时候,波斯语的显示是从右到左的,需要针对一些控件进行单独适配。

核心逻辑:根据语言动态设置 Directionality

dart 复制代码
Widget build(BuildContext context) {
  final isRtl = Localizations.localeOf(context).languageCode == 'fa';

  return Directionality(
    textDirection: isRtl ? TextDirection.rtl : TextDirection.ltr,
    child: YourMainWidget(),
  );
}

结合 MaterialApp 自动判断 Locale 设置方向

dart 复制代码
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      localizationsDelegates: const [
        GlobalMaterialLocalizations.delegate,
        GlobalWidgetsLocalizations.delegate,
        GlobalCupertinoLocalizations.delegate,
      ],
      supportedLocales: const [
        Locale('en'),
        Locale('fa'),
      ],
      builder: (context, child) {
        final locale = Localizations.localeOf(context);
        final isRtl = locale.languageCode == 'fa';

        return Directionality(
          textDirection: isRtl ? TextDirection.rtl : TextDirection.ltr,
          child: child!,
        );
      },
      home: HomePage(),
    );
  }
}

控制单个组件方向(局部 RTL / LTR)

你可以按需局部设置 TextField、Text、Row 等的方向:

dart 复制代码
final isRtl = Localizations.localeOf(context).languageCode == 'fa';

TextField(
  textDirection: isRtl ? TextDirection.rtl : TextDirection.ltr,
  textAlign: isRtl ? TextAlign.right : TextAlign.left,
)
dart 复制代码
Row(
  textDirection: isRtl ? TextDirection.rtl : TextDirection.ltr,
  children: [...],
)

工具函数封装建议(便于项目统一处理)

你可以写一个统一函数判断是否是 RTL 语言:

dart 复制代码
bool isRtlLanguage(BuildContext context) {
  final lang = Localizations.localeOf(context).languageCode;
  return lang == 'fa' || lang == 'ar' || lang == 'he';
}

特别提示

  1. TextAlign.start / TextAlign.end 会自动适配方向,不建议用 TextAlign.left/right。

  2. 推荐使用AlignmentDirectional,不建议使用Alignment。

  3. EdgeInsetsDirectional 自动适配左右方向,推荐代替 EdgeInsets.only(left/right)。

  4. 自动方向适配依赖于你在 MaterialApp 中设置正确的 locale 和 supportedLocales。

  5. 推荐使用BorderDirectional,不推荐使用Border。

  6. 推荐使用BorderRadiusDirection,不推荐使用BorderRadius。

相关推荐
tang&19 小时前
【Python自动化测试】Selenium常用函数详解
开发语言·python·selenium
卜锦元20 小时前
Golang项目开发过程中好用的包整理归纳(附带不同包仓库地址)
开发语言·后端·golang
Tony Bai1 天前
“我曾想付钱给 Google 去工作”—— Russ Cox 深度访谈:Go 的诞生、演进与未来
开发语言·后端·golang
sali-tec1 天前
C# 基于halcon的视觉工作流-章66 四目匹配
开发语言·人工智能·数码相机·算法·计算机视觉·c#
45288655上山打老虎1 天前
C++完美转发
java·jvm·c++
Seven971 天前
查找算法
java
hnlgzb1 天前
安卓app开发,如何快速上手kotlin和compose的开发?
android·开发语言·kotlin
无敌最俊朗@1 天前
STL-deque面试剖析(面试复习4)
开发语言
APIshop1 天前
用 Python 把“API 接口”当数据源——从找口子到落库的全流程实战
开发语言·python
毕设源码-朱学姐1 天前
【开题答辩全过程】以 公务员考试在线测试系统为例,包含答辩的问题和答案
java