אחרי שהפעילות שלכם השתלטה על הטיפול בכל השוליים הפנימיים, אתם יכולים להשתמש בממשקי API של Compose כדי לוודא שהתוכן לא מוסתר ושהאלמנטים האינטראקטיביים לא חופפים ל-UI של המערכת. ממשקי ה-API האלה מסנכרנים גם את פריסת האפליקציה עם שינויים במיקום.
טיפול בשוליים הפנימיים באמצעות מאפייני ריווח או שינוי גודל
לדוגמה, זו השיטה הכי בסיסית להחלת השוליים הפנימיים על התוכן של כל האפליקציה:
override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) enableEdgeToEdge() setContent { Box(Modifier.safeDrawingPadding()) { // the rest of the app } } }
קטע הקוד הזה מחיל את שולי החלון safeDrawing כריווח פנימי מסביב לכל התוכן של האפליקציה. אמנם זה מבטיח שרכיבים שאפשר לקיים איתם אינטראקציה לא יחפפו את ממשק המשתמש של המערכת, אבל זה גם אומר שאף חלק מהאפליקציה לא יוצג מאחורי ממשק המשתמש של המערכת כדי ליצור אפקט מקצה לקצה. כדי להשתמש בכל החלון, צריך לכוונן את המיקום של השוליים הפנימיים במסך או ברכיב.
כל סוגי ההזחה האלה מונפשים באופן אוטומטי באמצעות אנימציות של IME שהועברו לאחור ל-API 21. כתוצאה מכך, גם כל הפריסות שמשתמשות בערכי השוליים האלה מונפשות באופן אוטומטי כשהערכים משתנים.
יש שלוש דרכים לטפל בשוליים פנימיים כדי לשנות את פריסות ה-Composable:
ערכים לשינוי מרווח פנימי
Modifier.windowInsetsPadding(windowInsets: WindowInsets) מחיל את השוליים הפנימיים של החלון שצוינו כריפוד, בדיוק כמו ש-Modifier.padding היה עושה.
לדוגמה, Modifier.windowInsetsPadding(WindowInsets.safeDrawing) מוסיף את השוליים הפנימיים של האזור הבטוח לציור כריפוד בכל 4 הצדדים.
יש גם כמה שיטות מובנות לשימוש בסוגי השוליים הפנימיים הנפוצים ביותר.
Modifier.safeDrawingPadding() היא אחת מהשיטות האלה, והיא שוות ערך ל-Modifier.windowInsetsPadding(WindowInsets.safeDrawing). יש משנים דומים לסוגים האחרים של שוליים פנימיים.
שינוי גודל של תוספות
המשנים הבאים מחילים כמות של שוליים פנימיים של חלון על ידי הגדרת הגודל של הרכיב להיות הגודל של השוליים הפנימיים:
החלת הצד ההתחלתי של windowInsets כרוחב (כמו |
|
החלת הצד הסופי של windowInsets כרוחב (כמו |
|
החלת הצד העליון של windowInsets כגובה (כמו |
|
|
הגובה מוגדר לפי הצד התחתון של windowInsets (כמו |
המשנים האלה שימושיים במיוחד כשרוצים לשנות את הגודל של Spacer כך שיתפוס את המקום של המרווחים הפנימיים:
LazyColumn( Modifier.imePadding() ) { // Other content item { Spacer( Modifier.windowInsetsBottomHeight( WindowInsets.systemBars ) ) } }
צריכה של מוצרים מוטמעים
המשנים של שוליים פנימיים (windowInsetsPadding ועוזרים כמו safeDrawingPadding) צורכים באופן אוטומטי את החלק של השוליים הפנימיים שמוגדרים כשוליים פנימיים. כשמסתכלים על עומק העץ, מגבירי הריווח הפנימי המקוננים ומגבירי הגודל של הריווח הפנימי יודעים שחלק מהריווח הפנימי כבר נוצל על ידי מגבירי הריווח הפנימי החיצוניים, ולכן הם לא משתמשים באותו חלק של הריווח הפנימי יותר מפעם אחת, כדי שלא יהיה יותר מדי רווח נוסף.
גם משני גודל של שוליים פנימיים לא משתמשים באותו חלק של השוליים הפנימיים יותר מפעם אחת אם כבר נעשה שימוש בשוליים הפנימיים. עם זאת, מכיוון שהן משנות את הגודל שלהן ישירות, הן לא צורכות את השוליים הפנימיים בעצמן.
כתוצאה מכך, שינויים בערכי הריווח של רכיבים מוטמעים משנים אוטומטית את כמות הריווח שמוחלת על כל רכיב שאפשר להרכיב.
אם נסתכל על אותה דוגמה של LazyColumn כמו קודם, נראה שהגודל של LazyColumn משתנה על ידי המקש imePadding. בתוך LazyColumn, הפריט האחרון מוגדר בגובה של החלק התחתון של סרגלי המערכת:
LazyColumn( Modifier.imePadding() ) { // Other content item { Spacer( Modifier.windowInsetsBottomHeight( WindowInsets.systemBars ) ) } }
כשסוגרים את ה-IME, הכלי לשינוי imePadding() לא מוסיף ריווח פנימי, כי ל-IME אין גובה. מכיוון שהמשנה imePadding() לא מוסיף ריווח פנימי,
לא נעשה שימוש בשוליים הפנימיים, והגובה של Spacer יהיה הגודל של
הצד התחתון של סרגלי המערכת.
כשמקלדת ה-IME נפתחת, המרווחים הפנימיים של ה-IME מונפשים בהתאם לגודל של ה-IME, והמשנה imePadding() מתחיל להחיל ריווח תחתון כדי לשנות את הגודל של LazyColumn כשה-IME נפתח. כשמשנים את המאפיין imePadding() כדי להחיל ריווח פנימי תחתון, הוא גם מתחיל להשתמש באותו סכום של שוליים פנימיים. לכן, הגובה של Spacer מתחיל לרדת, כי חלק מהריווח של סרגלי המערכת כבר הוחל על ידי משנה imePadding(). אם משתמשים במגדיר imePadding() כדי להחיל ריווח פנימי תחתון גדול יותר מסרגלי המערכת, הגובה של Spacer יהיה אפס.
כשמקלדת ה-IME נסגרת, השינויים מתרחשים בסדר הפוך: Spacer מתחיל להתרחב מגובה אפס ברגע ש-imePadding() מוחל על פחות מהצד התחתון של סרגלי המערכת, עד שבסופו של דבר Spacer תואם לגובה של הצד התחתון של סרגלי המערכת ברגע שמקלדת ה-IME מסיימת את האנימציה שלה.
TextField.ההתנהגות הזו מתאפשרת באמצעות תקשורת בין כל משני windowInsetsPadding, ויש עוד כמה דרכים להשפיע עליה.
Modifier.consumeWindowInsets(insets: WindowInsets) גם צורך שוליים פנימיים, כמו Modifier.windowInsetsPadding, אבל הוא לא משתמש בשוליים הפנימיים שנצרכו כמרווח. המאפיין הזה שימושי בשילוב עם משני הגודל inset, כדי לציין לאחים שכבר נעשה שימוש בכמות מסוימת של שוליים פנימיים:
Column(Modifier.verticalScroll(rememberScrollState())) { Spacer(Modifier.windowInsetsTopHeight(WindowInsets.systemBars)) Column( Modifier.consumeWindowInsets( WindowInsets.systemBars.only(WindowInsetsSides.Vertical) ) ) { // content Spacer(Modifier.windowInsetsBottomHeight(WindowInsets.ime)) } Spacer(Modifier.windowInsetsBottomHeight(WindowInsets.systemBars)) }
הפונקציה Modifier.consumeWindowInsets(paddingValues: PaddingValues) מתנהגת באופן דומה מאוד לגרסה עם הארגומנט WindowInsets, אבל היא מקבלת את הארגומנט PaddingValues לשימוש. הדבר שימושי כדי להודיע לילדים מתי יש ריווח או מרווחים שנוצרו באמצעות מנגנון אחר ולא באמצעות משני הריווח הפנימי, כמו Modifier.padding רגיל או מרווחים בגובה קבוע:
Column(Modifier.padding(16.dp).consumeWindowInsets(PaddingValues(16.dp))) { // content Spacer(Modifier.windowInsetsBottomHeight(WindowInsets.ime)) }
במקרים שבהם נדרשים ערכי השוליים הגולמיים של החלון ללא צריכה, אפשר להשתמש ישירות בערכים של WindowInsets או להשתמש ב-WindowInsets.asPaddingValues() כדי להחזיר PaddingValues של השוליים שלא מושפעים מהצריכה.
עם זאת, בגלל ההערות הבאות, מומלץ להשתמש במקומות שבהם אפשר בשינויי הריפוד של חלון ההזחה ובשינויי הגודל של חלון ההזחה.
שוליים פנימיים ושלבים ב-Jetpack פיתוח נייטיב
Compose משתמש בממשקי ה-API הבסיסיים של AndroidX כדי לעדכן ולהנפיש את השוליים הפנימיים, שמשתמשים בממשקי ה-API הבסיסיים של הפלטפורמה לניהול השוליים הפנימיים. בגלל אופן הפעולה של הפלטפורמה, יש קשר מיוחד בין שוליים פנימיים לבין השלבים של Jetpack Compose.
הערך של insets מתעדכן אחרי שלב ההרכבה, אבל לפני שלב הפריסה. כלומר, כשקוראים את הערך של המרווחים הפנימיים בהרכבה, בדרך כלל משתמשים בערך של המרווחים הפנימיים שמאחר בפְרֵים אחד. המשנים המובנים שמתוארים בדף הזה נועדו לדחות את השימוש בערכי השוליים עד לשלב הפריסה, כדי להבטיח שהשימוש בערכי השוליים יתבצע באותו פריים שבו הם מתעדכנים.