玩转Android---2D图形及动画---Tween动画
Android平台提供了两类动画,分别是Tween动画,和Frame动画。Tween通过场景里的对象不断的进行图片的变换,比如平移、渐变、缩放、旋转等来产生动画效果;Frame动画叫做顺序播放实现做好的图像和电影类似。另外加上gif动画,因为如果直接使用Bitmap或其他方法直接调用gif图片资源的话,显示的是静态的,如果要做成动态的,就需要一些其他的方法来实现。
?
首先来谈谈Tween动画,它有四种
?
①Alpha:渐变透明度动画
②Scale:渐变尺寸伸缩动画
③Translate:画面转换位置移动动画
④Rotate:画面转移旋转动画
?
这些动画的执行步骤差不多:先定义Animation动画对象,然后设置动画的一些属性,最后通过startAnimation()方法开始动画。
?
setDuration(long durationMillis);
功能:设置动画显示的时间
参数:durationMillis为动画显示时间的长短,以毫秒为单位
?
startAnimation(Animation animation)
功能:animation为要播放的动画
参数:animation为要播放的动画
?
第一种:AlphaAnimation(float fromAlpha, float toAlpha)
功能:创建一个透明度渐变的动画
参数说明:fromAlpha是动画起始时透明度;toAlpha是动画结束时透明度
注:0.0表示完全透明,1.0表示完全不透明
?
实现它有两种方式。
1、直接在程序中创建动画
?
//创建Alpha动画Animation alpha = new AlphaAnimation(0.1f, 1.0f);//设置动画时间为5秒alpha.setDuration(5000);//开始播放img.startAnimation(alpha);?
?
2、通过XML来创建动画
alpha_anim.xml。在res/anim目录下
?
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"><alphaandroid:fromAlpha="0.1"android:toAlpha="1.0"android:duration="5000"></alpha></set>
?
?程序中直接调用
?
Animation scale = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.scale_anim);//开始动画img.startAnimation(scale);
?
效果:
?
?
第二种:ScaleAnimation(float fromX, float toX, float fromY, float toY, int pivotXType, floatXValue,
int pivotYType, float pivotYValue)
功能:创建一个渐变尺寸伸缩动画
参数:fromX,toX分别是起始和结束时x坐标上的伸缩尺寸。fromY,toY分别是起始和结束时ye坐标上的伸缩尺寸。
pivotXValue,pivotYValue分别为伸缩动画相对于x,y坐标开始的位置,pivotXType,pivotYType分别为x,y的
伸缩模式。
?
它有两种实现方式。
1、直接在程序中实现的方式
?
Animation scale = new ScaleAnimation(0f, 1f, 0f, 1f, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);//设置动画持续时间scale.setDuration(5000);//开始动画img.startAnimation(scale);
?
?2、在XML中是创建动画
scale_anim.xml,在res/anim目录下
?
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"><scaleandroid:interpolator="@android:anim/accelerate_decelerate_interpolator"android:fromXScale="0.0"android:toXScale="1.0"android:fromYScale="0.0"android:toYScale="1.0"android:pivotX="50%"android:pivotY="50%"android:fillAfter="false"android:duration="5000"/></set>
?Animation scale = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.scale_anim);
//开始动画img.startAnimation(scale);?
?
效果
第3种:TranslateAnimation(float fromXDelta, float toXDelta, float YDelta, float toYDelta)
功能:创建一个移动画面位置的动画
参数:fromXDelta,fromYDelta分别是其实坐标;toXDelta,toYDelta分别是结束坐标
?
它有两种是实现方式
1、直接在程序中实现
Animation translate = new TranslateAnimation(10, 100, 10, 100);//设置动画持续时间translate.setDuration(3000);//开始动画img.startAnimation(translate);?
2、在XML中创建动画
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"><translateandroid:fromXDelta="10"android:toXDelta="100"android:fromYDelta="10"android:toYDelta="100"android:duration="5000"/></set>
?在程序中可以定义其实现,比如在Button中的按钮事件
Animation translate = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.translate_anim);//开始动画img.startAnimation(translate);?
第4种:Rotate(float fromDegrees, float toDegrees, int pivotXType, float pivotXValue, int pivotYType,
float pivotYValue)
功能:创建一个旋转画面的动画
参数:fromDegrees为开始的角度;toDegrees为结束的角度。pivotXValue、pivotYType分别为x,y的伸缩模式。
pivotXValue,pivotYValue分别为伸缩动画相对于x,y的坐标开始位置
?
它有两种实现方式。
1、直接在程序中创建动画
Animation rotate = new RotateAnimation(0f,+360f,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF, 0.5f);rotate.setDuration(3000);img.startAnimation(rotate);?
2、在XML中创建动画
rotate_anim.xml
在res/anim目录下
<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android"><rotateandroid:interpolator="@android:anim/accelerate_decelerate_interpolator"android:fromDegrees="0"android:toDegrees="+360"android:pivotX="50%"android:pivotY="50%"android:duration="1000"/></set>?Animation rotate = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.rotate_anim);
img.startAnimation(rotate);
?
?
下面是程序的全部代码。XML定义的动画部分在上面
?
在程序中直接实现
package com.loulijun.tween;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.view.animation.AlphaAnimation;import android.view.animation.Animation;import android.view.animation.RotateAnimation;import android.view.animation.ScaleAnimation;import android.view.animation.TranslateAnimation;import android.widget.Button;import android.widget.ImageView;public class TweenActivity extends Activity {Button btn1,btn2,btn3,btn4;ImageView img;//定义Alpha动画private Animation alpha = null;//定义Scale动画private Animation scale = null;//定义Translate动画private Animation translate = null;//定义Rotate动画private Animation rotate = null; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); //装载图片资源 img = (ImageView)findViewById(R.id.imgview); btn1 = (Button)findViewById(R.id.btn1); btn2 = (Button)findViewById(R.id.btn2); btn3 = (Button)findViewById(R.id.btn3); btn4 = (Button)findViewById(R.id.btn4); //定义Alpha动画 btn1.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {//创建Alpha动画alpha = new AlphaAnimation(0.1f, 1.0f);//设置动画时间为5秒alpha.setDuration(5000);//开始播放img.startAnimation(alpha);} }); //定义Scale动画 btn2.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {scale = new ScaleAnimation(0f, 1f, 0f, 1f, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);//设置动画持续时间scale.setDuration(5000);//开始动画img.startAnimation(scale);} }); //定义Translate动画 btn3.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {translate = new TranslateAnimation(10, 100, 10, 100);//设置动画持续时间translate.setDuration(3000);//开始动画img.startAnimation(translate);} }); //定义Rotate动画 btn4.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {rotate = new RotateAnimation(0f, +360f,Animation.RELATIVE_TO_SELF, 0.5f,Animation.RELATIVE_TO_SELF, 0.5f);rotate.setDuration(3000);img.startAnimation(rotate);} }); }}?
在XML中定义动画
package com.loulijun.tween2;import android.app.Activity;import android.os.Bundle;import android.view.View;import android.view.animation.Animation;import android.view.animation.AnimationUtils;import android.view.animation.RotateAnimation;import android.view.animation.ScaleAnimation;import android.view.animation.TranslateAnimation;import android.widget.Button;import android.widget.ImageView;public class TweenActivity extends Activity {Button btn1,btn2,btn3,btn4;ImageView img;//定义Alpha动画private Animation alpha = null;//定义Scale动画private Animation scale = null;//定义Translate动画private Animation translate = null;//定义Rotate动画private Animation rotate = null; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); //装载图片资源 img = (ImageView)findViewById(R.id.imgview); btn1 = (Button)findViewById(R.id.btn1); btn2 = (Button)findViewById(R.id.btn2); btn3 = (Button)findViewById(R.id.btn3); btn4 = (Button)findViewById(R.id.btn4); //定义Alpha动画 btn1.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {//创建Alpha动画alpha = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.alpha_anim);//开始播放img.startAnimation(alpha);} }); //定义Scale动画 btn2.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {scale = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.scale_anim);//开始动画img.startAnimation(scale);} }); //定义Translate动画 btn3.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {translate = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.translate_anim);//开始动画img.startAnimation(translate);} }); //定义Rotate动画 btn4.setOnClickListener(new Button.OnClickListener() {@Overridepublic void onClick(View v) {rotate = AnimationUtils.loadAnimation(TweenActivity.this, R.anim.rotate_anim);img.startAnimation(rotate);} }); }}?