1.在res文件夹下,创建一个anim的子文件夹
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<rotate
android:fromDegrees="0"
android:toDegrees="360"
android:pivotX="50%"
android:pivotY="50%"
android:duration="600"
android:repeatMode="restart"
android:repeatCount="infinite"
android:interpolator="@android:anim/cycle_interpolator"/>
</set>
anim/rotate(旋转动画)
interpolator:动画插入器
accelerate_decelerate_interpolator:加速-减速
accelerate_interpolator:加速
decelerate_interpolator:减速
fromDegrees:开始的角度
toDegrees:结束的角度
pivotX,privotY:旋转中心的坐标(可以用百分比也可以用数字)
anim/translate(移动动画)
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<translate
android:duration="2000"
android:fromXDelta="30"
android:fromYDelta="30"
android:toXDelta="-80"
android:toYDelta="300" />
</set>
fromXDelta,fromYDelta:开始时候左上角的坐标
toXDelta,toYDelta:结束时候左上角的坐标
anim/scale(伸缩动画)
<?xml version="1.0" encoding="UTF-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<scale
android:duration="2000"
android:fromXScale="0.0"
android:fromYScale="0.0"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
android:pivotX="00%"
android:pivotY="00%"
android:toXScale="1.4"
android:toYScale="1.4" />
</set>
interpolator:动画插入器
accelerate_decelerate_interpolator:加速-减速
accelerate_interpolator:加速
decelerate_interpolator:减速
fromXScale,fromYScale:开始X和Y的大小(0为缩小到没有)
toXScale,toYScale:结束X和Y的大小(1为没有变化)
pivotX,privotY:左上角的坐标(可以用百分比也可以用数字)
anim/alpha.xml(渐变动画)
<?xml version="1.0" encoding="UTF-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
<alpha
android:duration="2000"
android:fromAlpha="0.1"
android:toAlpha="1.0" />
</set>
duration:动画的持续时间(单位是毫秒)
fromAlpha:开始的透明度
toAlpha:结束的透明度
透明度0.0是完全透明,1.0是不透明
2.接着在Activity创建一个Animation类,然后使用AnimationUtils类加载动画xml
// 动画对象
Animation animFadein;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_fadein);
txtMessage = (TextView) findViewById(R.id.txtMessage);
// 加载动画
animFadein = AnimationUtils.loadAnimation(getApplicationContext(),
R.anim.fade_in);
// 对image或view进行动画演示
txtMessage.startAnimation(animFadein);
}
3.设置动画监听器
如果
你要监听动画的事件,如开始,结束等,你需要实现
AnimationListener监听器,重写以下方法。
onAnimationEnd(Animation animation) -- 当动画结束时调用
onAnimationRepeat(Animation animation) -- 当动画重复时调用
onAniamtionStart(Animation animation) -- 当动画启动时调用
import android.os.Bundle;
import android.app.Activity;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.Animation.AnimationListener;
import android.view.animation.AnimationUtils;
import android.widget.Toast;
public class AlphaActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
View view=View.inflate(this, R.layout.activity_alpha, null);
setContentView(view);
Animation animation=AnimationUtils.loadAnimation(this, R.anim.alpha);
view.startAnimation(animation);
animation.setAnimationListener(new AnimationListener() {
@Override
public void onAnimationStart(Animation arg0) {}
@Override
public void onAnimationRepeat(Animation arg0) {}
@Override
public void onAnimationEnd(Animation arg0) {
Toast.makeText(AlphaActivity.this, "动画完成", Toast.LENGTH_SHORT).show();
}
});
}
}