直接上代码 我这个scrollview因为业务需求做了滑动监听 解决惯性问题只需在onInterceptTouchEvent(MotionEvent e)方法里做处理就行 别的不需要考虑 简单 暴力
/**
* 带滚动监听的Scrollview
* 用于随着Scrollview的滑动更改状态栏的透明度
*/
public class MyScrollview extends ScrollView {
private int downX;
private int downY;
private int mTouchSlop;
private ScrollViewListener scrollViewListener = null;
public MyScrollview(Context context) {
super(context);
}
public MyScrollview(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyScrollview(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
public void setScrollViewListener(ScrollViewListener scrollViewListener) {
this.scrollViewListener = scrollViewListener;
}
@Override
protected void onScrollChanged(int l, int t, int oldl, int oldt) {
super.onScrollChanged(l, t, oldl, oldt);
if (scrollViewListener != null) {
scrollViewListener.onScrollChanged(this, l, t, oldl, oldt);
}
}
public interface ScrollViewListener {
void onScrollChanged(MyScrollview scrollView, int l, int t, int oldl, int oldt);
}
/**
* 屏蔽内部recyclerview的滑动事件
* @param e
* @return
*/
@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);
}
}