סרגל הודעות חטופות

רכיב הסנקבר משמש כהתראה קצרה שמופיעה בתחתית המסך. היא מספקת משוב על פעולה או על פעילות בלי להפריע לחוויית המשתמש. ההודעות הקצרות נעלמות אחרי כמה שניות. המשתמש יכול גם לסגור אותן באמצעות פעולה, כמו הקשה על לחצן.

ריכזנו כאן שלושה תרחישי שימוש שכדאי להשתמש בהם בסרגל אינטראקטיבי:

  • אישור פעולה: אחרי שמשתמש מוחק אימייל או הודעה, מופיע סרגל אינטראקטיבי כדי לאשר את הפעולה, ומוצעת האפשרות ביטול.
  • סטטוס הרשת: אם החיבור לאינטרנט של האפליקציה מתנתק, מופיע סרגל אינטראקטיבי עם הודעה שהאפליקציה עכשיו במצב אופליין.
  • שליחת נתונים: אחרי שליחת טופס או עדכון הגדרות, מוצגת הודעה קצרה שמאשרת שהשינוי נשמר בהצלחה.
דוגמאות לרכיבי UI של סרגל אינטראקטיבי.
תרשים 1. דוגמאות לשימוש בסרגל אינטראקטיבי.

דוגמה בסיסית

כדי להטמיע סרגל אינטראקטיבי, קודם יוצרים SnackbarHost, שכולל מאפיין SnackbarHostState. ‫SnackbarHostState מספק גישה לפונקציה showSnackbar() שבה אפשר להשתמש כדי להציג את הסרגל האינטראקטיבי.

הפונקציה להשהיה דורשת CoroutineScope – כמו זו שמוחזרת על ידי rememberCoroutineScope – ואפשר לקרוא לה בתגובה לאירועים בממשק המשתמש כדי להציג Snackbar בתוך Scaffold.

val scope = rememberCoroutineScope()
val snackbarHostState = remember { SnackbarHostState() }
Scaffold(
    snackbarHost = {
        SnackbarHost(hostState = snackbarHostState)
    },
    floatingActionButton = {
        ExtendedFloatingActionButton(
            text = { Text("Show snackbar") },
            icon = { Icon(Icons.Filled.Image, contentDescription = "") },
            onClick = {
                scope.launch {
                    snackbarHostState.showSnackbar("Snackbar")
                }
            }
        )
    }
) { contentPadding ->
    // Screen content
}

סרגל אינטראקטיבי עם פעולה

אפשר לספק פעולה אופציונלית ולשנות את משך הזמן של Snackbar. הפונקציה snackbarHostState.showSnackbar() מקבלת פרמטרים נוספים של actionLabel ו-duration, ומחזירה SnackbarResult.

val scope = rememberCoroutineScope()
val snackbarHostState = remember { SnackbarHostState() }
Scaffold(
    snackbarHost = {
        SnackbarHost(hostState = snackbarHostState)
    },
    floatingActionButton = {
        ExtendedFloatingActionButton(
            text = { Text("Show snackbar") },
            icon = { Icon(Icons.Filled.Image, contentDescription = "") },
            onClick = {
                scope.launch {
                    val result = snackbarHostState
                        .showSnackbar(
                            message = "Snackbar",
                            actionLabel = "Action",
                            // Defaults to SnackbarDuration.Short
                            duration = SnackbarDuration.Indefinite
                        )
                    when (result) {
                        SnackbarResult.ActionPerformed -> {
                            /* Handle snackbar action performed */
                        }
                        SnackbarResult.Dismissed -> {
                            /* Handle snackbar dismissed */
                        }
                    }
                }
            }
        )
    }
) { contentPadding ->
    // Screen content
}

אפשר לספק Snackbar מותאם אישית באמצעות הפרמטר snackbarHost. מידע נוסף מופיע בSnackbarHostמסמכי הפניית ה-API.

נקודות עיקריות

  • actionLabel = "Action": הגדרת הטקסט של כפתור הפעולה.
  • duration = SnackbarDuration.Indefinite: שומר את חלונית ה-snackbar בתצוגה עד שהמשתמש או התוכנית סוגרים אותה.
  • SnackbarResult.ActionPerformed: מציין שהמשתמש לחץ על לחצן הפעולה של חלונית ה-Snackbar.
  • SnackbarResult.Dismissed: מציין שהמשתמש סגר את ההודעה הקצרה בלי ללחוץ על כפתור הפעולה.