קרוסלה

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

יש ארבע פריסות של קרוסלה שמתאימות לתרחישי שימוש שונים:

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

בדף הזה מוסבר איך להטמיע את פריסות הקרוסלה עם כמה תמונות ממוזערות וקרוסלה ללא תמונות ממוזערות. מידע נוסף על סוגי הפריסות מופיע בהנחיות לשימוש בגלגל קרוסלה ב-Material 3.

פלטפורמת ה-API

כדי להטמיע קרוסלות עם כמה פריטים וקרוסלות לא מוגבלות, משתמשים בקומפוזיציות HorizontalMultiBrowseCarousel ו-HorizontalUncontainedCarousel. לרכיבי ה-Composable האלה יש את אותם פרמטרים מרכזיים:

  • state: מופע CarouselState שמנהל את האינדקס הנוכחי של הפריט ואת מיקום הגלילה. כדי ליצור את המצב הזה, משתמשים ב-rememberCarouselState { itemCount }, כאשר itemCount הוא המספר הכולל של הפריטים בקרוסלה.
  • itemSpacing: מגדיר את כמות השטח הריק בין פריטים סמוכים בקרוסלה.
  • contentPadding: מוסיף ריווח מסביב לאזור התוכן של הקרוסלה. משתמשים בזה כדי להוסיף רווח לפני הפריט הראשון או אחרי הפריט האחרון, או כדי לספק שוליים לפריטים באזור שניתן לגלול בו.
  • content: פונקציה הניתנת להגדרה שמקבלת אינדקס של מספר שלם. אפשר להשתמש בפונקציית הלמדה הזו כדי להגדיר את ממשק המשתמש של כל פריט בקרוסלה על סמך האינדקס שלו.

הפונקציות האלה שונות זו מזו באופן שבו הן מציינות את גודל הפריט:

  • itemWidth (עבור HorizontalUncontainedCarousel): מציין את הרוחב המדויק של כל פריט בקרוסלה לא מוגבלת.
  • preferredItemWidth (ל-HorizontalMultiBrowseCarousel): מציע את הרוחב האידיאלי לפריטים בקרוסלה עם אפשרות גלילה אופקית, ומאפשר לרכיב להציג כמה פריטים אם יש מספיק מקום.

דוגמה: קרוסלה עם כמה מוצרים

בקטע הקוד הזה מוטמעת קרוסלה עם כמה מוצרים:

מידע חשוב על הקוד

  • התג מגדיר מחלקה של נתונים CarouselItem, שמבנה את הנתונים של כל רכיב בקרוסלה.
  • יוצרת List של CarouselItem אובייקטים ומאכלסת אותם במשאבי תמונות ובתיאורים.
  • הקוד משתמש ברכיב הקומפוזבילי HorizontalMultiBrowseCarousel, שמיועד להצגת כמה פריטים בקרוסלה.
    • המצב של הקרוסלה מאותחל באמצעות rememberCarouselState, שמקבל את המספר הכולל של הפריטים.
    • לפריטים יש מאפיין preferredItemWidth (כאן, 186.dp), שמציין רוחב אופטימלי לכל פריט. הקרוסלה משתמשת בערך הזה כדי לקבוע כמה פריטים יכולים להיכנס למסך בו-זמנית.
    • הפרמטר itemSpacing מוסיף רווח קטן בין הפריטים.
    • הפונקציה lambda האחרונה של HorizontalMultiBrowseCarousel חוזרת על עצמה ב-CarouselItems. בכל איטרציה, הפונקציה מאחזרת את הפריט באינדקס i ומציגה את הרכיב Image.
    • Modifier.maskClip(MaterialTheme.shapes.extraLarge) מחיל מסכת צורה מוגדרת מראש על כל תמונה, כך שהפינות שלה מעוגלות.
    • contentDescription מספק תיאור נגישות לתמונה.

התוצאה

בתמונה הבאה מוצגת התוצאה של קטע הקוד הקודם:

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

דוגמה: קרוסלה לא מוגבלת

בקטע הקוד הבא מוצגת הטמעה של קרוסלה לא מוגבלת:

מידע חשוב על הקוד

  • רכיב ה-HorizontalUncontainedCarousel יוצר את פריסת הקרוסלה.
    • הפרמטר itemWidth מגדיר רוחב קבוע לכל פריט בקרוסלה.

התוצאה

בתמונה הבאה מוצגת התוצאה של קטע הקוד הקודם:

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