Android TV 접근성 권장사항

이 가이드에서는 Android TV의 접근성 권장사항을 제공하고 네이티브 앱과 네이티브가 아닌 앱 모두에 관한 권장사항을 제공합니다.

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

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

무엇보다 시각 장애가 있는 사용자도 정상적인 사용자와 마찬가지로 미디어 콘텐츠를 즐길 수 있습니다. Comcast에서 의뢰한 2017년 설문조사에 따르면 시각 장애가 있거나 시력이 낮은 사용자의 96% 가 정기적으로 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에 리스너를 추가하여 사용자의 환경설정이 변경되는 시점을 모니터링할 수 있습니다.

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