每天跟我要展示gif图demo的人很多,我有点纳闷,大家不知道很多第三方库都可以加载gif吗?比如Glide和Fresco都可以啊,大家不用它加载gif图吗?我有点纳闷,这几个方式加载的效果都还可以。当然也有点坑在里面,需要大家注意一下。
我以前写的那个关于gif图的demo其实是很早以前写的,但是那时候水平很菜,好几年前了,也不是完全自己写的,参考的别人写的,之后自己整理的。所以很不咋的。我发现每天都有人跟我要展示gif的demo,我想分享给大家展示gif图的几个好用的库。
Glide
如果用过Glide的同学可能大家都知道Glide是谷歌的一位员工开源的,名字叫:bumptech。这个库被广泛的运用在google的开源项目中,这个Glide说到底和Picasso很像,Glide和Picasso有90%的相似度,应该是基于Picasso开发的。但是Glide是支持动态gif图的。
Glide gif图使用
其实和加载普通图片的方式是一样的,如下:
Glide.with(this).load("图片地址:url").asGif().into(iv);
这里如果使用了.asGif()方法的话,传入的图片必须是gif图,其他图会报错。当然不使用.asGif()方法同样也可以加载gif图。
遇到的坑
你以为这样就可以了吗?有时候有些坑大家不得不踩,你有没有遇到过加载gif图很慢或者出不来的情况?有的话,解决办法咱也是有的,如下:
Glide.with(this).load(url).asGif().diskCacheStrategy(DiskCacheStrategy.SOURCE).into(imageView);
加入了缓存策略,缓存策略有四种如下:
/** Caches with both {@link #SOURCE} and {@link #RESULT}. */
ALL(true, true),
/** Saves no data to cache. */
NONE(false, false),
/** Saves just the original data to cache. */
SOURCE(true, false),
/** Saves the media item after all transformations to cache. */
RESULT(false, true);
ALL和RESULT的缓存策略不可以,NONE是不缓存数据,SOURCE是缓存原型,原图。加上了如上的缓存策略就解决了很慢或者有时加载不出gif图的问题了。
可能大家还有一种要求就是,动态显示gif图的次数,比如我想显示一次gif就停止,也有解决办法如下:
Glide.with(this).load("url").diskCacheStrategy(DiskCacheStrategy.SOURCE).into(new GlideDrawableImageViewTarget(iv, 1));
这里的GlideDrawableImageViewTarget(ImageView view, int maxLoopCount)这个方法,maxloopCount可以控制显示次数,你不信试试。
还有一些话,是给投稿作者的,很抱歉,最近投稿的人挺多的,所以是排队发送的投稿文章,你们投稿的文章,我一定会推送的,还请按顺序耐心等待推送,我一定会对得起大家的推送,让更多的人看到你们的分享和无私奉献的精神,在这里我替看到你们文章的开发者感谢你们的投稿。
网友评论
一下是我的代码
public void onBindViewHolder(MyGifRecyclerViewAdapter.MyHolder holder, final int position) {
GifsBean gifsBean = gifsBeens.get(position);
ViewGroup.LayoutParams layoutParams = holder.imageView.getLayoutParams();
layoutParams.height = Integer.parseInt(gifsBean.getFixed_height_height());
holder.imageView.setLayoutParams(layoutParams);
holder.imageView.setFocusable(false);
Glide.with(holder.imageView.getContext())
.load(gifsBean.getFixed_height_url())
// .centerCrop()
//.fitCenter()
.asGif()
.placeholder(gif_bg[random.nextInt(3)])
// .error(R.mipmap.ic_launcher)
// .skipMemoryCache(true)
.diskCacheStrategy(DiskCacheStrategy.ALL)
.crossFade()
// .thumbnail(0.1f)
// .override(128,128)
.into(holder.imageView);
}
这个是在另一个activity中显示缓存好的的gif图片的url地址
代码如下
Glide.with(UserInfoActivity.this)
.load(photo)
// .centerCrop()
.transform(new GlideCircleTransform(UserInfoActivity.this))
.placeholder(R.mipmap.ic_launcher)
.crossFade()
.into(head_portrait);
加了缓存策略之后,在再次使用缓存的资源是不是根据url来获取的?
如果不是还请作者简单讲一些glide 缓存策略。谢谢