Glide 展示 gif 动态图的介绍和走过的坑

每天跟我要展示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可以控制显示次数,你不信试试。

还有一些话,是给投稿作者的,很抱歉,最近投稿的人挺多的,所以是排队发送的投稿文章,你们投稿的文章,我一定会推送的,还请按顺序耐心等待推送,我一定会对得起大家的推送,让更多的人看到你们的分享和无私奉献的精神,在这里我替看到你们文章的开发者感谢你们的投稿。

欢迎大家关注我的技术分享公众号:非著名程序员(smart_android)。技术文章均先首发于我的技术分享的微信公众号。

Glide 是一个高效、开源、 Android设备上的媒体管理框架,它遵循BSD、MIT以及Apache 2.0协议发布。Glide具有加载本地图片、远程图片、GIF动画等功能。项目地址:https://github.com/bumptech/glide 你也可以直接下载jar包:https://github.com/bumptech/glide/releases 如何使用:创建个ImageView2. 获取图片并填充到ImageView  获取远程图片: Glide.with(this).load("http://www.see-source.com/source/img/logo_01.png").into(iv);   获取本地图片:Glide.with(this).load(R.drawable.logo_01).into(iv);  获取GIF动画图片Glide.with(this).load(R.drawable.image02).into(iv);image02.gif是个动画图片具体功能如下:GIF 动画的解码 :通过调用Glide.with(context).load(“图片路径“)方法,GIF动画图片可以自动显示为动画效果。如果想有更多的控制,还可以使用Glide.with(context).load(“图片路径“).asBitmap()方法加载静态图片,使用Glide.with(context).load(“图片路径“).asGif()方法加载动画图片本地视频剧照的解码: 通过调用Glide.with(context).load(“图片路径“)方法,Glide能够支持Android设备中的所有视频剧照的加载展示缩略图的支持: 为了减少在同一个view组件里同时加载多张图片的时间,可以调用Glide.with(context).load(“图片路径“).thumbnail(“缩略比例“).into(“view组件“)方法加载一个缩略图,还可以控制thumbnail()中的参数的大小,以控制显示不同比例大小的缩略图Activity 生命周期的集成: 当Activity暂停重启时,Glide能够做到智能的暂停重新开始请求,并且当Android设备的连接状态变化时,所有失败的请求能够自动重新请求转码的支持: Glide的toBytes() transcode() 两个方法可以用来获取、解码变换背景图片,并且transcode() 方法还能够改变图片的样式动画的支持: 新增支持图片的淡入淡出动画效果(调用crossFade()方法)查看动画的属性的功能OkHttp Volley 的支持: 默认选择HttpUrlConnection作为网络协议栈,还可以选择OkHttpVolley作为网络协议栈其他功能: 如在图片加载过程中,使用Drawables对象作为占位符、图片请求的优化、图片的宽度高度可重新设定、缩略图原图的缓存等功能
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值