Android WebView 的使用
程序员文章站
2024-03-24 15:44:16
...
WebView
是 Android
中一个非常实用的组件, 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);
}
上一篇: GestureDetector使用详解