补间动画

1.作用对象

安卓视图控件(view)

2.效果

1.平移动画:对应TranslateAnimation类
2.缩放动画:对应ScaleAnimation类
3.旋转动画:对应RotateAnimation类
4.透明度动画:对应AlphaAnimation类

3.具体使用

使用方式

首先介绍在xml文件中设置动画效果的公有属性

android:duration = "3000"  动画持续时间(ms)
android:startOffset = "0"  动画延迟开始时间(ms)
android:fillBefore = "true"  动画播放完后,视图是否会停留在动画开始的状态,默认为true
android:fillAfter = "false"  动画播放完后,视图是否会停留在动画结束的状态,优先于fillBefore值,默认为false
android:fillEnabled = "true"  是否应用fillBefore值,对fillAfter值无影响,默认为true
android:repeatMode = "restart"   选择重复播放动画模式,restart代表正序重放,reverse代表倒序回放,默认为restart
android:repeatCount = "1"  重放次数(所以动画的播放次数=重放次数+1),为infinite时无限重复

以上是在xml文件中设置动画的共有属性,其中第一个必须设置,否则不会出现动画效果,其他都是可选的

xml文件中设置:

在res/anim文件目录下创建xml文件,即为动画效果的文件,如果没有anim文件夹,则需要自行创建一个目录。,接着在创建的xml文件中使用共有属性以及自身的特有属性

代码中动态设置:

在创建动画对象时,设置自身的特有属性,想使用共有属性时,在上面的属性前加上“set”即可,例如translateAnimation.setDuration(3000);便是设置了android:duration = "3000"

使用介绍
1.1平移动画(xml)

特有属性

android:fromXDelta = "0"  起始x位置
android:toXDelta = "800"  结束x位置
android:fromYDelta = "0"  起始y位置
android:toYDelta = "800"  结束y位置

示例
xml文件

<?xml version="1.0" encoding="utf-8"?>
<!--采用translate标签表示平移动画-->
<!--前面部分是共有属性,后四个是平移动画特有属性-->
<translate xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration = "3000"
    android:startOffset = "0"
    android:fillBefore = "true"
    android:fillAfter = "false"
    android:fillEnabled = "true"
    android:repeatMode = "restart"
    android:repeatCount = "0"

    android:fromXDelta = "0"
    android:toXDelta = "800"
    android:fromYDelta = "0"
    android:toYDelta = "800"
    />

Activity

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
       //创建需要设置动画的视图
        Button button = findViewById(R.id.translate);
        //创建动画对象,并传入设置的动画效果xml文件
        Animation translateAnimation = AnimationUtils.loadAnimation(this, R.anim.view_animation);
        //播放动画
        button.startAnimation(translateAnimation);
        setContentView(R.layout.activity_main);
    }
1.2平移动画(代码动态设置)
@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
        //创建需要设置动画的视图
        Button translateButton = findViewById(R.id.translate);
        //创建平移动画的对象:平移动画对应的Animation子类为TranslateAnimation
        Animation translateAnimation = new TranslateAnimation(0, 500, 0, 500);
        //anim中固定属性值前加“set”,设置共有属性
        translateAnimation.setDuration(3000);
        //播放动画
        translateButton.startAnimation(translateAnimation);
    }
2.1缩放动画(xml)

特有属性

android:fromXScale="0.5"  表示动画在水平方向X的起始缩放倍数
    android:toXScale="1.5"  表示动画在水平方向X的结束缩放倍数
    android:fromYScale="0.5" 表示动画在水平方向Y的起始缩放倍数
    android:toYScale="1.5"  表示动画在水平方向Y的结束缩放倍数
    android:pivotX="30%"
    android:pivotY="30%"
    />
<!--0.0表示收缩到没有;1.0表示正常无伸缩;大于1.0表示放大-->
<!--pivot可取值为数字,百分比,或者百分比p
设置数字时,轴点为View的左上角的原点在x和y方向加上设置数字dp的值的点。
设置为百分比时,轴点为View的左上角的原点在x和y方向分别加上自身xy乘设置百分比的点。
设置为百分比p时,轴点为View的左上角的原点在x和y方向分别加上父控件xy乘设置百分比的点。
-->

示例
xml文件

<?xml version="1.0" encoding="utf-8"?>
<!--采用scale标签表示缩放动画-->
<!--前面部分是共有属性,后六个是平移动画特有属性-->
<scale xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration = "3000"
    android:startOffset = "0"
    android:fillBefore = "true"
    android:fillAfter = "false"
    android:fillEnabled = "true"
    android:repeatMode = "restart"
    android:repeatCount = "0"
    android:interpolator = "@android:anim/overshoot_interpolator"

    android:fromXScale="0.5"
    android:toXScale="1.5"
    android:fromYScale="0.5"
    android:toYScale="1.5"
    android:pivotX="30%"
    android:pivotY="30%"
    />

Activity

Button scaleButton = findViewById(R.id.scale);
Animation scaleAnimation = AnimationUtils.loadAnimation(this, R.anim.scale_animation);
scaleButton.startAnimation(scaleAnimation);
2.2缩放动画(代码动态设置)
Button scaleButton = findViewById(R.id.scale);
//参数:起始x缩放倍数,结束x缩放倍数,起始y缩放倍数,结束y缩放倍数,轴点x坐标,轴点y坐标
//缩放倍数等于1,正常;小于1,缩放;大于1,放大;
//Animation.RELATIVE_TO_SELF对应xml文件中pivot的百分比
//Animation.ABSOLUTE对应xml文件中pivot的数字
//Animation.RELATIVE_TO_PARENT对应xml文件中pivot的百分比p
Animation scaleAnimation = new ScaleAnimation(0.5f, 1.5f, 0.5f, 1.5f,
        Animation.RELATIVE_TO_SELF, 0.3f, Animation.RELATIVE_TO_SELF, 0.3f);
scaleAnimation.setDuration(3000);
scaleButton.startAnimation(scaleAnimation);
3.1旋转动画(xml)

特有属性

android:fromDegrees="0"  动画开始时,视图的旋转角度(正数顺时针;负数逆时针)
    android:toDegrees="360"  动画结束时,视图的旋转角度(正数顺时针;负数逆时针)
    android:pivotX="50%"  旋转轴点的x坐标
    android:pivotY="50%"  旋转轴点的y坐标
    />
<!-- pivot可取值为数字,百分比,或者百分比p
    设置数字时,轴点为View的左上角的原点在x和y方向加上设置数字dp的值的点。
    设置为百分比时,轴点为View的左上角的原点在x和y方向分别加上自身xy乘设置百分比的点。
    设置为百分比p时,轴点为View的左上角的原点在x和y方向分别加上父控件xy乘设置百分比的点。
-->

示例
xml文件

<?xml version="1.0" encoding="utf-8"?>
<!--采用rotate标签表示旋转动画-->
<!--前面部分是共有属性,后四个是平移动画特有属性-->
<rotate xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration = "3000"
    android:startOffset = "0"
    android:fillBefore = "true"
    android:fillAfter = "false"
    android:fillEnabled = "true"
    android:repeatMode = "restart"
    android:repeatCount = "0"

    android:fromDegrees="0"
    android:toDegrees="360"
    android:pivotX="50%"
    android:pivotY="50%"
    />

Activity

Button rotateButton = findViewById(R.id.rotate);
Animation rotateAnimation = AnimationUtils.loadAnimation(this, R.anim.rotate_animation);
rotateButton.startAnimation(rotateAnimation);
3.2旋转动画(代码动态设置)
Button rotateButton = findViewById(R.id.rotate);
        //参数:起始角度,结束角度,轴点的x坐标,轴点的y坐标
        //Animation.RELATIVE_TO_SELF对应xml文件中pivot的百分比
        //Animation.ABSOLUTE对应xml文件中pivot的数字
        //Animation.RELATIVE_TO_PARENT对应xml文件中pivot的百分比p
        Animation rotateAnimation = new RotateAnimation(0, 360,
                Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
        rotateAnimation.setDuration(3000);
        rotateButton.startAnimation(rotateAnimation);
4.1透明度动画(xml)

特有属性

android:fromAlpha="1.0"  动画开始时视图的透明度(取值范围-1~1)
android:toAlpha="0.0"  toAlpha:动画结束时视图的透明度(取值范围-1~1)

示例
xml文件

<?xml version="1.0" encoding="utf-8"?>
<!--采用alpha标签表示透明度动画-->
<!--前面部分是共有属性,后两个是平移动画特有属性-->
<alpha xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration = "3000"
    android:startOffset = "0"
    android:fillBefore = "true"
    android:fillAfter = "false"
    android:fillEnabled = "true"
    android:repeatMode = "restart"
    android:repeatCount = "0"

    android:fromAlpha="1.0"
    android:toAlpha="0.0"
    />

Activity

Button alphaButton = findViewById(R.id.alpha);
Animation alphaAnimation = AnimationUtils.loadAnimation(this, R.anim.alpha_animation);
alphaButton.startAnimation(alphaAnimation);
4.2透明度动画(代码动态设置)
Button alphaButton = findViewById(R.id.alpha);
        //参数:起始和结束的透明度。取值范围-1~1
        Animation alphaAnimation = new AlphaAnimation(1,0);
        alphaAnimation.setDuration(3000);
        alphaButton.startAnimation(alphaAnimation);
5.1组合动画(xml)

示例
xml文件

<?xml version="1.0" encoding="utf-8"?>
<!--采用set标签表示组合动画-->
<!--前面部分是共有属性,后一个是平移动画特有属性-->
<set xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration = "3000"
    android:startOffset = "0"
    android:fillBefore = "true"
    android:fillAfter = "false"
    android:fillEnabled = "true"
    android:repeatMode = "restart"
    android:repeatCount = "0"

    android:shareInterpolator="true">

    <rotate
        android:duration="1000"
        android:fromDegrees="0"
        android:toDegrees="360"
        android:pivotX="50%"
        android:pivotY="50%"
        android:repeatMode="restart"
        android:repeatCount="infinite" />

    <translate
        android:duration="10000"
        android:startOffset = "1000"
        android:fromXDelta="-50%p"
        android:fromYDelta="0"
        android:toXDelta="50%p"
        android:toYDelta="0" />

    <alpha
        android:startOffset="7000"
        android:duration="3000"
        android:fromAlpha="1.0"
        android:toAlpha="0.0" />

    <scale
        android:startOffset="4000"
        android:duration="1000"
        android:fromXScale="1.0"
        android:fromYScale="1.0"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toXScale="0.5"
        android:toYScale="0.5" />
</set>

<!--shareInterpolator表示组合动画是否和集合共享一个插值器,如果集合不指定插值器,那么子动画需要单独设置
组合动画播放时是全部动画同时开始,若想不同的动画在不同时间开始,需分别设定延迟时间-->

Activity

Button animationButton = findViewById(R.id.animation);
        Animation animation = AnimationUtils.loadAnimation(this, R.anim.animation);
        animationButton.startAnimation(animation);
5.2组合动画(代码动态设置)
//创建视图对象
        Button animationButton = findViewById(R.id.animation);
        //创建动画对象
        AnimationSet animation = new AnimationSet(true);
        //设置组合属性
        animation.setRepeatMode(Animation.RESTART);
        animation.setRepeatCount(1);//由于旋转动画设置了无限循环,所以该语句循环一次,无效
        //设置子动画:平移动画
        Animation translate = new TranslateAnimation(TranslateAnimation.RELATIVE_TO_PARENT,-0.5f,
                TranslateAnimation.RELATIVE_TO_PARENT,0.5f,
                TranslateAnimation.RELATIVE_TO_SELF,0
                ,TranslateAnimation.RELATIVE_TO_SELF,0);
        translate.setDuration(10000);
        //设置子动画:缩放动画
        Animation scale1 = new ScaleAnimation(1,0.5f,1,0.5f,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f);
        scale1.setDuration(1000);
        scale1.setStartOffset(4000);
        //设置子动画:旋转动画
        Animation rotate = new RotateAnimation(0,360,Animation.RELATIVE_TO_SELF,0.5f,Animation.RELATIVE_TO_SELF,0.5f);
        rotate.setDuration(1000);
        rotate.setRepeatMode(Animation.RESTART);
        rotate.setRepeatCount(Animation.INFINITE);//表示无限循环
        //设置子动画:透明度动画
        Animation alpha = new AlphaAnimation(1,0);
        alpha.setDuration(3000);
        alpha.setStartOffset(7000);
        //将子动画添加到组合动画
        animation.addAnimation(translate);
        animation.addAnimation(scale1);
        animation.addAnimation(rotate);
        animation.addAnimation(alpha);
        animationButton.startAnimation(animation);

4.应用场景

在activity进行启动,跳转,退出时使用
Intent intent = new Intent(MainActivity.this, Main2Activity.class);
startActivity(intent);
//参数:enterAnim,exitAnim
// enterAnim:从Activity a跳转到Activity b,进入b时的动画效果资源ID
// exitAnim:从Activity a跳转到Activity b,离开a时的动画效果资源Id
overridePendingTransition(R.anim.translate_animation, R.anim.rotate_animation);
//系统自带的enterAnim,exitAnim资源ID为android.R.anim.xxx
//overridePendingTransition(android.R.anim.fade_in, android.R.anim.fade_out);//淡入淡出
//overridePendingTransition(android.R.anim.slide_in_left, android.R.anim.slide_out_right);//从左向右
//overridePendingTransition()必须要在startActivity(intent)后被调用才能生效
Fragment切换时使用
FragmentTransaction fragmentTransaction = mFragmentManager.beginTransaction();
//setTransition(int transit)进行设置系统动画
fragmentTransaction.setTransition(int transit);
// transit参数说明
// 1. FragmentTransaction.TRANSIT_NONE:无动画
// 2. FragmentTransaction.TRANSIT_FRAGMENT_OPEN:标准的打开动画效果
// 3. FragmentTransaction.TRANSIT_FRAGMENT_CLOSE:标准的关闭动画效果

//etCustomAnimations进行设置自定义动画
//fragmentTransaction.setCustomAnimations(R.anim.translate_animation,R.anim.rotate_animation);