---恢復內容開始--- 一.實例化WebView 通過xml實例化 xml <WebView android:id="@+id/webview" android:layout_width="fill_parent" android:layout_height="fill_parent" /> my
---恢復內容開始---
一.實例化WebView
- 通過xml實例化
- xml
<WebView android:id="@+id/webview" android:layout_width="fill_parent" android:layout_height="fill_parent" />
- myWebView = (WebView) findViewById(R.id.webview);
- xml
- 通過java代碼動態實例化
WebView webView = new WebView(this);
二.載入網頁
1、LoadUrl 直接載入網頁、圖片並顯示.(本地或是網路上的網頁、圖片、gif)(預設在瀏覽器中打開)
- 互聯網用:webView.loadUrl("http://www.google.com");
- 本地文件用:webView.loadUrl("file:///android_asset/XX.html"); 本地文件存放在:assets 文件中
使用LoadUrl 出現過的問題
- 亂碼問題:
-
設置html的編碼
<head> <title>這是標題</title> <meta name="content-type" content="text/html; charset=utf-8"> <meta http-equlv="Content-Type" content="text/html;charset=utf-8"> </ head>
- 設置WebView載入頁面的編碼
webview.getSettings().setDefaultTextEncodingName("utf-8");
-
2、LoadData 顯示文字與圖片內容(模擬器1.5、1.6)
String htmlString = "<h1>Title</h1><p>This is HTML text<br /><i>Formatted in italics</i><br />Anothor Line</p>";
myWebView.loadData(htmlString, "text/html", "utf-8");
使用LoadData可能出現的問題
- 特殊字元轉化問題:有四個字元比較特殊必須使用其它的字元代替,否則會報錯。分別是英文字元:'#', '%', '\' , '?' ;對應的改成:%23, %25, %27, %3f。儘量少轉化吧,會影響速度。
-
%,會報找不到頁面錯誤,頁面全是亂碼。
-
#,會讓你的goBack失效,但canGoBAck是可以使用的。於是就會產生返回按鈕生效,但不能返回的情況。
-
\ 和? 在轉換時,會報錯,因為它會把\當作轉義符來使用。
-
- 亂碼問題:修改loadData的第三個參數,使它與html頁面的編碼保持一致。
3、LoadDataWithBase 顯示文字與圖片內容(支持多個模擬器版本)沒有試過,第一個參數和最後一個參數可以為null。推測:但這樣就沒有歷史記錄了。
void loadDataWithBaseURL (String baseUrl, String data, String mimeType, String encoding, String historyUrl)
三.如何載入網頁:使用瀏覽器還是Activity的webview
-
//所有都在webView中打開網頁,不會使用瀏覽器打開網頁了
myWebView.setWebViewClient(new WebViewClient()); myWebView.loadUrl("http://www.baidu.com");
- 重寫WebViewClient類,控制網頁打開是在瀏覽器打開還是Activity的WebView中打開
private class MyWebViewClient extends WebViewClient { private final String TAG = MyWebViewClient.class.getSimpleName(); @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { Log.e(TAG, url+" getHost:"+Uri.parse(url).getHost()); if (Uri.parse(url).getHost().equals("m.baidu.com")) { // This is my web site, so do not override; let my WebView load // the page。在webview中載入網頁 return false; } // Otherwise, the link is not for a page on my site, so launch // another Activity that handles URLs.使用瀏覽器載入網頁 Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url)); startActivity(intent); return true; } } //控制打開網頁的地方 myWebView.setWebViewClient(new MyWebViewClient()); myWebView.loadUrl("http://www.baidu.com");
四.按返回鍵的時候按瀏覽歷史退回,(前進使用myWebView.goForward();)
/** * 按鍵響應,在WebView中查看網頁時,按返回鍵的時候按瀏覽歷史退回,如果不做此項處理則整個WebView返回退出 */ @Override public boolean onKeyDown(int keyCode, KeyEvent event) { // Check if the key event was the Back button and if there's history if ((keyCode == KeyEvent.KEYCODE_BACK) && myWebView.canGoBack()) { /* * canGoBack() 方法在網頁可以後退時返回true。 * 類似的,canGoForward()方法可以檢查是否有可以前進的歷史記錄。 */ // 這個是前進 // myWebView.goForward(); // 返回鍵退回 myWebView.goBack(); return true; } // If it wasn't the Back key or there's no web page history, bubble up // to the default // system behavior (probably exit the activity) return super.onKeyDown(keyCode, event); }
代碼示例:https://github.com/bigthing33/StudyDemo.git
在項目的WebViewActivity中.
---恢復內容結束---