שיטות מומלצות בנושא נגישות ב-Android TV

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

למה הנגישות חשובה באפליקציה שלי לטלוויזיה?

ליקויי ראייה אינם נפוצים בקרב אוכלוסיית הצופים בטלוויזיה. לפי ההערכות, 2.2 מיליארד אנשים ברחבי העולם ליקוי ראייה, לארגון הבריאות העולמי (WHO). בארה"ב, 32 מיליון אמריקאים בני 18 ומעלה חוו אובדן ראייה משמעותי, בהתאם ל-National Health Interview Survey 2018. באירופה, ההערכות ל-30 מיליון אנשים עיוורים או חלקיים, בהתאם לאיחוד האירופי לעיוורים (EBU).

הדבר החשוב ביותר הוא שמשתמשים עם ליקויי ראייה נהנים מתוכן מדיה בדיוק כמו החברים שלהם, בעלי יכולת ראיה מלאה. סקר לשנת 2017 שהוזמן על ידי Comcast הראו ש-96% מהמשתמשים שהם עיוורים או לקויי ראייה צופים באופן קבוע בטלוויזיה, כאשר 81% מהצופים צופים במשך יותר משעה ביום. עם זאת, 65% מהמשיבים דיווחו גם על בעיות בחיפוש תוכניות בטלוויזיה. בסקר שנערך בבריטניה בשנת 2020, 80% מהאנשים עם מוגבלויות אמרו שהם נתקלו בבעיות נגישות בשירותי סטרימינג של וידאו על פי דרישה.

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

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

משאבים בנושא נגישות ב-Android

למידע נוסף על נגישות ב-Android, כדאי לעיין במשאבים שלנו לפיתוח נגישות.

שינוי גודל הטקסט

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

שימו לב במיוחד כדי:

  • יש להשתמש ב-wrap_content למאפיינים ברכיבי ממשק המשתמש.
  • חשוב לוודא שהפריסות ממיינות מחדש את הרכיבים כשהמידות שלהם משתנות בהתאם לסולם הטקסט.
  • ודאו שהרכיבים עדיין מתאימים למסך כשגודל הטקסט הוא גדול יותר.
  • אין להשתמש ביחידות גודל טקסט sp לרכיבים לא גמישים.
  • בדיקת הערך של FONT_SCALE להתאמה בתצוגות בהתאמה אישית:

    // Checking font scale with Context
    val scale = resources.configuration.fontScale
    Log.d(TAG, "Text scale is: " + scale)
    

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

adb shell settings put system font_scale 1.2f

ב-Android מגרסה 12 ואילך, המשתמשים יכולים לשנות את גודל הטקסט במכשיר הגדרות.

פריסות מקלדת

ב-Android 13 (רמת API 33) ואילך, אפשר להשתמש ב-getKeyCodeForKeyLocation() כדי לחפש את קודי המפתחות במיקומים הצפויים שלהם. יכול להיות שתצטרכו לעשות זאת אם המשתמש מיפה מחדש את מיקומי המפתחות או אם הוא משתמש במקלדת ללא פריסה רגילה.

תיאור האודיו

ב-Android 13 (רמת API 33) ואילך, העדפת נגישות חדשה ברמת המערכת מאפשרת למשתמשים להפעיל תיאורים קוליים בכל האפליקציות. אפליקציות ל-Android TV יכולות לבדוק את ההעדפה של המשתמש על ידי שליחת שאילתה עם isAudioDescriptionRequested()

Kotlin


private lateinit var accessibilityManager: AccessibilityManager

// In onCreate():
accessibilityManager = getSystemService(AccessibilityManager::class.java)

// Where your media player is initialized
if (am.isAudioDescriptionRequested) {
    // User has requested to enable audio descriptions
}

Java


private AccessibilityManager accessibilityManager;

// In onCreate():
accessibilityManager = getSystemService(AccessibilityManager.class);

// Where your media player is initialized
if(accessibilityManager.isAudioDescriptionRequested()) {
    // User has requested to enable audio descriptions
}

אפליקציות ל-Android TV יכולות לעקוב אחרי שינויים בהעדפת המשתמש על ידי הוספת אוזן AccessibilityManager:

Kotlin


private val listener =
    AccessibilityManager.AudioDescriptionRequestedChangeListener { enabled ->
        // Preference changed; reflect its state in your media player
    }

override fun onStart() {
    super.onStart()

    accessibilityManager.addAudioDescriptionRequestedChangeListener(mainExecutor, listener)
}

override fun onStop() {
    super.onStop()

    accessibilityManager.removeAudioDescriptionRequestedChangeListener(listener)
}

Java


private AccessibilityManager.AudioDescriptionRequestedChangeListener listener = enabled -> {
    // Preference changed; reflect its state in your media player
};

@Override
protected void onStart() {
    super.onStart();

    accessibilityManager.addAudioDescriptionRequestedChangeListener(getMainExecutor(), listener);
}

@Override
protected void onStop() {
    super.onStop();

    accessibilityManager.removeAudioDescriptionRequestedChangeListener(listener);
}