【问题标题】:UICollectionViewFlowLayout Voice Over reads items out of order with Flow LayoutUICollectionViewFlowLayout Voice Over 使用 Flow Layout 乱序读取项目
【发布时间】:2013-04-29 22:47:40
【问题描述】:

我有两个关于可访问性和 UICollectionViews 的问题,希望得到专家的帮助。另一个关于节标题的问题可以在here 找到。我创建了一个 sample project 来演示这两个问题。

我有一个使用UICollectionViewFlowLayoutUICollectionView,其中包含可变高度的项目。 UIFlowLayout 将每行的元素垂直居中。不幸的是,启用 Voice Over 后,它似乎偏向于垂直放置较高的元素,导致它无序地读取项目。

您可以拉出此example project,运行它,启用旁白,然后在项目中滑动以查看问题。它会创建具有随机高度的单元格,因此很可能会乱序读取单元格。

有没有一种方法可以让集合视图按顺序浏览项目?我觉得这是唯一有意义的方法,但我找不到强制执行该行为的方法.将集合视图设置为对子视图进行分组似乎没有帮助。任何帮助将不胜感激。

【问题讨论】:

标签: ios uicollectionview uicollectionviewlayout uiaccessibility


【解决方案1】:

取自Accessibility for iOS, VoiceOver read order issue

在您的示例中实现此目的的最快方法是将三个标签放在一个透明的 UIView 子类中,作为标签的容器。必须正确设置此子类以让 VoiceOver 知道如何解释它。如果您的部署目标是 iOS6,那么您可以在这个子类中简单地回答“应该对可访问性子类进行分组”的问题。

-(BOOL)shouldGroupAccessibilityChildren{
     return YES;
 }

对于iOS6以下,它会更复杂,除了你的UIView容器子类将只包含UILabels,它们是可访问性元素。你可以这样实现它:

 -(BOOL)isAccessibilityElement{
     return NO;
  }
  -(NSInteger)accessibilityElementCount{
       return self.subviews.count;
  }
  -(id)accessibilityElementAtIndex:(NSInteger)index{
      return [self.subviews objectAtIndex:index];
  }
  -(NSInteger)indexOfAccessibilityElement:(id)element{
      return [self.subviews indexOfObject:element];
  }

我已经测试了这个示例代码,它可以满足您的需求,如果您需要任何说明,请添加评论。总是乐于帮助使事情变得更容易获得。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2018-05-11
    • 1970-01-01
    • 2023-02-21
    • 2021-12-22
    • 2020-08-09
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多