WebViewはホームページを表示します

6797 ワード

WebViewは、簡単にappに埋め込むことができますし、直接にjsと通話することもできます.
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