欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Android Property Animation 属性动画

程序员文章站 2022-03-16 16:14:33
...


在Android3.0之后推出了属性动画,属性动画比视图动画更高效。一般Android3.0是在平板上,手机上一般没有3.0,所以手机从4.0开始才支持属性动画。

简单举一个旋转的例子,用代码来实现:

1     findViewById(R.id.btnAnimateMe).setOnClickListener(new View.OnClickListener() {
2             @Override
3             public void onClick(View v) {
4                //属性动画
5                v.animate().rotation(360).setDuration(1000).start();
6  
7             }
8         });

 


也可通过xml文件配置,在res目录中创建animator文件夹,在其中创建animate_me.xml:

<?xml version="1.0" encoding="utf-8"?>
<objectAnimator xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="1000"
    android:propertyName="rotation"
    android:valueFrom="0"
    android:valueTo="360">

</objectAnimator>

 


android:propertyName="rotation"的内容必须是API有的函数。

使用这个xml代码如下:

       findViewById(R.id.btnAnimateMe).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
 
                //xml配置属性动画
                ObjectAnimator animator = (ObjectAnimator) AnimatorInflater.loadAnimator(MainActivity.this,R.animator.animate_me);
 
                animator.setTarget(v);
                animator.start();
 
            }
        });

上面的效果也可以用定制化更高的方式实现:

        findViewById(R.id.btnAnimateMe).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
 
         
             ObjectAnimator.ofFloat(v,"rotation",0,90,90,360).setDuration(1000).start();//0,90,90,360相当于关键帧
    
            }
        });



我们还可以通过xml文件配置动画集合,让动画混合实现:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" android:ordering="sequentially">
    <objectAnimator android:propertyName="alpha" android:duration="1000" android:valueFrom="0" android:valueTo="1"/>
    <objectAnimator android:propertyName="translationY" android:duration="1000" android:valueFrom="0" android:valueTo="200"/>

</set>

set有android:ordering="sequentially"属性,sequentially表示分开一次执行,together表示同时执行

findViewById(R.id.btnAnimateMe).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
 

                //xml属性集合
                AnimatorSet animator = (AnimatorSet) AnimatorInflater.loadAnimator(MainActivity.this,R.animator.animate_me_set);
                animator.setTarget(v);
                animator.start();
 
            }
        });


也可以通过代码直接实现混合动画:

        findViewById(R.id.btnAnimateMe).setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
       
                AnimatorSet set = new AnimatorSet();
                set.setDuration(1000);
              
                set.playSequentially(ObjectAnimator.ofFloat(v, "translationX", 0, 200),
                        ObjectAnimator.ofFloat(v, "translationY", 0, 200),
                        ObjectAnimator.ofFloat(v,"translationY",200,0),
                        ObjectAnimator.ofFloat(v,"translationX",200,0));
                set.start();

            }
        });