Android TV 접근성 권장사항

이 가이드에서는 Android TV의 접근성에 관한 권장사항을 제공하며 다음 내용을 설명합니다. 네이티브 및 비네이티브 앱 모두에 대한 권장사항을 제공합니다.

TV 앱에서 접근성이 중요한 이유는 무엇인가요?

TV 시청 인구는 시각 장애를 갖고 있는 경우가 많습니다. 세계보건기구(WHO)에 따르면 전 세계적으로 22억 명이 시각 장애를 앓고 있습니다. 2018년 전국 보건 인터뷰 설문조사에 따르면 미국에서 18세 이상 3,200만 명의 미국인이 심각한 시력 상실을 경험했습니다. 유럽의 경우 3천만 유럽맹인연맹 (EBU)에 따르면 시각장애인 및 부분 시력의 사용자를 대상으로 합니다.

무엇보다도 시각장애가 있는 사용자는 미디어 콘텐츠를 좋아하고 완전히 시력이 정상인 동료들만큼이나 말이죠 Comcast에서 의뢰한 2017년 설문조사 시각장애인 또는 저시력 사용자 중 96% 가 81%의 TV 시청자 중 81%가 하루 1시간 이상을 시청하고 있습니다. 그러나 65% 는 TV에 나오는 콘텐츠를 찾는 데 문제가 발생한 경우를 말합니다. 2020년 영국 설문조사에 따르면 장애인의 80%가 주문형 동영상 스트리밍 서비스에서 접근성 문제를 경험했다고 말했습니다.

보조 기술은 저시력 사용자에게도 도움이 될 수 있지만 이는 TV 앱의 콘텐츠 탐색 여정에서 접근성을 지원하는 데 중요합니다. 예를 들어 탐색 안내를 제공하고 요소에 올바르게 라벨을 지정하는 데 각별히 주의하고 TV 앱이 TalkBack과 같은 접근성 기능과 잘 작동하는지 확인합니다. 이러한 단계를 통해 시각 장애가 있는 사용자의 환경을 크게 개선할 수 있습니다.

접근성 개선을 위한 첫 번째 단계는 인식입니다. 이 가이드를 통해 개발자와 개발자팀이 TV 앱의 접근성 문제를 파악할 수 있습니다.

Android 접근성 리소스

Android의 접근성에 관해 자세히 알아보려면 접근성 개발 리소스를 참고하세요.

텍스트 크기 조정

Android TV 앱은 다양한 픽셀 밀도를 지원하여 텍스트 크기 조정에 관한 사용자의 환경설정을 존중해야 합니다.

다음과 같은 사항에 특히 주의하세요.

  • UI 구성요소의 크기에 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
}
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에 리스너를 추가하여 사용자의 환경설정이 변경되는 시점을 모니터링할 수 있습니다.

KotlinJava
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)
}
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);
}