// 爲了繼續在WebView中顯示,需要重寫shouldOverrideUrlLoading方法
mWebView.setWebViewClient(new MyWebViewClient());
。。。。。。。。。。。。。。。。。。。。。。。。
}
private class MyWebViewClient extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
}
@Override
public void onCreate(Bundle savedInstanceState) {
。。。。。。。。。。。。。。。。。。。。。。。。
// 雖然Google主頁在WebView中顯示了,但是如果點擊鏈接繼續瀏覽,則會顯示到系統默認的Browser中
// 爲了繼續在WebView中顯示,需要重寫shouldOverrideUrlLoading方法
mWebView.setWebViewClient(new MyWebViewClient());
。。。。。。。。。。。。。。。。。。。。。。。。
}
private class MyWebViewClient extends WebViewClient {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
}
另外,如果想按回退鍵回到上一個頁面,那麼
[java] /**
* 按back鍵可以回到上個網頁
*/
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {
mWebView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}
/**
* 按back鍵可以回到上個網頁
*/
@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 方法即可,代碼如下
[java] @Override
public void onBackPressed() {
// 這裏處理邏輯代碼,該方法僅適用於2.0或更高版本的sdk
return ;
}
@Override
public void onBackPressed() {
// 這裏處理邏輯代碼,該方法僅適用於2.0或更高版本的sdk
return ;
}
如果想加載工程中的HTML,那麼可以用到下面的方法(前提是HTML放在assets目錄中)
[java] mWebView.loadUrl("file:///android_asset/test.html");
mWebView.loadUrl("file:///android_asset/test.html");
如果想直接load一段HTML文,可以用下面的方法
[java] mWebView.loadData("<html><body>abcdefg</body></html>", "text/html", "utf-8");
mWebView.loadData("<html><body>abcdefg</body></html>", "text/html", "utf-8");
下面是WebView其他的一下用法:
設置允許訪問文件數據
[java] mWebView.getSettings().setAllowFileAccess(true);
mWebView.getSettings().setAllowFileAccess(true);
設置支持縮放
[java] mWebView.getSettings().setBuiltInZoomControls(true);
mWebView.getSettings().setBuiltInZoomControls(true);
設置是否保存密碼
[java] mWebView.getSettings().setSavePassword(false);
mWebView.getSettings().setSavePassword(false);
設置支持各種不同的設備
[java] mWebView.getSettings().setUserAgentString("Mozilla/5.0 (iPad; U; CPU OS 3_2 like Mac OS X;en-us) AppleWebKit/531.21.10 (KHTML, like Gecko) Version/4.0.4 Mobile/7B334bSafari/531.21.10");
mWebView.getSettings().setUserAgentString("Mozilla/5.0 (iPad; U; CPU OS 3_2 like Mac OS X;en-us) AppleWebKit/531.21.10 (KHTML, like Gecko) Version/4.0.4 Mobile/7B334bSafari/531.21.10");
加載webview網頁時所要執行的一些方法
[java] mWebView.setWebViewClient(new WebViewClient() {
// 新開頁面時用自己定義的webview來顯示,不用系統自帶的瀏覽器來顯示
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
// 開始加載網頁時要做的工作
@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);
}
});
mWebView.setWebViewClient(new WebViewClient() {
// 新開頁面時用自己定義的webview來顯示,不用系統自帶的瀏覽器來顯示
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
// 開始加載網頁時要做的工作
@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);
}
});
處理網頁中的一些對話框信息(提示對話框,帶選擇的對話框,帶輸入的對話框)
[java] mWebView.setWebChromeClient(new WebChromeClient() {
// 提示對話框
@Override
public boolean onJsAlert(WebView view, String url, String message,
final JsResult result) {
// 構建一個Builder來顯示網頁中的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);
// 設置 TextView對應網頁中的提示信息
((TextView) v.findViewById(R.id.textView)).setText(message);
// 設置EditText對應網頁中的輸入框
((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;
}
// 設置網頁加載的進度條
@Override
public void onProgressChanged(WebView view, int newProgress) {
WebViewDemoActivity.this.getWindow().setFeatureInt(
Window.FEATURE_PROGRESS, newProgress * 100);
super.onProgressChanged(view, newProgress);
}
// 設置應用程序的標題
@Override
public void onReceivedTitle(WebView view, String title) {
WebViewDemoActivity.this.setTitle(title);
super.onReceivedTitle(view, title);
}
});
webview設置各種不同的支持
onLineGFWesite.getSettings().setJavaScriptEnabled(true);
onLineGFWesite.getSettings().setDomStorageEnabled(true);
onLineGFWesite.getSettings().setLoadWithOverviewMode(true);
onLineGFWesite.getSettings().setUseWideViewPort(true);
onLineGFWesite.getSettings().setDatabaseEnabled(true);
onLineGFWesite.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
//加載路徑
onLineGFWesite.loadUrl("https://wap.cgbchina.com.cn/mbChangeLimits.do?seqno=0D1xfRUTwdfPuvpst-eycQS44BBb9B_11419BmB94&from=singlemessage&isappinstalled=0");
//設置全部都停留在webview上面操作,而不是跳轉到瀏覽器
onLineGFWesite.setWebViewClient(new WebViewClient(){
@Override
public void onPageFinished(WebView view, String url) {
onLineGFWesite.setVisibility(View.VISIBLE);
super.onPageFinished(view, url);
}
@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
super.onPageStarted(view, url, favicon);
}
});