我有一个分页的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,以便它们位于主页单元格下面。
  • 在layoutAttributesForElementsInRect中,检查rect是否为两页宽,如果是,则在页面之间滚动,因此不要获取任何额外的页面
  • 在单元格的applyLayoutAttributes中,我检查z-index
    干杯

    关于ios - 尝试使用自定义布局使屏幕外的UICollectionViewCells预先呈现,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21899945/

  • 10-09 08:06