Похожая на трамплин анимация для удаления UICollectionViewCells
Я пытаюсь найти способ оживить удаление 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]];
}];
Но они заставляют клетки переходить к нужным точкам, а не скользить.
Я также нашел этот проект, который использует следующее:
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, на всякий случай, если это важно для вас.
Есть идеи?
2 ответа
Подкласс UICollectionViewFlowLayout
, Воплощать в жизнь:
- (UICollectionViewLayoutAttributes *)finalLayoutAttributesForDisappearingItemAtIndexPath:(NSIndexPath *)indexPath
{
UICollectionViewLayoutAttributes *attr = [self layoutAttributesForItemAtIndexPath:indexPath]; // might need to replace self with super
attr.transform = CGAffineTransformMakeScale(0, 0);
return attr;
}
В дополнение к ответу duci9y, (используя attr.transform = CGAffineTransformMakeScale(0,0);
), следующее заставляет плитки скользить. Я не могу поверить, что я не думал об этом раньше.
[self.collectionView performBatchUpdates:^{
[self.collectionView deleteItemsAtIndexPaths:@[indexPath]];
[dataSource removeObjectAtIndex:indexPath.row];
} completion:nil];