Hướng dẫn này giải thích cách tạo thanh ứng dụng trên cùng động trong Compose, thay đổi các lựa chọn khi chọn mục trong danh sách. Bạn có thể sửa đổi tiêu đề và các thao tác của thanh ứng dụng trên cùng dựa trên trạng thái lựa chọn.
Triển khai hành vi của thanh ứng dụng trên cùng động
Mã này xác định một hàm composable cho thanh ứng dụng trên cùng, thay đổi dựa trên lựa chọn mục:
@Composable fun AppBarSelectionActions( selectedItems: Set<Int>, modifier: Modifier = Modifier, ) { val hasSelection = selectedItems.isNotEmpty() val topBarText = if (hasSelection) { "Selected ${selectedItems.size} items" } else { "List of items" } TopAppBar( title = { Text(topBarText) }, colors = TopAppBarDefaults.topAppBarColors( containerColor = MaterialTheme.colorScheme.primaryContainer, titleContentColor = MaterialTheme.colorScheme.primary, ), actions = { if (hasSelection) { IconButton(onClick = { /* click action */ }) { Icon( imageVector = Icons.Filled.Share, contentDescription = "Share items" ) } } }, modifier = modifier ) }
Các điểm chính về mã
AppBarSelectionActionschấp nhận mộtSetchỉ mục mục đã chọn.topBarTextthay đổi tuỳ thuộc vào việc bạn có chọn mục nào hay không.- Khi bạn chọn các mục, văn bản mô tả số lượng mục đã chọn
xuất hiện trong
TopAppBar. - Nếu bạn không chọn mục nào,
topBarTextsẽ là "List of items" (Danh sách mục).
- Khi bạn chọn các mục, văn bản mô tả số lượng mục đã chọn
xuất hiện trong
- Khối
actionsxác định các thao tác mà bạn hiển thị trong thanh ứng dụng trên cùng. NếuhasSelectionlà true, thì biểu tượng chia sẻ sẽ xuất hiện sau văn bản. - Lambda
onClickcủaIconButtonxử lý thao tác chia sẻ khi bạn nhấp vào biểu tượng.
Kết quả
Tích hợp danh sách có thể chọn vào thanh ứng dụng trên cùng động
Ví dụ này minh hoạ cách thêm danh sách có thể chọn vào thanh ứng dụng trên cùng động:
@Composable private fun AppBarMultiSelectionExample( modifier: Modifier = Modifier, ) { val listItems by remember { mutableStateOf(listOf(1, 2, 3, 4, 5, 6)) } var selectedItems by rememberSaveable { mutableStateOf(setOf<Int>()) } Scaffold( modifier = modifier, topBar = { AppBarSelectionActions(selectedItems) } ) { innerPadding -> LazyColumn(contentPadding = innerPadding) { itemsIndexed(listItems) { _, index -> val isItemSelected = selectedItems.contains(index) ListItemSelectable( selected = isItemSelected, Modifier .combinedClickable( interactionSource = remember { MutableInteractionSource() }, indication = null, onClick = { /* click action */ }, onLongClick = { if (isItemSelected) selectedItems -= index else selectedItems += index } ) ) } } } }
Các điểm chính về mã
- Thanh trên cùng cập nhật dựa trên số lượng mục trong danh sách mà bạn chọn.
selectedItemsgiữ tập hợp chỉ mục mục đã chọn.AppBarMultiSelectionExamplesử dụngScaffoldđể cấu trúc màn hình.topBar = { AppBarSelectionActions(selectedItems) }đặt thành phần kết hợpAppBarSelectionActionslàm thanh ứng dụng trên cùng.AppBarSelectionActionsnhận trạng tháiselectedItems.
LazyColumnhiển thị các mục trong danh sách dọc, chỉ hiển thị các mục có thể nhìn thấy trên màn hình.ListItemSelectableđại diện cho một mục trong danh sách có thể chọn.combinedClickablecho phép xử lý cả thao tác nhấp và nhấp giữ để chọn mục. Thao tác nhấp thực hiện một hành động, trong khi thao tác nhấp giữ một mục sẽ chuyển đổi trạng thái lựa chọn của mục đó.
Kết quả