[转]android webview学习
本文轉(zhuǎn)自:http://hi.baidu.com/relayon/blog/item/92b15463677d3e6b0d33fa79.html
在移動互聯(lián)網(wǎng)的爭奪日趨白熱化,各個互聯(lián)網(wǎng)巨頭紛紛推出自己的手機瀏覽器,瀏覽器市場的爭奪從桌面轉(zhuǎn)移到了手機。
在Android手機中內(nèi)置了一款高性能webkit內(nèi)核瀏覽器,在SDK中封裝為一個叫做WebView組件。
什么是webkit
WebKit是Mac OS X v10.3及以上版本所包含的軟件框架(對v10.2.7及以上版本也可通過軟件更新獲取)。同時,WebKit也是Mac OS X的Safari網(wǎng)頁瀏覽器的基礎(chǔ)。WebKit是一個開源項目,主要由KDE的KHTML修改而來并且包含了一些來自蘋果公司的一些組件。
傳統(tǒng)上,WebKit包含一個網(wǎng)頁引擎WebCore和一個腳本引擎JavaScriptCore,它們分別對應(yīng)的是KDE的KHTML和KJS。不過,隨著JavaScript引擎的獨立性越來越強,現(xiàn)在WebKit和WebCore已經(jīng)基本上混用不分(例如Google Chrome和Maxthon 3采用V8引擎,卻仍然宣稱自己是WebKit內(nèi)核)。
這里我們初步體驗一下在android是使用webview瀏覽網(wǎng)頁,在SDK的Dev Guide中有一個WebView的簡單例子 。
在開發(fā)過程中應(yīng)該注意幾點:
1.AndroidManifest.xml中必須使用許可"android.permission.INTERNET",否則會出Web page not available錯誤。
2.如果訪問的頁面中有Javascript,則webview必須設(shè)置支持Javascript。
webview.getSettings().setJavaScriptEnabled(true);?
3.如果頁面中鏈接,如果希望點擊鏈接繼續(xù)在當前browser中響應(yīng),而不是新開Android的系統(tǒng)browser中響應(yīng)該鏈接,必須覆蓋webview的WebViewClient對象。[code]mWebView.setWebViewClient(new WebViewClient(){?
public boolean shouldOverrideUrlLoading(WebView view, String url) {?
view.loadUrl(url);?
return true;?
}?
});[/code]4.如果不做任何處理,瀏覽網(wǎng)頁,點擊系統(tǒng)“Back”鍵,整個Browser會調(diào)用finish()而結(jié)束自身,如果希望瀏覽的網(wǎng)頁回退而不是推出瀏覽器,需要在當前Activity中處理并消費掉該Back事件。[code]public boolean onKeyDown(int keyCode, KeyEvent event) {?
if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {?
mWebView.goBack();?
return true;?
}?
return super.onKeyDown(keyCode, event);?
}? [/code]下一步讓我們來了解一下android中webview是如何支持javascripte自定義對象的,在w3c標準中js有window,history,document等標準對象,同樣我們可以在開發(fā)瀏覽器時自己定義我們的對象調(diào)用手機系統(tǒng)功能來處理,這樣使用js就可以為所欲為了。
看一個實例:[code]public class WebViewDemo extends Activity {?
private WebView mWebView;?
private Handler mHandler = new Handler();?
public void onCreate(Bundle icicle) {?
super.onCreate(icicle);?
setContentView(R.layout.webviewdemo);?
mWebView = (WebView) findViewById(R.id.webview);?
WebSettings webSettings = mWebView.getSettings();?
webSettings.setJavaScriptEnabled(true);?
mWebView.addJavascriptInterface(new Object() {?
public void clickOnAndroid() {?
mHandler.post(new Runnable() {?
public void run() {?
mWebView.loadUrl("javascript:wave()");?
}?
});?
}?
}, "demo");?
mWebView.loadUrl("file:///android_asset/demo.html");?
}?
}? [/code]我們看addJavascriptInterface(Object obj,String interfaceName)這個方法,該方法將一個java對象綁定到一個javascript對象中,javascript對象名就是 interfaceName(demo),作用域是Global。這樣初始化webview后,在webview加載的頁面中就可以直接通過 javascript:window.demo訪問到綁定的java對象了。來看看在html中是怎樣調(diào)用的。[code]<html>?
<script language="javascript">?
function wave() {?
document.getElementById("droid").src="android_waving.png";?
}?
</script>?
<body>?
<a onClick="window.demo.clickOnAndroid()">?
<img id="droid" src="android_normal.png"/><br>?
Click me!?
</a>?
</body>?
</html>?
[/code]這樣在javascript中就可以調(diào)用java對象的clickOnAndroid()方法了,同樣我們可以在此對象中定義很多方法(比如發(fā)短信,調(diào)用聯(lián)系人列表等手機系統(tǒng)功能。),這里wave()方法是java中調(diào)用javascript的例子。
這里還有幾個知識點:
1)為了讓W(xué)ebView從apk文件中加載assets,Android SDK提供了一個schema,前綴為"file:///android_asset/"。WebView遇到這樣的schema,就去當前包中的assets目錄中找內(nèi)容。如上面的"file:///android_asset/demo.html"
2)addJavascriptInterface方法中要綁定的Java對象及方法要運行另外的線程中,不能運行在構(gòu)造他的線程中,這也是使用Handler的目的。
總結(jié)
以上是生活随笔為你收集整理的[转]android webview学习的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 在Hyper-v中创建并安装虚拟机
- 下一篇: CentOS 6.2 本地安装YUM