android开发第二弹--WebView总结

1. 打开网页时不调用系统浏览器, 而是在本WebView中显示:

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

2. 通过java代码调用javascript

  WebSettings webSettings =   mWebView .getSettings();       
  webSettings.setJavaScriptEnabled(true); 
  mWebView.addJavascriptInterface(new Object() {       
        public void clickOnAndroid() {       
            mHandler.post(new Runnable() {       
                public void run() {       
                    webview.loadUrl("javascript:wave()");       
                }       
            });       
        }       
    }, "demo"); 

3. 按返回键时, 不退出程序而是返回上一浏览页面:

/**
 * 按键响应,在WebView中查看网页时,按返回键的时候按浏览历史退回,如果不做此项处理则整个                  
 * WebView返回退出
 */

`@Override
 public boolean onKeyDown(int keyCode, KeyEvent event) {
    // TODO Auto-generated method stub
    if ((keyCode == KeyEvent.KEYCODE_BACK) && webview.canGoBack()) {
        webview.goBack();

        //向后跳转页面
        //webview.goForward();
        //向后几个网页
        //webview.goBackOrForward(1);
        return true;

    }
    return super.onKeyDown(keyCode, event);
}

4. 打开页面时, 自适应屏幕:

    WebSettings webSettings =   mWebView .getSettings();       
    webSettings.setUseWideViewPort(true);//设置此属性,可任意比例缩放
    webSettings.setLoadWithOverviewMode(true);

5. 页面支持缩放:

    WebSettings webSettings =   mWebView .getSettings();       
    webSettings.setJavaScriptEnabled(true);  
    webSettings.setBuiltInZoomControls(true);
    webSettings.setSupportZoom(true);        
6.如果webView中需要用户手动输入用户名、密码或其他,则webview必须设置支持获取手势焦点。
webview.requestFocusFromTouch();

7.WebView 加载界面主要调用三个方法:LoadUrl、LoadData、LoadDataWithBaseURL.

1、LoadUrl            直接加载网页、图片并显示.(本地或是网络上的网页、图片、gif)  
2、LoadData           显示文字与图片内容 (模拟器1.5、1.6)  
3、LoadDataWithBaseURL  显示APK 中图片和文字混合的Html 内容(支持多个模拟器版本)

     protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        webView=(WebView)findViewById(R.id.webView);

        String body="<img  src=\"http://img03.3dmgame.com/uploads/allimg/141115/271_141115025804_1_lit.jpg'\"/>";

        String html="<html><body>"+body+"</html></body>";
        webView.loadDataWithBaseURL(null, html, "text/html","UTF-8", null);

          String htmlString = "<h1>Title</h1><p>This is HTML text<br /><i>Formatted in italics</i><br />Anothor Line</p>";
// 载入这个html页面
myWebView.loadData(htmlString, "text/html", "utf-8");

8.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);  //支持自动加载图片

9.WebViewClient 的方法全解

    doUpdateVisitedHistory(WebView view, String url, boolean isReload)  //(更新历史记录) 

    onFormResubmission(WebView view, Message dontResend, Message resend) //(应用程序重新请求网页数据) 

    onLoadResource(WebView view, String url) // 在加载页面资源时会调用,每一个资源(比如图片)的加载都会调用一次。 

    onPageStarted(WebView view, String url, Bitmap favicon) //这个事件就是开始载入页面调用的,通常我们可以在这设定一个loading的页面,告诉用户程序在等待网络响应。 

    onPageFinished(WebView view, String url) //在页面加载结束时调用。同样道理,我们知道一个页面载入完成,于是我们可以关闭loading 条,切换程序动作。 

    onReceivedError(WebView view, int errorCode, String description, String failingUrl)// (报告错误信息) 

    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事件未被加载时调用) 

    shouldOverrideKeyEvent(WebView view, KeyEvent event)//重写此方法才能够处理在浏览器中的按键事件。 

    shouldOverrideUrlLoading(WebView view, String url) 
    //在点击请求的是链接是才会调用,重写此方法返回true表明点击网页里面的链接还是在当前的webview里跳转,不跳到浏览器那边。这个函数我们可以做很多操作,比如我们读取到某些特殊的URL,于是就可以不打开地址,取消这个操作,进行预先定义的其他操作,这对一个程序是非常必要的。
    // 强制使用自身的WebView打开网页
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            // TODO Auto-generated method stub
            return true;
            // return super会调用别的浏览器
            // return super.shouldOverrideUrlLoading(view, url);
    }     
10.webview加载网页时显示顶部进度条
     requestWindowFeature(Window.FEATURE_PROGRESS);

     webview.setWebChromeClient(new WebChromeClient() {  
                public void onProgressChanged(WebView view, int progress) {  
                    // Activity和Webview根据加载程度决定进度条的进度大小  
                    // 当加载到100%的时候 进度条自动消失  
                 TestActivity.this.setProgress(progress * 100);  
                }  

                 //拿到一个网页的标题   
                public void onReceivedTitle(WebView view, String title){}


            });  
            webview.loadUrl("http://www.baidu.com");

11加载网页前显示一个进度条

    webview.setWebViewClient(new WebViewClient() {
            /** 
             * 网页加载开始
             */
            @Override
            public void onPageStarted(WebView view, String url, Bitmap favicon) {
                // TODO Auto-generated method stub

                //pb是ProgressBar
                //设置显示
                pb.setVisibility(View.INVISIBLE);

                super.onPageStarted(view, url, favicon);

            }
        /** 
         * 网页加载结束
         */
        @Override
        public void onPageFinished(WebView view, String url) {
            // TODO Auto-generated method stub
            //设置隐藏
            pb.setVisibility(View.GONE);
            super.onPageFinished(view, url);
        }

·

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值