Pemilih waktu menyediakan cara bagi pengguna untuk memilih waktu. Anda dapat
menggunakan composable TimePicker
dan TimeInput
untuk menerapkan pemilih
waktu di aplikasi Anda.
Jenis
Ada dua jenis pemilih waktu:
- Telepon: Memungkinkan pengguna menyetel waktu dengan menggerakkan tuas di sekeliling kenop.
- Input: Memungkinkan pengguna menyetel waktu menggunakan keyboard.
Gambar berikut memberikan contoh pemilih waktu panggilan di sebelah kiri, dan pemilih waktu input di sebelah kanan:
Platform API
Untuk menerapkan pemilih waktu, gunakan composable
TimePicker
atau TimeInput
:
TimePicker
: Mengimplementasikan pemilih waktu panggilan.TimeInput
: Menerapkan pemilih waktu input.
Status
Untuk TimePicker
dan TimeInput
, Anda juga harus meneruskan
TimePickerState
. Dengan begitu, Anda dapat menetapkan waktu yang dipilih secara default yang muncul
di pemilih. Fungsi ini juga merekam waktu yang dipilih pengguna menggunakan pemilih.
Dialog
Pemilih waktu muncul dalam dialog. Contoh dalam panduan ini tidak menggunakan dialog. Untuk contoh yang menggunakan dialog, lihat panduan Dialog untuk alat pilih waktu.
Pemilih waktu panggilan
Cuplikan ini menunjukkan cara menerapkan pemilih waktu panggilan dasar.
@Composable fun DialExample( onConfirm: () -> Unit, onDismiss: () -> Unit, ) { val currentTime = Calendar.getInstance() val timePickerState = rememberTimePickerState( initialHour = currentTime.get(Calendar.HOUR_OF_DAY), initialMinute = currentTime.get(Calendar.MINUTE), is24Hour = true, ) Column { TimePicker( state = timePickerState, ) Button(onClick = onDismiss) { Text("Dismiss picker") } Button(onClick = onConfirm) { Text("Confirm selection") } } }
Pertimbangkan hal berikut dalam cuplikan ini:
Calendar.getInstance()
melakukan inisialisasiTimePickerState
dengan waktu saat ini.- Contoh ini menggunakan
java.util.Calendar
. Aktifkan desugaring API Java 8+ di project Anda untuk menggunakanjava.time.LocalTime
secara alternatif di semua versi Android.
- Contoh ini menggunakan
- Composable
TimePicker
menampilkan alat pilih waktu, yang menggunakantimePickerState
sebagai parameter. - Implementasi ini mencakup dua tombol: satu untuk mengonfirmasi pilihan dan satu lagi untuk menutup alat pilih.
Implementasi ini muncul sebagai berikut:
Memasukkan pemilih waktu
Cuplikan ini menunjukkan cara mengimplementasikan pemilih waktu gaya input dasar.
@Composable fun InputExample( onConfirm: () -> Unit, onDismiss: () -> Unit, ) { val currentTime = Calendar.getInstance() val timePickerState = rememberTimePickerState( initialHour = currentTime.get(Calendar.HOUR_OF_DAY), initialMinute = currentTime.get(Calendar.MINUTE), is24Hour = true, ) Column { TimeInput( state = timePickerState, ) Button(onClick = onDismiss) { Text("Dismiss picker") } Button(onClick = onConfirm) { Text("Confirm selection") } } }
Poin-poin penting yang perlu diperhatikan dalam penerapan ini:
- Strukturnya pada dasarnya sama dengan pemilih waktu panggilan, dengan perbedaan utama
adalah penggunaan
TimeInput
, bukanTimePicker
. - Parameter
is24Hour
untuktimePickerState
ditetapkan secara eksplisit ketrue
. Secara default, nilainya adalahfalse
.
Implementasi ini muncul sebagai berikut:
Menggunakan status
Untuk memanfaatkan waktu yang dipilih pengguna dalam alat pilih waktu, teruskan
TimePickerState
yang sesuai ke fungsi onConfirm
Anda. Composable
induk kemudian dapat mengakses waktu yang dipilih melalui TimePickerState.hour
dan
TimePickerState.minute
.
Cuplikan berikut menunjukkan cara melakukannya:
@Composable fun DialUseStateExample( onConfirm: (TimePickerState) -> Unit, onDismiss: () -> Unit, ) { val currentTime = Calendar.getInstance() val timePickerState = rememberTimePickerState( initialHour = currentTime.get(Calendar.HOUR_OF_DAY), initialMinute = currentTime.get(Calendar.MINUTE), is24Hour = true, ) Column { TimePicker( state = timePickerState, ) Button(onClick = onDismiss) { Text("Dismiss picker") } Button(onClick = { onConfirm(timePickerState) }) { Text("Confirm selection") } } }
Kemudian, Anda dapat memanggil composable seperti ini:
var selectedTime: TimePickerState? by remember { mutableStateOf(null) }
// ...
DialUseStateExample(
onDismiss = {
showDialExample = false
},
onConfirm = {
time ->
selectedTime = time
showDialExample = false
},
)
// ...
if (selectedTime != null) {
val cal = Calendar.getInstance()
cal.set(Calendar.HOUR_OF_DAY, selectedTime!!.hour)
cal.set(Calendar.MINUTE, selectedTime!!.minute)
cal.isLenient = false
Text("Selected time = ${formatter.format(cal.time)}")
} else {
Text("No time selected.")
}
Untuk mengetahui detail selengkapnya, lihat penerapan lengkap di aplikasi cuplikan.