UICollectionView 使用自定义动画更改布局

Has*_*jmi 3 animation objective-c ios uicollectionview uicollectionviewlayout

我有两个 collectionViewLayout、verticalFlowLayout 和 fullScreenHorizo​​ntalFlowLayout。

@implementation VerticalFlowLayout
- (instancetype)init
{
    if (self = [super init]) {
        self.sectionInset = UIEdgeInsetsMake(12, 0, 0, 0);
        self.minimumLineSpacing = 10;
        self.minimumInteritemSpacing = 0;
        self.itemSize = CGSizeMake(CGRectGetWidth([UIScreen mainScreen].bounds), 244);
    }
    return self;
}
@end
Run Code Online (Sandbox Code Playgroud)
@implementation FullScreenFlowLayout
- (instancetype)init
{
    if (self = [super init]) {
        self.sectionInset = UIEdgeInsetsMake(0, 0, 0, 0);
        self.minimumLineSpacing = 10;
        self.minimumInteritemSpacing = 0;
        self.itemSize = CGSizeMake(CGRectGetWidth([UIScreen mainScreen].bounds), CGRectGetHeight([UIScreen mainScreen].bounds));
        self.scrollDirection = UICollectionViewScrollDirectionHorizontal;
    }
    return self;
}
Run Code Online (Sandbox Code Playgroud)

当我选择一个单元格时,我想使用自定义动画更改 collectionView 布局。默认动画是持续时间为 0.33 的线性动画。

    - (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath
{
    if ([_collectionView.collectionViewLayout isKindOfClass:[FullScreenFlowLayout class]]) {
        VerticalFlowLayout *flowLayout = [VerticalFlowLayout new];
        [_collectionView setCollectionViewLayout:flowLayout animated:YES completion:^(BOOL finished) {

        }];
    }
    else
        [_collectionView setCollectionViewLayout:[FullScreenFlowLayout new] animated:YES];

}
Run Code Online (Sandbox Code Playgroud)

我怎样才能做到这一点?

Col*_*lin 5

只需包裹_collectionView.collectionViewFlowLayout = flowLayout一个UIView动画块。

[UIView animateWithDuration:5.0 delay:0.0 options:UIViewAnimationOptionCurveEaseIn animations:^{
    self.collectionView.collectionViewLayout = flowLayout;
} completion:^(BOOL finished) {
    if (finished) {
        // Do Something
    }
}];
Run Code Online (Sandbox Code Playgroud)

  • 这是自定义 collectionView 布局动画的完整指南:https://github.com/cnoon/CollectionViewAnimations (5认同)
  • 我认为你从询问如何做到这一点到创建一个有据可查的 GitHub 存储库供其他人参考真是太棒了。很好。 (2认同)