微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Android Jetpack Compose NumberPicker 小部件等效项

如何解决Android Jetpack Compose NumberPicker 小部件等效项

在 Jetpack Compose 中创建 NumberPicker 小部件的推荐解决方案是什么?类似于下图。我能够在我的可组合中使用 AndroidView 创建一个 NumberPicker,但该视图似乎不允许翻转或对齐位置。顺便说一句,下面的 UI 显示了三个排成一行的 NumberPickers。它不应该代表 DatePicker

enter image description here

解决方法

巧合的是,我上周实现了这样的屏幕。 我不能在这里分享整个代码,但基本上我所做的是:

  1. 使用 DatePicker 创建布局 (res/layout/date_picker.xml)。
<DatePicker xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/datePicker"
    android:theme="@style/DatePickerStyle"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:calendarViewShown="false"
    android:datePickerMode="spinner" />
  1. 然后,在您的可组合函数中使用它。
@Composable
fun DatePicker(
    onDateSelected: (Date) -> Unit
) {
    AndroidView(
        modifier = Modifier.fillMaxWidth(),factory = { context ->
            val view = LayoutInflater.from(context).inflate(R.layout.date_picker,null)
            val datePicker = view.findViewById<DatePicker>(R.id.datePicker)
            val calendar = Calendar.getInstance() // show today by default
            datePicker.init(
                calendar.get(Calendar.YEAR),calendar.get(Calendar.MONTH),calendar.get(Calendar.DAY_OF_MONTH)
            ) { _,year,monthOfYear,dayOfMonth ->
                val date = Calendar.getInstance().apply {
                    set(year,dayOfMonth)
                }.time
                onSelectedDateUpdate(date)
            }
            datePicker
        }
    )
}
  1. 最后,在 ModalBottomSheetLayout 中使用它
,

我知道您可能不是在寻找这样的东西。但是由于 compose 中还没有这样的小部件,所以 compose 就是为了让您更轻松地构建自己的组件。所以除了 android.widget NumberPicker,你还可以制作这样的东西。您可以像 NumberPicker 小部件一样更改可视化效果,并添加您的回调和其他内容。

你在github上检查过这个吗? ComposeNumberPicker.Kt

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?