Флажок

Флажки позволяют пользователям выбирать один или несколько элементов из списка. Вы можете использовать флажок, чтобы позволить пользователю делать следующее:

  • Включите или выключите элемент.
  • Выберите один из нескольких вариантов в списке.
  • Укажите согласие или принятие.

Анатомия

Флажок состоит из следующих элементов:

  • Box : это контейнер для флажка.
  • Проверка : это визуальный индикатор, показывающий, установлен флажок или нет.
  • Метка : это текст, описывающий флажок.

состояния

Флажок может находиться в одном из трех состояний:

  • Не выбрано : флажок не установлен. Коробка пуста.
  • Неопределенный : флажок находится в неопределенном состоянии. В поле есть тире.
  • Выбрано : флажок установлен. В поле стоит галочка.

На следующем изображении показаны три состояния флажка.

Пример компонента флажка в каждом из трех состояний: не выбрано, выбрано и неопределенно.
Рисунок 1. Три состояния флажка. Невыбранный, неопределенный и выбранный.

Выполнение

Вы можете использовать компонуемый 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 состояние.

Результат

В этом примере создается следующий компонент, если флажок не установлен:

Неотмеченный флажок с меткой. Текст под ним гласит: «Флажок снят».
Рисунок 2. Флажок снят

А вот как тот же флажок появляется, когда он установлен:

Установленный флажок с меткой. Текст под ним гласит: «Флажок установлен».
Рисунок 3. Установленный флажок

Расширенный пример

Ниже приведен более сложный пример того, как можно реализовать флажки в своем приложении. В этом фрагменте есть родительский флажок и ряд дочерних флажков. Когда пользователь нажимает родительский флажок, приложение проверяет все дочерние флажки.

@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 », когда установлены все дочерние флажки.

Результат

В этом примере создается следующий компонент, когда все флажки сняты.

Серия неотмеченных флажков с меткой.
Рисунок 4. Неотмеченные флажки

Аналогично, вот как компонент выглядит, когда отмечены все параметры, например, когда пользователь нажимает «Выбрать все»:

Серия отмеченных флажков с меткой. Первый помечен как «выбрать все». Под ними находится текстовый компонент с надписью «выбраны все параметры».
Рисунок 5. Установленные флажки

Если отмечен только один параметр, родительский флажок отображает неопределенное состояние:

Серия неотмеченных флажков с меткой. Все, кроме одного, не отмечены. Флажок с надписью «Выбрать все» является неопределенным и отображается тире.
Рисунок 6. Неопределенный флажок

Дополнительные ресурсы