Hướng dẫn này cung cấp các phương pháp hay nhất về khả năng hỗ trợ tiếp cận trên Android TV và đưa ra các đề xuất cho cả ứng dụng gốc và ứng dụng không phải ứng dụng gốc.
Tại sao khả năng tiếp cận lại quan trọng đối với ứng dụng truyền hình của tôi?
Không ít người xem truyền hình bị suy giảm thị lực. Theo Tổ chức Y tế Thế giới (WHO), ước tính có 2,2 tỷ người trên toàn cầu bị suy giảm thị lực. Theo Khảo sát phỏng vấn sức khoẻ quốc gia năm 2018, ở Hoa Kỳ, 32 triệu người Mỹ từ 18 tuổi trở lên đã bị suy giảm thị lực đáng kể. Theo Liên minh Người mù Châu Âu (EBU), ở Châu Âu, ước tính có 30 triệu người mù và người khiếm thị.
Quan trọng nhất là người dùng bị suy giảm thị lực có thể thưởng thức nội dung nghe nhìn như những người có thị lực bình thường. Một khảo sát năm 2017 do Comcast thực hiện cho thấy 96% người dùng khiếm thị hoặc có thị lực kém thường xuyên xem TV, trong đó 81% xem hơn một giờ mỗi ngày. Tuy nhiên, 65% người dùng cũng cho biết họ gặp vấn đề khi tìm kiếm nội dung trên TV. Trong một cuộc khảo sát năm 2020 ở Vương quốc Anh, 80% người khuyết tật cho biết họ gặp phải các vấn đề về khả năng hỗ trợ tiếp cận khi sử dụng dịch vụ phát trực tuyến video theo yêu cầu.
Mặc dù các công nghệ hỗ trợ có thể và thực sự giúp người dùng có thị lực kém, nhưng điều quan trọng là bạn phải hỗ trợ tính năng hỗ trợ tiếp cận trong hành trình khám phá nội dung cho các ứng dụng truyền hình. Ví dụ: hãy đặc biệt chú ý đến việc cung cấp hướng dẫn điều hướng và gắn nhãn đúng cách cho các phần tử, đồng thời đảm bảo rằng các ứng dụng truyền hình hoạt động tốt với các tính năng hỗ trợ tiếp cận như TalkBack. Các bước này có thể cải thiện đáng kể trải nghiệm của người dùng khiếm thị.
Bước đầu tiên để cải thiện khả năng hỗ trợ tiếp cận là nâng cao nhận thức. Hướng dẫn này có thể giúp bạn và nhóm của bạn phát hiện các vấn đề về khả năng hỗ trợ tiếp cận trong ứng dụng truyền hình.
Tài nguyên hỗ trợ tiếp cận trên Android
Để tìm hiểu thêm về tính năng hỗ trợ tiếp cận trên Android, hãy xem các tài nguyên phát triển tính năng hỗ trợ tiếp cận của chúng tôi.
Tăng cỡ chữ
Các ứng dụng Android TV phải tuân theo lựa chọn ưu tiên của người dùng về việc điều chỉnh tỷ lệ văn bản bằng cách hỗ trợ nhiều mật độ điểm ảnh.
Hãy đặc biệt chú ý đến:
- Sử dụng
wrap_content
cho các phương diện trong thành phần giao diện người dùng. - Đảm bảo rằng bố cục sắp xếp lại các thành phần khi kích thước của chúng thay đổi tuỳ theo tỷ lệ văn bản.
- Đảm bảo các thành phần vẫn vừa với màn hình ở tỷ lệ văn bản lớn hơn.
- Đừng sử dụng đơn vị kích thước văn bản sp cho các thành phần không linh hoạt.
Kiểm tra giá trị của
FONT_SCALE
để điều chỉnh trong chế độ xem tuỳ chỉnh:// Checking font scale with Context val scale = resources.configuration.fontScale Log.d(TAG, "Text scale is: " + scale)
Bạn có thể thay đổi tỷ lệ văn bản bằng lệnh sau:
adb shell settings put system font_scale 1.2f
Trên Android 12 trở lên, người dùng có thể thay đổi tỷ lệ văn bản trong phần cài đặt thiết bị.
Bố cục bàn phím
Trong Android 13 (API cấp 33) trở lên, bạn có thể dùng getKeyCodeForKeyLocation()
để tra cứu mã khoá cho các vị trí khoá dự kiến.
Điều này có thể cần thiết nếu người dùng đã ánh xạ lại một số vị trí khoá hoặc nếu họ đang sử dụng bàn phím không có bố cục thông thường.
Nút mô tả bằng âm thanh
Trong Android 13 (API cấp 33) trở lên, một lựa chọn ưu tiên mới về hỗ trợ tiếp cận trên toàn hệ thống cho phép người dùng bật nội dung mô tả bằng âm thanh trên tất cả các ứng dụng. Các ứng dụng Android TV có thể kiểm tra lựa chọn ưu tiên của người dùng bằng cách truy vấn lựa chọn ưu tiên đó bằng 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 }
Các ứng dụng Android TV có thể theo dõi thời điểm người dùng thay đổi lựa chọn ưu tiên bằng cách thêm một trình nghe vào 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); }