史上最全webview详解
史上最全webview详解
本篇最后有一个非常不错 的 Html5Activity 加载类,不想看的可以直接跳下载。
WebSettings
WebSettings webSettings = mWebView .getSettings();
//支持获取手势焦点,输入用户名、密码或其他
questFocusFromTouch();
setJavaScriptEnabled(true);  //支持js
setPluginsEnabled(true);  //支持插件
设置自适应屏幕,两者合用
setUseWideViewPort(true);  //将图片调整到适合webview的大小
setLoadWithOverviewMode(true); // 缩放至屏幕的大小
setSupportZoom(true);  //支持缩放,默认为true。是下面那个的前提。
setBuiltInZoomControls(true); //设置内置的缩放控件。
  若上面是false,则该WebView不可缩放,这个不管设置什么都不能缩放。
setDisplayZoomControls(false); //隐藏原生的缩放控件
setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局 
supportMultipleWindows();  //多窗口
setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);  //关闭webview中缓存
setAllowFileAccess(true);  //设置可以访问文件
setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点
setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口
setLoadsImagesAutomatically(true);  //支持自动加载图片
setDefaultTextEncodingName("utf-8");//设置编码格式
加载方式
加载一个网页:
webView.loadUrl("le/");
加载apk包中的一个html页面
webView.loadUrl("file:///android_asset/test.html");
加载手机本地的一个html页面的方法:
webView.loadUrl("content://com.Android.htmlfileprovider/sdcard/test.html");
WebViewClient
WebViewClient就是帮助WebView处理各种通知、请求事件的。
打开网页时不调用系统浏览器, 而是在本WebView中显示:
mWebView.setWebViewClient(new WebViewClient(){
      @Override
      public boolean shouldOverrideUrlLoading(WebView view, String url) {
          view.loadUrl(url);
      return true;
      }
  });
WebViewClient 方法
WebViewClient mWebViewClient = new WebViewClient() 
    shouldOverrideUrlLoading(WebView view, String url)  最常用的,比如上面的。
    //在网页上的所有加载都经过这个方法,这个函数我们可以做很多操作。
    //比如获取url,查看ains(“add”),进行添加操作
    shouldOverrideKeyEvent(WebView view, KeyEvent event)
    //重写此方法才能够处理在浏览器中的按键事件。
    onPageStarted(WebView view, String url, Bitmap favicon)
    //这个事件就是开始载入页面调用的,我们可以设定一个loading的页面,告诉用户程序在等待网络响应。
    onPageFinished(WebView view, String url)
    //在页面加载结束时调用。同样道理,我们可以关闭loading 条,切换程序动作。
    onLoadResource(WebView view, String url)
    // 在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。
    onReceivedError(WebView view, int errorCode, String description, String failingUrl)
    // (报告错误信息)
    doUpdateVisitedHistory(WebView view, String url, boolean isReload) 
    //(更新历史记录)
    onFormResubmission(WebView view, Message dontResend, Message resend)
    //(应用程序重新请求网页数据)
    onReceivedHttpAuthRequest(WebView view, HttpAuthHandler handler, String host,String realm)
    //(获取返回信息授权请求)
    onReceivedSslError(WebView view, SslErrorHandler handler, SslError error)
    //重写此方法可以让webview处理https请求。
    onScaleChanged(WebView view, float oldScale, float newScale)
恢复历史浏览记录    // (WebView发生改变时调用)
    onUnhandledKeyEvent(WebView view, KeyEvent event)
    //(Key事件未被加载时调用)
}
将上面定义的WebViewClient设置给WebView:
  webView.setWebViewClient(webViewClient);
WebChromeClient
WebChromeClient是辅助WebView处理JavaScript的对话框,网站图标,网站title,加载进度等 :
方法中的代码都是由Android端自己处理。
WebChromeClient mWebChromeClient = new WebChromeClient() {
    //获得网页的加载进度,显示在右上角的TextView控件中
    @Override
    public void onProgressChanged(WebView view, int newProgress) {
        if (newProgress < 100) {
            String progress = newProgress + "%";
        } else {
        }
    }
    //获取Web页中的title用来设置自己界面中的title
    //当加载出错的时候,比如无网络,这时onReceiveTitle中获取的标题为 不到该网页,
    //因此建议当触发onReceiveError时,不要使用获取到的title
    @Override
    public void onReceivedTitle(WebView view, String title) {
        MainActivity.this.setTitle(title);
    }
    @Override
    public void onReceivedIcon(WebView view, Bitmap icon) {
        //
    }
    @Override
    public boolean onCreateWindow(WebView view, boolean isDialog, boolean isUserGesture, Message resultMsg) {
        //
        return true;
    }
    @Override
    public void onCloseWindow(WebView window) {
    }
    //处理alert弹出框,html 弹框的一种方式
    @Override
    public boolean onJsAlert(WebView view, String url, String message, JsResult result) {
        //
        return true;
    }
    //处理confirm弹出框
    @Override
    public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, JsPromptResult
            result) {
        //
        return true;
    }
    //处理prompt弹出框
    @Override
    public boolean onJsConfirm(WebView view, String url, String message, JsResult result) {

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。