WebView控件基本使用2_第1頁
WebView控件基本使用2_第2頁
WebView控件基本使用2_第3頁
WebView控件基本使用2_第4頁
WebView控件基本使用2_第5頁
已閱讀5頁,還剩1頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)

文檔簡介

/WebView控件基本使用這一期創(chuàng)新,我們來談?wù)劄g覽器控件即WebView。先說什么是webView控件吧。WebView是一個瀏覽器控件,通過這個控件可以直接訪問網(wǎng)頁,或者把輸入的HTML字符串顯示出來,功能比較強大,有以下幾個優(yōu)點:1、功能強大,支持CSS,Javascript等HTML語言,這樣頁面就能更漂亮。2、能夠?qū)g覽器控件進行非常詳細(xì)的設(shè)置,比如字體大小,背景色,滾動條樣式等等。3、能夠捕捉到所有瀏覽器操作,比如點擊URL,打開或關(guān)閉URL4、能夠很好的融入布局。5、甚至webView還能和JS進行交互。在使用webView時,我們要先取得一個webView實例,如下:WebViewbrowser=(WebView)findViewById(R.id.webkit);取得實例后,我們要給browser定義一下WebSettings,WebSettings是WebView的具體設(shè)置類,可以對WebView進行非常詳細(xì)的設(shè)置。WebSettingsbs=browser.getSettings(); 取得了webView設(shè)置對象。下面開始設(shè)置瀏覽器控件,幾個最常用的設(shè)置如下:1、bs.setSupportMultipleWindows(false);瀏覽器不支持多窗口顯示,意思就是說所有頁面在單一窗口打開,這樣避免了頁面布局控制顯示問題,也便于操作控制頁面。2、bs.setSupportZoom(false); 頁面是否可以進行縮放。3、bs.setBlockNetworkImage(false);是否阻止圖像的顯示4、bs.setCacheMode();設(shè)置緩存的模式,分為幾種:LOAD_CACHE_ELSE_NETWORK當(dāng)本地沒有緩存時,從網(wǎng)上下載LOAD_CACHE_ONLY只讀取本地緩存LOAD_DEFAULT默認(rèn)的緩存模式LOAD_NORMAL一般的緩存模式LOAD_NO_CACHE不讀取緩存,所有內(nèi)容均從網(wǎng)絡(luò)下載。5、bs.setJavaScriptEnabled(flag);是否支持JS。其他比如設(shè)置字體等更不必詳說,通過設(shè)置我們可以獲得一個我們需要的瀏覽器窗口。接著,我們還需一個類來繼承WebViewClient,這個類用來監(jiān)控瀏覽器的一系列事件。webNotifywn=newwebNotify();browser.setWebViewClient(wn);下面列舉比較常用的4個事件:1,接收到Http請求的事件onReceivedHttpAuthRequest(WebViewview,HttpAuthHandlerhandler,Stringhost,Stringrealm)2,打開鏈接前的事件publicbooleanshouldOverrideUrlLoading(WebViewview,Stringurl){view.loadUrl(url);returntrue;}在這個函數(shù)我們可以做很多操作,比如我們讀取到某些特殊的URL,于是就可以不打開地址,取消這個操作,進行預(yù)先定義的其他操作,這對一個程序是非常必要的。3,載入頁面完成的事件publicvoidonPageFinished(WebViewview,Stringurl){}同樣道理,我們知道一個頁面載入完成,于是我們可以關(guān)閉loading條,切換程序動作。4,載入頁面開始的事件publicvoidonPageStarted(WebViewview,Stringurl,Bitmapfavicon){}這個事件就是開始載入頁面調(diào)用的,通常我們可以在這設(shè)定一個loading的頁面,告訴用戶程序在等待網(wǎng)絡(luò)響應(yīng)。通過這幾個事件,我們可以很輕松的控制程序操作,一邊用著瀏覽器顯示內(nèi)容,一邊監(jiān)控著用戶操作實現(xiàn)我們需要的各種顯示方式,同時可以防止用戶產(chǎn)生誤操作。最后我們的瀏覽器設(shè)置好了,可以監(jiān)控操作了,于是打開一個網(wǎng)址:browser.loadUrl("");當(dāng)然也可以是自己設(shè)定的一段html字符串,當(dāng)然你的URL要符合規(guī)范。browser.loadDataWithBaseURL()如何和JS進行交互到這里基本的webView的基本使用介紹完畢,接下來我們來討論一下webView如何與JS進行交互,這個功能非常強大,能夠做出很多意想不到的事情。首先我們在頁面里有這么一段JS代碼:<html><scriptlanguage="javascript"> functionwave(){document.getElementById("droid").src="android_waving.png"; }</script><body> <a><imgid="droid"src="android_normal.png"/><br>Clickme!</a></body></html>functionwave()就是我們要調(diào)用的函數(shù),首先要讓browser能與頁面進行交互bs.setJavaScriptEnabled(true);(讓瀏覽器支持JS)接著:browser.addJavascriptInterface(newObject(){publicvoidclickOnAndroid(){mHandler.post(newRunnable(){publicvoidrun(){mWebView.loadUrl("javascript:wave()");}});}},"index");這里的重點就是addJavascriptInterface(Objectobj,StringinterfaceName)方法,該方法將一個java對象綁定到一個javascript對象中,javascript對象名就是interfaceName,作用域是Global。這樣初始化webvi

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論