Android的Animation之LayoutAnimation使用方法

LayoutAnimationController用于为一个layout里面的控件,或者是一个ViewGroup里面的控件设置动画效果,可以在XML文件中设置,亦可以在Java代码中设置。


一种直接在XML文件中设置
1.  在res/anim文件夹下新建一个XML文件,名为list_anim_layout.xml,
 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 的取值有 
normal 0    默认
reverse 1   倒序
random 2   随机
android:animation="@anim/slide_right" 表示孩子显示时的具体动画是什么

说明:其中delay的单位为秒;animation为设置动画的文件。animationOrder为进入方式
2.  在res/anim文件夹下新建一个XML文件,名为slide_right,即上面用到的文件。

 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);

转自:http://blog.csdn.net/imdxt1986/article/details/6952943

android特效展示一:ListView


ViewGroup等空间的动画效果实战
常常我们会为一些空间制定动画效果,当然也能在布局空间中制定动画效果:
如:
<ListView
        android:id="@android:id/list"
        android:persistentDrawingCache="animation|scrolling"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layoutAnimation="@anim/layout_bottom_to_top_slide" />
android:layoutAnimation="@anim/layout_bottom_to_top_slide" 制定了该组建显示的时候的动画效果
layoutAnimation指定了前面定义的LayoutAnimationController,为了使动画效果比较流畅这里还通过persistentDrawingCache设置了控件的绘制缓存策略,一共有4中策略:
PERSISTENT_NO_CACHE 说明不在内存中保存绘图缓存;
PERSISTENT_ANIMATION_CACHE 说明只保存动画绘图缓存;
PERSISTENT_SCROLLING_CACHE 说明只保存滚动效果绘图缓存
PERSISTENT_ALL_CACHES 说明所有的绘图缓存都应该保存在内存中。


layout_bottom_to_top_slide 的代码如下
<layoutAnimation xmlns:android="http://schemas.android.com/apk/res/android"
           android:delay="70%"
        android:animationOrder="random"
        android:animation="@anim/slide_right" />
android:delay  子类动画时间间隔 (延迟)   70% 也可以是一个浮点数 如“1.2”等
android:animationOrder="random"   子类的显示方式 random表示随机
android:animationOrder 的取值有
normal        0           默认
reverse        1          倒序
random        2          随机
android:animation="@anim/slide_right" 表示孩子显示时的具体动画是什么

slide_right.xml
<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)的区域向右滑动到显示的地方

摘自:http://w1985chun.iteye.com/blog/1161891

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值