我正在尝试找出一种方法来为 UICollectionViewCell 的删除设置动画,类似于 iOS 7 中的跳板。已删除的单元格应缩小为虚无,其余单元格应滑过以填充其位置(滑动是重要的部分)。我试过了:
• 将每个单元格的框架设置为前一个单元格的框架,如下所示:
UICollectionViewCell *cell = [self.collectionView cellForItemAtIndexPath:[NSIndexPath indexPathForItem:i inSection:0]];
CGRect rect = [self.collectionView cellForItemAtIndexPath:[NSIndexPath indexPathForItem:i - 1 inSection:0]].frame;
[UIView animateWithDuration:0.2 animations:^{
cell.frame = rect;
}];
但这不起作用,因为细胞根本没有移动。
• 以下两项:
[self.collectionView performBatchUpdates:^{
[self.collectionView reloadSections:[NSIndexSet indexSetWithIndex:0]];
} completion:nil];
和
[UIView animateWithDuration:0.2 animations:^{
[self.collectionView reloadSections:[NSIndexSet indexSetWithIndex:0]];
}];
但这些会使细胞交叉淡化到所需的位置,而不是滑动。
我还找到了 this project ,它使用以下内容:
for (int i = index+1; i<[items count]; i++) {
SEMenuItem *item = [items objectAtIndex:i];
[UIView animateWithDuration:0.2 animations:^{
if (i < index + remainingNumberOfItemsInPage) {
int intVal = item.frame.origin.x;
if (intVal %3== 0)
[item setFrame:CGRectMake(item.frame.origin.x+2*item.frame.size.width, item.frame.origin.y-item.frame.size.height-5, item.frame.size.width, item.frame.size.height)];
else
[item setFrame:CGRectMake(item.frame.origin.x-item.frame.size.width, item.frame.origin.y, item.frame.size.width, item.frame.size.height)];
}
[item updateTag:item.tag-1];
}];
}
但是,它不在 UICollectionView 中,所以对我没有帮助。
注意:我在 iPad 上执行此操作,以防万一对您很重要。
有什么想法吗?
Best Answer-推荐答案 strong>
子类 UICollectionViewFlowLayout 。实现:
- (UICollectionViewLayoutAttributes *)finalLayoutAttributesForDisappearingItemAtIndexPathNSIndexPath *)indexPath
{
UICollectionViewLayoutAttributes *attr = [self layoutAttributesForItemAtIndexPath:indexPath]; // might need to replace self with super
attr.transform = CGAffineTransformMakeScale(0, 0);
return attr;
}
关于ios - 用于删除 UICollectionViewCells 的类似跳板的动画,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/24843057/
|