虚位以待(AD)
虚位以待(AD)
首页 > 软件编程 > IOS编程/Objective-C > iOS UICollectionView刷新时闪屏的解决方法

iOS UICollectionView刷新时闪屏的解决方法
类别:IOS编程/Objective-C   作者:码皇   来源:互联网   点击:

本篇文章主要介绍了iOS UICollectionView刷新时闪屏的解决方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

在做相册的时候遇到了一个问题,就是UICollectionView刷新的时候会闪屏,网上搜了搜,解决的方法也是挺多,并没有一一尝试,只是存下来做个笔记,来看看遇到的几种方法。

方法一:

    [UIView performWithoutAnimation:^{
    //刷新界面 [self.collectionView reloadData];
    }
    ];

把刷新界面的事件放在这个BLock里就可以了!

方法二

    [UIView animateWithDuration:0 animations:^{
    [collectionView performBatchUpdates:^{
    [collectionView reloadItemsAtIndexPaths:@[[NSIndexPath indexPathForItem:index inSection:0]]];
    }
    completion:nil];
    }
    ];

方法三

    [UIView setAnimationsEnabled:NO];
    [self.trackPanel performBatchUpdates:^{
    [collectionView reloadItemsAtIndexPaths:@[[NSIndexPath indexPathForItem:index inSection:0]]];
    }
    completion:^(BOOL finished) {
    [UIView setAnimationsEnabled:YES];
    }
    ];

如果你的APP只支持iOS7+,推荐使用第一种方式performWithoutAnimation简单方便。

上面说的方法只能解决UIView的Animation,但是如果你的cell中还包含有CALayer的动画,比如这样:

    - (void)layoutSubviews{
    [super layoutSubviews];
    self.frameLayer.frame = self.frameView.bounds;
    }

上述情况多用于自定义控件使用了layer.mask的情况,如果有这种情况,上面提到的方法是无法取消CALayer的动画的,但是解决办法也很简单:

    - (void)layoutSubviews{
    [super layoutSubviews];
    [CATransaction begin];
    [CATransaction setDisableActions:YES];
    self.frameLayer.frame = self.frameView.bounds;
    [CATransaction commit];
    }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

  • iOS 通过collectionView实现照片删除功能
  • iOS中关于Swift UICollectionView横向分页的问题
  • iOS自定义UICollectionViewLayout实现瀑布流布局
  • 使用iOS控件UICollectionView生成可拖动的桌面的实例
  • IOS collectionViewCell防止复用的两种方法
  • iOScollectionView广告无限滚动实例(Swift实现)
  • iOS自定义collectionView实现毛玻璃效果
  • IOS简单实现瀑布流UICollectionView
  • ios的collection控件的自定义布局实现与设计
相关热词搜索: iOS UICollectionView 闪屏 iOS UICollect