Android WebView組件用法詳解
本文實(shí)例講述了Android WebView組件用法。分享給大家供大家參考,具體如下:
如果想WebView能夠訪問網(wǎng)絡(luò),必須在AndroidManifest.xml里面添加權(quán)限
<uses-permission android:name="android.permission.INTERNET" />
main.xml很簡單,就是一個(gè)WebView
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <WebView android:id="@+id/webView" android:layout_width="fill_parent" android:layout_height="fill_parent" /> </LinearLayout>
WebViewDemoActivity.java代碼:
package com.tianjf; import android.app.Activity; import android.os.Bundle; import android.webkit.WebView; public class WebViewDemoActivity extends Activity { private WebView mWebView; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); mWebView = (WebView) findViewById(R.id.webView); // 得到WebSettings對象,設(shè)置支持JavaScript參數(shù) // 如果訪問的頁面中有JavaScript,則WebView必須設(shè)置支持JavaScript ,否則顯示空白頁面 mWebView.getSettings().setJavaScriptEnabled(true); // 加載URL mWebView.loadUrl("http://www.baidu.com/"); } }
運(yùn)行一下就會看到URL被正確load出來了。
但是有個(gè)問題,當(dāng)點(diǎn)擊鏈接繼續(xù)瀏覽,則會彈出系統(tǒng)默認(rèn)的Browser,為了能夠繼續(xù)在WebView中瀏覽,要用到shouldOverrideUrlLoading方法:
@Override public void onCreate(Bundle savedInstanceState) { 。。。。。。。。。。。。。。。。。。。。。。。。 // 雖然Google主頁在WebView中顯示了,但是如果點(diǎn)擊鏈接繼續(xù)瀏覽,則會顯示到系統(tǒng)默認(rèn)的Browser中 // 為了繼續(xù)在WebView中顯示,需要重寫shouldOverrideUrlLoading方法 mWebView.setWebViewClient(new MyWebViewClient()); 。。。。。。。。。。。。。。。。。。。。。。。。 } private class MyWebViewClient extends WebViewClient { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } }
另外,如果想按回退鍵回到上一個(gè)頁面,那么
/** * 按back鍵可以回到上個(gè)網(wǎng)頁 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) { if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) { mWebView.goBack(); return true; } return super.onKeyDown(keyCode, event); }
對于Android 2.0開始又多出了一種新的方法,對于Activity 可以單獨(dú)獲取Back鍵的按下事件,直接重寫onBackPressed 方法即可,代碼如下
@Override public void onBackPressed() { // 這里處理邏輯代碼,該方法僅適用于2.0或更高版本的sdk return ; }
如果想加載工程中的HTML,那么可以用到下面的方法(前提是HTML放在assets目錄中)
mWebView.loadUrl("file:///android_asset/test.html");
如果想直接load一段HTML文,可以用下面的方法
mWebView.loadData("<html><body>abcdefg</body></html>", "text/html", "utf-8");
下面是WebView其他的一下用法:
設(shè)置允許訪問文件數(shù)據(jù)
mWebView.getSettings().setAllowFileAccess(true);
設(shè)置支持縮放
mWebView.getSettings().setBuiltInZoomControls(true);
設(shè)置是否保存密碼
mWebView.getSettings().setSavePassword(false);
設(shè)置支持各種不同的設(shè)備
加載webview網(wǎng)頁時(shí)所要執(zhí)行的一些方法
mWebView.setWebViewClient(new WebViewClient() { // 新開頁面時(shí)用自己定義的webview來顯示,不用系統(tǒng)自帶的瀏覽器來顯示 @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { view.loadUrl(url); return true; } // 開始加載網(wǎng)頁時(shí)要做的工作 @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon); } // 加載完成時(shí)要做的工作 @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); } // 加載錯誤時(shí)要做的工作 @Override public void onReceivedError(WebView view, int errorCode, String description, String failingUrl) { super.onReceivedError(view, errorCode, description, failingUrl); } });
處理網(wǎng)頁中的一些對話框信息(提示對話框,帶選擇的對話框,帶輸入的對話框)
mWebView.setWebChromeClient(new WebChromeClient() { // 提示對話框 @Override public boolean onJsAlert(WebView view, String url, String message, final JsResult result) { // 構(gòu)建一個(gè)Builder來顯示網(wǎng)頁中的alert對話框 Builder builder = new Builder(WebViewDemoActivity.this); builder.setTitle("提示對話框"); builder.setMessage(message); builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.confirm(); } }); builder.setCancelable(false); builder.create(); builder.show(); return true; } // 帶按鈕的對話框 @Override public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) { Builder builder = new Builder(WebViewDemoActivity.this); builder.setTitle("帶選擇的對話框"); builder.setMessage(message); builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.confirm(); } }); builder.setNeutralButton(android.R.string.cancel, new AlertDialog.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.cancel(); } }); builder.setCancelable(false); builder.create(); builder.show(); return true; } // 帶輸入框的對話框 @Override public boolean onJsPrompt(WebView view, String url, String message, String defaultValue, final JsPromptResult result) { LayoutInflater inflater = LayoutInflater .from(WebViewDemoActivity.this); final View v = inflater.inflate(R.layout.myDialog, null); // 設(shè)置 TextView對應(yīng)網(wǎng)頁中的提示信息 ((TextView) v.findViewById(R.id.textView)).setText(message); // 設(shè)置EditText對應(yīng)網(wǎng)頁中的輸入框 ((EditText) v.findViewById(R.id.editText)) .setText(defaultValue); Builder builder = new Builder(WebViewDemoActivity.this); builder.setTitle("帶輸入的對話框"); builder.setView(v); builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { String value = ((EditText) v .findViewById(R.id.editText)).getText() .toString(); result.confirm(value); } }); builder.setNegativeButton(android.R.string.cancel, new AlertDialog.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { result.cancel(); } }); builder.setOnCancelListener(new DialogInterface.OnCancelListener() { @Override public void onCancel(DialogInterface dialog) { result.cancel(); } }); builder.create(); builder.show(); return true; } // 設(shè)置網(wǎng)頁加載的進(jìn)度條 @Override public void onProgressChanged(WebView view, int newProgress) { WebViewDemoActivity.this.getWindow().setFeatureInt( Window.FEATURE_PROGRESS, newProgress * 100); super.onProgressChanged(view, newProgress); } // 設(shè)置應(yīng)用程序的標(biāo)題 @Override public void onReceivedTitle(WebView view, String title) { WebViewDemoActivity.this.setTitle(title); super.onReceivedTitle(view, title); } });
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android開發(fā)入門與進(jìn)階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計(jì)有所幫助。
相關(guān)文章
android實(shí)現(xiàn)微信聯(lián)合登錄開發(fā)示例
本篇文章主要介紹了android實(shí)現(xiàn)微信聯(lián)合登錄開發(fā)示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10Android?Jetpack庫剖析之ViewModel組件篇
這篇文章主要介紹了Android?Jetpack架構(gòu)組件?ViewModel詳解,ViewModel類讓數(shù)據(jù)可在發(fā)生屏幕旋轉(zhuǎn)等配置更改后繼續(xù)存在,ViewModel類旨在以注重生命周期的方式存儲和管理界面相關(guān)的數(shù)據(jù)。感興趣可以來學(xué)習(xí)一下2022-07-07android中GridView實(shí)現(xiàn)點(diǎn)擊查看更多功能示例
本篇文章主要介紹了android中GridView實(shí)現(xiàn)點(diǎn)擊查看更多功能示例,非常具有實(shí)用價(jià)值,需要的朋友可以參考下。2017-02-02Android數(shù)字選擇器NumberPicker使用詳解
這篇文章主要為大家詳細(xì)介紹了Android數(shù)字選擇器NumberPicker的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-08-08使用Flutter開發(fā)一個(gè)圖片UI組件的代碼示例
在移動應(yīng)用開發(fā)中,圖片展示是一個(gè)常見的需求,為了滿足不同場景的圖片展示需求,我們可以開發(fā)一個(gè)靈活配置的圖片UI組件,本文將介紹如何使用Flutter開發(fā)一個(gè)圖片UI組件,并提供了豐富的配置選項(xiàng),需要的朋友可以參考下2023-09-09Android中使用ContentProvider管理系統(tǒng)資源的實(shí)例
這篇文章主要介紹了Android中使用ContentProvider管理系統(tǒng)資源的實(shí)例,講解了ContentProvider對系統(tǒng)中聯(lián)系人及多媒體資源的管理例子,需要的朋友可以參考下2016-04-04