listview滚动

1,listview回顶部:

1.1: listView.setSelection(0);  瞬间回顶部,推荐

1.2: listView.smoothScrollToPosition(0);  快速滑动顶部,如果有100条会顺序向上回到顶部,体验感不好。

1.3:listView.scrollTo(0, 0);  看不出效果,跟焦点有关吧。 


2,listview的滚动监听:OnTouchListener和OnScrollListener还有setOnScrollChangeListener

OnTouchListener:

OnTouchListener方法来自View中的监听事件,可以在监听三个Action事件发生时通过MotionEvent的getX()方法或getY()方法获取到当前触摸的坐标值,来对用户的滑动方向进行判断,并可在不同的Action状态中做出相应的处理

mListView.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
// 触摸按下时的操作

break;
case MotionEvent.ACTION_MOVE:
// 触摸移动时的操作

break;
case MotionEvent.ACTION_UP:
// 触摸抬起时的操作

break;
}
return false;
}
});

不仅仅只有上面的三种Action状态,MotionEvent类中还定义了很多其它状态,我们可以灵活的使用这些状态

MotionEvent.ACTION_DOWN:开始触摸
MotionEvent.ACTION_MOVE:触摸移动
MotionEvent.ACTION_UP:触摸抬起
MotionEvent.ACTION_OUTSIDE:触摸范围超过了UI边界
MotionEvent.ACTION_CANCEL:触摸被取消时(详见:http://stackoverflow.com/questions/11960861/what-causes-a-motionevent-action-cancel-in-android)
MotionEvent.ACTION_POINTER_DOWN:当有另外一个触摸按下时(多点触摸)
MotionEvent.ACTION_POINTER_UP:当另一个触摸抬起时(多点触摸)

OnScrollListener:

OnScrollListener来自AbsListView中的监听事件,因为ListView直接继承自AbsListView,所以在AbsListView中有很多ListView相关信息 
OnScrollListener中有两个回调方法

  • public void onScrollStateChanged(AbsListView view, int scrollState):监听滑动状态的改变
  • public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount):监听滑动
2.1 OnScrollSateChanged方法

OnScrollSateChanged根据scrollState来决定其回调的次数,它有三种模式:

OnScrollListener.SCROLL_STATE_IDLE:滚动停止时的状态
OnScrollListener.SCROLL_STATE_STOUCH_SCROLL:触摸正在滚动,手指还没离开界面时的状态
OnScrollListener.SCROLL_STATE_FLING:用户在用力滑动后,ListView由于惯性将继续滑动时的状态
当用户没有用力滑动时,OnScrollSateChanged方法只会回调2次,否则回调三次,我们在使用时通常会以设置Flag标志,来区分不同的滑动状态,从而进行相应的处理

2.2 OnScroll方法

在ListView滚动时会一直被回调,它通过里面有三个参数来显示当前ListView的滚动状态

firstVisibleItem:当前能看见的第一个item的ID(从0开始)
visibleItemCount:当前可见的item总数
totalItemCount:列表中适配器总数量,也就是整个ListView中item总数
注意:当前可见的item总数,包括屏幕中没有显示完整的item,如显示一半的item也会算在可见范围内

通过这三个参数,我么可以实现很多事件判断,如:
(1)判断当前是否滑动到最后一行
当前视图中第一个item的ID加上当前屏幕中可见item的总数如果等于ListView中所有item总数时,就表示移动到了最后一行 

if (firstVisibleItem + visibleItemCount == totalItemCount && totalItemCount > 0) {
// 滚动到最后一行了
}


(2)判断滑动的方向
通过oldVisibleItem 记录上一次firstVisibleItem的位置,再与滑动后的firstVisibleItem进行比较,就可得知滑动的方向

if (firstVisibleItem > oldVisibleItem) {
// 向上滑动
}
if (firstVisibleItem < oldVisibleItem) {
// 向下滑动
}
oldVisibleItem = firstVisibleItem;

ListView也为我们提供了一些封装好了的方法,来获取item的位置信息

// 获取当前可见区域内第一个item的id
mListView.getFirstVisiblePosition();

// 获取当前可见区域内最后一个item的id
mListView.getLastVisiblePosition();

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值