Android开发--动态图片的显示
Android开发——动态图片的显示
一、动态图片的显示方式
在编码的时候我们可以轻松显示静态图片,然而当我们加载动态图片的时候,它显示的还是一张静态图,达不到动态的效果,也就起不到吸引用户的作用,今天我将分享自己的亲身实践,总结出了两种加载动态图片的方式,下面就让我为大家介绍这两种方式:
1.用到GifView.jar,首先我们需要在网上下载这个jar包,然后导入到我们的工程里面的文件夹libs里面,如果是android studio,需要右击选择add as library,等重新运行成功后即可使用。这里我为大家提供一个下载地址:百度网盘链接:http://pan.baidu.com/s/1c14wrPe 密码:5dsx。
2.用到GifImageView这个jar包,在网上还没有搜到,但是android studio可以在Project Structure中搜索,然后设置依赖,同样可以使用。
点击选中的条目,会出现下图:
在搜索框中输入GifImageView,点击后面的搜索按钮,会出现下面显示的2.1.0结果,然后点击OK即可,等待产生依赖。
二、布局文件中实现:
1.GifView 注意这块要使用全类名
2.GifImageView 注意这块要使用全类名
其余的设置基本的参数就不多做介绍了。。。
三、代码中实现
1.GifView
/*** GifView获取图片资源*/private void gifView(){try {InputStream is = this.getResources().openRawResource(R.drawable.che);//获取动图资源ByteArrayOutputStream baos = new ByteArrayOutputStream();byte[] b = new byte[2048];int len = 0;while ((len = is.read(b, 0, 2048)) != -1) {baos.write(b, 0, len);}baos.flush();//刷新流,确保传递完全byte[] bytes = baos.toByteArray();//转换成Byte数组mGif.setGifImage(bytes);// 添加监听器//gif.setOnClickListener(this);// 设置显示的大小,拉伸或者压缩,由于GiftView在布局文件中设置宽和高无效,所以要设置宽和高mGif.setShowDimension(500, 200);// 设置加载方式:先加载后显示、边加载边显示、只显示第一帧再显示mGif.setGifImageType(GifView.GifImageType.WAIT_FINISH);} catch (IOException e) {e.printStackTrace();}} 2.GifImageView
/*** GifImageView获取图片资源并通过流的形式传递到*/private void gifImageView() {try {InputStream is = this.getResources().openRawResource(R.drawable.che);//获取动图资源ByteArrayOutputStream baos = new ByteArrayOutputStream();byte[] b = new byte[2048];int len = 0;while ((len = is.read(b, 0, 2048)) != -1) {baos.write(b, 0, len);}baos.flush();//刷新流,确保传递完全byte[] bytes = baos.toByteArray();//转换成Byte数组mImg.setBytes(bytes);//设置gif图片mImg.startAnimation();//运行动画} catch (IOException e) {e.printStackTrace();}} 在手机上的运行效果图: 四、总结
以上两种显示动图的方法只是加载了本地的动态图片,要下载并显示网上的动态图片,就需要使用异步任务,连接网络,下载动态图片,具体的实现方法会在后续的文章中给大家揭晓,欢迎关注我的博客。本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
