แถบข้างสำหรับไปยังส่วนต่างๆ

รางช่วยให้เข้าถึงปลายทางในแอปที่ทำงานบนอุปกรณ์ที่มีหน้าจอขนาดใหญ่ คุณควรใช้แถบนําทางในกรณีต่อไปนี้

  • ปลายทางระดับบนสุดที่ต้องเข้าถึงได้จากทุกที่ในแอป
  • จุดหมายหลัก 3-7 แห่ง
  • เลย์เอาต์แท็บเล็ตหรือเดสก์ท็อป
แถบนำทางแนวตั้งทางด้านซ้ายของหน้าจอซึ่งมีปลายทาง 4 แห่ง (ไฟล์ทั้งหมด ล่าสุด รูปภาพ และไลบรารี) โดยแต่ละปลายทางจะมีไอคอนที่เกี่ยวข้องและปุ่มการดำเนินการแบบลอยตัว
รูปที่ 1 แถบนําทางที่มีปลายทาง 4 แห่งและปุ่มการทำงานแบบลอย

หน้านี้จะแสดงวิธีแสดงรางในแอปด้วยหน้าจอที่เกี่ยวข้องและการนำทางพื้นฐาน

แพลตฟอร์ม API

ใช้ NavigationRail ที่คอมโพสิเบิลกับ NavigationRailItem เพื่อติดตั้งใช้งานรางในแอปพลิเคชัน NavigationRailItem แสดงถึงรายการรางเดียวในคอลัมน์ราง

NavigationRailItem มีพารามิเตอร์หลักต่อไปนี้

  • selected: กำหนดว่ารายการโฆษณาแบบเรียลไทม์ปัจจุบันจะไฮไลต์ด้วยภาพหรือไม่
  • onClick(): ฟังก์ชัน Lambda ที่ต้องระบุซึ่งกําหนดการดําเนินการที่จะทําเมื่อผู้ใช้คลิกรายการโฆษณา โดยปกติแล้ว คุณจะจัดการเหตุการณ์การนําทาง อัปเดตสถานะรายการโฆษณาที่เลือก หรือโหลดเนื้อหาที่เกี่ยวข้องในส่วนนี้
  • label: แสดงข้อความภายในรายการโฆษณาแบบราง ไม่บังคับ
  • icon: แสดงไอคอนภายในรายการราง ไม่บังคับ

ตัวอย่าง: การนําทางตามราง

ข้อมูลโค้ดต่อไปนี้ใช้แถบข้างสำหรับไปยังส่วนต่างๆ เพื่อให้ผู้ใช้ไปยังหน้าจอต่างๆ ในแอปได้

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

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

ข้อมูลสำคัญ

  • NavigationRail แสดงคอลัมน์แนวตั้งของรายการราง โดยแต่ละรายการจะสอดคล้องกับ Destination
  • val navController = rememberNavController() จะสร้างและจดจําNavHostController ขึ้นมา ซึ่งจะจัดการการนําทางภายใน NavHost
  • var selectedDestination by rememberSaveable { mutableIntStateOf(startDestination.ordinal) } จัดการสถานะของรายการรางที่เลือกอยู่ในปัจจุบัน
    • startDestination.ordinal รับดัชนีตัวเลข (ตำแหน่ง) ของรายการ enum Destination.SONGS
  • เมื่อคลิกรายการในแถบ navController.navigate(route = destination.route) จะเรียกให้ไปยังหน้าจอที่เกี่ยวข้อง
  • onClick lambda ของ NavigationRailItem จะอัปเดตสถานะ selectedDestination เพื่อไฮไลต์รายการในแถบโฆษณาที่คลิกให้เห็น
  • โดยจะเรียกใช้คอมโพสิชัน AppNavHost โดยส่ง navController และ startDestination เพื่อแสดงเนื้อหาจริงของหน้าจอที่เลือก

ผลลัพธ์

รูปภาพต่อไปนี้แสดงผลลัพธ์ของข้อมูลโค้ดก่อนหน้า

แถบนำทางแนวตั้งที่มีปลายทาง 3 แห่งพร้อมไอคอนที่เกี่ยวข้อง ได้แก่ เพลง อัลบั้ม และเพลย์ลิสต์ ไอคอนจะระบุวัตถุประสงค์ของปุ่มการนำทางแต่ละปุ่มในแถบนำทาง โดยปลายทางแต่ละแห่งจะมีไอคอนที่เกี่ยวข้อง (เช่น โน้ตเพลงสำหรับ
รูปที่ 2 แถบนําทางที่มีปลายทาง 3 แห่งพร้อมไอคอนที่เกี่ยวข้อง ได้แก่ เพลง อัลบั้ม และเพลย์ลิสต์

แหล่งข้อมูลเพิ่มเติม