Android 用Animation-list实现逐帧动画
在处理耗时工作的时候,大多数会弹出一个加载的框,里面有一个连续旋转的图片,很多时候都是用一张图片,使用rotate来设定旋转,不过看起来不太美观,没有形象感,在3.0之前Android有两种动画效果分别是补间动画和帧动画,用一张图片实现的是使用补间动画,定义给出两个关键帧,通过一些算法将给定属性值在给定的时间内在两个关键帧间渐变。我个人比较倾向的是帧动画,不过这个需要美工的支持,还有一种方式就是通过反编译其他的软件获取图片,我不是美工也没有美工的支持,所以就解压QQ的apk,获取它里面的显示加载动画的图片,图片资源http://download.csdn.net/download/jwzhangjie/6852981。
看看如何实现的
load_animation_1.xml
<?xml version="1.0" encoding="utf-8"?> <!-- 根标签为animation-list,其中oneshot代表着是否只展示一遍,设置为false会不停的循环播放动画 根标签下,通过item标签对动画中的每一个图片进行声明 android:duration 表示展示所用的该图片的时间长度 --> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false" > <item android:drawable="@drawable/qb_tenpay_loading_1" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_2" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_3" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_4" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_5" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_6" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_7" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_8" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_9" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_10" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_11" android:duration="150"></item> <item android:drawable="@drawable/qb_tenpay_loading_12" android:duration="150"></item> </animation-list>load_animation_2.xml
<?xml version="1.0" encoding="utf-8"?> <!-- 根标签为animation-list,其中oneshot代表着是否只展示一遍,设置为false会不停的循环播放动画 根标签下,通过item标签对动画中的每一个图片进行声明 android:duration 表示展示所用的该图片的时间长度 --> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false" > <item android:drawable="@drawable/common_loading_0" android:duration="150"></item> <item android:drawable="@drawable/common_loading_1" android:duration="150"></item> <item android:drawable="@drawable/common_loading_2" android:duration="150"></item> <item android:drawable="@drawable/common_loading_3" android:duration="150"></item> <item android:drawable="@drawable/common_loading_4" android:duration="150"></item> <item android:drawable="@drawable/common_loading_5" android:duration="150"></item> <item android:drawable="@drawable/common_loading_6" android:duration="150"></item> <item android:drawable="@drawable/common_loading_7" android:duration="150"></item> <item android:drawable="@drawable/common_loading_8" android:duration="150"></item> <item android:drawable="@drawable/common_loading_9" android:duration="150"></item> <item android:drawable="@drawable/common_loading_10" android:duration="150"></item> <item android:drawable="@drawable/common_loading_11" android:duration="150"></item> </animation-list>
wifi_animation_1.xml
<?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false" > <item android:drawable="@drawable/wifi_1" android:duration="150"></item> <item android:drawable="@drawable/wifi_2" android:duration="150"></item> <item android:drawable="@drawable/wifi_3" android:duration="150"></item> <item android:drawable="@drawable/wifi_4" android:duration="150"></item> <item android:drawable="@drawable/wifi_5" android:duration="150"></item> <item android:drawable="@drawable/wifi_6" android:duration="150"></item> </animation-list>布局文件:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="动画加载1" android:id="@android:id/button1" ></Button> <Button android:id="@android:id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@android:id/button1" android:layout_marginLeft="20dip" android:text="动画加载2" /> <Button android:id="@android:id/button3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@android:id/button2" android:layout_marginLeft="20dip" android:text="动画wifi1" /> <ImageView android:id="@+id/animationIV" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_centerInParent="true" android:contentDescription="@string/app_name" /> <ImageView android:id="@+id/animationIV2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toRightOf="@id/animationIV" android:src="@anim/load_animation_2" android:contentDescription="@string/app_name" android:layout_alignBottom="@id/animationIV" android:layout_marginLeft="30dip" /> <ImageView android:id="@+id/animationIV3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_above="@id/animationIV" android:contentDescription="@string/app_name" android:layout_marginTop="20dip" /> </RelativeLayout>
public class Test extends BaseActivity{ private Button button1,button2,button3; private ImageView animationIV; private ImageView animationIV2; private ImageView animationIV3; private AnimationDrawable AniDraw, AniDraw2, AniDraw3; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.test); button1 = (Button)findViewById(android.R.id.button1); button1.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { if (AniDraw.isRunning()) { AniDraw.stop(); }else { AniDraw.start(); } } }); button2 = (Button)findViewById(android.R.id.button2); button2.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { if (AniDraw2.isRunning()) { AniDraw2.stop(); }else { AniDraw2.start(); } } }); button3 = (Button)findViewById(android.R.id.button3); button3.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { if (AniDraw3.isRunning()) { AniDraw3.stop(); }else { AniDraw3.start(); } } }); animationIV = (ImageView)findViewById(R.id.animationIV); /** * 这里设置的是setBackgroundResource,那么你获取的时候通过getBackground */ animationIV.setBackgroundResource(R.anim.load_animation_1); AniDraw = (AnimationDrawable)animationIV.getBackground(); /** * 在xml里面通过src来设置跟在代码里面使用setImageResource获取的时候通过getDrawable * 例如:animationIV2.setImageResource(R.anim.load_animation_2);是一样的 */ animationIV2 = (ImageView)findViewById(R.id.animationIV2); AniDraw2 = (AnimationDrawable)animationIV2.getDrawable(); animationIV3 = (ImageView)findViewById(R.id.animationIV3); animationIV3.setImageResource(R.anim.wifi_animation_1); AniDraw3 = (AnimationDrawable)animationIV3.getDrawable(); }
效果由于我不会做动画效果图片,所以效果图也就不贴了
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。