OnScrollListener回调分析
如果adapter中的数据量很大的时候,在加载listview时会出现卡顿的现象。这是会让用户抓狂!最好的解决办法就是先加载一定数量的数据,然后在最下方提示正在加载!
动态加载就是把放入adapter中的数据分好几次加载。在用户拖动listview时再加载一定的数据,和sina微博的客户端类似。
给listview添加OnScrollListener监听事件默认会覆盖下面两个方法:
动态加载就是把放入adapter中的数据分好几次加载。在用户拖动listview时再加载一定的数据,和sina微博的客户端类似。
给listview添加OnScrollListener监听事件默认会覆盖下面两个方法:
newOnScrollListener(){
booleanisLastRow= false;
@Override
public voidonScroll(AbsListViewview, intfirstVisibleItem, intvisibleItemCount, inttotalItemCount){
// 滚动时一直回调,直到停止滚动时才停止回调。单击时回调一次。
// firstVisibleItem:当前能看见的第一个列表项ID(从0开始)
// visibleItemCount:当前能看见的列表项个数(小半个也算)
// totalItemCount:列表项共数
// 判断是否滚到最后一行
if(firstVisibleItem+visibleItemCount==totalItemCount&&totalItemCount>0){
isLastRow= true;
}
}
@Override
public voidonScrollStateChanged(AbsListViewview, intscrollState){
// 正在滚动时回调,回调2-3次,手指没抛则回调2次。scrollState=2的这次不回调
// 回调顺序如下
// 第1次:scrollState=SCROLL_STATE_TOUCH_SCROLL(1)正在滚动
// 第2次:scrollState=SCROLL_STATE_FLING(2)手指做了抛的动作(手指离开屏幕前,用力滑了一下)
// 第3次:scrollState=SCROLL_STATE_IDLE(0)停止滚动
booleanisLastRow= false;
@Override
public voidonScroll(AbsListViewview, intfirstVisibleItem, intvisibleItemCount, inttotalItemCount){
// 滚动时一直回调,直到停止滚动时才停止回调。单击时回调一次。
// firstVisibleItem:当前能看见的第一个列表项ID(从0开始)
// visibleItemCount:当前能看见的列表项个数(小半个也算)
// totalItemCount:列表项共数
// 判断是否滚到最后一行
if(firstVisibleItem+visibleItemCount==totalItemCount&&totalItemCount>0){
isLastRow= true;
}
}
@Override
public voidonScrollStateChanged(AbsListViewview, intscrollState){
// 正在滚动时回调,回调2-3次,手指没抛则回调2次。scrollState=2的这次不回调
// 回调顺序如下
// 第1次:scrollState=SCROLL_STATE_TOUCH_SCROLL(1)正在滚动
// 第2次:scrollState=SCROLL_STATE_FLING(2)手指做了抛的动作(手指离开屏幕前,用力滑了一下)
// 第3次:scrollState=SCROLL_STATE_IDLE(0)停止滚动
//当屏幕停止滚动时为0;当屏幕滚动且用户使用的触碰或手指还在屏幕上时为1;
//由于用户的操作,屏幕产生惯性滑动时为2
//当滚到最后一行且停止滚动时,执行加载
if(isLastRow&&scrollState==AbsListView.OnScrollListener.SCROLL_STATE_IDLE){
//加载元素
......
isLastRow=false;
}
}
}