Android WebView組件用法詳解_Android

來源:互聯網
上載者:User

本文執行個體講述了Android WebView組件用法。分享給大家供大家參考,具體如下:
如果想WebView能夠訪問網路,必須在AndroidManifest.xml裡面添加許可權

<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>

WebViewDemoActivity.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被正確load出來了。

但是有個問題,當點選連結繼續瀏覽,則會彈出系統預設的Browser,為了能夠繼續在WebView中瀏覽,要用到shouldOverrideUrlLoading方法:

@Overridepublic 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鍵可以回到上個網頁 */@Overridepublic 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 方法即可,代碼如下

@Overridepublic void onBackPressed() { // 這裡處理邏輯代碼,該方法僅適用於2.0或更高版本的sdkreturn ;}

如果想載入工程中的HTML,那麼可以用到下面的方法(前提是HTML放在assets目錄中)

mWebView.loadUrl("file:///android_asset/test.html");

如果想直接load一段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);    }});

更多關於Android相關內容感興趣的讀者可查看本站專題:《Android開發入門與進階教程》、《Android多媒體操作技巧匯總(音頻,視頻,錄音等)》、《Android基本組件用法總結》、《Android視圖View技巧總結》、《Android布局layout技巧總結》及《Android控制項用法總結》

希望本文所述對大家Android程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.