Флажок

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

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

Анатомия

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

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

Штаты

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

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

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

Пример компонента флажка в каждом из трех его состояний: не выбран, выбран и неопределен.
Рисунок 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. Неопределенный флажок

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