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

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

#### 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(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值