属性动画的基本用法

Android 3.0版本开始,系统给我们提供了一种全新的动画模式,属性动画(property animation),它的功能非常强大,弥补了之前补间动画的一些缺陷,几乎是可以完全替代掉补间动画了。

补间动画的缺陷:
1、补间动画只能够作用在View上;
2、补间动画只能够实现移动、缩放、旋转和淡入淡出这四种动画操作;
3、补间动画只是改变了View的显示效果而已,而不会真正去改变View的属性。

属性动画机制实际上是一种不断地对值进行操作的机制,并将值赋值到指定对象的指定属性上,可以是任意对象的任意属性。

使用Java代码定义属性动画

ValueAnimator

属性动画的运行机制是通过不断地对值进行操作来实现的,而初始值和结束值之间的动画过渡就是由ValueAnimator这个类来负责计算的。除此之外,ValueAnimator还负责管理动画的播放次数、播放模式、以及对动画设置监听器等。

示例演示

// 获取ValueAnimator实例
// 0f, 5f, 3f, 10f为给定的值
ValueAnimator anim = ValueAnimator.ofFloat(0f, 5f, 3f, 10f);
// 设置动画持续时间
anim.setDuration(300);
// 添加监听器
anim.addUpdateListener(new ValueAnimator.AnimatorUpdateListener() {
    @Override
    public void onAnimationUpdate(ValueAnimator animation) {
                // 获取当前值
        float currentValue = (float) animation.getAnimatedValue();
        Log.d(TAG, "currentValue: " + currentValue);
    }
});
anim.start();       

运行结果

D/MainActivity: currentValue: 0.0
D/MainActivity: currentValue: 0.11853263
D/MainActivity: currentValue: 1.7715302
D/MainActivity: currentValue: 2.659067
D/MainActivity: currentValue: 3.818223
D/MainActivity: currentValue: 4.9866004
D/MainActivity: currentValue: 4.469303
D/MainActivity: currentValue: 3.9685845
D/MainActivity: currentValue: 3.365308
D/MainActivity: currentValue: 10.0

ValueAnimator的常用方法:
  1)ValueAnimator.ofFloat()方法:添入float类型的值
  2)ValueAnimator.ofInt()方法:添入int类型的值
  3)ValueAnimator.ofObject()方法:添入Object对象
  4)anim.setStartDelay()方法:设置动画延迟播放的时间
  5)anim.setRepeatCount()方法:设置动画循环播放的次数
  6)anim.setRepeatMode()方法:设置动画循环播放的模式,循环模式(RESTART:重新播放、REVERSE:倒序播放)

ObjectAnimator

ObjectAnimator继承自ValueAnimator它是可以直接对任意对象的任意属性进行动画操作的,比如说View的alpha属性。

1)淡入淡出

ObjectAnimator animator = ObjectAnimator.ofFloat(textview, "alpha", 1f, 0f, 1f);  
animator.setDuration(5000);  
animator.start();  

2)旋转

ObjectAnimator animator = ObjectAnimator.ofFloat(textview, "rotation", 0f, 360f);  
animator.setDuration(5000);  
animator.start();  

3)移动

float curTranslationX = textview.getTranslationX();  
ObjectAnimator animator = ObjectAnimator.ofFloat(textview, "translationX", 
curTranslationX, -500f, curTranslationX);  
animator.setDuration(5000);  
animator.start();  

4)缩放

ObjectAnimator animator = ObjectAnimator.ofFloat(textview, "scaleY", 1f, 3f, 1f);  
animator.setDuration(5000);  
animator.start(); 
AnimatorSet

实现组合动画功能主要需要借助AnimatorSet这个类。
  1)play(Animator anim)方法:播放动画
  2)after(Animator anim)方法:将现有动画插入到传入的动画之后执行
  3)after(long delay)方法:将现有动画延迟指定毫秒后执行
  4)before(Animator anim)方法:将现有动画插入到传入的动画之前执行
  5)with(Animator anim)方法:将现有动画和传入的动画同时执行

ObjectAnimator moveIn = ObjectAnimator.ofFloat(textview, "translationX", -500f, 0f);  
ObjectAnimator rotate = ObjectAnimator.ofFloat(textview, "rotation", 0f, 360f);  
ObjectAnimator fadeInOut = ObjectAnimator.ofFloat(textview, "alpha", 1f, 0f, 1f);  
AnimatorSet animSet = new AnimatorSet();  
animSet.play(rotate).with(fadeInOut).after(moveIn);  
animSet.setDuration(5000);  
animSet.start();  
Animator监听器

1)AnimatorListener

anim.addListener(new Animator.AnimatorListener() {
        // 在动画开始的时候调用
    @Override
    public void onAnimationStart(Animator animation) {
                
    }

        // 在动画结束的时候调用
    @Override
    public void onAnimationEnd(Animator animation) {

    }

        // 在动画被取消的时候调用
    @Override
    public void onAnimationCancel(Animator animation) {

    }

        // 在动画重复执行的时候调用
    @Override
    public void onAnimationRepeat(Animator animation) {

    }
});

2)AnimatorListenerAdapter

anim.addListener(new AnimatorListenerAdapter() {  
     // 在动画结束的时候调用
    @Override  
    public void onAnimationEnd(Animator animation) {  
    }  
}); 

使用XML定义属性动画

如果想要使用XML来编写动画,要在res目录下面新建一个animator文件夹,所有属性动画的XML文件都应该存放在这个文件夹当中。

在XML文件中一共可以使用如下三种标签:
  <animator> 对应代码中的ValueAnimator
  <objectAnimator>对应代码中的ObjectAnimator
  <set>对应代码中的AnimatorSet

编写
res/animator/anim_file

<animator xmlns:android="http://schemas.android.com/apk/res/android"  
    android:valueFrom="0"  
    android:valueTo="100"  
    android:valueType="intType"/>  
<objectAnimator xmlns:android="http://schemas.android.com/apk/res/android"  
    android:valueFrom="1"  
    android:valueTo="0"  
    android:valueType="floatType"  
    android:propertyName="alpha"/>  
<set xmlns:android="http://schemas.android.com/apk/res/android"  
    android:ordering="sequentially" >  
  
    <objectAnimator  
        android:duration="2000"  
        android:propertyName="translationX"  
        android:valueFrom="-500"  
        android:valueTo="0"  
        android:valueType="floatType" >  
    </objectAnimator>  
  
    <set android:ordering="together" >  
        <objectAnimator  
            android:duration="3000"  
            android:propertyName="rotation"  
            android:valueFrom="0"  
            android:valueTo="360"  
            android:valueType="floatType" >  
        </objectAnimator>  
  
        <set android:ordering="sequentially" >  
            <objectAnimator  
                android:duration="1500"  
                android:propertyName="alpha"  
                android:valueFrom="1"  
                android:valueTo="0"  
                android:valueType="floatType" >  
            </objectAnimator>  
            <objectAnimator  
                android:duration="1500"  
                android:propertyName="alpha"  
                android:valueFrom="0"  
                android:valueTo="1"  
                android:valueType="floatType" >  
            </objectAnimator>  
        </set>  
    </set>  
</set>  

使用

Animator animator = AnimatorInflater.loadAnimator(context, R.animator.anim_file);  
animator.setTarget(view);  
animator.start();  

参考

Android属性动画完全解析(上),初识属性动画的基本用法

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容