Похожая на трамплин анимация для удаления 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];
Другие вопросы по тегам