解决自定义ListView中滑动事件和点击的setOnItemClickListener事件冲突的问题

来源:互联网 发布:修改视图的sql语句 编辑:程序博客网 时间:2024/04/28 03:13

解决自定义ListView滑动事件和点击事件冲突的问题

一、问题描述

自定义的ListView加入下拉刷新和上拉加载更多后会出现滑动时触发了点击单个条目的setOnItemClickListener事件,导致两个事件冲突了

二、解决方案

当我们重写ListView的OnTouchEvent方法时,通常都会switch一下MotionEvent的action,检查符合一定条件是return true,比如重写ListView添加下拉刷新时出现下拉刷新时容易误点Item出发点击事件或者出发长按事件。先看看下面的代码,我忽略了非关键部分:
@Override  public boolean onTouchEvent(MotionEvent ev) {    switch (ev.getAction()) {      case MotionEvent.ACTION_DOWN :       // ...        break;      case MotionEvent.ACTION_MOVE :        if (...) {            // 下拉刷新逻辑...          return true;//这里拦截了触摸事件        }        break;      case MotionEvent.ACTION_UP :            // ...        break;    }    return super.onTouchEvent(ev);  }
分析:
发现OnTouchEvent中条件出发下拉刷新逻辑后直接
return true;
而没有执行到
super.onTouchEvent(ev);
方法,在
super.onTouchEvent(ev);
方法中有可以解决ListView触摸事件和点击Item事件冲突的代码,可以防止下拉刷新时容易误点Item出发点击事件或者出发长按事件。


解决

return ture;
前调用
super.onTouchEvent(ev);
,代码如下:
@Override  public boolean onTouchEvent(MotionEvent ev) {    switch (ev.getAction()) {      case MotionEvent.ACTION_DOWN :       // ...        break;      case MotionEvent.ACTION_MOVE :        if (...) {            // 下拉刷新逻辑...          super.onTouchEvent(ev);//调用父类方法,防止滑动时触发点击事件          return true;//这里拦截了触摸事件        }        break;      case MotionEvent.ACTION_UP :            // ...        break;    }    return super.onTouchEvent(ev);  }

如果上面的还是无法解决问题,我们可以重写ListView的onInterceptTouchEvent方法,将所有的触摸事件都拦截由该listview处理即可,代码如下:
@Overridepublic boolean onInterceptTouchEvent(MotionEvent ev) {//触摸事件由此listview处理return true;}


2 0
原创粉丝点击