Thanh trượt

Thành phần kết hợp Slider cho phép người dùng đưa ra lựa chọn trong một loạt giá trị. Bạn có thể dùng thanh trượt để cho phép người dùng thực hiện các thao tác sau:

  • Điều chỉnh chế độ cài đặt sử dụng khoảng giá trị, chẳng hạn như âm lượng và độ sáng.
  • Lọc dữ liệu trong biểu đồ như khi đặt khoảng giá.
  • Thông tin do người dùng cung cấp, chẳng hạn như đặt điểm xếp hạng trong một bài đánh giá.

Thanh trượt chứa bản nhạc, thumb, nhãn giá trị và dấu kiểm:

  • Theo dõi: Thành phần theo dõi là thanh ngang đại diện cho phạm vi giá trị mà thanh trượt có thể nhận.
  • Thumb: Thumb là một phần tử điều khiển có thể kéo trên thanh trượt, cho phép người dùng chọn một giá trị cụ thể trong phạm vi do kênh xác định.
  • Dấu kiểm: Dấu kiểm là các điểm đánh dấu hoặc chỉ báo trực quan không bắt buộc xuất hiện dọc theo đường trượt của thanh trượt.
Thanh trượt có các dấu thumb, track và tick.
Hình 1. Cách triển khai thanh trượt.

Cách triển khai cơ bản

Hãy xem tài liệu tham khảo Slider để biết định nghĩa đầy đủ về API. Sau đây là một số thông số chính cho thành phần kết hợp Slider:

  • value: Giá trị hiện tại của thanh trượt.
  • onValueChange: Hàm lambda được gọi mỗi khi giá trị được thay đổi.
  • enabled: Một giá trị boolean cho biết liệu người dùng có thể tương tác với thanh trượt hay không.

Sau đây là ví dụ về một thanh trượt đơn giản. Điều đó cho phép người dùng chọn một giá trị từ 0.0 đến 1.0. Vì người dùng có thể chọn bất kỳ giá trị nào trong phạm vi đó, nên thanh trượt có trạng thái liên tục.

@Preview
@Composable
fun SliderMinimalExample() {
    var sliderPosition by remember { mutableFloatStateOf(0f) }
    Column {
        Slider(
            value = sliderPosition,
            onValueChange = { sliderPosition = it }
        )
        Text(text = sliderPosition.toString())
    }
}

Phương thức triển khai có dạng như sau:

Một thành phần thanh trượt có giá trị được chọn khoảng ba phần tư dọc theo đường đi.
Hình 2. Cách triển khai cơ bản của thanh trượt.

Cách triển khai nâng cao

Khi triển khai một thanh trượt phức tạp hơn, bạn có thể sử dụng thêm các tham số sau.

  • colors: Một thực thể của SliderColors cho phép bạn kiểm soát màu sắc của thanh trượt.
  • valueRange: Phạm vi giá trị mà thanh trượt có thể nhận.
  • steps: Số rãnh trên thanh trượt mà ngón cái bật vào.

Đoạn mã sau đây sẽ triển khai một thanh trượt có 3 bước, với phạm vi từ 0.0 đến 50.0. Vì ngón tay cái gắn vào từng bước, nên thanh trượt này là rời rạc.

@Preview
@Composable
fun SliderAdvancedExample() {
    var sliderPosition by remember { mutableFloatStateOf(0f) }
    Column {
        Slider(
            value = sliderPosition,
            onValueChange = { sliderPosition = it },
            colors = SliderDefaults.colors(
                thumbColor = MaterialTheme.colorScheme.secondary,
                activeTrackColor = MaterialTheme.colorScheme.secondary,
                inactiveTrackColor = MaterialTheme.colorScheme.secondaryContainer,
            ),
            steps = 3,
            valueRange = 0f..50f
        )
        Text(text = sliderPosition.toString())
    }
}

Quy trình triển khai có dạng như sau:

Viết văn bản thay thế tại đây
Hình 3. Thanh trượt hiển thị các bước và một phạm vi giá trị đã đặt.

Thanh trượt phạm vi

Bạn cũng có thể dùng thành phần kết hợp RangeSlider dành riêng. Điều này cho phép người dùng chọn 2 giá trị. Điều này có thể hữu ích trong những trường hợp như khi người dùng muốn chọn mức giá tối thiểu và tối đa.

Ví dụ sau đây là một ví dụ tương đối đơn giản về thanh trượt phạm vi liên tục.

@Preview
@Composable
fun RangeSliderExample() {
    var sliderPosition by remember { mutableStateOf(0f..100f) }
    Column {
        RangeSlider(
            value = sliderPosition,
            steps = 5,
            onValueChange = { range -> sliderPosition = range },
            valueRange = 0f..100f,
            onValueChangeFinished = {
                // launch some business logic update with the state you hold
                // viewModel.updateSelectedSliderValue(sliderPosition)
            },
        )
        Text(text = sliderPosition.toString())
    }
}

Thành phần thanh trượt dải ô với hai giá trị được chọn. Nhãn hiển thị giới hạn trên và giới hạn dưới của lựa chọn.
Hình 4. Cách triển khai thanh trượt phạm vi.

Tài nguyên khác