Android中给listview/gridview设置动画(逐条加载条目动画)

先看实现的效果如下:

演示效果如上:
   上面的列表是GridView 要给这个GridView添加一个动画,才可以逐个加载。网上找了大量资料,不少人说用多线程加载,通过SetAdapter设置数据改变,还有用到Handler这样太扯淡了,几乎放弃了。发现直接在配置里设置动画即可。效果非常好,看效果。

   ListView配置方法如下:
<GridView
                android:background="@drawable/navagation_shape"
                android:id="@+id/gv_navagation"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_marginTop="1dip"
                android:listSelector="#CDCD00" 
                
                android:drawSelectorOnTop="false"
                android:fadingEdgeLength="0.0dp"
                android:layoutAnimation="@anim/navagation_gridview_anim"
                android:cacheColorHint="@android:color/transparent"
                >
            </GridView> 
关键是这句:   android:layoutAnimation="@anim/navagation_gridview_anim"
 

我们在anim目录下新建一个动画xml文件 配置内容如下navagation_gridview_anim.xml目录文件如下:
<layoutAnimation xmlns:android="http://schemas.android.com/apk/res/android"
    android:animation="@anim/list_anim"
    android:animationOrder="normal"
    android:delay="0.5" />
接下来实现 list_anim.xml这个文件也是在 anim文件夹下新建这样的文件配置内容如下:
<?xml version="1.0" encoding= "utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
       <translate android:fromXDelta="-100%"
                android:fromYDelta="0"
                android:toXDelta="0"
                android:toYDelta="0"
                android:duration="2550"
                android:interpolator="@android:anim/anticipate_overshoot_interpolator" />
</set>
--------------------------------------------------------------------------------
稍微解释一下:
   android:interpolator="@android:anim/anticipate_overshoot_interpolator" 
   这里是配置出来的动画效果,是加速跑到终点(过了一点)然后再回到原点)效果不错。
    其他的含义结合者给的属性大致上都能看懂就不多说了
                android:fromXDelta="-100%"  //起始横坐标的位置;; 
                android:fromYDelta="0"      //起始中坐标的位置
                android:toXDelta="0"        //要到达什么地方(X坐标)
                android:toYDelta="0"        //要到达什么地方(y坐标) 
--------------------------------------------------------------------------------


 

  • 13
    点赞
  • 35
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值