SDWebImage图片下载完成后渐进显示动画

大部分APP在图片下载完成后都有一个渐进显示的动画,本文讲下在不动SDWebImage代码的前提下,怎么给下载完成后的图片加上渐进显示的动画,这是最终的效果:

2017-02-12 22_53_44.gif

一般情况下,我们都会写一个UIImageViewcategory来处理图片下载,代码如下:

- (void)setWithImageURL:(NSString *)imageURL placeholder:(UIImage *)placeholder completion:(void (^)(UIImage *))completion
{
        [self sd_setImageWithURL:[NSURL URLWithString:imageURL]
                placeholderImage:placeholder
                       completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
                               // handle downloaded image
                           }
                       }];
        
}

completed回调中,我们可以获取到下载完成的image,图片的缓存类型。回调完成后,不做任何处理的话,那么下载完的图片会直接加载到UIImageView上。这样对于用户来讲会比较生硬,给图片加上一个渐进显示的动画效果会好很多。

要实现这个效果,我们会用到CATransition这个类,CATransitionCAAnimation的一个子类,CATransition的官方定义是An object that provides an animated transition between a layer's states. You can transition between a layer's states by creating and adding a CATransition object to it. 就是说我们可以通过CATransition来转换layer的状态,那么想实现渐进显示的动画效果,我们只需要加一个CATransitionUIImageView对象上。

那么CATransition都有哪些transition的种类呢?看一下官方文档,总共有4种:

  • kCATransitionFade
  • kCATransitionMoveIn
  • kCATransitionPush
  • kCATransitionReveal

第一种kCATransitionFade的解释是The layer’s content fades as it becomes visible or hidden.,看上去正是我们需要的transition type。通过一个CATransition使得图片加载由hidden变成visible状态时有一个渐进显示的动画效果。

完整代码如下:

[self sd_setImageWithURL:[NSURL URLWithString:imageURL]
        placeholderImage:placeholder
               completed:^(UIImage * _Nullable image, NSError * _Nullable error, SDImageCacheType cacheType, NSURL * _Nullable imageURL) {
                   if (image && cacheType == SDImageCacheTypeNone) {
                       CATransition *transition = [CATransition animation];
                       transition.type = kCATransitionFade;
                       transition.duration = 0.3;
                       transition.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
                       [weakself.layer addAnimation:transition forKey:nil];
                   }
               }];

转载请注明出处,原文地址:http://kobedai.me/p9rsts-5o/

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥iOS动画全貌。在这里你可以看...
    F麦子阅读 5,152评论 5 13
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,267评论 4 61
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 8,595评论 6 30
  • 本文转载自:http://www.cocoachina.com/ios/20150105/10812.html 为...
    idiot_lin阅读 1,308评论 0 1
  • 01 天朝是个官本位的社会,只要是个正式注册的机构,总免不了会有人莅临造访,如果是上级来人,那可能就是“视察"。 ...
    孤山踏歌阅读 732评论 5 7