尝试使用自定义布局使屏幕外 UICollectionViewCells 预渲染
Posted
技术标签:
【中文标题】尝试使用自定义布局使屏幕外 UICollectionViewCells 预渲染【英文标题】:Trying to make off-screen UICollectionViewCells pre-render using a custom layout 【发布时间】:2014-02-20 06:28:38 【问题描述】:我有一个分页的 UICollectionView,每页有一个单元格。但是,我的 UICollectionViewCells 渲染速度很慢(第三方库,没有选项)。所以作为优化,我需要预先渲染当前页面左右两边的单元格,这样滚动是平滑的。
我所做的是,在我的自定义 UICollectionViewLayout 中,在检查应该返回哪些单元格的 UICollectionViewLayoutAttributes 之前,将传递的 rect 偏移 1 点,请参见此处:
- (NSArray *)layoutAttributesForElementsInRect:(CGRect)rect
CGRect outsetRect = CGRectInset(rect, -1, 0);
return [_myAttributes filter:^BOOL(UICollectionViewLayoutAttributes *attribs)
return CGRectIntersectsRect(attribs.frame, outsetRect);
];
这按预期工作。然而,当实际的 UICollectionView 执行它的操作时,它似乎会忽略屏幕外的单元格,并且只为第一个单元格调用 cellForItemAtIndexPath
,而不是右侧(或左侧)的单元格。
有什么想法吗?谢谢
【问题讨论】:
我正在考虑的选项是:屏幕外的单元格返回它们的坐标,就好像它们在屏幕上一样,z-index 将它们放在主要的“可见”单元格后面。 【参考方案1】:为了将来参考,我通过以下方式解决了这个问题:
使用于预渲染的单元格在屏幕上强制移动一点,但大小相同。 将其 z-index 更改为 -1,使其位于主页单元格下方。 在 layoutAttributesForElementsInRect 中,检查矩形是否为两页宽,如果是,则它在页面之间滚动,所以不要抓取任何多余的页面 在我的单元格的 applyLayoutAttributes 中,我检查 z-index 是否干杯
【讨论】:
以上是关于尝试使用自定义布局使屏幕外 UICollectionViewCells 预渲染的主要内容,如果未能解决你的问题,请参考以下文章
ListView 使 textview 在超出屏幕可见性时可见