Android RLT布局兼容注意事项

3 篇文章 0 订阅
1 篇文章 0 订阅

近期公司项目需要开拓阿拉伯市场,故需要在APP端兼容阿拉伯语。
阿拉伯语与其他多语言不同之处在于其布局是由右到左排布的,与我们常见的从左到右的布局不同。故需要修改部分代码的写法以兼容右到左布局。

开发问题及修改方法

模块注意功能点解决方法
字符串文件String.xml翻译校验注意占位符是否正常存在
货币符号阿拉伯货币符号会使金额在前符号在后通过代码中货币切换方法转变顺序
货币金额在部分语种下金额小数点会变成逗号通过代码中货币切换方法中调用DecimalFormatSymbols 指定LOCAL为US,保持小数点详见注释1
布局文件xmlpaddingLeft/paddingRight增加paddingStart/paddingEnd
marginLeft/lmarginRight增加marginStar/lmarginEnd
drawableLeft/drawableRight增加drawableStart/drawableEnd详见注释2
TextView,EditText中RTL布局下英语无法靠右显示的问题在Style文件中设置特定属性统一修改详见注释3
FrameLayout中靠左子View未设置Start属性时,无法兼容RTL布局添加android:layout_gravity=start
图标翻转ImageView设置rotationY为180,可通过在不同布局的xml文件中声明
TextView中Drawable图标素材翻转
代码中动态设置间距setMargins根据Left,Right参数值在下方分别添加setMarginStart和setMarginEnd
setPadding替换为setPaddingRelative
TextView设置DrawablesetCompoundDrawables替换为setCompoundDrawablesRelative
RecycleView分割线RTL布局中分割线不会相应替换创建基类ItemDecoration,在getItemOffsets方法中根据作用布局决定是否进行left right调换详见注释4
自定义View自定义圆角属性未随着RTL布局变换获取对应圆角属性时,根据布局方向做相关值转换
自定义动画setTranslationX在RTL布局无法正常转换RTL布局中设置的参数需取反,translationX -> -translationX
ViewPager官方不能兼容从右到左1.引入第三方rtlViewPager 2.引入官方viewpager2
字符串拼接阿拉伯语+英语位置错误从左到右嵌入(U 202A) >从右到左嵌入(U 202B) >流行方向格式化(U 202C)

注释

1.在部分语种下金额小数点会变成逗号

//设置LOCAL为US,默认LOCAL为当前语言LOCAL
DecimalFormatSymbols symbols = new DecimalFormatSymbols(Locale.US);
//创建对应的格式化,取小数点后两位
DecimalFormat format = new DecimalFormat("0.##", symbols);
//将金额转换为String类型
format.format(d)

2.布局文件xml,Left变Start
XML文件的修改可通过Android Studio自带的工具进行统一修改。
步骤为菜单栏Refactor->Add RTL Support Where Possible

3.TextView,EditText中阿拉伯语环境下英语无法靠右显示的问题

<!-- 在BaseStyle中指定editTextStyle和android:textViewStyle -->
<style name="AppBaseTheme" parent="Theme.AppCompat.NoActionBar">
    <item name="editTextStyle">@style/EditTextStyle.Alignment</item>
    <item name="android:textViewStyle">@style/TextViewStyle.TextDirection</item>
</style>

<!--EditText Style-->
<style name="EditTextStyle.Alignment" parent="@android:style/Widget.EditText">
    <item name="android:textAlignment">viewStart</item>
    <item name="android:gravity">start</item>
    <item name="android:textDirection">locale</item>
</style>

<!--TextView Style-->
<style name="TextViewStyle.TextDirection" parent="android:Widget.TextView">
    <item name="android:textDirection">locale</item>
</style>

4.右到左布局中分割线不会相应替换

public abstract class BaseCustomRtlDecoration extends RecyclerView.ItemDecoration {

    @Override
    public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
        getCustomItemOffsets(outRect, view, parent, state);
        if (TextUtilsCompat.getLayoutDirectionFromLocale(
                view.getContext().getResources().getConfiguration().locale) == ViewCompat.LAYOUT_DIRECTION_RTL){
            //使用异或操作完成数据交换,以免创建额外变量。
            outRect.right = outRect.left ^ outRect.right;
            outRect.left = outRect.left ^ outRect.right;
            outRect.right = outRect.left ^ outRect.right;
        }
    }

    //所有子ItemDecoration实现此方法,用法与getItemOffsets一致
    public void getCustomItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) { }
}

参考文章

Android 中东阿拉伯语适配

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值