首页 > 解决方案 > MaterialDatePicker RTL 月份分页按钮

问题描述

任何人都知道如何使 android MaterialDatePicker 支持 RTL,包括用于月份分页的箭头?

你可以看到应该面向相反的方向..有什么建议如何镜像箭头按钮? 在此处输入图像描述

编辑:

我将视图声明为 RTL 的自定义主题:

    <style name="datePickerTheme" parent="@style/ThemeOverlay.MaterialComponents.MaterialCalendar">
        <item name="materialCalendarHeaderTitle">@style/materialCalendarTitle</item>
        <item name="android:layoutDirection">rtl</item>
    </style>

我在我的应用程序中使用的语言环境(以色列希伯来语):

        val languageToLoad = "iw_IL"
        val locale = Locale(languageToLoad)
        Locale.setDefault(locale)
        baseContext.resources.configuration.setLocale(locale)

我的MaterialDatePicker初始化:

            val datePickerBuilder =
                MaterialDatePicker.Builder.datePicker()
            val constraints = CalendarConstraints.Builder()
                .setValidator(object : CalendarConstraints.DateValidator {
                    override fun describeContents(): Int {
                        return 0
                    }

                    override fun writeToParcel(p0: Parcel?, p1: Int) {

                    }

                    override fun isValid(date: Long): Boolean {
                        //checks if date is more than 3 months
                        if (Calendar.getInstance().timeInMillis - date > 90 * daysInMilli
                            || Calendar.getInstance().timeInMillis < date
                        ) {
                            return false
                        }
                        return true
                    }
                })
            datePickerBuilder
                .setTitleText("החל מתאריך")
                .setTheme(R.style.datePickerTheme)
                .setSelection(MaterialDatePicker.todayInUtcMilliseconds() - 3 * daysInMilli)
                .setCalendarConstraints(constraints.build())
            val datePicker = datePickerBuilder.build()

R.style.datePickerTheme

    <style name="materialCalendarTitle">
        <item name="android:textSize">18dp</item>
        <item name="android:textColor">@color/white</item>
    </style>

    <style name="datePickerTheme" parent="@style/ThemeOverlay.MaterialComponents.MaterialCalendar">
        <item name="materialCalendarHeaderTitle">@style/materialCalendarTitle</item>
    </style>

标签: androiduser-interfacematerial-designandroid-datepicker

解决方案


据我所知,此错误已通过此提交修复,可将材料库更新到版本1.3.0-alpha03及更高版本。1.3.0如果可以的话,我会尝试至少更新到。

更新:我在catalog这里运行了材料示例应用程序:https ://github.com/material-components/material-components-android

然后我添加了这个方法以编程方式更改语言环境MainActivity

@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN_MR1)
public static void setLocale(Activity activity, String languageCode) {
    Locale locale = new Locale(languageCode);
    Locale.setDefault(locale);
    Resources resources = activity.getResources();
    Configuration config = resources.getConfiguration();
    config.setLocale(locale);
    resources.updateConfiguration(config, resources.getDisplayMetrics());
}

并在onCreate

//wrapped in build check just to hide warnings
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN_MR1) {
    setLocale(this, "iw_IL");
}

这是导航到DatePicker示例页面并按“启动材料日期选择器”时的结果。

在此处输入图像描述

如您所见,月份箭头很好,因此问题出在您的实施中。您应该检查示例应用程序以找到它,或者开始逐步删除您的自定义项,直到它工作为止。


推荐阅读