如何将时间选择器的结果设置为TextField

时间:2020-10-23 10:00:49

标签: android android-timepicker android-jetpack-compose

我想将时间选择器的结果设置为TextField,如何通过onValueChange实现它?

@Composable
fun TestTimePickerTextField(
    selectTime: (Context) -> String
) {
    val context = ContextAmbient.current
    TextField(
        // How to pass result to TextField
    )
}

// viewModel
fun selectTime(context: Context): String {
    var time = ""
    val currentDateTime = Calendar.getInstance()
    val startYear = currentDateTime.get(Calendar.YEAR)
    val startMonth = currentDateTime.get(Calendar.MONTH)
    val startDay = currentDateTime.get(Calendar.DAY_OF_MONTH)
    val startHour = currentDateTime.get(Calendar.HOUR_OF_DAY)
    val startMinute = currentDateTime.get(Calendar.MINUTE)
    DatePickerDialog(context, { _, year, month, day ->
        TimePickerDialog(context, { _, hour, minute ->
            val pickedDateTime = Calendar.getInstance()
            pickedDateTime.set(year, month, day, hour, minute)
            time = "$year-$month-$day $hour:$minute"
        }, startHour, startMinute, false).show()
    }, startYear, startMonth, startDay).show()
    return time
}

1 个答案:

答案 0 :(得分:2)

ViewModel不应包含具有上下文的方法。将所有与Android相关的代码放入活动/片段中。

活动中:

@Composable
fun init() {
    val time by viewModel.time.observeAsState()
    MaterialTheme {
        Column {
            TextButton(onClick = { selectTime() }) {
                Text("Select time")
            }
            Text(time ?: "no time set")
        }
    }
}

private fun selectTime(): String {
    var time = ""
    val currentDateTime = Calendar.getInstance()
    val startYear = currentDateTime.get(Calendar.YEAR)
    val startMonth = currentDateTime.get(Calendar.MONTH)
    val startDay = currentDateTime.get(Calendar.DAY_OF_MONTH)
    val startHour = currentDateTime.get(Calendar.HOUR_OF_DAY)
    val startMinute = currentDateTime.get(Calendar.MINUTE)
    DatePickerDialog(this, { _, year, month, day ->
        TimePickerDialog(context, { _, hour, minute ->
            val pickedDateTime = Calendar.getInstance()
            pickedDateTime.set(year, month, day, hour, minute)
            time = "$year-$month-$day $hour:$minute"
            viewModel.updateTime(time)
        }, startHour, startMinute, false).show()
    }, startYear, startMonth, startDay).show()
    return time
}

ViewModel类:

class MainViewModel : ViewModel() {

var time = MutableLiveData<String>()

fun updateTime(time: String) {
    this.time.value = time
}
}