您的位置:首页 > 移动开发 > Android开发

Android的Animation之LayoutAnimation使用方法

2015-07-06 22:15 531 查看
LayoutAnimationController用于为一个layout里面的控件,或者是一个ViewGroup里面的控件设置动画效果,可以在XML文件中设置,亦可以在Java代码中设置。

一种直接在XML文件中设置

1.  在res/anim文件夹下新建一个XML文件,名为list_anim_layout.xml,



[java] view
plaincopy

<layoutAnimation xmlns:android="http://schemas.android.com/apk/res/android"  

        android:delay="30%"  

        android:animationOrder="reverse"  

        android:animation="@anim/slide_right" />  

android:delay  子类动画时间间隔 (延迟)   70% 也可以是一个浮点数 如“1.2”等

android:animationOrder="random"   子类的显示方式 random表示随机

android:animationOrder 的取值有 
normal0   默认
reverse1  倒序
random2  随机
android:animation="@anim/slide_right" 表示孩子显示时的具体动画是什么

说明:其中delay的单位为秒;animation为设置动画的文件。animationOrder为进入方式

2.  在res/anim文件夹下新建一个XML文件,名为slide_right,即上面用到的文件。

[html] view
plaincopy

    <set xmlns:android="http://schemas.android.com/apk/res/android"   

        android:interpolator="@android:anim/accelerate_interpolator">  

    <translate android:fromXDelta="-100%p" android:toXDelta="0"  

            android:duration="@android:integer/config_shortAnimTime" />  

</set>  

 显示的效果为ListView第一次出现的时候为 item随机出现 每个Item都是从左不可见(-100%p)的区域向右滑动到显示的地方

3.  在主布局文件中为控件添加如下配置:

android:layoutAnimation="@anim/list_anim_layout",即第一步的布局文件。

第二种设置方法:在Java代码中设置

1. 同上;

2. 同上;

4.  在Acitivty中添加如下代码:

//通过加载XML动画设置文件来创建一个Animation对象;

       Animation animation=AnimationUtils.loadAnimation(this,
R.anim.list_anim);

       //得到一个LayoutAnimationController对象;

       LayoutAnimationController lac=new LayoutAnimationController(animation);

       //设置控件显示的顺序;

       lac.setOrder(LayoutAnimationController.ORDER_REVERSE);

       //设置控件显示间隔时间;

       lac.setDelay(1);

       //为ListView设置LayoutAnimationController属性;

   datalist.setLayoutAnimation(lac);

//-----------------------------------------------------------------------------------------------------------------------------------

推荐文章

Android中给listview/gridview设置动画(逐条加载条目动画)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: