iOS 简单的播放gif动画

基本上有三种方式来播放gif动画

1.webView播放方式

webView是一个很强大的控件,可以很容易的实现gif的播放,不过只能循环播放。

    CGRect rect =CGRectMake(3,10,100,100);

    rect.size = [UIImageimageNamed:@"jiafei.gif"].size;

    

   _webView = [[UIWebViewalloc]initWithFrame:rect];

    NSData *imgData = [NSDatadataWithContentsOfFile:[[NSBundlemainBundle]pathForResource:@"jiafei"ofType:@"gif"]];

    [_webViewloadData:imgDataMIMEType:@"image/gif"textEncodingName:nilbaseURL:nil];

    _webView.userInteractionEnabled =NO;//用不不可交互

    _webView.backgroundColor = [UIColorclearColor];

   _webView.opaque =NO;

    [self.viewaddSubview:_webView];


//获取图片数据的格式的代码 

+ (NSString *)MIMETypeForImageData:(NSData *)data {

   if (!data)returnnil;

    

   uint8_t c;

    [datagetBytes:&clength:1];

    

   switch (c) {

       case0xFF:

           return@"image/jpeg";

       case0x89:

           return@"image/png";

       case0x47:

           return@"image/gif";

       case0x49:

       case0x4D:

           return@"image/tiff";

    }

    return nil;

}


2.第三方播放方式

采用ImageIO库,对gif文件进行解析,然后做动画显示

我觉得OLImageView写的不错,支持循环播放、暂停和继续播放,下载地址:http://code4app.com/ios/OLImageView/50beb9a26803fac635000001

注:需要导入两个库:ImageIO.framework 和 MobileCoreServices.framework

3.UIImageView播放方式

将gif分解成多张png图片,用UIImageView播放。

    NSMutableArray *resourceArr = [[NSMutableArrayalloc]init];

   for (int i =1;i <=17;i++)

    {

       UIImage *pic =nil;

       if (i <10)

        {

           pic = [UIImageimageNamed:[NSStringstringWithFormat:@"campFire0%i.gif",i]];

        }

       else

        {

           pic = [UIImageimageNamed:[NSStringstringWithFormat:@"campFire%i.gif",i]];

        }

        [resourceArraddObject:pic];

    }

    

   UIImageView *fireImageView = [[UIImageViewalloc]initWithFrame:self.view.bounds];

    fireImageView.animationImages = resourceArr;

    //执行一次完整动画所需时长

    fireImageView.animationDuration =1.75;

    //repeat the animation forever

    fireImageView.animationRepeatCount =0;

    [fireImageViewstartAnimating];

    [self.viewaddSubview:fireImageView];

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值