一、WebView的简单使用
1,xml中引入继承自WebView的自定义控件,manifest中配置INTERNET权限
2,调用WebView的loadUrl()方法加载资源,以网页播放优酷视频举例,详细代码如下:
public class MainActivity extends AppCompatActivity {
private WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
webView=findViewById(R.id.webView);
WebSettings setting = webView.getSettings();
setSettings(setting);
webView.setWebChromeClient(new WebChromeClient());
webView.setWebViewClient(new WebViewClient());
//方式1. 加载一个网页:
webView.loadUrl("http://www.youku.com/");
//
// //方式2:加载apk包中的html页面
// webView.loadUrl("file:///android_asset/test.html");
//
// //方式3:加载手机本地的html页面
// webView.loadUrl("content://com.android.htmlfileprovider/sdcard/test.html");
//
// // 方式4: 加载 HTML 页面的一小段内容
// WebView.loadData(String data, String mimeType, String encoding)
// 参数说明:
// 参数1:需要截取展示的内容
// 内容里不能出现 ’#’, ‘%’, ‘\’ , ‘?’ 这四个字符,若出现了需用 %23, %25, %27, %3f 对应来替代,否则会出现异常
// 参数2:展示内容的类型
// 参数3:字节码
}
@SuppressLint("NewApi")
private void setSettings(WebSettings setting) {
setting.setJavaScriptEnabled(true);
setting.setBuiltInZoomControls(true);
setting.setDisplayZoomControls(false);
setting.setSupportZoom(true);
setting.setDomStorageEnabled(true);
setting.setDatabaseEnabled(true);
// 全屏显示
setting.setLoadWithOverviewMode(true);
setting.setUseWideViewPort(true);
//设置自适应屏幕,两者合用
setting.setUseWideViewPort(true); //将图片调整到适合webview的大小
setting.setLoadWithOverviewMode(true); // 缩放至屏幕的大小
//缩放操作
setting.setSupportZoom(true); //支持缩放,默认为true。是下面那个的前提。
setting.setBuiltInZoomControls(true); //设置内置的缩放控件。若为false,则该WebView不可缩放
setting.setDisplayZoomControls(false); //隐藏原生的缩放控件
//其他细节操作
setting.setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK); //关闭webview中缓存
setting.setAllowFileAccess(true); //设置可以访问文件
setting.setJavaScriptCanOpenWindowsAutomatically(true); //支持通过JS打开新窗口
setting.setLoadsImagesAutomatically(true); //支持自动加载图片
setting.setDefaultTextEncodingName("utf-8");//设置编码格式
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if ((keyCode == KEYCODE_BACK) && webView.canGoBack()) {
webView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}
}
二、WebView提供的常见方法
2.1,WebView的状态
//激活WebView为活跃状态,能正常执行网页的响应
webView.onResume() ;
//当页面被失去焦点被切换到后台不可见状态,需要执行onPause
//通过onPause动作通知内核暂停所有的动作,比如DOM的解析、plugin的执行、JavaScript执行。
webView.onPause();
//当应用程序(存在webview)被切换到后台时,这个方法不仅仅针对当前的webview而是全局的全应用程序的webview
//它会暂停所有webview的layout,parsing,javascripttimer。降低CPU功耗。
webView.pauseTimers()
//恢复pauseTimers状态
webView.resumeTimers();
//销毁Webview
//在关闭了Activity时,如果Webview的音乐或视频,还在播放。就必须销毁Webview
//但是注意:webview调用destory时,webview仍绑定在Activity上
//这是由于自定义webview构建时传入了该Activity的context对象
//因此需要先从父容器中移除webview,然后再销毁webview:
rootLayout.removeView(webView);
webView.destroy();
2.2,前进后退网页
//是否可以后退
Webview.canGoBack()
//后退网页
Webview.goBack()
//是否可以前进
Webview.canGoForward()
//前进网页
Webview.goForward()
//以当前的index为起始点前进或者后退到历史记录中指定的steps
//如果steps为负数则为后退,正数则为前进
Webview.goBackOrForward(intsteps)
三、WebView加载String字符串
webview.loadDataWithBaseURL(null,bean.getContent(),"text/html","utf-8",null);
四、WebView使用post请求
mPageBinding.webView.postUrl(url, EncodingUtils.getBytes(postParams, "BASE64"));