ListView的item动画效果

最近有一个需求,在滑动listview的过程中 ,刚进入的item要有动画效果。
接下来写一个简单的demo:
尽量将demo封装好,所以写一个用来出来动画的Adapter。
package com.app.listanim;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.AnimationSet;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.ListView;

/**
* Created by llb on 2016/1/26.
*/

public abstract class ListAdapter extends BaseAdapter{
private AnimationSet animationSet;
private ListView mListView;

private int mFirstPosition; // 第一个可见item的位置
private int mFirstTop; // 第一个可以item的top值
private boolean isScrollDown;// 是否向下滑动

//绑定listview 设置其滑动监听
public void bindView(ListView listView){
    mListView=listView;
    mListView.setOnScrollListener(mScrollListener);
}


//设置动画
public void setAnimation(AnimationSet set){
    animationSet=set;
}

private AbsListView.OnScrollListener mScrollListener=new AbsListView.OnScrollListener() {
    @Override
    public void onScrollStateChanged(AbsListView view, int scrollState) {
        if(scrollState== AbsListView.OnScrollListener.SCROLL_STATE_IDLE)
            isScrollDown=false;
    }

    @Override
    public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
        View firstChild=view.getChildAt(0);
        if(firstChild==null)
            return;
        int top=firstChild.getTop();//获得当前view最高点的坐标
        isScrollDown = firstVisibleItem > mFirstPosition || mFirstTop > top;
        //每次记录下来  与下次滑动的位置进行比较  判断往上 还是往下滑动
        mFirstTop = top;
        mFirstPosition = firstVisibleItem;
    }
};

@Override
public View getView(int position, View convertView, ViewGroup parent){
    View view=buildView(position,convertView,parent);
    if(isScrollDown&&animationSet!=null){
        cancelAnimation();
        view.startAnimation(animationSet);
    }
    return view;
}

//清除所有的动画
private void cancelAnimation() {
    int count = mListView.getChildCount();
    for(int i=0;i<count;i++) {
        mListView.getChildAt(i).clearAnimation();
    }
}

public abstract View buildView(int position, View convertView, ViewGroup parent);

}
写一个Adapter继承ListAdapter 写自己想要的布局:

class MyAdapter extends ListAdapter{

        @Override
        public int getCount() {
            return 40;
        }

        @Override
        public Object getItem(int position) {
            return null;
        }

        @Override
        public long getItemId(int position) {
            return position;
        }

        @Override
        public View buildView(int position, View convertView, ViewGroup parent) {
            if(convertView==null){
                convertView=View.inflate(parent.getContext(),R.layout.item,null);
            }
            return convertView;
        }
    }

使用:

lv=(ListView)findViewById(R.id.lv);
        MyAdapter myAdapter=new MyAdapter();
        myAdapter.bindView(lv);
        myAdapter.setAnimation((AnimationSet) AnimationUtils.loadAnimation(this, R.anim.anim));
        lv.setAdapter(myAdapter);

动画:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
    <scale
        android:duration="500"
        android:fromXScale="0.9"
        android:toXScale="1"
        android:fromYScale="0.8"
        android:pivotX="50%"
        android:pivotY="50%"
        android:toYScale="1"
        />
</set>

效果图
这里写图片描述

每次进入的item都会有一个稍微放大的效果。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值