Drawable动画是通过载入一系列的drawable资源陆续创建动画。这是一个传统的动画,它像一卷电影一样将一个序列不同的图像按播放顺序播放形成。Animationdrawable类是Drawable动画的基础。
XML文件包含一个作为根节点和一系列子节点,每个定义一帧:一帧的图片资源和一帧的持续时间。这里是一个Drawable动画实例的XML文件:
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="true">
<item android:drawable="@drawable/horse1" android:duration="100"></item>
<item android:drawable="@drawable/horse2" android:duration="100"></item>
<item android:drawable="@drawable/horse3" android:duration="100"></item>
<item android:drawable="@drawable/horse4" android:duration="100"></item>
<item android:drawable="@drawable/horse5" android:duration="100"></item>
<item android:drawable="@drawable/horse6" android:duration="100"></item>
<item android:drawable="@drawable/horse7" android:duration="100"></item>
<item android:drawable="@drawable/horse8" android:duration="100"></item>
</animation-list>
这个动画只运行三帧。通过设置android:oneshot的属性为true,它将只循环一次然后停止并保持在最后一帧。如果设置为false,则动画将循环。通过将这个XML保存在res/drawable/rocket_thrust.xml目录,它可以被View对象添加背景然后播放。这里的一个例子,其中动画添加到ImageView然后屏幕被触摸时播放动画:
AnimationDrawable rocketAnimation;
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ivDrawable = (ImageView) findViewById(R.id.ivDrawable);
ivDrawable.setBackgroundResource(R.drawable.horese);
animationDrawable= (AnimationDrawable) ivDrawable.getBackground();
}
public boolean onTouchEvent(MotionEvent event) {
if (event.getAction() == MotionEvent.ACTION_DOWN) {
if(animationDrawable.isRunning()){
animationDrawable.stop();
}
animationDrawable.start();
return true;
}
return super.onTouchEvent(event);
}
运行效果如下:
也可通过标签将图片层叠起来,实现多个动画效果:
<?xml version="1.0" encoding="UTF-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false">
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_00" />
<item android:drawable="@drawable/login_loading_10" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_01" />
<item android:drawable="@drawable/login_loading_11" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_02" />
<item android:drawable="@drawable/login_loading_12" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_03" />
<item android:drawable="@drawable/login_loading_13" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_04" />
<item android:drawable="@drawable/login_loading_14" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_05" />
<item android:drawable="@drawable/login_loading_15" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_06" />
<item android:drawable="@drawable/login_loading_16" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_07" />
<item android:drawable="@drawable/login_loading_17" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_08" />
<item android:drawable="@drawable/login_loading_18" />
</layer-list>
</item>
<item android:duration="100">
<layer-list>
<item android:drawable="@drawable/login_loading_09" />
<item android:drawable="@drawable/login_loading_19" />
</layer-list>
</item>
</animation-list>
运行效果如下:
值得注意的是,在oncreate()方法中不能调用AnimationDrawable的start()方法,因为此时Animationdrawable尚未完全依附于窗口。如果你想立刻播放的动画不需要互动,那么你可以在onwindowfocuschanged()方法中调用start()方法。
参考
1、http://blog.youkuaiyun.com/chziroy/article/details/40424343/
2、https://developer.android.google.cn/guide/topics/graphics/drawable-animation.html