.最近做的项目中遇到了ScrollView嵌套RecyclerView,刚写完功能测试,直接卡出翔了,后来通过网上查找资料和
自己的实践,找出了两种方法解决这个问题。
首先来个最简单的方法:
recyclerView.setNestedScrollingEnabled(false);这个方法就可以解决这一问题。
既然有首先那肯定有第二种解决的办法,只不过相对于第一种方法来说就太麻烦了。
我们知道ScrollView嵌套listView或者GridView的时候需要自定义listView或者是GridView,在这儿我们也需要自定义,
但是也有区别,我们这儿不是自定义RecyclerView,而是自定义ScrollView。下面给出自定义的方法。
自己的实践,找出了两种方法解决这个问题。
首先来个最简单的方法:
recyclerView.setNestedScrollingEnabled(false);这个方法就可以解决这一问题。
既然有首先那肯定有第二种解决的办法,只不过相对于第一种方法来说就太麻烦了。
我们知道ScrollView嵌套listView或者GridView的时候需要自定义listView或者是GridView,在这儿我们也需要自定义,
但是也有区别,我们这儿不是自定义RecyclerView,而是自定义ScrollView。下面给出自定义的方法。
public class TopicScrollView extends ScrollView{
private int downX;
private int downY;
private int mTouchSlop;
public TopicScrollView(Context context) {
super(context);
mTouchSlop= ViewConfiguration.get(context).getScaledTouchSlop();
}
public TopicScrollView(Context context, AttributeSet attrs) {
super(context, attrs);
mTouchSlop= ViewConfiguration.get(context).getScaledTouchSlop();
}
public TopicScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
mTouchSlop= ViewConfiguration.get(context).getScaledTouchSlop();
}
@Override
public boolean onInterceptTouchEvent(MotionEvent e) {
int action = e.getAction();
switch (action) {
case MotionEvent.ACTION_DOWN:
downX = (int) e.getRawX();
downY = (int) e.getRawY();
break;
case MotionEvent.ACTION_MOVE:
int moveY = (int) e.getRawY();
if (Math.abs(moveY - downY) > mTouchSlop) {
return true;
}
}
return super.onInterceptTouchEvent(e);
}
}
说明: //getScaledTouchSlop是一个距离,表示滑动的时候,手的移动要大于这个距离才开始移动控件
//getX()是表示Widget相对于自身左上角的x坐标,而getRawX()是表示相对于屏幕左上角的x坐标值(注意:这个屏幕左上角是手机屏幕左上角,不管activity是否有titleBar或是否全屏幕),getY(),getRawY()一样的道理