
Android 开发时,最常用的控件之一就是ListView了,而使用ListView的同时,必然需要对它设置监听器,常用的监听器有这么几个:
1. OnItemClickListener // 监听器在点击该子项时触发;
2. OnTouchListener // 监听器在触碰到ListView时触发;
3. OnScrollListener // 监听器在ListView滚动时触发。
下面几个例子分别表述了具体处理的办法:
1. OnItemClickListener:
class ItemClickEvent implements AdapterView.OnItemClickListener { @Override
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
// TODO Auto-generated method stub
// parent.setVisibility(View.GONE); // 对子项处理的办法 // BtnCheck(0);
System.out.println(position);
}
}
2. OnTouchListener:
class ItemTouchEvent implements View.OnTouchListener { @Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
// System.out.println("触摸..");
if (event.getAction() == MotionEvent.ACTION_MOVE) {
// System.out.println("MOVE"); // 触摸滑动ListView时
BtnCheck(0);
} else if (event.getAction() == MotionEvent.ACTION_UP) {
// System.out.println("up"); // 离开ListView时
BtnCheck(currentPage);
} else if (event.getAction() == MotionEvent.ACTION_DOWN) {
// System.out.println("down"); // 开始接触到ListView时
BtnCheck(0);
} return false;
} }
不仅仅只有上面的三种Action状态,MotionEvent类中还定义了很多其它状态,我们可以灵活的使用这些状态
- MotionEvent.ACTION_DOWN:开始触摸;
- MotionEvent.ACTION_MOVE:触摸移动;
- MotionEvent.ACTION_UP:触摸抬起;
- MotionEvent.ACTION_OUTSIDE:触摸范围超过了UI边界;
- MotionEvent.ACTION_CANCEL:触摸被取消时(当用户保持按下操作,并从你的控件转移到外层控件时,会触发ACTION_CANCEL);
- MotionEvent.ACTION_POINTER_DOWN:当有另外一个触摸按下时(多点触摸);
- MotionEvent.ACTION_POINTER_UP:当另一个触摸抬起时(多点触摸)。
3. OnScrollListener:
class LvScrollEvent implements AbsListView.OnScrollListener { @Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) { // 监听滑动
// TODO Auto-generated method stub } @Override
public void onScrollStateChanged(AbsListView view, int scrollState) { // 监听滑动状态的改变
// TODO Auto-generated method stub
switch (scrollState) {
case OnScrollListener.SCROLL_STATE_IDLE: //
BtnCheck(currentPage);
// mBusy = false;
System.out.println("停止...");
break;
case OnScrollListener.SCROLL_STATE_TOUCH_SCROLL:
BtnCheck(0);
// mBusy = true;
System.out.println("正在滑动...");
break;
case OnScrollListener.SCROLL_STATE_FLING:
BtnCheck(0);
// mBusy = true;
System.out.println("开始滚动..."); break;
}
} }
3.1 OnScrollSateChanged() 方法
OnScrollSateChanged根据scrollState来决定其回调的次数,它有三种模式:
- OnScrollListener.SCROLL_STATE_IDLE:滚动停止时的状态
- OnScrollListener.SCROLL_STATE_STOUCH_SCROLL:触摸正在滚动,手指还没离开界面时的状态
- OnScrollListener.SCROLL_STATE_FLING:用户在用力滑动后,ListView由于惯性将继续滑动时的状态
当用户没有用力滑动时,OnScrollSateChanged方法只会回调2次,否则回调三次,我们在使用时通常会以设置Flag标志,来区分不同的滑动状态,从而进行相应的处理。
3.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 的position
mListView.getFirstVisiblePosition(); // 获取当前可见区域内最后一个item 的position
mListView.getLastVisiblePosition();