Android-Animation动画学习

本文详细介绍了Android中补间动画的四种类型:透明度渐变、缩放、旋转和平移动画,并提供了每种动画的XML配置及代码实现方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android动画主要分为 补间动画逐帧动画

动画的实现方式
1.代码实现
2.xml文件实现

所有演示都基于一张图片

补间动画

补间动画 之 Alpha:透明度渐变动画

(1)编写Alpha渐变动画文件

duration:持续时长,以ms为单位
fromAlpha:开始时的渐变度
toAlpha:结束时的渐变度
若需无限循环,需要设置repeatCount=”infinite”

<?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"
        >
    </alpha>
</set>

(2)加载动画

 //代码创建
 AlphaAnimation alphaAnimation=new AlphaAnimation(0.1f,1.0f);
alphaAnimation.setDuration(2000);
//加载xml文件
 Animation alphaAnimation= AnimationUtils.loadAnimation(MainActivity.this,R.anim.alpha);
 //调用动画
image_Example.startAnimation(alphaAnimation);

效果如下:
alpha

补间动画 之 Alpha:缩放动画

(1)编写xml文件
fromXScale:在X轴上的开始点
toXScale:在X轴上的结束点
fromYScale:在Y轴上的开始点
toYScale:在Y轴上的结束点
pivotX:变换起点X坐标
pivotY:变换起点Y坐标

<ml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <scale
        android:duration="3000"
        android:fromXScale="0"
        android:toXScale="1.0"
        android:fromYScale="0"
        android:toYScale="1.0"
        android:pivotX="100%"
        android:pivotY="100%">
    </scale>
</set>

(2)加载动画

//代码生成动画
 ScaleAnimation scaleAnimation=new ScaleAnimation(0f,1f,0f,1f);
 scaleAnimation.setDuration(2000);
 //调用资源文件生成动画
 Animation animation1=AnimationUtils.loadAnimation(this,R.anim.scale);
//加载动画
image_Example.startAnimation(scaleAnimation);

(3)效果如下
这里写图片描述

补间动画 之 Alpha:旋转动画

(1)编写xml文件
上面有的这里不再重复,只叙述新的
android:fromDegrees:起始旋转角度
android:toDegrees:一共旋转多少度
repeatMode:重复模式,从有restart和reserve两种。就是一种正着来,一种反着来。
repeatCount:重复次数

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <rotate
        android:duration="3000"
        android:fromDegrees="0"
        android:toDegrees="360"
        android:pivotY="50%"
        android:pivotX="50%"
        android:repeatMode="reverse"
        android:repeatCount="3">

    </rotate>
</set>

(2)加载动画

//代码生成动画
 RotateAnimation rotateAnimation=new RotateAnimation(0,360);
                rotateAnimation.setDuration(3000);
                rotateAnimation.setRepeatCount(2);
                rotateAnimation.setRepeatMode(Animation.REVERSE);
 //调用资源文件生成动画
 Animation rotateAnimation=AnimationUtils.loadAnimation(this,R.anim.rotate);
//加载动画
image_Example.startAnimation(rotateAnimation);

(3)效果如下
这里写图片描述

补间动画 之 Alpha:平移动画

(1)编写xml文件
上面有的这里不再重复,只叙述新的
android:fromXDelta:起始X轴平移坐标
android:toXDelta:起始X轴终点坐标
android:fromYDelta:起始Y轴的平移坐标
android:toYDelta:起始Y轴的终点坐标

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:fromXDelta="0"
        android:toXDelta="100"
        android:fromYDelta="0"
        android:toYDelta="100"
        android:duration="3000">

    </translate>
</set>

(2)加载动画

//代码生成动画
  TranslateAnimation translateAnimation=new TranslateAnimation(0,100,0,100);
               translateAnimation.setDuration(3000);
 //调用资源文件生成动画
  Animation animation3=AnimationUtils.loadAnimation(this,R.anim.translate);
//加载动画
image_Example.startAnimation(translateAnimation);

(3)效果如下
这里写图片描述


逐帧动画

下次在介绍

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值