android 使用xml让animation按顺序播放
需求:
想让一个View按顺序播放我已经用xml文件定义好的动画,之前我是监听动画的结束,在前一个动画结束的时候,开启第二个动画,但是这样写太麻烦。
最后发现还可以这样写。
实现
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<scale
android:pivotX="50%"
android:pivotY="50%"
android:fromXScale="0.5"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
android:toXScale="1.2"
android:fromYScale="0.5"
android:fillAfter="true"
android:duration="500"//第一个动画时间500
android:toYScale="1.2">
</scale>
<scale
android:startOffset="500"//第二个动画延迟500毫秒
android:pivotX="50%"
android:pivotY="50%"
android:fromXScale="1.2"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
android:toXScale="0.8"
android:fromYScale="1.2"
android:fillAfter="true"
android:duration="1000"//第二个动画时间1000,
android:toYScale="0.8">
</scale>
<scale android:startOffset="1000"//第二个动画延迟1000毫秒
android:pivotX="50%"
android:pivotY="50%"
android:fromXScale="0.8"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
android:toXScale="1"
android:fromYScale="0.8"
android:fillAfter="true"
android:duration="1500"//第二个动画时间1500,
android:toYScale="1">
</scale>
</set>
解释
其实这三个动画是一起开始执行的,但是第一个动画没有延迟,
执行500毫秒结束,第二个动画延迟500毫秒开始,刚好第一个动画结束,第二个动画开始,虽然第二个动画总时长是1000毫秒,但是延迟了500毫秒,实际执行动画的时间是1000(总时长)-500(延迟时间)=500毫秒。你可以算一下,第三个动画刚好是第二个动画结束时开始执行的。
注意:
android:fillAfter=”true”