Android Glide加载gif

本文介绍如何使用Glide加载GIF动画,并设置了播放次数及监听。通过代码示例展示了如何计算GIF动画时长并发送延时消息通知动画结束。此外还提供了加载GIF时的缓存策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用glide加载gif动画,有时需要设置播放的次数,然后播放玩一次或者几次之后,需要在播放完做一些其他的操作,直接看代码:

Glide.with(this)
                .load(R.drawable.xiaoguo)
                .diskCacheStrategy(DiskCacheStrategy.SOURCE)
                .listener(new RequestListener<Integer, GlideDrawable>() {

                    @Override
                    public boolean onException(Exception arg0, Integer arg1,
                            Target<GlideDrawable> arg2, boolean arg3) {
                        return false;
                    }

                    @Override
                    public boolean onResourceReady(GlideDrawable resource,
                            Integer model, Target<GlideDrawable> target,
                            boolean isFromMemoryCache, boolean isFirstResource) {
                        // 计算动画时长
                        GifDrawable drawable = (GifDrawable) resource;
                        GifDecoder decoder = drawable.getDecoder();
                        for (int i = 0; i < drawable.getFrameCount(); i++) {
                            duration += decoder.getDelay(i);
                        }
                        //发送延时消息,通知动画结束
                        handler.sendEmptyMessageDelayed(MESSAGE_SUCCESS,
                                duration);
                        return false;
                    }
                }) //仅仅加载一次gif动画
                .into(new GlideDrawableImageViewTarget(imageview, 1));
   
   

    glide简单加载动画用法:

    Glide.with(MainActivity.this).load(url).asGif().into(imageView);  
       
       

      如果添加.asGif(),这样的话就只能加载gif文件,如果不加,既可以加载图片也可以加载.gif。

      解决加载gif文件非常慢的情况:
      为其添加缓存策略

      Glide.with(MainActivity.this).load(url).asGif().diskCacheStrategy(DiskCacheStrategy.SOURCE).into(imageView);  
      
         
         

        其中缓存策略可以为:Source及None,None及为不缓存,Source缓存原型.如果为ALL和Result就不行
        DiskCacheStrategy.NONE 什么都不缓存
        DiskCacheStrategy.SOURCE 仅仅只缓存原来的全分辨率的图像。
        DiskCacheStrategy.RESULT 仅仅缓存最终的图像,即,降低分辨率后的(或者是转换后的)
        DiskCacheStrategy.ALL 缓存所有版本的图像(默认行为)

        设置gif播放次数:
        这样写会报错的:

        Glide.with(MainActivity.this).load(url).asGif().into(new GlideDrawableImageViewTarget(imageview, 1));
           
           

          设置播放次数和播放监听的时候,不应加上.asGif()

          Glide.with(MainActivity.this).load(url).into(new GlideDrawableImageViewTarget(imageview, 1));
             
             

            new GlideDrawableImageViewTarget(imageview, 1),imageview是控件,1是播放次数

            设置播放监听:
            添加listener()

            listener(new RequestListener<Integer, GlideDrawable>() {
            
                                @Override//加载出错
                                public boolean onException(Exception arg0, Integer arg1,
                                        Target<GlideDrawable> arg2, boolean arg3) {
                                    return false;
                                }
            
                                @Override//加载完成
                                public boolean onResourceReady(GlideDrawable resource,
                                        Integer model, Target<GlideDrawable> target,
                                        boolean isFromMemoryCache, boolean isFirstResource) {
                                    // 计算动画时长
                                    GifDrawable drawable = (GifDrawable) resource;
                                    GifDecoder decoder = drawable.getDecoder();
                                    for (int i = 0; i < drawable.getFrameCount(); i++) {
                                        duration += decoder.getDelay(i);
                                    }
                                    //发送延时消息,通知动画结束
                                    handler.sendEmptyMessageDelayed(MESSAGE_SUCCESS,
                                            duration);
                                    return false;
                                }
                            })
               
               
                                  <link rel="stylesheet" href="https://csdnimg.cn/release/phoenix/production/markdown_views-68a8aad09e.css">
                                      </div>
              
              评论 2
              添加红包

              请填写红包祝福语或标题

              红包个数最小为10个

              红包金额最低5元

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

              抵扣说明:

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

              余额充值