Android Animation动画

简介: Android Animation动画

效果图

image.png


都在注释里了


补间动画

package com.yechaoa.viewanimationdemo;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.util.Log;
import android.view.View;
import android.view.animation.AlphaAnimation;
import android.view.animation.Animation;
import android.view.animation.AnimationSet;
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 MainActivity extends AppCompatActivity implements View.OnClickListener {
    private ImageView mImageView;
    private Button mBtnGone, mBtnVisible, mBtnMoveToLeft, mBtnMoveToRight,
            mBtnRotate, mBtnScale, mBtnAlpha, mBtnAnimGroup;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        initView();
        initListener();
    }
    private void initView() {
        mImageView = findViewById(R.id.imageView);
        mBtnGone = findViewById(R.id.btn_gone);
        mBtnVisible = findViewById(R.id.btn_visible);
        mBtnMoveToLeft = findViewById(R.id.btn_move_to_left);
        mBtnMoveToRight = findViewById(R.id.btn_move_to_right);
        mBtnRotate = findViewById(R.id.btn_rotate);
        mBtnScale = findViewById(R.id.btn_Scale);
        mBtnAlpha = findViewById(R.id.btn_alpha);
        mBtnAnimGroup = findViewById(R.id.btn_anim_group);
    }
    private void initListener() {
        mBtnGone.setOnClickListener(this);
        mBtnVisible.setOnClickListener(this);
        mBtnMoveToLeft.setOnClickListener(this);
        mBtnMoveToRight.setOnClickListener(this);
        mBtnRotate.setOnClickListener(this);
        mBtnScale.setOnClickListener(this);
        mBtnAlpha.setOnClickListener(this);
        mBtnAnimGroup.setOnClickListener(this);
    }
    @Override
    public void onClick(View view) {
        switch (view.getId()) {
            case R.id.btn_gone:
                //位移动画
                //4个数值分别表示坐标轴中以远点为中心的正负X轴Y轴 f表示float
                TranslateAnimation mHiddenAnimation = new TranslateAnimation(Animation.RELATIVE_TO_SELF,
                        0.0f, Animation.RELATIVE_TO_SELF, 0.0f,
                        Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                        -1.0f);
                //设置时长
                mHiddenAnimation.setDuration(500);
                mImageView.startAnimation(mHiddenAnimation);
                //0.0f 加一个渐变的效果
                mImageView.animate().alpha(0);
                mImageView.setVisibility(View.GONE);
                break;
            case R.id.btn_visible:
                TranslateAnimation mShowAnimation = new TranslateAnimation(Animation.RELATIVE_TO_SELF, 0.0f,
                        Animation.RELATIVE_TO_SELF, 0.0f, Animation.RELATIVE_TO_SELF,
                        -1.0f, Animation.RELATIVE_TO_SELF, 0.0f);
                mShowAnimation.setDuration(500);
                mImageView.startAnimation(mShowAnimation);
                mImageView.animate().alpha(1);
                mImageView.setVisibility(View.VISIBLE);
                break;
            case R.id.btn_move_to_left:
                TranslateAnimation mLeftAnimation = new TranslateAnimation(Animation.RELATIVE_TO_SELF, 0.0f,
                        Animation.RELATIVE_TO_SELF, -1.0f, Animation.RELATIVE_TO_SELF,
                        0.0f, Animation.RELATIVE_TO_SELF, 0.0f);
                mLeftAnimation.setDuration(500);
                mImageView.startAnimation(mLeftAnimation);
                mImageView.animate().alpha(0);
                mImageView.setVisibility(View.VISIBLE);
                break;
            case R.id.btn_move_to_right:
                TranslateAnimation mRightAnimation = new TranslateAnimation(Animation.RELATIVE_TO_SELF, 0.0f,
                        Animation.RELATIVE_TO_SELF, 1.0f, Animation.RELATIVE_TO_SELF,
                        0.0f, Animation.RELATIVE_TO_SELF, 0.0f);
                mRightAnimation.setDuration(500);
                mImageView.startAnimation(mRightAnimation);
                mImageView.animate().alpha(0);
                mImageView.setVisibility(View.VISIBLE);
                break;
            case R.id.btn_rotate:
                //旋转动画
                RotateAnimation mRotateAnimation = new RotateAnimation(0, 60, 0.5f, 0.5f);
                mRotateAnimation.setDuration(2000);
                mImageView.startAnimation(mRotateAnimation);
                break;
            case R.id.btn_Scale:
                /**
                 * 一共8个参数
                 * 前4个参数是分别是X轴、Y轴的起始位置和结束位置
                 * 后4个参数相对位置值,Animation.RELATIVE_TO_SELF表示自己,也就是以自己为中心点向四周缩放
                 */
                //缩放动画
                ScaleAnimation mScaleAnimation = new ScaleAnimation(0.0f, 1.0f, 0.0f, 1.0f,
                        Animation.RELATIVE_TO_SELF, 0.5f,
                        Animation.RELATIVE_TO_SELF, 0.5f);
                mScaleAnimation.setDuration(2000);
                //设置重复次数
                mScaleAnimation.setRepeatCount(2);
                //动画执行完后是否停留在执行完的状态
                mScaleAnimation.setFillAfter(true);
                //执行前的等待时间
                mScaleAnimation.setStartOffset(500);
                //取消动画
                //mScaleAnimation.cancel();
                mScaleAnimation.setAnimationListener(new Animation.AnimationListener() {
                    @Override
                    public void onAnimationStart(Animation animation) {
                        Log.d("onAnimationStart", "动画开始");
                    }
                    @Override
                    public void onAnimationEnd(Animation animation) {
                        Log.d("onAnimationEnd", "动画结束");
                    }
                    @Override
                    public void onAnimationRepeat(Animation animation) {
                        Log.d("onAnimationRepeat", "动画重复");
                    }
                });
                mImageView.startAnimation(mScaleAnimation);
                break;
            case R.id.btn_alpha:
                //渐变动画
                AlphaAnimation mAlphaAnimation = new AlphaAnimation(1.0f, 0.0f);
                mAlphaAnimation.setDuration(2000);
                mAlphaAnimation.setAnimationListener(new Animation.AnimationListener() {
                    @Override
                    public void onAnimationStart(Animation animation) {
                    }
                    @Override
                    public void onAnimationEnd(Animation animation) {
                        //淡出之后再淡入
                        //xml的方式引用,参数与代码设置一样
                        Animation aa = AnimationUtils.loadAnimation(MainActivity.this, R.anim.fade_in);
                        mImageView.startAnimation(aa);
                    }
                    @Override
                    public void onAnimationRepeat(Animation animation) {
                    }
                });
                mImageView.startAnimation(mAlphaAnimation);
                break;
            case R.id.btn_anim_group:
                /**
                 * 两种方式可以实现组合动画
                 * 1.给第一个动画设置监听,结束之后执行第二个动画
                 * 2.用AnimationSet,动画集合类
                 */
                RotateAnimation ra = new RotateAnimation(0, 360,
                        Animation.RELATIVE_TO_SELF, 0.5f,
                        Animation.RELATIVE_TO_SELF, 0.5f);
                ra.setDuration(2000);
                AlphaAnimation aa = new AlphaAnimation(0.0f, 1.0f);
                aa.setDuration(2000);
                ScaleAnimation sa = new ScaleAnimation(0.0f, 1.0f, 0.0f, 1.0f,
                        Animation.RELATIVE_TO_SELF, 0.5f,
                        Animation.RELATIVE_TO_SELF, 0.5f);
                sa.setDuration(2000);
                AnimationSet animationSet = new AnimationSet(true);
                animationSet.addAnimation(ra);
                animationSet.addAnimation(aa);
                animationSet.addAnimation(sa);
                //animationSet.setInterpolator(new DecelerateInterpolator(5));
                mImageView.startAnimation(animationSet);
                animationSet.start();
                /**
                 * Interpolator定义动画的速率
                 * AccelerateDecelerateInterpolator延迟减速,在动作执行到中间的时候才执行该特效。
                 * AccelerateInterpolator会使慢慢以(float)的参数降低速度
                 * CycleInterpolator曲线运动特效,要传递float型的参数。
                 * DecelerateInterpolator开头和结尾慢,中间快
                 * LinearInterpolator匀速
                 */
                break;
        }
    }
}


fade_in.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.0"
        android:toAlpha="1.0" />
</set>


帧动画


<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
    android:oneshot="true">
    <item
        android:drawable="@mipmap/ic_launcher"
        android:duration="200" />
    <item
        android:drawable="@mipmap/ic_launcher"
        android:duration="200" />
    <item
        android:drawable="@mipmap/ic_launcher"
        android:duration="200" />
    <item
        android:drawable="@mipmap/ic_launcher"
        android:duration="200" />
    <item
        android:drawable="@mipmap/ic_launcher"
        android:duration="200" />
    <item
        android:drawable="@mipmap/ic_launcher"
        android:duration="200" />
</animation-list>

drawable是图片地址,oneshot=true表示只展示一遍,false表示循环

这个文件必须放在drawable文件下

目录
相关文章
|
3月前
|
存储 Shell Android开发
基于Android P,自定义Android开机动画的方法
本文详细介绍了基于Android P系统自定义开机动画的步骤,包括动画文件结构、脚本编写、ZIP打包方法以及如何将自定义动画集成到AOSP源码中。
74 2
基于Android P,自定义Android开机动画的方法
|
20天前
|
Android开发 UED
Android 中加载 Gif 动画
【10月更文挑战第20天】加载 Gif 动画是 Android 开发中的一项重要技能。通过使用第三方库或自定义实现,可以方便地在应用中展示生动的 Gif 动画。在实际应用中,需要根据具体情况进行合理选择和优化,以确保用户体验和性能的平衡。可以通过不断的实践和探索,进一步掌握在 Android 中加载 Gif 动画的技巧和方法,为开发高质量的 Android 应用提供支持。
|
6月前
|
Java Android开发 开发者
Android10 修改开发者选项中动画缩放默认值
Android10 修改开发者选项中动画缩放默认值
184 0
|
6月前
|
XML Java Android开发
android的三种动画
android的三种动画
38 0
|
4月前
|
XML Android开发 数据格式
Android 中如何设置activity的启动动画,让它像dialog一样从底部往上出来
在 Android 中实现 Activity 的对话框式过渡动画:从底部滑入与从顶部滑出。需定义两个 XML 动画文件 `activity_slide_in.xml` 和 `activity_slide_out.xml`,分别控制 Activity 的进入与退出动画。使用 `overridePendingTransition` 方法在启动 (`startActivity`) 或结束 (`finish`) Activity 时应用这些动画。为了使前 Activity 保持静止,可定义 `no_animation.xml` 并在启动新 Activity 时仅设置新 Activity 的进入动画。
96 12
|
4月前
|
XML Android开发 UED
Android动画之共享元素动画简单实践
本文介绍Android共享元素动画, 实现两Activity间平滑过渡特定UI元素。通过设置`transitionName`属性和使用`ActivityOptions.makeSceneTransitionAnimation`启动目标Activity实现动画效果。可自定义过渡动画提升体验。
63 0
|
5月前
|
Android开发 UED
Android Item平移动画
【6月更文挑战第18天】
105 8
|
4月前
|
Android开发
android 动画 插值器和估值器
android 动画 插值器和估值器
|
4月前
|
Android开发 容器
android animation clipToPadding clipChildren
android animation clipToPadding clipChildren