Android WebView組件用法詳解
本文實例講述了Android WebView組件用法。分享給大家供大家參考,具體如下:
如果想WebView能夠訪問網(wǎng)絡(luò),必須在AndroidManifest.xml里面添加權(quán)限
<uses-permission android:name="android.permission.INTERNET" />
main.xml很簡單,就是一個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/");
}
}
運行一下就會看到URL被正確load出來了。
但是有個問題,當(dāng)點擊鏈接繼續(xù)瀏覽,則會彈出系統(tǒng)默認的Browser,為了能夠繼續(xù)在WebView中瀏覽,要用到shouldOverrideUrlLoading方法:
@Override
public void onCreate(Bundle savedInstanceState) {
。。。。。。。。。。。。。。。。。。。。。。。。
// 雖然Google主頁在WebView中顯示了,但是如果點擊鏈接繼續(xù)瀏覽,則會顯示到系統(tǒng)默認的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;
}
}
另外,如果想按回退鍵回到上一個頁面,那么
/**
* 按back鍵可以回到上個網(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 可以單獨獲取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)頁時所要執(zhí)行的一些方法
mWebView.setWebViewClient(new WebViewClient() {
// 新開頁面時用自己定義的webview來顯示,不用系統(tǒng)自帶的瀏覽器來顯示
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
// 開始加載網(wǎng)頁時要做的工作
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
}
// 加載完成時要做的工作
@Override
public void onPageFinished(WebView view, String url) {
super.onPageFinished(view, url);
}
// 加載錯誤時要做的工作
@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)建一個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)頁加載的進度條
@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ā)入門與進階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結(jié)》、《Android視圖View技巧總結(jié)》、《Android布局layout技巧總結(jié)》及《Android控件用法總結(jié)》
希望本文所述對大家Android程序設(shè)計有所幫助。
相關(guān)文章
Android點亮屏幕或屏幕解鎖和鎖定以及其他相關(guān)權(quán)限實現(xiàn)代碼
本文將帶你實現(xiàn)Android屏幕解鎖和鎖定;Android屏幕常亮/點亮以及其他相關(guān)權(quán)限,感興趣的朋友可以參考下,希望本文對你有所幫助2013-01-01
Flutter啟動頁(閃屏頁)的具體實現(xiàn)及原理詳析
這篇文章主要給大家介紹了關(guān)于Flutter啟動頁(閃屏頁)的具體實現(xiàn)及原理的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用Flutter具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Android自定義scrollView實現(xiàn)頂部圖片下拉放大
這篇文章主要為大家詳細介紹了Android自定義scrollView實現(xiàn)頂部圖片下拉放大,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
Android的webview支持HTML5的離線應(yīng)用功能詳細配置
HTML5的離線應(yīng)用功能可以使得WebApp即使在網(wǎng)絡(luò)斷開的情況下仍能正常使用這是個非常有用的功能,但如何使Webivew支持HTML5離線應(yīng)用功能呢,需要的朋友可以參考下2012-12-12
Android布局技巧之創(chuàng)建可重用的UI組件
這篇文章主要為大家詳細介紹了Android布局技巧之創(chuàng)建可重用的UI組件,文中提到了include標(biāo)簽的使用方法,感興趣的小伙伴們可以參考一下2016-05-05
Android開發(fā)之ListView的簡單用法及定制ListView界面操作示例
這篇文章主要介紹了Android開發(fā)之ListView的簡單用法及定制ListView界面操作,結(jié)合實例形式分析了Android ListView界面布局相關(guān)操作技巧,需要的朋友可以參考下2019-04-04

