Флажки позволяют пользователям выбирать один или несколько элементов из списка. Вы можете использовать флажок, чтобы позволить пользователю делать следующее:
- Включите или выключите элемент.
- Выберите один из нескольких вариантов в списке.
- Укажите согласие или принятие.
Анатомия
Флажок состоит из следующих элементов:
- Box : это контейнер для флажка.
- Проверка : это визуальный индикатор, показывающий, установлен флажок или нет.
- Метка : это текст, описывающий флажок.
Штаты
Флажок может находиться в одном из трёх состояний:
- Не выбрано : флажок не установлен. Коробка пуста.
- Неопределенный : флажок находится в неопределенном состоянии. В поле есть тире.
- Выбрано : флажок установлен. В поле стоит галочка.
На следующем изображении показаны три состояния флажка.
Выполнение
Вы можете использовать компонуемый Checkbox
для создания флажка в своем приложении. Необходимо учитывать всего несколько ключевых параметров:
-
checked
: логическое значение, которое определяет, установлен ли флажок или нет. -
onCheckedChange()
: функция, которую приложение вызывает, когда пользователь нажимает на флажок.
В следующем фрагменте показано, как использовать составной Checkbox
:
@Composable fun CheckboxMinimalExample() { var checked by remember { mutableStateOf(true) } Row( verticalAlignment = Alignment.CenterVertically, ) { Text( "Minimal checkbox" ) Checkbox( checked = checked, onCheckedChange = { checked = it } ) } Text( if (checked) "Checkbox is checked" else "Checkbox is unchecked" ) }
Объяснение
Этот код создает флажок, который изначально не установлен. Когда пользователь нажимает на флажок, лямбда onCheckedChange
обновляет checked
состояние.
Результат
В этом примере создается следующий компонент, если флажок не установлен:
А вот как тот же флажок появляется, когда он установлен:
Расширенный пример
Ниже приведен более сложный пример того, как можно реализовать флажки в своем приложении. В этом фрагменте есть родительский флажок и ряд дочерних флажков. Когда пользователь нажимает родительский флажок, приложение проверяет все дочерние флажки.
@Composable fun CheckboxParentExample() { // Initialize states for the child checkboxes val childCheckedStates = remember { mutableStateListOf(false, false, false) } // Compute the parent state based on children's states val parentState = when { childCheckedStates.all { it } -> ToggleableState.On childCheckedStates.none { it } -> ToggleableState.Off else -> ToggleableState.Indeterminate } Column { // Parent TriStateCheckbox Row( verticalAlignment = Alignment.CenterVertically, ) { Text("Select all") TriStateCheckbox( state = parentState, onClick = { // Determine new state based on current state val newState = parentState != ToggleableState.On childCheckedStates.forEachIndexed { index, _ -> childCheckedStates[index] = newState } } ) } // Child Checkboxes childCheckedStates.forEachIndexed { index, checked -> Row( verticalAlignment = Alignment.CenterVertically, ) { Text("Option ${index + 1}") Checkbox( checked = checked, onCheckedChange = { isChecked -> // Update the individual child state childCheckedStates[index] = isChecked } ) } } } if (childCheckedStates.all { it }) { Text("All options selected") } }
Объяснение
Ниже приведены несколько моментов, которые следует отметить в этом примере:
- Государственное управление :
-
childCheckedStates
: список логических значений, использующихmutableStateOf()
для отслеживания проверенного состояния каждого дочернего флажка. -
parentState
:ToggleableState
, значение которого извлекается из состояний дочерних флажков.
-
- Компоненты пользовательского интерфейса :
-
TriStateCheckbox
: необходим для родительского флажка, поскольку он имеет параметрstate
, который позволяет установить для него неопределенное значение. -
Checkbox
: используется для каждого дочернего флажка, состояние которого связано с соответствующим элементом вchildCheckedStates
. -
Text
: отображает метки и сообщения («Выбрать все», «Опция X», «Выбраны все параметры»).
-
- Логика :
-
onClick
родительского флажка обновляет все дочерние флажки до состояния, противоположного текущему родительскому состоянию. -
onCheckedChange
каждого дочернего флажка обновляет соответствующее состояние в спискеchildCheckedStates
. - Код отображает «
All options selected
», когда установлены все дочерние флажки.
-
Результат
В этом примере создается следующий компонент, когда все флажки сняты.
Аналогично, вот как компонент выглядит, когда отмечены все параметры, например, когда пользователь нажимает «Выбрать все»:
Если отмечен только один параметр, родительский флажок отображает неопределенное состояние: