作者:邹峰立,微博:zrunker,邮箱:zrunker@yahoo.com,微信公众号:书客创作,个人平台:www.ibooker.cc。
书客创作
Frame Animation(帧动画/逐帧动画/Drawable Animation),顾名思义是指将画面一帧一帧的进行播放的动画,它有两种实现方式,第一种方式是通过Java代码实现,这里需要使用到AnimationDrawable。第二种方式XML进行实现,这里需要用到<animation-list>标签。
第一种方式,Java实现:
这里我在res/drawable下放置loading_01~loading_12张png文件,用来显示每帧的效果图。先要从该文件夹下取出Drawable最后通过anim.addFrame(drawable,100)添加进来即可,其中anim.setOneShot(false);这个方法是用来设置该动画效果是否为一次播放,true的时候表示播放一次就停止,false的时候表示可以联系播放。
AnimationDrawable anim =new AnimationDrawable();
for(int i =1; i <=12; i++) {
int id;
// 获取Drawable文件夹下的图片文件
if(i <10)
id = getResources().getIdentifier("loading_0"+ i,"drawable",getPackageName());
else
id = getResources().getIdentifier("loading_"+ i,"drawable",getPackageName());
Drawable drawable = getResources().getDrawable(id);
anim.addFrame(drawable,100);
}
anim.setOneShot(false);
imageView.setImageDrawable(anim);
第二种方式:XML进行实现。
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false">
<!--oneshot:是否只展示一遍-->
<item android:drawable="@drawable/loading_01" android:duration="100"/>
......
<item android:drawable="@drawable/loading_12" android:duration="100"/>
</animation-list>
这样就将该一个帧动画设置完成,然后只需要在XML布局文件中进行调用。
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:contentDescription="@null"
android:src="@drawable/loading"/>
然而当我们运行的时候会发现动画没有运行而是停留在第一帧,这是为什么呢?
那是因为AnimationDrawable播放动画是依附在window上面的,而在Activity onCreate方法中调用时Window还未初始化完毕,所有才会停留在第一帧,要想实现播放可以在onWindowFocusChanged或onCreate方法中添加如下代码:
// XML实现逐帧动画
imageView.setImageResource(R.drawable.loading);
AnimationDrawable animationDrawable = (AnimationDrawable)imageView.getDrawable();
animationDrawable.start();
补充:AnimationDrawable 几个常见的api。
- void start()- 开始播放动画
- void stop()- 停止播放动画
- addFrame(Drawable frame, int duration)- 添加一帧,并设置该帧显示的持续时间
- void setOneShoe(boolean flag)- false为循环播放,true为仅播放一次
- boolean isRunning()- 是否正在播放
总结:逐帧动画使用起来较为简单,但是大量的使用,会占用大部分的CPU资源,是界面卡顿,而且如果画面使用图片过大时候还会出现OOM问题。
微信公众号:书客创作
网友评论