WebViewはホームページを表示します
6797 ワード
WebViewは、簡単にappに埋め込むことができますし、直接にjsと通話することもできます.
webviewには二つの方法があります.set WebChromeClientとset WebClient
set WebCient:主な処理は解析して、ホームページなどのブラウザーのする事を誇張します.
set WebChromeCient:Javascriptのダイアログ、ウェブサイトのアイコン、ウェブサイトのtitle、ローディングの進度などを処理します.
WebView CientはWebViewのために各種の通知を処理し、イベントを要求するのです.
Android Manifest.xmlにアクセスネットワーク権限を設定します.
WebViewのloadUrl()を呼び出します.
ローカルリソースを読み込み
自分のWebView Cientを作成して、set WebView Clientを通じて関連します.
もしアクセスページにJavascriptがあるなら、webviewはJavascriptをサポートするように設定しなければなりません.
ブラウザーから退出するのではなく、ブラウズしたい場合は、ウェブビューのURLローディングが必要であり、自動的に履歴アクセス記録を生成させ、前進または後退を通じて訪問したサイトにアクセスすることができます.
webviewには二つの方法があります.set WebChromeClientとset WebClient
set WebCient:主な処理は解析して、ホームページなどのブラウザーのする事を誇張します.
set WebChromeCient:Javascriptのダイアログ、ウェブサイトのアイコン、ウェブサイトのtitle、ローディングの進度などを処理します.
WebView CientはWebViewのために各種の通知を処理し、イベントを要求するのです.
Android Manifest.xmlにアクセスネットワーク権限を設定します.
<uses-permission android:name="android.permission.INTERNET"/>
WebViewコントロール:<WebView android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/webView" />
用途一:ローカル/Webリソースexampleを読み込み、astesフォルダに保存するWebViewのloadUrl()を呼び出します.
ローカルリソースを読み込み
webView = (WebView) findViewById(R.id.webView);
webView.loadUrl("file:///android_asset/example.html");
ウェブリソースを読み込み:webView = (WebView) findViewById(R.id.webView);
webView.loadUrl("http://baidu.com");
アプリケーション2:プログラム内でページを開く自分のWebView Cientを作成して、set WebView Clientを通じて関連します.
package com.example.testopen;
import android.app.Activity;
import android.os.Bundle;
import android.webkit.WebView;
import android.webkit.WebViewClient;
public class MainActivity extends Activity {
private WebView webView;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.test);
init();
}
private void init(){
webView = (WebView) findViewById(R.id.webView);
//WebView web
webView.loadUrl("http://baidu.com");
// shouldOverrideUrlLoading。return true , url,webview url;return false ,webview url。
// , true , , 。return false webview 。
webView.setWebViewClient(new WebViewClient(){
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
view.loadUrl(url);
return true;
}
});
}
}
用途3:もしアクセスページにJavascriptがあるなら、webviewはJavascriptをサポートするように設定しなければなりません.
// javascript
WebSettings settings = webView.getSettings();
settings.setJavaScriptEnabled(true);
用途四:ブラウザーから退出するのではなく、ブラウズしたい場合は、ウェブビューのURLローディングが必要であり、自動的に履歴アクセス記録を生成させ、前進または後退を通じて訪問したサイトにアクセスすることができます.
// ——
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
// TODO Auto-generated method stub
if(keyCode==KeyEvent.KEYCODE_BACK)
{
if(webView.canGoBack())
{
webView.goBack();//
return true;
}
else
{
System.exit(0);//
}
}
return super.onKeyDown(keyCode, event);
}
用途5:ページのロード過程を判断する webView.setWebChromeClient(new WebChromeClient() {
@Override
public void onProgressChanged(WebView view, int newProgress) {
// TODO Auto-generated method stub
if (newProgress == 100) {
//
} else {
//
}
}
});
用途六:キャッシュの使用は優先的にキャッシュを使用する:webView.getSettings().setCacheMode(WebSettings.LOAD_CACHE_ELSE_NETWORK);
キャッシュを使わない:webView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
関連参考:http://www.cnblogs.com/tinyphp/p/3858997.html