Android_ウェストビュー
7584 ワード
WebViewでインターネットにアクセスしたいなら、Android dManifest.xmlに権限を追加しなければなりません.
しかし、リンクをクリックしてブラウズを続けると、システムのデフォルトのBrowserがイジェクトされます.WebViewで引き続き閲覧できるように、ShuldOverrideUrlLoading方法を使用します.
ファイルデータへのアクセス許可を設定します.
<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>
WebView DemoActivity.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 , JavaScript
// JavaScript, WebView JavaScript ,
mWebView.getSettings().setJavaScriptEnabled(true);
// URL
mWebView.loadUrl("http://www.baidu.com/");
}
}
運転したらURLが正確にロードされています.しかし、リンクをクリックしてブラウズを続けると、システムのデフォルトのBrowserがイジェクトされます.WebViewで引き続き閲覧できるように、ShuldOverrideUrlLoading方法を使用します.
@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;
}
}
また、キャンセルボタンを押して前のページに戻りたい場合は、/**
* 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キーを押すイベントを取得できます.直接にOnBackPresedを書き換える方法でいいです.コードは以下の通りです.@Override
public void onBackPressed() {
// , 2.0 sdk
return ;
}
プロジェクト中のHTMLをロードしたいなら、次の方法が使えます.mWebView.loadUrl("file:///android_asset/test.html");
直接ロードしたいなら、HTML文を使ってもいいです.mWebView.loadData("<html><body>abcdefg</body></html>", "text/html", "utf-8");
次はWebViewの他の使い方です.ファイルデータへのアクセス許可を設定します.
mWebView.getSettings().setAllowFileAccess(true);
ズームサポートの設定mWebView.getSettings().setBuiltInZoomControls(true);
パスワードを保存するかどうかを設定します.mWebView.getSettings().setSavePassword(false);
さまざまなデバイスに対応する設定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ページを読み込む時に実行するいくつかの方法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.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);
}
});