android 实现listview 的item 出现在屏幕有个动画效果 类似于知乎的那个app

这个是知乎1.80版本上面的一个效果,后面的版本好像砍掉了


先上图:


,很难直观的看出来,因为录gif效果比较差,listview每一个item出现在屏幕的可见范围内的时候会有一个从上而下或者从下而上的动画效果。


原理很简单的,这里也只是简单说下原理实现。


步骤:

1、复写listview

2、实现OnScrollListener接口

3、关键在这个实现函数里面public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount)


onScroll()后面的参数


/**
	 * 当ListView滚动时触发
	 * firstVisibleItem 屏幕上显示的第一个Item的position
	 * visibleItemCount 当前屏幕显示的总个数
	 * totalItemCount   ListView的总条数
	 */
	int i=0;
	int j=0;
	@Override
	public void onScroll(AbsListView view, int firstVisibleItem,
			int visibleItemCount, int totalItemCount) {
		firstVisibleItemPosition = firstVisibleItem;
		Log.i("RefreshListView", "onScroll: " + firstVisibleItem + ", " + visibleItemCount + ", " + totalItemCount+"|_--");
		
		if(mOnRefreshListener != null && (i!=firstVisibleItem+visibleItemCount-1 || j!=firstVisibleItem)) {
			if(i<(firstVisibleItem+visibleItemCount-1)){
				mOnRefreshListener.onOutitem(firstVisibleItem+visibleItemCount-1,1);
				
				}else if(j>firstVisibleItem || j==0)
				{
					mOnRefreshListener.onOutitem(firstVisibleItem,0);//这是回调函数,当屏幕出现listview新的item,会将出的item传给activity
				
				}
		}
		j=firstVisibleItem;//保存上一次滑动可视的第一个item的position
		i=firstVisibleItem+visibleItemCount-1;//保存上一次滑动可视的最后item的position
		
		
		if((firstVisibleItem + visibleItemCount) >= totalItemCount
				&& totalItemCount > 0) {
//			Log.i("RefreshListView", "加载更多");
			isScroll2Bottom = true;
		} else {
			isScroll2Bottom = false;
		}
	}
activity 的回调函数收到这个position之后,就可以实现动画效果了


mPullRefreshListView.setOnRefreshListener(new OnRefreshListener() {

			public void onRefresh() {
				// Do work to refresh the list here.
				getSpilts(Contacts.GetSpiltTypeUp);
			}

			@Override
			public void onLoadMoring() {
				// TODO Auto-generated method stub
				getSpilts(Contacts.GetSpiltTypeDown);
			}

			@Override
			public void onOutitem(int itemNum, int from) {
				// TODO Auto-generated method stub
				System.out.println(itemNum);
				int wantedPosition = itemNum; // Whatever position you're looking for
				int firstPosition = mPullRefreshListView.getFirstVisiblePosition() ; // - mPullRefreshListView.getHeaderViewsCount() This is the same as child #0
				int wantedChild = wantedPosition - firstPosition;
				if (wantedChild < 0 || wantedChild >= mPullRefreshListView.getChildCount()) {
				  Log.w("tag", "Unable to get view for desired position, because it's not being displayed on screen.");
				  return;
				}
				// Could also check if wantedPosition is between listView.getFirstVisiblePosition() and listView.getLastVisiblePosition() instead.
				View view = mPullRefreshListView.getChildAt(wantedChild);
				
				Animation procAnim = null;
				if(from == 1)
				{
					procAnim=new TranslateAnimation(0, 0,20,0);
				}else
				{
					procAnim=new TranslateAnimation(0, 0,-20,0);
				}
				procAnim.setDuration(700);
				procAnim.setFillAfter(true);
				view.startAnimation(procAnim);
				
			}
		});


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值