之前寫了怎麼解決ScrollView嵌套ScrollView滑動衝突的問題,因爲這種不同嵌套所造成的滑動衝突本質上是一樣的問題和原因,解決思路也都相同,唯一的具體差別就差在判斷條件上,故此貼之上代碼,想看問題原因和解決思路的可以查看這篇文章——完美解決Android中ScrollView嵌套ScrollView滑動衝突問題
public class MyScrollListView extends ListView {
public MyScrollListView(Context context) {
super(context);
}
public MyScrollListView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyScrollListView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
public MyScrollListView(Context context, AttributeSet attrs, int defStyleAttr, int defStyleRes) {
super(context, attrs, defStyleAttr, defStyleRes);
}
float preY = 0;
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
preY = ev.getY();
getParent().requestDisallowInterceptTouchEvent(true);
break;
case MotionEvent.ACTION_MOVE:
if (slideToTheTop(ev) || slideToTheBottom(ev))
getParent().requestDisallowInterceptTouchEvent(false);
else
getParent().requestDisallowInterceptTouchEvent(true);
break;
case MotionEvent.ACTION_UP:
getParent().requestDisallowInterceptTouchEvent(false);
break;
}
return super.dispatchTouchEvent(ev);
}
/**
* 當第一個可見item爲0且手勢爲向下滑動且全部露出
* @param ev
* @return
*/
private boolean slideToTheTop(MotionEvent ev) {
return getFirstVisiblePosition() == 0 && getChildAt(0).getTop() == 0 && ev.getY() - preY > 0;
}
/**
* 最後一個可見item爲全部item最後一個且手勢向上滑動且全部露出
* @param ev
* @return
*/
private boolean slideToTheBottom(MotionEvent ev) {
return getLastVisiblePosition() == getCount() - 1 && getChildAt(getChildCount() - 1).getBottom() == getHeight() && ev.getY() - preY < 0;
}
}