Android WebView 的使用

WebViewAndroid 中一个非常实用的组件, WebView 可以使得网页轻松的内嵌到 App 里,还可以直接跟 js 相互调用。

1. 添加网络权限

<uses-permission android:name="android.permission.INTERNET" />

2. WebSettings 对访问页面进行设置。

WebView mWebView = new WebView(this);
 
WebSettings webSettings = mWebView .getSettings();//支持获取手势焦点,输入用户名、密码或其他
 
mWebView.requestFocusFromTouch();
 
webSettings.setJavaScriptEnabled(true);  //支持js
 
webSettings.setUseWideViewPort(true);  //将图片调整到适合webview的大小 
 
webSettings.setLoadWithOverviewMode(true); // 缩放至屏幕的大小
 
webSettings.setSupportZoom(true);  //支持缩放,默认为true。是下面那个的前提。
 
webSettings.setBuiltInZoomControls(true); //设置内置的缩放控件。
 
webSettings.setDisplayZoomControls(false); //隐藏原生的缩放控件
 
webSettings.setLayoutAlgorithm(LayoutAlgorithm.SINGLE_COLUMN); //支持内容重新布局  
 
webSettings.supportMultipleWindows();  //多窗口 
 
webSettings.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);  //关闭webview中缓存 
 
webSettings.setAllowFileAccess(true);  //设置可以访问文件 
 
webSettings.setNeedInitialFocus(true); //当webview调用requestFocus时为webview设置节点
 
webSettings.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口 
 
webSettings.setLoadsImagesAutomatically(true);  //支持自动加载图片
 
webSettings.setDefaultTextEncodingName("utf-8");//设置编码格式

3. 页面加载方式

//加载一个网页:
mWebView.loadUrl();
 
//加载apk包中的一个html页面
mWebView.loadUrl();
 
//加载手机本地的一个html页面的方法:
mWebView.loadUrl("content://com.android.htmlfileprovider/sdcard/test.html");

4. WebViewClient

WebViewClient 就是帮助 WebView 处理各种通知、请求事件的

//打开网页时不调用系统浏览器, 而是在本WebView中显示:
mWebView.setWebViewClient(new WebViewClient(){     
  
 @Override
    public boolean shouldOverrideUrlLoading(WebView view, String url) {
        view.loadUrl(url);  
        return true;
    }
});
//将上面定义的webviewclinet设置给webview 
mWebView.setWebViewClient(webViewClient);

下面介绍 WebViewClient 的一些事件:

WebViewClient mWebViewClient = new WebViewClient()  
{  
    shouldOverrideUrlLoading(WebView view, String url); 
    //在网页上的所有加载都经过这个方法,这个函数我们可以做很多操作。
    //比如获取url,查看url.contains(“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事件未被加载时调用) 
}

5. WebChromeClient

辅助 WebView 处理 Javascript 的对话框,网站图标,网站title,加载进度等

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) {
        //
        return true;
    }
};
 
//同样,将上面定义的WebChromeClient设置给WebView:
webView.setWebChromeClient(mWebChromeClient);

6. 调用 JS 代码

待定

7. WebView 返回键

public boolean onKeyDown(int keyCode, KeyEvent event) {
    if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {       
 
        mWebView.goBack();       
        return true; 
    } 
    return super.onKeyDown(keyCode, event);
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值