android 动画使用机制2

Andriod 的Animations可以从形式上分为两大类,分别是 Tweened Animations 和Frame-By-Frame Animations。Tweened Animations可以理解为补间动画,也就是某一张图或者其他对象,进行旋转、变形等动画;而Frame-By-Frame Animations是多张图片或对象,进行一帧一帧的变化。简单而也,前者是本身改变的动画,后者是与其他内容的交替显示形成的动画。

Tweened Animations有4种样式,分别为Alpha,Rotate,Translate,Scale。分别表示渐变,旋转,位移,缩放。要实现以上4种动画,必须要给出每种动画的需要参数。

Alpha:因为是渐变,所以需要给出改变之前的透明度,改变之后的透明度,总共改变的时间。

Rotate:旋转,必定要知道旋转的圆心在哪边,所以要定义圆心的X与Y轴,以及转动的时间,转动的角度等。

Translate:位移,即要知道原来对象的XY轴和改变后的XY轴,以及运动的时间等。

Scale:缩放,首先要知道XY轴缩放的比率,以及缩放前后中心坐标的变化,当然还有缩放的时间。

使用Animation还需要知道一些知识点:

Interpolator:它定义了动画的速率,它有若干子类,AccelerateDecelerateInterpolator是两头慢,中间快的动画效果, AccelerateInterpolator是加速的动画效果,DecelerateInterpolator是减速动画效果, LinearInterpolator是匀速动画效果,等等。这些加速效果可以根据实际的需求来使用。

AnimationSet:它是Animation的一个集合,可以将定义好的各个动画,放入AnimationSet集合中,然后再进行对集合的设置,控制集合内的动画如何运行。

Tweened Animations的实现

Tweened Animations实现有两种方式,一种为在Java代码中设置,另一种为在XML文件中设置。两种方式各有优劣,下面一一介绍。

Tweened Animations的第一种实现:

我们的例子是Activity上有4个按钮和一张图片,4个按钮分别代表上面的四种动画效果。

布局文件很简单,就是4个按钮和一张图片的定义设置,在此略去,附件中可见详情。

在Java代码中,我们为每个按钮绑定了监听器。

Alpha监听器:

class AlphaOnClickListener implements OnClickListener{

@Override

publicvoid onClick(View arg0) {

// TODO Auto-generated method stub

AnimationSet animationSet = new AnimationSet(true);//创建一个Animation的集合,这里构造函数的参数是个boolean值,他表示的是这个AnimationSet中是否共享一个Interpolator,也就是在这个集合内不同的动画是否以同样地速率变化,如果为false,那么下面需要对每一个动画进行Interpolator的设置。

AlphaAnimation alphaAnimation = new AlphaAnimation(1,0);//设置从不透明到透明,这里两个参数的取值为0~1,0表示完全透明,1表示完全不透明

alphaAnimation.setDuration(2000);//设置动画的时间为2秒

animationSet.addAnimation(alphaAnimation);//将创建的alphaAnimation加入Animation集合中

item.startAnimation(animationSet);//在ImageView上设置动画

}

}

Rotate监听器:

class RotateOnClickListener implements OnClickListener{

@Override

publicvoid onClick(View arg0) {

// TODO Auto-generated method stub

AnimationSet animationSet = new AnimationSet(true);//同上

RotateAnimation rotateAnimation = new RotateAnimation(0, 360, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);

//RotateAnimation有6个参数

//1.初始的角度

//2.旋转的角度,可以为负的,即为逆时针转

//3.转的圆心的X坐标是相对谁为参照物的,这里有3种情况:RELATIVE_TO_SELF,RELATIVE_TO_PARENT,ABSOLUTE,分别是相对自己,相对父控件,绝对位置

//4.具体的X坐标,与第三个参数有关,若第3个参数是Animation.RELATIVE_TO_SELF,第四个参数是0.5f,那么圆心的X坐标就是自身控件宽度的0.5倍

//5.转的圆心的Y坐标是相对谁为参照物,参数同3

//6. 具体的Y坐标,与第三个参数有关,若第3个参数是Animation.RELATIVE_TO_SELF,第四个参数是0.5f,那么圆心的Y坐标就是自身控件宽度的0.5倍

rotateAnimation.setDuration(2000);//设置动画的时间

animationSet.addAnimation(rotateAnimation);//将创建的alphaAnimation加入Animation集合中

item.startAnimation(animationSet);//在ImageView上设置动画

}

}

Translate监听器:

 

class TranslateOnClickListener implements OnClickListener{

@Override

publicvoid onClick(View arg0) {

// TODO Auto-generated method stub

AnimationSet animationSet = new AnimationSet(true);//创建一个Animation的集合

TranslateAnimation translateAnimation = newTranslateAnimation(Animation.RELATIVE_TO_SELF,0,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0,Animation.RELATIVE_TO_SELF,1f);

//第1,2个参数是变化之前的X坐标

//第3,4个参数是变化之后的X坐标

//第5,6个参数是变化之前的Y坐标

//第7,8个参数是变化之后的Y坐标

translateAnimation.setDuration(2000);//设置动画的时间

animationSet.addAnimation(translateAnimation);//将创建的alphaAnimation加入Animation集合中

item.startAnimation(animationSet);//在ImageView上设置动画

}

}

Scale监听器:

 

class ScaleOnClickListener implements OnClickListener{

@Override

publicvoid onClick(View arg0) {

// TODO Auto-generated method stub

AnimationSet animationSet = new AnimationSet(true);//同上

ScaleAnimation scaleAnimation = new ScaleAnimation(1, 0.1f,1,0.1f, Animation.RELATIVE_TO_SELF,0.5f, Animation.RELATIVE_TO_SELF, 0.5f);

//第1个参数是X的原始比率,第2个参数是X变化后的比率

//第3个参数是Y的原始比率,第4个参数是Y变化后的比率

//第5,6个参数是最后动画结束时的X轴坐标

//第7,8个参数是最后动画结束时的Y轴坐标

scaleAnimation.setDuration(2000);//设置动画的时间

animationSet.addAnimation(scaleAnimation);//将创建的alphaAnimation加入Animation集合中

item.startAnimation(animationSet);//在ImageView上设置动画

}

}

以上是Tweened Animations的基本使用,当然还有其他的设置,比如设置延迟动画可以使用对Animation或AnimationSet设置setStartOffset(long time)等。

Tweened Animations的第二种实现:

使用XML文件来对动画进行定义和设置,首先要在res目录下建立anim文件夹,在这个文件夹下面就放置一个我们定义的XML文件,而且,每个XML文件都是以如下为标签:

<?xmlversion="1.0"encoding="UTF-8"?>

<setxmlns:android="http://schemas.android.com/apk/res/android"

android:interpolator="@android:anim/accelerate_interpolator"

>

</set>

我们将要定义的动画放在set标签中,里面的android:interpolator属性就是定义了这个set中的动画是以什么速率进行变化的,它的值是android自带的,可以再Android API中查到。

看一下上述4中动画的定义:

<alpha

android:fromAlpha="1.0"//初始透明度

android:toAlpha="0.0"//结束透明度

android:duration="3000"//时长

></alpha>

<rotate

android:fromDegrees="0"//初始旋转角度

android:toDegrees="-360"//结束旋转角度,可为负,即逆时针

android:duration="3000"//时长

android:pivotX="50%" //下方介绍

android:pivotY="50%"//下方介绍

></rotate>

<scale

android:fromXScale="1.0"//初始X坐标比率

android:toXScale="0.1"//结束X坐标比率

android:fromYScale="1.0"//初始Y坐标比率

android:toYScale="0.1"//结束Y坐标比率

android:pivotX="50%"//下方介绍

android:pivotY="50%"//下方介绍

android:duration="3000"//时长

></scale>

<translate

android:fromXDelta="0%"//下方介绍

android:toXDelta="50%"//下方介绍

android:fromYDelta="0%"//下方介绍

android:toYDelta="100%"//下方介绍

android:duration="3000"//时长

></translate>

我们在上面代码标注“下方介绍”的这些值,我们有三种写法,如:50,50%,50%p。这三种写法就分别代表了ABSOLUTE,RELATIVE_TO_SELF和RELATIVE_TO_PARENT。

定义完XML文件后,我们就要在Java代码中对其使用了。

举例,若将上面的Alpha的XML文件命名为alpha.xml,则如此使用:

class AlphaOnClickListener implements OnClickListener{

@Override

publicvoid onClick(View arg0) {

// TODO Auto-generated method stub

Animation alphaAnimation = AnimationUtils.loadAnimation(AnimationDemo2Activity.this, R.anim.alpha);//载入alpha.xml

item.startAnimation(alphaAnimation);//在ImageView上设置动画

}

}

也可以将多个效果放在一个文件中的一个set内,那么这几个动画会根据自己的设置一起运行,达到对同一个对象的多种效果的叠加效果。

以上是Tweened Animations的两种基本用法,Animation的使用远远不止这些,需要进一步的学习哇。

附件是Tweened Animations的两种基本用法的示例代码,仅供参考。

 

你可能感兴趣的:(Android开发)