Android中让GIF图片动起来

最近在做东西的时候,有个需求就是在界面上添加一个GIF图片,一开始我把一个imageview的背景设置为GIF图片,但是在界面却呈现不出来,只显示出GIF图片的一帧,然后查了下资料,找到了解决方案:使用安卓提供的AnimationDrawable这一函数,对GIF图片进行逐帧播放

首先把GIF图片打散,

动画分割器网址   http://files.cnblogs.com/TerryBlog/easygifanimator.rar

点击文件将帧文件导出即可,

得到帧文件就可以来编写代码了,在res/drawable文件夹下新建个xml文件,

 
 
  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <animation-list android:oneshot="false" 
  3.     xmlns:android="http://schemas.android.com/apk/res/android"> 
 
 
  1.  
  2.     <item android:duration="150" android:drawable="@drawable/xiu0" /> 
  3.     <item android:duration="150" android:drawable="@drawable/xiu1" /> 
  4.     <item android:duration="150" android:drawable="@drawable/xiu2" /> 
  5.     <item android:duration="150" android:drawable="@drawable/xiu3" /> 
  6. </animation-list>   
  7.    
对应的item标签的顺序代表了帧播放的顺序,toneshot为false代表为无限循环播放,而true表示只播放一次,duration表示帧之间的播放间隔

对应的Activity代码如下:

    • import android.app.Activity;  
    • import android.graphics.drawable.AnimationDrawable;  
    • import android.os.Bundle;  
    • import android.view.View;  
    • import android.view.View.OnClickListener;  
    • import android.widget.ImageView;  
    •  
    • public class animActivity extends Activity implements OnClickListener {  
    •     ImageView iv = null;  
    •  
    •     /** Called when the activity is first created. */  
    •     @Override  
    •     public void onCreate(Bundle savedInstanceState) {  
    •         super.onCreate(savedInstanceState);  
    •         setContentView(R.layout.main);  
    •  
    •         iv = (ImageView) findViewById(R.id.ImageView01);  
    •         iv.setOnClickListener(this);  
    •     }  
    •  
    •     @Override  
    •     public void onClick(View v) {  
    •         // TODO Auto-generated method stub  
    •         AnimationDrawable anim = null;  
    •         Object ob = iv.getBackground();  
    •         anim = (AnimationDrawable) ob;  
    •         anim.stop();  
    •         anim.start();  
    •     }  
    • }
使用AnimationDrawable 对象获得图片的图片,然后指定这个AnimationDrawable 开始播放动画

Tip:使用此方法不会默认播放,必须要有事件触发才可播放动画,如上面的通过点击监听触发动画的播放

那么如何使用图片自动播放呢?我们可以联想一下,ProgressBar 是不是默认的时候就会转,那就是那个圆形的进度条,是的。我们可以对它进行改造合它也可以自动播放,在Values 文件下新建一个styles 文件,编写如下代码 :

    • <?xml version="1.0" encoding="UTF-8"?> 
    • <resources> 
    •     <style name="animStyle" parent="@android:style/Widget.ProgressBar.Large"> 
    •         <item name="android:indeterminateDrawable">@anim/test</item> 
    •     </style> 
    • </resources>
针对一些比较小的图片Laege改为smal就行了。。

上面样式文件自Widget.ProgressBar.Large 为其设置动画文件,我们在XML中就可以通过设置它的样式使其为我们工作

 
 
  1. <ProgressBar android:id="@+id/ProgressBar01" style="@style/animStyle" 
  2.     android:layout_width="128px" android:layout_height="128px"></ProgressBar>






















  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值