הרכיב חלונית הזזה לניווט הוא תפריט נשלף שמאפשר למשתמשים לנווט בין הקטעים השונים באפליקציה. המשתמשים יכולים להפעיל אותו בהחלקה מהצד או בהקשה על סמל התפריט.
ריכזנו כאן שלושה תרחישים לדוגמה להטמעה של מגירת ניווט:
- ארגון התוכן: מאפשרים למשתמשים לעבור בין קטגוריות שונות, כמו באפליקציות של חדשות או בלוגים.
- ניהול חשבון: קישורים מהירים לקטעים של הגדרות החשבון והפרופיל באפליקציות עם חשבונות משתמשים.
- גילוי תכונות: ארגון של כמה תכונות והגדרות בתפריט אחד כדי להקל על המשתמשים לגלות את התכונות ולגשת אליהן באפליקציות מורכבות.
ב-Material Design, יש שני סוגים של מגירות ניווט:
- רגיל: שיתוף מקום במסך עם תוכן אחר.
- חלון מודאלי: מופיע מעל תוכן אחר במסך.
דוגמה
אפשר להשתמש בקוד ModalNavigationDrawer קומפוזבילי כדי להטמיע חלונית הזזה לניווט.
משתמשים במשבצת drawerContent כדי לספק ModalDrawerSheet ואת התוכן של מגירת הצד, כמו בדוגמה הבאה:
ModalNavigationDrawer( drawerContent = { ModalDrawerSheet { Text("Drawer title", modifier = Modifier.padding(16.dp)) HorizontalDivider() NavigationDrawerItem( label = { Text(text = "Drawer Item") }, selected = false, onClick = { /*TODO*/ } ) // ...other drawer items } } ) { // Screen content }
ModalNavigationDrawer מקבלת מספר פרמטרים נוספים של מגירה. לדוגמה, אפשר להפעיל או להשבית אם חלונית ההזזה תגיב לגרירות או לא באמצעות הפרמטר gesturesEnabled, כמו בדוגמה הבאה:
ModalNavigationDrawer( drawerContent = { ModalDrawerSheet { // Drawer contents } }, gesturesEnabled = false ) { // Screen content }
התנהגות של קבוצת הבקרה
כדי לשלוט באופן הפתיחה והסגירה של מגירת האפליקציות, משתמשים בDrawerState. צריך להעביר DrawerState אל ModalNavigationDrawer באמצעות הפרמטר drawerState.
DrawerState מספק גישה לפונקציות open ו-close, וגם לנכסים שקשורים למצב הנוכחי של חלונית הזזה. כדי להשתמש בפונקציות ההשעיה האלה צריך CoroutineScope, שאפשר ליצור באמצעות rememberCoroutineScope. אפשר גם לקרוא לפונקציות ההשעיה בתגובה לאירועים בממשק המשתמש.
val drawerState = rememberDrawerState(initialValue = DrawerValue.Closed) val scope = rememberCoroutineScope() ModalNavigationDrawer( drawerState = drawerState, drawerContent = { ModalDrawerSheet { /* Drawer content */ } }, ) { Scaffold( floatingActionButton = { ExtendedFloatingActionButton( text = { Text("Show drawer") }, icon = { Icon(Icons.Filled.Add, contentDescription = "") }, onClick = { scope.launch { drawerState.apply { if (isClosed) open() else close() } } } ) } ) { contentPadding -> // Screen content } }
יצירת קבוצות בחלונית הזזה לניווט
קטע הקוד הבא מראה איך ליצור חלונית הזזה לניווט מפורטת, עם קטעים ומחיצות:
@Composable fun DetailedDrawerExample( content: @Composable (PaddingValues) -> Unit ) { val drawerState = rememberDrawerState(initialValue = DrawerValue.Closed) val scope = rememberCoroutineScope() ModalNavigationDrawer( drawerContent = { ModalDrawerSheet { Column( modifier = Modifier.padding(horizontal = 16.dp) .verticalScroll(rememberScrollState()) ) { Spacer(Modifier.height(12.dp)) Text("Drawer Title", modifier = Modifier.padding(16.dp), style = MaterialTheme.typography.titleLarge) HorizontalDivider() Text("Section 1", modifier = Modifier.padding(16.dp), style = MaterialTheme.typography.titleMedium) NavigationDrawerItem( label = { Text("Item 1") }, selected = false, onClick = { /* Handle click */ } ) NavigationDrawerItem( label = { Text("Item 2") }, selected = false, onClick = { /* Handle click */ } ) HorizontalDivider(modifier = Modifier.padding(vertical = 8.dp)) Text("Section 2", modifier = Modifier.padding(16.dp), style = MaterialTheme.typography.titleMedium) NavigationDrawerItem( label = { Text("Settings") }, selected = false, icon = { Icon(Icons.Outlined.Settings, contentDescription = null) }, badge = { Text("20") }, // Placeholder onClick = { /* Handle click */ } ) NavigationDrawerItem( label = { Text("Help and feedback") }, selected = false, icon = { Icon(Icons.AutoMirrored.Outlined.Help, contentDescription = null) }, onClick = { /* Handle click */ }, ) Spacer(Modifier.height(12.dp)) } } }, drawerState = drawerState ) { Scaffold( topBar = { TopAppBar( title = { Text("Navigation Drawer Example") }, navigationIcon = { IconButton(onClick = { scope.launch { if (drawerState.isClosed) { drawerState.open() } else { drawerState.close() } } }) { Icon(Icons.Default.Menu, contentDescription = "Menu") } } ) } ) { innerPadding -> content(innerPadding) } } }
מידע חשוב על הקוד
- מאכלס את
drawerContentעםColumnשמכיל קטעים, קווים מפרידים ופריטי ניווט. -
ModalDrawerSheetמספק סגנון Material Design לחלונית הזזה. -
HorizontalDividerמפריד בין הקטעים בחלונית ההזזה. -
ModalNavigationDrawerיוצר את המגירה. -
drawerContentמגדיר את התוכן של חלונית ההזזה. - בתוך
ModalDrawerSheet, הרכיבColumnמסדר את הרכיבים של המגירה בצורה אנכית. - רכיבי ה-Composable
NavigationDrawerItemמייצגים פריטים נפרדים בחלונית ההזזה. - ה-
Scaffoldמספק את המבנה הבסיסי של המסך, כוללTopAppBar. - הלחצן
navigationIconבTopAppBarשולט במצב הפתוח והסגור של חלונית ההזזה.
תוצאה
בתמונה הבאה אפשר לראות איך חלונית ההזזה נראית כשהיא פתוחה, עם החלקים והפריטים שמוצגים בה:
מקורות מידע נוספים
- Material Design: חלונית הזזה לניווט