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),請進行舉報或認領(lǐng)

文檔簡介

/WebView控件基本使用這一期創(chuàng)新,我們來談?wù)劄g覽器控件即WebView。先說什么是webView控件吧。WebView是一個瀏覽器控件,通過這個控件可以直接訪問網(wǎng)頁,或者把輸入的HTML字符串顯示出來,功能比較強大,有以下幾個優(yōu)點:1、功能強大,支持CSS,Javascript等HTML語言,這樣頁面就能更漂亮。2、能夠?qū)g覽器控件進行非常詳細的設(shè)置,比如字體大小,背景色,滾動條樣式等等。3、能夠捕捉到所有瀏覽器操作,比如點擊URL,打開或關(guān)閉URL4、能夠很好的融入布局。5、甚至webView還能和JS進行交互。在使用webView時,我們要先取得一個webView實例,如下:WebViewbrowser=(WebView)findViewById(R.id.webkit);取得實例后,我們要給browser定義一下WebSettings,WebSettings是WebView的具體設(shè)置類,可以對WebView進行非常詳細的設(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當本地沒有緩存時,從網(wǎng)上下載LOAD_CACHE_ONLY只讀取本地緩存LOAD_DEFAULT默認的緩存模式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("");當然也可以是自己設(shè)定的一段html字符串,當然你的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)容負責。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論