Thanh điều hướng

Thanh điều hướng cho phép người dùng chuyển đổi giữa các đích đến trong một ứng dụng. Bạn nên sử dụng thanh điều hướng cho:

  • Từ 3 đến 5 điểm đến có tầm quan trọng ngang nhau
  • Kích thước cửa sổ thu gọn
  • Các đích đến nhất quán trên các màn hình ứng dụng
 Một thanh điều hướng có 4 đích đến. Mỗi đích đến đều có một tên giữ chỗ được gọi là
Hình 1. Một thanh điều hướng có 4 đích đến.

Trang này hướng dẫn bạn cách hiển thị một thanh điều hướng trong ứng dụng của mình cùng với các màn hình liên quan và chế độ điều hướng cơ bản.

Nền tảng API

Sử dụng các thành phần kết hợp NavigationBarNavigationBarItem để triển khai logic chuyển đổi đích đến. Mỗi NavigationBarItem đại diện cho một điểm đến duy nhất.

NavigationBarItem bao gồm các thông số chính sau:

  • selected: Xác định xem mục hiện tại có được làm nổi bật bằng hình ảnh hay không.
  • onClick(): Một hàm lambda bắt buộc xác định hành động sẽ được thực hiện khi người dùng nhấp vào mục. Đây là nơi bạn thường xử lý các sự kiện điều hướng, cập nhật trạng thái của mục đã chọn hoặc tải nội dung tương ứng.
  • label: Hiển thị văn bản trong mục. Không bắt buộc.
  • icon: Hiển thị một biểu tượng trong mục. Không bắt buộc.

Ví dụ: Thanh điều hướng dưới cùng

Đoạn mã sau đây triển khai một thanh điều hướng dưới cùng có các mục để người dùng có thể di chuyển giữa các màn hình trong một ứng dụng:

@Composable
fun NavigationBarExample(modifier: Modifier = Modifier) {
    val navController = rememberNavController()
    val startDestination = Destination.SONGS
    var selectedDestination by rememberSaveable { mutableIntStateOf(startDestination.ordinal) }

    Scaffold(
        modifier = modifier,
        bottomBar = {
            NavigationBar(windowInsets = NavigationBarDefaults.windowInsets) {
                Destination.entries.forEachIndexed { index, destination ->
                    NavigationBarItem(
                        selected = selectedDestination == index,
                        onClick = {
                            navController.navigate(route = destination.route)
                            selectedDestination = index
                        },
                        icon = {
                            Icon(
                                destination.icon,
                                contentDescription = destination.contentDescription
                            )
                        },
                        label = { Text(destination.label) }
                    )
                }
            }
        }
    ) { contentPadding ->
        AppNavHost(navController, startDestination, modifier = Modifier.padding(contentPadding))
    }
}

Điểm chính

  • NavigationBar hiển thị một tập hợp các mục, trong đó mỗi mục tương ứng với một Destination.
  • val navController = rememberNavController() tạo và ghi nhớ một thực thể của NavHostController, đối tượng này quản lý hoạt động điều hướng trong một NavHost.
  • var selectedDestination by rememberSaveable { mutableIntStateOf(startDestination.ordinal) } quản lý trạng thái của mục hiện được chọn.
  • var selectedDestination by rememberSaveable { mutableIntStateOf(startDestination.ordinal) } quản lý trạng thái của mục hiện được chọn.
    • startDestination.ordinal lấy chỉ mục số (vị trí) của mục nhập enum Destination.SONGS.
  • Khi một mục được nhấp vào, navController.navigate(route = destination.route) sẽ được gọi để chuyển đến màn hình tương ứng.
  • Hàm lambda onClick của NavigationBarItem sẽ cập nhật trạng thái selectedDestination để làm nổi bật trực quan mục được nhấp.
  • Thao tác này gọi thành phần kết hợp AppNavHost, truyền navControllerstartDestination để hiển thị nội dung thực tế của màn hình đã chọn.

Kết quả

Hình ảnh sau đây cho thấy thanh điều hướng có được từ đoạn mã trước:

Màn hình ứng dụng có 3 điểm đến được liệt kê theo chiều ngang trong thanh điều hướng dưới cùng: Bài hát, Album và Danh sách phát. Mỗi đích đến đều có một biểu tượng liên quan đi kèm (ví dụ: nốt nhạc cho "Bài hát").
Hình 2. Thanh điều hướng chứa 3 đích đến có biểu tượng liên kết: Bài hát, Đĩa nhạc và Danh sách phát.

Tài nguyên khác