如果webview嵌套的html中含有轮播图我们就会发现滑动很不舒畅,这对用户体验来说是很差的,所以咯这肯定不行,当然解决的方法也很简单,就是根据滑动方向和距离简单的做下事件的屏蔽。
所以这里自定义一个webview
public class MyWebView extends WebView{
private float startx;
private float starty;
private float offsetx;
private float offsety;
public MyWebView (Context context) {
super(context);
}
public MyWebView (Context context, AttributeSet attrs) {
super(context, attrs);
}
public MyWebView (Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
switch (event.getAction()) {
case MotionEvent.ACTION_DOWN:
getParent().requestDisallowInterceptTouchEvent(true);
startx = event.getX();
starty = event.getY();
Log.e("MotionEvent", "webview按下");
break;
case MotionEvent.ACTION_MOVE:
Log.e("MotionEvent", "webview滑动");
offsetx = Math.abs(event.getX() - startx);
offsety = Math.abs(event.getY() - starty);
if (offsetx > offsety) {
getParent().requestDisallowInterceptTouchEvent(true);
Log.e("MotionEvent", "屏蔽了父控件");
} else {
getParent().requestDisallowInterceptTouchEvent(false);
Log.e("MotionEvent", "事件传递给父控件");
}
break;
default:
break;
}
return super.onTouchEvent(event);
}
}