网上关于HTML5规范定稿的一篇看法文章:javascript
http://www.csdn.net/article/2014-11-06/2822513-how-html5-changescss
本篇主要基于这段时间对WebView的使用经验和网上学习到的对WebView开发作一个要点小结:html
1、WebView基于webkit引擎展示web页面的控件,使用前需要在Android Manifest file中配置internet訪问权限,不然提示页面没法訪问。html5
<manifest ... > <uses-permission android:name="android.permission.INTERNET" /> ... </manifest>
WebSettings webSettings = mWebView.getSettings(); webSettings.setJavaScriptEnabled(true); webSettings.setCacheMode(WebSettings.LOAD_DEFAULT); webSettings.setDomStorageEnabled(true); webSettings.setDatabaseEnabled(true); webSettings.setAppCacheEnabled(true); webSettings.setAllowFileAccess(true); webSettings.setSavePassword(true); webSettings.setSupportZoom(true); webSettings.setBuiltInZoomControls(true); /** * 用WebView显示图片,可以使用这个參数 设置网页布局类型: * 一、LayoutAlgorithm.NARROW_COLUMNS :适应内容大小 * 二、LayoutAlgorithm.SINGLE_COLUMN : 适应屏幕,内容将本身主动缩放 */ webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS); webSettings.setUseWideViewPort(true); mWebView.setScrollBarStyle(WebView.SCROLLBARS_OUTSIDE_OVERLAY); mWebView.setHorizontalScrollbarOverlay(true); mWebView.setHorizontalScrollBarEnabled(true); mWebView.requestFocus();二、设置WebChromeClient子类
mWebView.setWebChromeClient(new MyWebChromeClient());三、设置WebViewClient子类
mWebView.setWebViewClient(new MyWebViewClient());四、设置addJavascriptInterface方法
3、设置当前网页的连接仍在WebView中跳转,而不是跳到手机浏览器里显示,
在WebViewClient的子类中重写shouldOverrideUrlLoading函数 代码例如如下:java
webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } });shouldOverrideUrlLoading表示当前webView中的一个新url需要载入时,给当前应用程序一个处理机会,假设没有重写此函数,webView请求ActivityManage选择合适的方式处理请求,就像弹出uc和互联网让用户选择浏览器同样。重写后return true表示让当前程序处理,return false表示让当前webView处理
webView.setWebViewClient(new WebViewClient() { @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon); // 開始载入网页时处理 如:显示"载入提示" 的载入对话框 DialogManager.showLoadingDialog(this); } @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); // 网页载入完毕时处理 如:让 载入对话框 消失 DialogManager.dismissLoadingDialog(); } @Override public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { super.onReceivedError(view, errorCode, description, failingUrl); // 载入网页失败时处理 如: view.loadDataWithBaseURL(null, "<span style=\"color:#FF0000\">网页载入失败</span>", "text/html", "utf-8", null); } });5、处理https请求,为WebView处理ssl证书设置
webView.setWebViewClient(new WebViewClient() { @Override public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) { handler.proceed(); // 接受信任所有站点的证书 // handler.cancel(); // 默认操做 不处理 // handler.handleMessage(null); // 可作其它处理 } });
webView.setWebChromeClient(new WebChromeClient() { public void onProgressChanged(WebView view, int progress) { setTitle("页面载入中,请稍候..." + progress + "%"); setProgress(progress * 100); if (progress == 100) { setTitle(R.string.app_name); } } });onProgressChanged通知应用程序当前页面载入的进度
public boolean onKeyDown(int keyCode, KeyEvent event) { if (webView.canGoBack() && event.getKeyCode() == KeyEvent.KEYCODE_BACK && event.getRepeatCount() == 0) { webView.goBack(); return true; } return super.onKeyDown(keyCode, event); }当中webView.canGoBack()在webView含有一个可后退的浏览记录时返回true
8、使用addJavascriptInterface完毕和js交互
一、Js中调Native本地Java方法
设置webView的addJavascriptInterface方法,该方法有两个參数,第一个參数为被绑定到js中的类实例,第二个參数为在js中暴露的类别名,在js中引用java对象就是用这个名字
在Native Java代码例如如下:
android
mWebView.getSettings().setJavaScriptEnabled(true); mWebView.addJavascriptInterface(new JavaScriptInterface(this), "Android"); class JavaScriptInterface{ Context mContext; /** Instantiate the interface and set the context */ JavaScriptInterface(Context c) { mContext = c; } /** Show a toast from the web page * 由Js调用运行Native本地Java方法 */ @JavascriptInterface public void showToast(String toast) { Log.d("TAG", "Js Invoker Native Function"); Toast.makeText(mContext, toast, Toast.LENGTH_SHORT).show(); } }在HTML中Js调用Native方法 代码例如如下:
<input type="button" value="Say hello" onClick="showAndroidToast('Hello Android!')" /> <script type="text/javascript"> function showAndroidToast(toast) { Android.showToast(toast); } </script>二、Java调Js方法
<script type="text/javascript"> function showAlert() { alert("Be executed by Native"); } </script>在Native调Js方法例如如下:
mWebView.loadUrl("javascript:showAlert()");
WebSettings webSettings = mWebView.getSettings(); webSettings.setCacheMode(WebSettings.LOAD_DEFAULT); //设置 缓存模式 // 开启 DOM storage API 功能 webSettings.setDomStorageEnabled(true); //开启 database storage API 功能 webSettings.setDatabaseEnabled(true);
String cacheDirPath = getCacheDir().getAbsolutePath()+ "/webViewCache "; WebSettings webSettings = mWebView.getSettings(); //开启 database storage API 功能 webSettings.setDatabaseEnabled(true); //设置数据库缓存路径 webSettings.setDatabasePath(cacheDirPath); //开启Application H5 Caches 功能 webSettings.setAppCacheEnabled(true); //设置Application Caches 缓存文件夹 webSettings.setAppCachePath(cacheDirPath);
public void int () { if(Build.VERSION.SDK_INT >= 19) { webView.getSettings().setLoadsImagesAutomatically(true); } else { webView.getSettings().setLoadsImagesAutomatically(false); } }同一时候在WebView的WebViewClient子类中重写onPageFinished()方法加入例如如下代码:
@Override public void onPageFinished(WebView view, String url) { if(!webView.getSettings().getLoadsImagesAutomatically()) { webView.getSettings().setLoadsImagesAutomatically(true); } }从上面的代码,可以看出咱们对系统API在19以上的版本号做了兼容。因为4.4以上系统在onPageFinished时再恢复图片载入时,假设存在多张图片引用的是一样的src时,会仅仅有一个image标签获得载入,于是对于这种系统咱们就先直接载入。
11、WebView硬件加速致使页面渲染闪烁问题解决方法
关于Android硬件加速 開始于Android 3.0 (API level 11),在四个级别上开启/关闭硬件加速
一、Application级别:为整个应用程序开启硬件加速,在AndroidManifest中增长例如如下配置web
<application android:hardwareAccelerated="true" ...>二、Activity级别:控制每个activity是否开启硬件加速,仅仅需在activity元素中加入android:hardwareAccelerated属性就能够
<activity android:hardwareAccelerated="true" ...>三、Window级别:注:眼下还不支持在Window级别上关闭硬件加速
getWindow().setFlags( WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED, WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED);四、View级别:执行时单个view硬件加速,眼下Android还不支持在View级别开启硬件加速 代码例如如下:
mView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
[//TODO 关于Android硬件加速 小吕有时间会更具体的单独整理成一篇来作介绍
先提供学习地址:http://android.toolib.net/guide/topics/graphics/hardware-accel.html]
咱们开启硬件加速后,WebView渲染页面更加高速,拖动也更加顺滑。但有个反作用就是easy会出现页面载入白块同一时候界面闪烁现象。解决问题的方法是设置WebView临时关闭硬件加速 代码例如如下:
数据库
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) { webview.setLayerType(View.LAYER_TYPE_SOFTWARE, null); }
12、WebView载入本地HTML文件乱码问题解决方式
分析1、保证html页面有设置编码格式 如: api
<meta http-equiv="content-type" content="text/html;charset=utf-8"/>
分析2、为WebView 指定显示的编码,WebView设置编码是在Settings中来设置,如: 浏览器
mWebView.getSettings().setDefaultTextEncodingName("utf-8");分析3、假设你是使用的loadData()来载入显示网页。中文出现乱码 则改成loadDataWithBaseURL
//webview.loadData(data, "text/html", "utf-8"); webview.loadDataWithBaseURL(baseUrl, data, "text/html", "utf-8", failUrl);
十3、其它注意事项:
1> 从网络上下载html页面的过程应放在工做线程(后台线程)中 2> html下载成功后渲染出html的步骤应放在UI主线程,否则WebView载入网页过程会easy报错