一个可访问的app可以让任何人使用,包括哪些残疾或物理认知障碍的人,作为一个有用的工具,保留其功能和可用性。为了可访问,一个iOS 应用必须提供VoiceOver用户界面元素信息,这样让视觉障碍的用户可以与这些元素交互。UIKit对象默认可访问,但你仍然可以从视图控制器角度做一些事情解决可访问性,如下:
· 确保每个用户界面的元素可访问,包括控件和静态元素如label。
· 确保可访问元素提供准确和有用的信息。
通过编程的方式设置VoiceOver焦点位置,响应特殊VoiceOver手势,观察可访问性通知,可以增强VoiceOver用户体验。
移动VoiceOver光标到一个特定的元素
当你的应用present新视图到屏幕上,考虑设置VoiceOver光标的位置。当屏幕的布局发生变化,VoiceOver焦点,也成为VoiceOver光标,重置其位置到屏幕从左到右从上到下的第一个元素。将光标移动到更合适的元素可以加速界面的用户导航。例如,当push一个新视图控制器到导航控制器的堆栈上,VoiceOver光标会落到导航栏的后退按钮上。你可能希望移动光标到导航栏或新push的页面的一个元素上。
为了改变光标的位置,使用 UIAccessibilityPostNotification函数推送UIAccessibilityScreenChangedNotification通知。通知告诉VoiceOver屏幕上的内容发生变化。当推送通知时,光标定位到你指定的元素上,如列表6-1所示。
列表6-1 推送一个可访问性通知可以改变读出的第一个元素
<pre><code>
- @implementation MyViewController
- (void)viewDidAppear:(BOOL)animated {
- [super viewDidAppear:animated];
- // The second parameter is the new focus element.
- UIAccessibilityPostNotification(UIAccessibilityScreenChangedNotification, self.myFirstElement);
- }
- @end
</pre></code>
布局变化,包括旋转引起的变化,会重置VoiceOver光标的位置。当视图控制器的布局发生变化,推送UIAccessibilityLayoutChangedNotification通知。类似UIAccessibilityScreenChangedNotification
通知,可以指定对象成为VoiceOver的第一个元素。
响应特殊VoiceOver手势
VoiceOver定义了五个特殊动作触发特定的应用动作。
· Escape。两个手指Z形手势,关闭模态对话框或返回到导航层级结构。
· Magic Tap。双指双击执行最想执行的动作。
· Three-Finger Scroll。三指划动垂直或水平滚动内容。
· Increment。一个手指向上划动增加元素的值。
· Decrement。一个手指向下划动减少元素的值。
使用这些手势执行视图和视图控制器的特定任务。UIKit查找实现相关手势的方法。它使用responder链从VoiceOver聚焦的元素开始搜索方法。如果没有对象实现合适的方法,UIKit为该手势执行默认系统动作。例如,如果在当前视图或应用代理中没有找到magic tap的实现,magic tap手势播放和暂停音乐应用的音乐播放。
虽然可以采取任何行动处理程序,VoiceOver用户期望应用的行为遵循一定的准则。像其他手势,VoiceOver手势的实现应该遵循模式,这样与可访问应用的交互仍然是直观的。
注意
所有特殊VoiceOver手势方法返回一个布尔值,该值确定是否通过响应链传播。停止传播,返回YES。否则,返回NO。
Escape
使用 accessibilityPerformEscape方法处理Escape手势。对于覆盖内容的视图。例如模态对话框或弹框,使用该方法移除覆盖。Escape手势的功能就像键盘上Esc键的功能;它取消临时对话框或显示主要内容的表单。你可以使用Escape手势返回到自定义导航层级结构。如果使用UINavigationController
对象,你不需要实现这个手势,该对象已经处理这个手势。
Magic Tap
使用 accessibilityPerformMagicTap方法处理Magic Tap手势。Magic Tap手势可以非常迅速执行常用或最想用的行为。例如,在手机应用中,Magic Tap可以接起或挂断电话,在时钟应用中,Magic Tap启动或停止秒表。可以使用这个手势来触发VoiceOver光标突出显示的元素的其他动作。在应用中处理Magic Tap手势,需在应用代理中实现accessibilityPerformMagicTap
方法。
Three-Finger Scroll
当一个VoiceOver用户执行一个three-finger scroll手势,使用accessibilityScroll: 方法滚动自定义视图的内容。自定义视图显示书籍的一页,可以使用该手势翻页。传递给该方法的参数表示滚动的方向。
Increment and Decrement
使用 accessibilityIncrement和accessibilityDecrement方法来增加或减少元素的值。UIAccessibilityTraitAdjustable
特征的元素必须使用该方法。
监听可访问性通知
UIKit发送可访问性通知告知应用相关的事件。应用对象可以监听任何相关通知,并使用它们执行适当的任务。例如,当VoiceOver说完最后一行,iBook应用使用通知来翻页并继续阅读。这种行为提供了一个无缝不间断的阅读体验。
使用默认通知中心来注册一个可访问性通知的观察者。列表6-2中的例子展示了一个视图记录阅读通知是成功还是被用户打断。
列表6-2 注册可访问性通知的观察者
<pre><code>
- @implementation MyViewController
- (void)viewDidLoad
- {
- [super viewDidLoad];
- [[NSNotificationCenter defaultCenter]
- addObserver:self
- selector:@selector(didFinishAnnouncement:)
- name:UIAccessibilityAnnouncementDidFinishNotification
- object:nil];
- }
- (void)didFinishAnnouncement:(NSNotification *)dict
- {
- NSString *valueSpoken = [[dict userInfo] objectForKey:UIAccessibilityAnnouncementKeyStringValue];
- NSString *wasSuccessful = [[dict userInfo] objectForKey:UIAccessibilityAnnouncementKeyWasSuccessful];
- // ...
- }
- @end
</pre></code>
另一个有用的通知是UIAccessibilityVoiceOverStatusChanged通知。可以使用该通知来检测VoiceOver是否开启。如果应用暂停时,通知出现,接收到通知后应用返回到前台。
关于可以监听的可访问性通知列表,参见UIAccessibility协议参考( UIAccessibilityProtocol Reference)。
官方原文地址:
VoiceOver光标
网友评论