当点击图片的时候,gif图片播放,当没有点击的时候是gif的第一帧,这时是一张图片。

参考:https://blog.csdn.net/guolin_blog/article/details/11100315

首先在values目录下新建一个attrs.xml的文件

<?xml version="1.0" encoding="utf-8"?>
<resources><declare-styleable name="AnimaImageView"><attr name="auto_play" format="boolean"></attr></declare-styleable>
</resources>
 

AnimaImageView继承自ImageView,这个类支持ImageView的所有功能。

package com.example.administrator.taiyang;/*** Created by Administrator on 2018/11/4.*/import android.content.Context;
import android.content.res.TypedArray;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Movie;
import android.os.Build;
import android.os.SystemClock;
import android.util.AttributeSet;
import android.util.TypedValue;
import android.view.View;
import android.widget.ImageView;import java.io.InputStream;
import java.lang.reflect.Field;/*** @author EX_YINQINGYANG* @version [Android PABank C01, @2016-09-29]* @date 2016-09-29* @description 可以播放gif动画的ImageView*/
public class AnimaImageView extends ImageView implements View.OnClickListener {/*** 是否自动播放*/private boolean isAutoPlay;/*** 播放GIF动画的关键类*/private Movie mMovie;/*** gif宽高*/private BitmapSize bitmapSize;/*** 播放按钮*/private Bitmap mStartBotton;/*** 是否正在播放gif*/private boolean isPlaying;/*** gif开始时间*/private long mMovieStart;public AnimaImageView(Context context) {super(context);}public AnimaImageView(Context context, AttributeSet attrs) {this(context, attrs,0);}public AnimaImageView(Context context, AttributeSet attrs, int defStyleAttr) {super(context, attrs, defStyleAttr);if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {this.setLayerType(View.LAYER_TYPE_SOFTWARE,null);}obtainStyledAttr(context,attrs,defStyleAttr);}private void obtainStyledAttr(Context context, AttributeSet attrs, int defStyleAttr) {TypedArray a=context.getTheme().obtainStyledAttributes(attrs,R.styleable.AnimaImageView,defStyleAttr,0);int resId=getIdentifier(a);if(resId!=0){// 当资源id不等于0时,就去获取该资源的流InputStream is=getResources().openRawResource(resId);// 使用Movie类对流进行解码mMovie=Movie.decodeStream(is);//mMovie不等null说明这是一个GIF图片if(mMovie!=null){this.setLayerType(View.LAYER_TYPE_SOFTWARE,null);//是否自动播放isAutoPlay=a.getBoolean(R.styleable.AnimaImageView_auto_play,false);/*** 获取gif图片大小*/Bitmap bitmap= BitmapFactory.decodeStream(is);bitmapSize=new BitmapSize(bitmap.getWidth(),bitmap.getHeight());bitmap.recycle();if(!isAutoPlay){// 当不允许自动播放的时候,得到开始播放按钮的图片,并注册点击事件mStartBotton=BitmapFactory.decodeResource(getResources(),R.drawable.g1);setOnClickListener(this);}}}a.recycle();}@Overrideprotected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {super.onMeasure(widthMeasureSpec, heightMeasureSpec);//当时gif图片的时候,控件宽高为gif文件大小if(mMovie!=null){setMeasuredDimension(bitmapSize.width,bitmapSize.height);}}@Overrideprotected void onDraw(Canvas canvas) {//当为一张普通的图片的时候if(mMovie==null){super.onDraw(canvas);}else{//如果自动播放的话,就直接播放if(isAutoPlay){playMovie(canvas);invalidate();}else{//如果已经点击了播放按钮的话就开始播放gifif(isPlaying){if(playMovie(canvas)){isPlaying=false;}invalidate();}else{// 还没开始播放就只绘制GIF图片的第一帧,并绘制一个开始按钮mMovie.setTime(0);mMovie.draw(canvas, 0, 0);int offsetW = bitmapSize.width ;int offsetH = bitmapSize.height;canvas.drawBitmap(mStartBotton, offsetW, offsetH, null);}}}}/*** 开始播放GIF动画,播放完成返回true,未完成返回false。** @param canvas* @return 播放完成返回true,未完成返回false。*/private boolean playMovie(Canvas canvas) {//获取当前时间long now = SystemClock.uptimeMillis();if (mMovieStart == 0) {mMovieStart = now;}int duration = mMovie.duration();if (duration == 0) {duration = 1000;}int relTime = (int) ((now - mMovieStart) % duration);mMovie.setTime(relTime);//不断的设置gif的播放位置mMovie.draw(canvas, 0, 0);//将movie画在canvas上//如果(当前时间-gif开始的时间=gif总时长)说明播放完毕了if ((now - mMovieStart) >= duration) {mMovieStart = 0;return true;}return false;}/*** 通过反射获取src中的资源id* @param a*/private int getIdentifier(TypedArray a) {try {Field mValueFiled = a.getClass().getDeclaredField("mValue");mValueFiled.setAccessible(true);TypedValue typedValue= (TypedValue) mValueFiled.get(a);return typedValue.resourceId;} catch (NoSuchFieldException e) {e.printStackTrace();} catch (IllegalAccessException e) {e.printStackTrace();}return 0;}/*** 当点击图片的时候播放gif*/@Overridepublic void onClick(View v) {isPlaying = true;invalidate();}/*** BitmapSize*/class BitmapSize{private int width;private int height;public BitmapSize(int width, int height) {this.width = width;this.height = height;}}
}

activity_main.xml

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"xmlns:app="http://schemas.android.com/apk/res-auto"xmlns:attr="http://schemas.android.com/apk/res-auto"xmlns:tools="http://schemas.android.com/tools" ><com.example.administrator.taiyang.AnimaImageViewandroid:layerType="software"android:layout_width="wrap_content"android:layout_height="wrap_content"attr:auto_play="false"android:src="@drawable/g1"android:layout_weight= "1"/></RelativeLayout>
这里要注意包名:<com.example.administrator.taiyang.AnimaImageView

attr:auto_play="false" 是禁止fig动画自动播放。

可改为 attr:auto_play="true" 自动播放。

有些4.0以上系统的手机启动了硬件加速功能之后会导致GIF动画播放不出来,因此我们需要在AndroidManifest.xml中去禁用硬件加速功能。

AndroidManifest.xml,在<application 下增加

 android:hardwareAccelerated="false"android:largeHeap="true"

如果src属性里面指定的是一张PNG图片,图片在布局正中央也会显示出来,正是普通ImageView所具备的功能。

Android ImageView播放gif图片相关推荐

  1. android 自动播放 幻灯片,Android自动播放Banner图片轮播效果

    本文实例为大家分享了Android自动播放Banner图片轮播的具体代码,供大家参考,具体内容如下 先看一下效果图 支持本地图片以及网络图片or本地网络混合. 使用方式: android:id=&qu ...

  2. Android ImageView圆形头像 图片完全解析

    转载http://m.oschina.net/blog/321024 Android ImageView圆形头像 图片完全解析 我们在做项目的时候会用到圆形的图片,比如用户头像,类似QQ.用户在用QQ ...

  3. android imageview 显示资源图片,ImageView显示网络图片资源

    Android ImageView如何加载网络图片资源有些事,可以看透,但不要看破;有些人,可以看穿,但不要戳穿;有些话,能不说就沉默,藏在心里更适合;有些伤,能不揭就不提起,无声忘记更明智. 用im ...

  4. android 怎么播放gif图片不显示,android 播放gif动态图片

    android不推荐使用gif图片,一般都是png的,对于gif的图片解析比较消耗资源,但是对于一些动态gif图片的播放,如果比较小的话还是可以的,要是大的话,建议还是把gif图片转换成一帧一帧的pn ...

  5. android:ImageView选择本地图片并显示

    运行结果: 模拟器图库就三张 没办法~画质挺感人~ 一个隐式意图 布局文件: <RelativeLayout xmlns:android="http://schemas.android ...

  6. android 图片分析,Android ImageView圆形头像 图片完全解析

    我们在做项目的时候会用到圆形的图片,比如用户头像,类似QQ.用户在用QQ更换头像的时候,上传的图片都是矩形的,但显示的时候确是圆形的. 原理:先在canvas上面画一个圆形,参照圆形的起点坐标.半径, ...

  7. android imageview点击图片放大缩小,Android实现ImageView图片双击放大及缩小

    病人肝癌肿瘤治疗前9.0*8.8cm,通过一疗程服药治疗缩小到8.0*7.3cm. 肝肿瘤9.0*8.8cm 肝肿瘤缩小到8.0*7.3cm 河南偃师任某某乙肝癌肿瘤治疗前6.7*9.3cm,通过一疗 ...

  8. android首页图片轮播效果,Android_Android自动播放Banner图片轮播效果,先看一下效果图支持本地图 - phpStudy...

    Android自动播放Banner图片轮播效果 先看一下效果图 支持本地图片以及网络图片or本地网络混合. 使用方式: android:id="@+id/banner" andro ...

  9. Android ImageView扩展 支持本地gif图片 支持网络gif图片

    转载自:http://blog.csdn.net/guolin_blog/article/details/11100315 主要改进: 在原有的代码基础上加入了网络图片的显示. 源码地址 我个人是比较 ...

最新文章

  1. 软件测试需要学习什么技术
  2. CMU最新《深度学习》2022春季课程,Ruslan Salakhutdinov教授主讲
  3. 学习java技术有前途吗?当然有前途
  4. Maven 搭建spring boot多模块项目(附源码)
  5. 广播网关GPC为MDS多媒体调度再添虎翼
  6. 奔小康赚大钱 HDU - 2255( 二分图匹配KM算法详解)
  7. Intel Core Enhanced Core架构/微架构/流水线 (5) - 分支预测/指令预取
  8. APPIUM+Python+HTMLTestRunner(转)
  9. 代理模式-Java实现-静态代理、动态代理
  10. Mac(不限于)中几个有内涵的工具
  11. 华为设备BGP中的路由控制与实验
  12. @property 参数问题
  13. java tmp 目录_Tmp目录丢失引发Java进程异常
  14. vue 引入vue-resource给页面加点动态数据
  15. VB.NET/C# Free Grid Control 免费开源表格控件 - ReoGrid 介绍(1)
  16. Robotium体验----白盒
  17. 什么是数据可视化大屏?如何制作一个数据可视化大屏?
  18. 百度世界推出“轻应用” :人人都可开发
  19. 【附源码】计算机毕业设计SSM社区志愿者管理系统
  20. 跨境电商如何利用Quora帮你引上万流量

热门文章

  1. 5.8 最小均方误差(维纳)滤波
  2. 买卖股票的最佳时机四
  3. 解决Starting virtual machine...
  4. 不懂人情世故就是垃圾
  5. 椭圆按钮点击移动 vue实现
  6. 爱立信简介及中国2005校园招聘
  7. 腾讯副总裁张小龙谈微信:对人性把握最重要
  8. SSL证书失效导致无法上传问题
  9. JSP基础语法(手写笔记)
  10. 如何从0到1做好一项产品?(课上总结加上课外扩展)【产品经理】