IOS 高效GIF播放

  • 时间:2017-11-24
  • 分类:IOS开发
  • 1657 人浏览
[导读]ios通常播放gif的方式由如下几种:1.使用webview(用起来不是很方便,又不够灵活)2.将GIF图片分解成多张PNG图片,使用UIImageView播放(内存消耗过大,一个200多帧率的gif图片,内存能够涨上天,页面上有几张这样的

ios通常播放gif的方式由如下几种:

1.使用webview(用起来不是很方便,又不够灵活)

2.将GIF图片分解成多张PNG图片,使用UIImageView播放(内存消耗过大,一个200多帧率的gif图片,内存能够涨上天,页面上有几张这样的图片,不敢想象)

3.使用SDWebImage(原理与方式2类似,只是上层封装了一层,方便调用,内存消耗过大)

4.定时刷新imageview.layer(实现循环播放图片的效果,可以做到释放迅速,但是加重cpu的负担)

 

这个是我实现播放GIF图片imageview的repo:https://github.com/lizilong1989/LongImageCache

我实现的原理很简单,首先我定义了一个UIImageView+LongCache.h(作为ImageView的扩展,方便不同场景下,是您的ImageView对Gif的支持,同时还支持对网络图片的下载),核心就是将gif图片的播放放在displaylink中,然后添加到loop中,循环刷新image,到达播放gif图片的效果。

plagGif方法就是刷新ImageView的方法,

使用了方法替换,将startAnimating和stopAnimating替换成下面的方法,当使用像tableview这样复用结构时,imageview会根据设置的新数据,停止当前gif的播放,效果就是当滑动到其它位置时,cpu和内存就会降低,不会影响整个tableview的性能。

整体播放效果较为流畅,需要消耗一定的cpu,但是内存消耗明显较低。

下面是播放相同的GIF图片,使用iphone8模拟器,对内存和cpu的效果对比

使用SDImageCache播放GIF图片时的内存和CPU消耗:

 

使用SDWebImage的效果

使用LongImageCache播放GIF图片时的内存和CPU消耗:

 

 

来源:本文为线上采编,如涉及作品内容、版权和其它问题,请及时与本网联系,我们将在第一时间删除!
标签: IOS GIF播放