android webview设置以及与h5交互

1、设置内部打开浏览器,而不是外部浏览器打开连接,那么必须要重写WebViewClient类里面的shouldOverrideUrlLoading方法:

       mWebview.setWebViewClient(new WebViewClient(){           

            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }

        });

2、设置网页进度条progress,在布局添加控件progress,重写onProgressChanged方法:

      private class MyWebChromeClient extends WebChromeClient {  
          @Override  
          public void onProgressChanged(WebView view, int newProgress) {            

                    if (newProgress == 100) {
                      progress.setVisibility(View.GONE);
                    } else {
                        if (progress.getVisibility() == View.GONE)
                            progress.setVisibility(View.VISIBLE);
                        progress.setProgress(newProgress);
                    }
              super.onProgressChanged(view, newProgress);  
          }  
       } 

     mWebview.setWebChromeClient(new MyWebChromeClient ());
3、按返回键时, 不退出程序而是返回上一浏览页面:

       public boolean onKeyDown(int keyCode, KeyEvent event) {       
                  if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {       
                     mWebView.goBack();       
                     return true;       
                  }       
                 return super.onKeyDown(keyCode, event);       
    }

4、JS和WebView交互:

    首先设置WebView支持JS脚本,设置如下:

     WebSettings settings = mWebView.getSettings();
     settings.setJavaScriptEnabled(true);
     settings.setJavaScriptCanOpenWindowsAutomatically(true);

     其次设置本地调用对象及其接口  
      mWebView.addJavascriptInterface(new JavaScriptObject(mContext), "myObj"); 

     单独写一个类,封装JS要调用的本地方法,由于版本问题需要加注解。在本地方法

     里面如果需要更新android页面需要跑在UI线   程里面例如加一个runOnUiThread,否则会报错
     public class JavaScriptObject {
         Context mContxt;
         @JavascriptInterface //sdk17版本以上加上注解
         public JavaScriptObject(Context mContxt) {
             this.mContxt = mContxt;
         }
         public void funFromAndroid(String name) {
            Toast.makeText(mContxt, name, Toast.LENGTH_LONG).show();
         }
     }

     在JS里面如下写法即可

     myObj.funFromAndroid("调用android本地方法funFromAndroid");

     那么在android里如何调用JS方法呢,方法如下,如果JS里面有方法叫funFromjs(),那么做法如下即可:

      mWebView.loadUrl("javascript:funFromjs()");

      这也可以来做H5局部刷新。

5、打开页面时, 自适应屏幕:
     WebSettings webSettings =   mWebView .getSettings();       
     webSettings.setUseWideViewPort(true);//设置此属性,可任意比例缩放
     webSettings.setLoadWithOverviewMode(true);
6、使页面支持缩放:
     WebSettings webSettings =   mWebView .getSettings();       
     webSettings.setJavaScriptEnabled(true);  
     webSettings.setBuiltInZoomControls(true);
     webSettings.setSupportZoom(true);
7、如果webView中需要用户手动输入用户名、密码或其他,则webview必须设置支持获取手势焦点。
     webview.requestFocusFromTouch();

8、WebView 加载界面主要调用三个方法:LoadUrl、LoadData、LoadDataWithBaseURL.
      LoadUrl            直接加载网页、图片并显示.(本地或是网络上的网页、图片、gif) 

     LoadData           显示文字与图片内容 (模拟器1.5、1.6) 

     LoadDataWithBase  显示文字与图片内容(支持多个模拟器版本)

9、webview打开下载链接的时候
      mWebView.setDownloadListener(new DownloadListener() {
            @Override
            public void onDownloadStart(String url, String userAgent, String contentDisposition, String mimetype, long contentLength) {
                Uri uri = Uri.parse(url);
                Intent intent = new Intent(Intent.ACTION_VIEW, uri);
                startActivity(intent);
            }
        });

10、WebSettings 的常用方法介绍
    setJavaScriptEnabled(true);  //支持js
    setPluginsEnabled(true);  //支持插件
    setUseWideViewPort(false);  //将图片调整到适合webview的大小
    setSupportZoom(true);  //支持缩放
    setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局  
    supportMultipleWindows();  //多窗口
    setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);  //关闭webview中缓存
    setAllowFileAccess(true);  //设置可以访问文件
    setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点
    webview webSettings.setBuiltInZoomControls(true); //设置支持缩放
    setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口
    setLoadWithOverviewMode(true); // 缩放至屏幕的大小
    setLoadsImagesAutomatically(true);  //支持自动加载图片






  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值