WebView使用まとめ1


1.WebViewのみの場合、最初に注意するのはもちろん、設定ファイルにインターネットにアクセスする権限を追加することです.
2.訪問ページにJavascriptがある場合は、必ずサポートJavascriptを設定する必要があります.

webview.getSettings().setJavaScriptEnabled(true);
3.リンクをクリックしたいなら、自分で処理します.Androidを新しくオープンしたシステムbrowserではなく、リンクすべきです.WebViewにイベントの傍受対象を追加して、いくつかの方法を書き直します.shordOverrideUrlLoadingはウェブページのハイパーリンクボタンに対する応答です.

mWebView.setWebViewClient(new WebViewClient() {
/**
* Show in webview not system webview.
*/
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return super.shouldOverrideUrlLoading(view, url);
}
}
このようにして、毎回開いているページはWebViewのインスタンスに表示されて実行されることを保証する.
4.WebViewを表示する時、携帯のBackをクリックすると、現在のActivityを完全に終了します.履歴閲覧ページに戻りたいなら、back監聴を書き直します.

public boolean onKeyDown(int keyCode, KeyEvent event) {
WebView mWebView = (WebView) findViewById(R.id.browser);
if ((keyCode == KeyEvent.KEYCODE_BACK) && mWebView.canGoBack()) {
mWebView.goBack();
return true;
}
return super.onKeyDown(keyCode, event);
}
5.Android SDKは、schemaプレフィックスを提供します.file:///android_asset/「WebViewでこのようなschemaに会ったら、現在のカバンの中のassetsカタログに内容を探しに行きます.例えば:」file:///android_asset/demo.html「
次のコードは、ウェブページのJSの類似するAlert()類の関数に対して対応する書き換え応答を行うものです.

webView.setWebChromeClient(new WebChromeClient() {
public boolean onJsAlert(WebView view, String url, String message,
final JsResult result) {
AlertDialog.Builder b = new AlertDialog.Builder(BrowserJs.this);
b.setTitle("Alert");
b.setMessage(message);
b.setPositiveButton(android.R.string.ok,
new AlertDialog.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
result.confirm();
}
});
b.setCancelable(false);
b.create();
b.show();
return true;
};

@Override
public boolean onJsConfirm(WebView view, String url,
String message, final JsResult result) {
AlertDialog.Builder b = new AlertDialog.Builder(BrowserJs.this);
b.setTitle("Confirm");
b.setMessage(message);
b.setPositiveButton(android.R.string.ok,
new AlertDialog.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
result.confirm();
}
});
b.setNegativeButton(android.R.string.cancel,
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
result.cancel();
}
});
b.setCancelable(false);
b.create();
b.show();
return true;
};

@Override
public boolean onJsPrompt(WebView view, String url, String message,
String defaultValue, final JsPromptResult result) {
final LayoutInflater factory = LayoutInflater
.from(BrowserJs.this);
final View v = factory.inflate(
R.layout.prompt_dialog, null);
((TextView) v.findViewById(R.id.prompt_message_text))
.setText(message);
((EditText) v.findViewById(R.id.prompt_input_field))
.setText(defaultValue);

AlertDialog.Builder b = new AlertDialog.Builder(BrowserJs.this);
b.setTitle("Prompt");
b.setView(v);
b.setPositiveButton(android.R.string.ok,
new AlertDialog.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
String value = ((EditText) v
.findViewById(R.id.prompt_input_field))
.getText().toString();
result.confirm(value);
}
});
b.setNegativeButton(android.R.string.cancel,
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
result.cancel();
}
});
b.setOnCancelListener(new DialogInterface.OnCancelListener() {
public void onCancel(DialogInterface dialog) {
result.cancel();
}
});
b.show();
return true;
};

public void onProgressChanged(WebView view, int newProgress) {
BrowserJs.this.getWindow().setFeatureInt(
Window.FEATURE_PROGRESS, newProgress * 100);
super.onProgressChanged(view, newProgress);
}

public void onReceivedTitle(WebView view, String title) {
BrowserJs.this.setTitle(title);
super.onReceivedTitle(view, title);
}
});

go.setOnClickListener(new OnClickListener() {
public void onClick(View view) {
String url = text.getText().toString();
webView.loadUrl(url);
}
});
webView.loadUrl("file:///android_asset/index.html");
上記のコードの中で使用されるprompt_dialog.xml:


android:gravity="center_horizontal" android:orientation="vertical"
android:layout_width="fill_parent" android:layout_height="wrap_content">
android:layout_width="fill_parent" android:layout_height="wrap_content" />
android:layout_width="fill_parent" android:layout_height="wrap_content"
android:selectAllOnFocus="true" android:scrollHorizontally="true"
android:minWidth="250dp" />

また、クラスメイトのHtmlファイルがあります.


<br> function onAlert(){<br> alert("This is a alert sample from html");<br> }<br> function onConfirm(){<br> var b=confirm("are you sure to login?");<br> alert("your choice is "+b);<br> }<br> function onPrompt(){<br> var b=prompt("please input your password","aaa");<br> alert("your input is "+b);<br> }<br>





Google