本文将为讲解Android中Gif图片播放的教程。Android 中是不支持直接使用Gif 图片关联播放帧动画,如下动画在Android 中是无法播放的,我们将教会您使用有效方法让Gif图片在Android下动起来。
咱们现已接连推出《怎么完成TCP和UDP传输》、《“Android UI”规划官方教程》多个Android开发教程,本文将为解说Android中Gif图片播映的教程。Android 中是不支撑直接运用Gif 图片相关播映帧动画,如下动画在Android 中是无法播映的:
Android 供给了别的一种处理的办法,便是运用AnimationDrawable 这一函数使其支撑逐帧播映,可是怎么把gif 图片打散开来,成为每一帧的图片呢?下面介绍两种比较不错的软件,能够帮咱们打散图片。
gifsplitter2.0
下载地址:gif切割
运用办法如下:
这一软件切割图片都是bmp图片,图片比较大,这儿不引荐运用,尽量节约不必要的字节,所以这儿引荐运用如下 软件
easygifanimator
软件下载:动画切割器
运用办法如下:
点击文件将帧文件导出即可
得到了帧文件后咱们能够就编写代码,在res目录下新建anim动画文件夹,写下如下代码
- <?xmlversion="1.0"encoding="UTF-8"?>
- <animation-listandroid:oneshot="false"
- xmlns:android="http://schemas.android.com/apk/res/android">
- <itemandroid:duration="150"android:drawable="@drawable/xiu0"/>
- <itemandroid:duration="150"android:drawable="@drawable/xiu1"/>
- <itemandroid:duration="150"android:drawable="@drawable/xiu2"/>
- <itemandroid:duration="150"android:drawable="@drawable/xiu3"/>
- </animation-list>
对应的item 为次序的图片从开端到完毕,duration为每张逐帧播映距离,oneshot 为false 代表循环播映,设置为true 即播映一次即中止。
对应Activity 代码如下编写:
- importandroid.app.Activity;
- importandroid.graphics.drawable.AnimationDrawable;
- importandroid.os.Bundle;
- importandroid.view.View;
- importandroid.view.View.OnClickListener;
- importandroid.widget.ImageView;
- publicclassanimActivityextendsActivityimplementsOnClickListener{
- ImageViewiv=null;
- /**Calledwhentheactivityisfirstcreated.*/
- @Override
- publicvoidonCreate(BundlesavedInstanceState){
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- iv=(ImageView)findViewById(R.id.ImageView01);
- iv.setOnClickListener(this);
- }
- @Override
- publicvoidonClick(Viewv){
- //TODOAuto-generatedmethodstub
- AnimationDrawableanim=null;
- Objectob=iv.getBackground();
- anim=(AnimationDrawable)ob;
- anim.stop();
- anim.start();
- }
- }
运用AnimationDrawable 目标取得图片的图片,然后指定这个AnimationDrawable 开端播映动画
Tip:运用此办法不会默许播映,有必要要有事情触发才可播映动画,如上面的经过点击监听触发动画的播映
那么怎么运用图片自动播映呢?咱们能够联想一下,ProgressBar 是不是默许的时分就会转,那便是那个圆形的进度条,是的。咱们能够对它进行改造合它也能够自动播映,在Values 文件下新建一个styles 文件,编写如下代码 :
- <?xmlversion="1.0"encoding="UTF-8"?>
- <resources>
- <stylename="animStyle"parent="@android:style/Widget.ProgressBar.Large">
- <itemname="android:indeterminateDrawable">@anim/test</item>
- </style>
- </resources>
上面款式文件自Widget.ProgressBar.Large为其设置动画文件,咱们在XML中就能够经过设置它的款式使其为咱们作业
- <ProgressBarandroid:id="@+id/ProgressBar01"style="@style/animStyle"
- android:layout_width="128px"android:layout_height="128px"></ProgressBar>
OK,便是这么简略,下面看看运转作用:
【修改引荐】
- Android开发:自由选择TextView的文字
- Android开发:怎么完成TCP和UDP传输
- 多图详解 “Android UI”规划官方教程
- 图文并茂 在MyEclipse 8.6上建立Android开发环境