ניפוי באגים בממשק המשתמש של Compose

ב-Android Studio יש כלים לניפוי באגים בממשק המשתמש של Compose.

כלי לבדיקת פריסות

הכלי Layout Inspector מאפשר לבדוק פריסה של Compose בתוך אפליקציה שפועלת באמולטור או במכשיר פיזי. אתם יכולים להשתמש בכלי לבדיקת פריסות כדי לבדוק כמה פעמים רכיב הניתן להרכבה מחדש מורכב מחדש או נדלג, וכך לזהות בעיות באפליקציה. לדוגמה, שגיאות מסוימות בקוד עשויות לגרום לממשק המשתמש שלכם להרכיב מחדש באופן מוגזם, מה שעלול לגרום לביצועים ירודים. חלק משגיאות הקידוד יכולות למנוע את ההרכבה מחדש של ממשק המשתמש, ולכן למנוע את הצגת השינויים בממשק המשתמש על המסך. אם אתם חדשים ב-Layout inspector, כדאי לעיין בהנחיות להפעלת הכלי.

קבלת נתוני שינוי קומפוזיציה

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

הכלי Layout Inspector מראה לכם מתי רכיבי composable נפרדים בהיררכיית הפריסה שלכם עברו קומפוזיציה מחדש או דילוג, בזמן שאתם מבצעים אינטראקציה עם האפליקציה. ב-Android Studio, הקומפוזיציות מחדש מודגשות כדי לעזור לכם לקבוע איפה בממשק המשתמש רכיבי ה-composable עוברים קומפוזיציה מחדש.

איור 1. הפריסות מחדש מודגשות ב-Layout Inspector.

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

איור 2. הקומפוזיציה והדלפק של הדילוג בכלי לבדיקת פריסות.

פותחים את החלון Layout Inspector ומתחברים לתהליך של האפליקציה. בעץ הרכיבים, מופיעות שתי עמודות לצד היררכיית הפריסה. בעמודה הראשונה מוצג מספר הקומפוזיציות לכל צומת, ובעמודה השנייה מוצג מספר הדילוגים לכל צומת. אם בוחרים בצומת שאפשר להרכיב, מוצגים המאפיינים והפרמטרים של הצומת, אלא אם מדובר בפונקציה מוטמעת, ובמקרה כזה אי אפשר להציג את הפרמטרים. אפשר לראות מידע דומה גם בחלונית Attributes כשבוחרים רכיב מתוך Component Tree או Layout Display.

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

הפעלת הקומפוזיציה ודלג על מונה ב-Layout
Inspector

איור 3. הפעלת מונה הקומפוזיציה ודילוגים בכלי לבדיקת פריסות.

סמנטיקה של כתיבה

ב-Compose, Semantics מתאר את ממשק המשתמש בדרך חלופית שמובנת לשירותי Accessibility ול-framework של Testing. אפשר להשתמש בכלי לבדיקת פריסות כדי לבדוק מידע סמנטי בפריסות של Compose.

מידע סמנטי שמוצג באמצעות הכלי לבדיקת פריסות.
איור 4. מידע סמנטי שמוצג באמצעות הכלי לבדיקת פריסות.

כשבוחרים בצומת Compose, משתמשים בחלונית Attributes כדי לבדוק אם הצומת מצהיר על מידע סמנטי באופן ישיר, ממזג סמנטיקה מהצומת הצאצא או עושה את שניהם. כדי לזהות במהירות אילו צמתים כוללים סמנטיקה, מוצהרת או ממוזגת, לוחצים על התפריט הנפתח View options בחלונית Component Tree ובוחרים באפשרות Highlight Semantics Layers. האפשרות הזו מדגישה רק את הצמתים בעץ שכוללים סמנטיקה, ואפשר להשתמש במקלדת כדי לנווט ביניהם במהירות.

בדיקת ממשק המשתמש של יצירת הודעה

כדי לעזור לכם ליצור ממשקי משתמש נגישים יותר ובעלי יכולת הסתגלות טובה יותר ב-Jetpack Compose, ‏ Android Studio מספק מצב בדיקת ממשק משתמש בתצוגה המקדימה של Compose. התכונה הזו דומה לסורק הנגישות לתצוגות.

כשמפעילים את מצב הבדיקה של ממשק המשתמש של Compose בתצוגה מקדימה של Compose, ‏ Android Studio מבצע אוטומטית ביקורת על ממשק המשתמש של Compose ומציע שיפורים כדי להפוך את ממשק המשתמש לנגיש יותר וניתן להתאמה. ‫Android Studio בודק שממשק המשתמש פועל בגדלים שונים של מסכים. בחלונית בעיות, הכלי מציג את הבעיות שהוא מזהה, כמו טקסט שנמתח במסכים גדולים או ניגודיות צבעים נמוכה.

כדי לגשת לתכונה הזו, לוחצים על סמל בדיקת ממשק המשתמש בתצוגה המקדימה של Compose:

איור 5. נקודת כניסה למצב בדיקת ממשק המשתמש.

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

איור 6. מצב בדיקה של ממשק המשתמש בפעולה.

תיקון בעזרת AI

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

איור 7. הנציג מתקן בעיות בממשק המשתמש במצב 'בדיקת ממשק המשתמש'.