一,逐帧动画
代码如下:
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
android:oneshot="false">
<item
android:drawable="@mipmap/img_miao1"
android:duration="80" />
<item
android:drawable="@mipmap/img_miao2"
android:duration="80" />
<item
android:drawable="@mipmap/img_miao3"
android:duration="80" />
<!--限于篇幅,省略其他item,自己补上-->
...
</animation-list>
注意:oneshot为true时只播放一次,false时则进行循环播放。item节点中drawable为显示的元素,duration为显示的时间。
逐帧动画的使用:
xxx.xml
<ImageView
android:id="@+id/xxx"
android:layout_width="120dp"
android:layout_height="120dp"
android:layout_gravity="center"
android:background="@anim/miao_gif" />
xxx.java
AnimationDrawable anim = (AnimationDrawable) xxxView.getBackground();
anim.start();
anim.stop();
二,补间动画
补间动画分为以下四种种类:
1),透明度 AlphaAnimation对应的xml标签为alpha,动画效果为从某一个透明度渐变至另一个透明度。
2),缩放 ScaleAnimation对应的xml标签为scale,动画效果为从某一个缩放比列渐变至另一个缩放比列。
3),位移 TranslateAnimation对应的xml标签为translate,动画效果为从某一个位置渐变位移至另一个位置。
4),旋转 RotateAnimation应的xml标签为rotate,动画效果为从某一个角度旋转至另一个角度。
5),组合动画 AnimationSet对应的xml标签为set 将多个动画效果进行组合。
另外我们需要额外的注意一下Interpolator的属性值含义。
LinearInterpolator
:动画以均匀的速度改变
AccelerateInterpolator
:在动画开始的地方改变速度较慢,然后开始加速
AccelerateDecelerateInterpolator
:在动画开始、结束的地方改变速度较慢,中间时加速
CycleInterpolator
:动画循环播放特定次数,变化速度按正弦曲线改变: Math.sin(2 mCycles Math.PI * input)
DecelerateInterpolator
:在动画开始的地方改变速度较快,然后开始减速
AnticipateInterpolator
:反向,先向相反方向改变一段再加速播放
AnticipateOvershootInterpolator
:开始的时候向后然后向前甩一定值后返回最后的值
BounceInterpolator
: 跳跃,快到目的值时值会跳跃,如目的值100,后面的值可能依次为85,77,70,80,90,100
OvershottInterpolator
:回弹,最后超出目的值然后缓慢改变到目的值
1.透明度动画 AlphaAnimation示例:
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
android:fromAlpha="1.0"
android:toAlpha="0.1"
android:duration="2000"/>
属性解释:
fromAlpha
:起始透明度
toAlpha
:结束透明度
透明度的范围为:0-1,完全透明-完全不透明
2.缩放动画 ScaleAnimation示例:
<scale xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/accelerate_interpolator"
android:fromXScale="0.2"
android:toXScale="1.5"
android:fromYScale="0.2"
android:toYScale="1.5"
android:pivotX="50%"
android:pivotY="50%"
android:duration="2000"/>
属性解释:
fromXScale/fromYScale
:沿着X轴/Y轴缩放的起始比例
toXScale/toYScale
:沿着X轴/Y轴缩放的结束比例
pivotX/pivotY
:缩放的中轴点X/Y坐标,即距离自身左边缘的位置,比如50%就是以图像的 中心为中轴点
3.位移动画 TranslateAnimation示例:
<translate xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
android:fromXDelta="0"
android:toXDelta="320"
android:fromYDelta="0"
android:toYDelta="0"
android:duration="2000"/>
属性解释:
fromXDelta/fromYDelta
:动画起始位置的X/Y坐标
toXDelta/toYDelta
:动画结束位置的X/Y坐标
4.旋转动画 RotateAnimation示例:
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
android:fromDegrees="0"
android:toDegrees="360"
android:duration="1000"
android:repeatCount="1"
android:repeatMode="reverse"/>
属性解释:
fromDegrees/toDegree
:旋转的起始/结束角度
repeatCount
:旋转的次数,默认值为0,代表一次,假如是其他值,比如3,则旋转4次 另外,值为-1或者infinite时,表示动画永不停止
repeatMode
:设置重复模式,默认restart,但只有当repeatCount大于0或者infinite或-1时 才有效。还可以设置成reverse,表示偶数次显示动画时会做方向相反的运动!
5.组合动画 AnimationSet示例:
<set xmlns:android="http://schemas.android.com/apk/res/android"
android:interpolator="@android:anim/decelerate_interpolator"
android:shareInterpolator="true" >
<scale
.... />
<rotate
.... />
<translate
.... />
<alpha
.... />
</set>
补间动画的使用:
Animation animation = AnimationUtils.loadAnimation(this,R.anim.xxx);
img_show.startAnimation(animation);