有這樣一個需求:RecyclerView嵌套WebView時,當WebView顯示寬度超出手機屏幕寬度時,需要用手指左右滑動WebView,但是由于手指在滑動時很難保持水平滑動,于是WebView和RecyclerView發生了滑動沖突,當手指稍微偏離水平方向時,WebView的滑動便停止,RecyclerView開始滑動,這樣的體驗很不好。于是乎便有了這樣的自定義WebView:
public class RecyclerViewFitWebView extends WebView {
public float oldY;
public float oldX;
public float newY;
public float newX;
public RecyclerViewFitWebView(Context context) {
super(context);
}
public RecyclerViewFitWebView(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public boolean onTouchEvent(MotionEvent ev) {
getParent().getParent().requestDisallowInterceptTouchEvent(true);
switch (ev.getAction()) {
case MotionEvent.ACTION_DOWN:
newX = ev.getX();
newY = ev.getY();
break;
case MotionEvent.ACTION_MOVE:
//手指滑動同時判斷滑動方向,一旦滑動方向大于+-60便調用
//getParent().getParent().requestDisallowInterceptTouchEvent(false);
//將滑動事件交給RecyclerView來處理
oldX = newX;
oldY = newY;
newX = ev.getX();
newY = ev.getY();
float moveX = Math.abs(oldX - newX);
float moveY = Math.abs(oldY - newY);
//moveX * 1.73 < moveY ,判斷左右滑動范圍為+-60度
if (moveX * 1.73 < moveY) {
getParent().getParent().requestDisallowInterceptTouchEvent(false);
}
break;
}
return super.onTouchEvent(ev);
}
}