Android 关于在Activity中监听ListView

Android 开发时,最常用的控件之一就是ListView了,而使用ListView的同时,必然需要对它设置监听器,常用的监听器有这么几个:
  1. OnItemClickListener // 监听器在点击该子项时触发;
  2. OnTouchListener     // 监听器在触碰到ListView时触发;
  3. OnScrollListener     // 监听器在ListView滚动时触发。


下面几个例子分别表述了具体处理的办法:

1. OnItemClickListener:

 1 class ItemClickEvent implements AdapterView.OnItemClickListener {
 2 
 3     @Override
 4     public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
 5         // TODO Auto-generated method stub
 6         // parent.setVisibility(View.GONE);
 7 
 8         // 对子项处理的办法
 9 
10         // BtnCheck(0);
11         System.out.println(position);
12     }
13 }

 

2. OnTouchListener:

 1 class ItemTouchEvent implements View.OnTouchListener {
 2 
 3     @Override
 4     public boolean onTouch(View v, MotionEvent event) {
 5         // TODO Auto-generated method stub
 6         // System.out.println("触摸..");
 7         if (event.getAction() == MotionEvent.ACTION_MOVE) {
 8             // System.out.println("MOVE");  // 触摸滑动ListView时
 9             BtnCheck(0);
10         } else if (event.getAction() == MotionEvent.ACTION_UP) {
11             // System.out.println("up");   // 离开ListView时
12             BtnCheck(currentPage);
13         } else if (event.getAction() == MotionEvent.ACTION_DOWN) {
14             // System.out.println("down");   // 开始接触到ListView时
15             BtnCheck(0);
16         }
17 
18         return false;
19     }
20 
21 }

不仅仅只有上面的三种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:

 1 class LvScrollEvent implements AbsListView.OnScrollListener {
 2 
 3     @Override
 4     public void onScroll(AbsListView view, int firstVisibleItem, 
                  int visibleItemCount, int totalItemCount) { // 监听滑动 5 // TODO Auto-generated method stub 6 7 } 8 9 @Override 10 public void onScrollStateChanged(AbsListView view, int scrollState) { // 监听滑动状态的改变 11 // TODO Auto-generated method stub 12 switch (scrollState) { 13 case OnScrollListener.SCROLL_STATE_IDLE: // 14 BtnCheck(currentPage); 15 // mBusy = false; 16 System.out.println("停止..."); 17 break; 18 case OnScrollListener.SCROLL_STATE_TOUCH_SCROLL: 19 BtnCheck(0); 20 // mBusy = true; 21 System.out.println("正在滑动..."); 22 break; 23 case OnScrollListener.SCROLL_STATE_FLING: 24 BtnCheck(0); 25 // mBusy = true; 26 System.out.println("开始滚动..."); 27 28 break; 29 } 30 } 31 32 }

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总数时,就表示移动到了最后一行

1 if (firstVisibleItem + visibleItemCount == totalItemCount && totalItemCount > 0) {
2     // 滚动到最后一行了
3 }
(2)判断滑动的方向 

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

1 if (firstVisibleItem > oldVisibleItem) {
2     // 向上滑动
3 } 
4 if (firstVisibleItem < oldVisibleItem) {
5     // 向下滑动
6 }
7 oldVisibleItem = firstVisibleItem;

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

1 // 获取当前可见区域内第一个item 的position
2 mListView.getFirstVisiblePosition();
3 
4 // 获取当前可见区域内最后一个item 的position
5 mListView.getLastVisiblePosition();

 

转载于:https://www.cnblogs.com/steffen/p/5986769.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值