WebView的缩放与左右滑动手势

来源:互联网 发布:数据终端设备干嘛用 编辑:程序博客网 时间:2024/05/16 11:44

在使用WebView的时候如果需要访问网页时,经常需要使用缩放,一般WebView都喜欢添加左右滑动的监听事件,可以方便的goBack和goForward。如果在打开放大的网页时,会出现一种情况就是,放大了以后需要左右的移动查看完整的内容,但同时左右移动查看的同时又会出发左右滑动的监听事件,导致goBack和goForward。所以为了解决这个问题,自己想了一种解决办法,经实验后发现有效,思路是在放大的时候屏蔽掉滑动的监听事件。

MainActivity.java

public MainActivity extends Activity {      private final int FIRST_TIME = 0;    private final int SECOND_TIME = 1;    private final int SERVERAL_TIME = 2;    private float orginalScale = 0;    // 原始的scale    private float currentScale = 0;    // 当前页面的原始scale    private int times = FIRST_TIME;    // 记录当前页面的缩放次数,每次页面跳转的时候都需要将times设置为FIRST_TIME(注意!!!)    private boolean canSlip = false;   // 是否能左右滑动,因为缩放的时候需要屏蔽掉左右滑动防止goBack和goForward    @Override        public void onCreate(Bundle savedInstanceState) {   // 设置缩放        webView.getSettings().setBuiltInZoomControls(true);// 使页面适应用户屏幕webView.getSettings().setUseWideViewPort(true); webView.getSettings().setLoadWithOverviewMode(true);mWebView.setWebViewClient(new WebViewClient() {    @Override    public void onReceivedError(WebView view, int errorCode,String description, String failingUrl) {Toast.makeText(getActivity(), "Oh no! " + description, Toast.LENGTH_SHORT).show();super.onReceivedError(view, errorCode, description, failingUrl);    }    @Override    public void onScaleChanged(WebView view, float oldScale,   float newScale) {        // 记录当前页面未缩放时的currentScale        if (times == FIRST_TIME) {    orginalScale = oldScale;    currentScale = newScale;    times = SECOND_TIME;        }        // 有手机版的网页启动时都会两次scale变化,这个currentScale是手机网页未缩放时的scale,原理不太明白        else if (times == SECOND_TIME && newScale == orginalScale) {    currentScale = newScale;    times = SERVERAL_TIME;        }                // 已经缩放了网页        else {    times = SERVERAL_TIME;        }        // 如果当前缩放规模不等于未缩放时的规模,则不允许滑动切换网页        if (currentScale != newScale) {                    canSlip = false;        }        // 如果当前缩放规模等于未缩放时的规模,则允许滑动切换网页        else {                    canSlip = true;        }        super.onScaleChanged(view, oldScale, newScale);                                                                                                      }       });    }    public boolean onTouchEvent(MotionEvent event) {  if (canSlip) {    gestureDetector.onTouchEvent(event);    }    return super.onTouchEvent(event);    }  }
要获取WebView的缩放规模,本来可以使用getScale函数,但现在官方已经不推荐使用,推荐使用WebViewClient里面的onScaleChanged回调函数,所以缩放规模的判断放到此函数中。

0 0