解决-Glide使用DiskLruCache缓存Gif图失效

在使用Glide时,发现配置了DiskLruCache缓存Gif图,但在断网情况下无法加载。问题源于Glide在获取缓存时使用带尺寸信息的Key,而DiskLruCache保存时Key不含尺寸。解决方案是将DiskCacheStrategy改为ALL,但缓存所有尺寸并非最优解。已在Glide GitHub Issue中提出。

#### 1. Glide配置
我加载Gif图的配置如下,skipMemoryCache设置为true只是为了测试DiskLruCache,实际使用中应设置为false。

        RequestOptions mOptions = new RequestOptions()
                .fitCenter()
                .priority(Priority.HIGH)
                .skipMemoryCache(true)
                .diskCacheStrategy(DiskCacheStrategy.RESOURCE);
  • priority(Priority.HIGH): 图片加载的优先级。优先级高的会先加载。
  • skipMemoryCache(): 是否跳过内存缓存,默认为false
  • DiskCacheStrategy.RESOURCE表示只保存原始尺寸的图片。

我用该配置去加载Gif图,代码为:

Glide.with(context)
    .load(url)
    .apply(mOptions)
    .into(new ImageViewTarget<Drawable>(imageView) {

    @Override
    protected void setResource(@Nullable Drawable resource) {
    }

    @Override
    public void onLoadStarted(@Nullable Drawable placeholder) {
           imageView.setImageDrawable(localPlaceHolder);
    }

    @Override
    public void onLoadFailed(@Nullable Drawable errorDrawable) {
           imageView.setImageDrawable(localPlaceHolder);
    }

    @Override
    public void onResourceReady(Drawable resource, @Nullable Transition<? super Drawable> transition) {
        if (resource instanceof GifDrawable) {
            (GifDrawable)(resource).start();
        }
    }
    });
2. 出现的现象

先从网络上加载一张GIF图片,由于跳过了内存缓存,因此理论上这张图片会保存在DiskLruCache里面。但是当把网络断开,重新进入的时候,发现GIF图并没有加载出来。但是相同的配置,JPG PNG的图片却能加载出来。

3. 产生的原因

通过查看DiskLruCache的journal文件(默认在data/data/package_name/cache/image_manager_disk_cache目录下),发现确实有一个和GIF图片相同大小的.0文件。说明确实已经缓存成功。

然后debug进DiskLruCacheWrapper的get和put方法,发现保存这张GIF图的时候的Key里面不包含该图片的尺寸,但是调用get方法去取的时候的Key确是一个有图片尺寸的Key。所以每次get的时候找不到缓存的图片。

使用diskCacheStrategy(DiskCacheStrategy.RESOURCE)缓存的是原始文件,并不会有图片的宽高信息。但是Glide去取GIF图的缓存时带上了宽高信息。

4. 解决办法

将DiskCacheStrategy调整为DiskCacheStrategy.ALL。DiskCacheStrategy.ALL会缓存所有尺寸的图片。

不知道是不是我的使用方式有问题,使用时确实碰到了这个问题,所以记录下来。这个问题我在Glide的github上提了一个Issue单(https://github.com/bumptech/glide/issues/2218)。希望如果有碰到相同问题的朋友们可以一起讨论下。毕竟缓存所有尺寸的图片不是一个好的解决办法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值