1. 程式人生 > 其它 >Android Webview載入本地資源

Android Webview載入本地資源

public voidloadData(Stringdata,StringmimeType,Stringencoding)

則會出現html程式碼中圖片路徑不對導致不能正常顯示圖片(通常是一個白色的固定大小的框,或者沒有)

當把路徑改為絕對路徑加上file://都還無法解決

終於,在網上查資料的時候發現了這個函式,正好解決這個問題

public voidloadDataWithBaseURL(StringbaseUrl,Stringdata,StringmimeType,Stringencoding,StringhistoryUrl)

baseUrl是圖片的目錄,在html程式碼中就寫關於此目錄的相對路徑就可以了,哇嘎嘎!~

附帶程式碼解釋:

String htmlPath = "file:///mnt/sdcard/test/11.html";


String baseUrl = "file:///mnt/sdcard/test/";

webView.loadDataWithBaseURL(baseUrl, data, "text/html", "utf-8", null);

則兩個呼叫都可以顯示正常的html網頁了,並且前一種可以對針對不同解析度大小的螢幕做縮放了!!

在網上看了許多關於WebView 的例子。但當自己做起來時,總是有些差別,是另一種體會。這節我就以 模擬器為2.1 為例來講。

WebView 主要呼叫三個方法:LoadUrl、LoadData、LoadDataWithBaseURL。

1、LoadUrl 直接載入網頁、圖片並顯示。(本地或是網路上的網頁、圖片、gif)

2、LoadData 顯示文字與圖片內容 (模擬器1.5、1.6)

3、LoadDataWithBase 顯示文字與圖片內容(支援多個模擬器版本)

下面來看看程式碼片段:

  1. packagecom.webviewdemo;
  2. importjava.net.URLEncoder;
  3. importandroid.app.Activity;
  4. importandroid.os.Bundle;
  5. importandroid.webkit.WebView;
  6. publicclassWebViewDemoextendsActivity{
  7. privateWebViewMyWebView;
  8. staticfinalStringmimeType="text/html";
  9. staticfinalStringencoding="utf-8";
  10. /**Calledwhentheactivityisfirstcreated.*/
  11. @Override
  12. publicvoidonCreate(BundlesavedInstanceState){
  13. super.onCreate(savedInstanceState);
  14. setContentView(R.layout.main);
  15. //
  16. MyWebView=(WebView)findViewById(R.id.MyWebview);
  17. //this.webHtml();
  18. //this.webImage();
  19. //this.localHtmlZh();
  20. //this.localImage();
  21. //this.localHtml();
  22. this.localHtmlImage();
  23. }
  24. /**
  25. *直接網頁顯示
  26. */
  27. privatevoidwebHtml(){
  28. try{
  29. MyWebView.loadUrl("http://www.google.com");
  30. }catch(Exceptionex){
  31. ex.printStackTrace();
  32. }
  33. }
  34. /**
  35. *直接網路圖片顯示
  36. */
  37. privatevoidwebImage(){
  38. try{
  39. MyWebView.loadUrl("http://www.google.com.hk/intl/zh-CN/images/logo_cn.gif");
  40. }catch(Exceptionex){
  41. ex.printStackTrace();
  42. }
  43. }
  44. /**
  45. *中文顯示
  46. */
  47. privatevoidlocalHtmlZh(){
  48. try{
  49. Stringdata="<html>在模擬器2.1上測試</html>";
  50. //utf-8編碼處理(在SDK1.5模擬器和真實裝置上都將出現亂碼,SDK1.6上能正常顯示)
  51. //MyWebView.loadData(data,mimeType,encoding);
  52. //對資料進行編碼處理(SDK1.5版本)
  53. MyWebView.loadData(URLEncoder.encode(data,encoding),mimeType,encoding);
  54. //MyWebView.loadDataWithBaseURL(null,data,mimeType,encoding,null);
  55. }catch(Exceptionex){
  56. ex.printStackTrace();
  57. }
  58. }
  59. /**
  60. *顯示本地圖片檔案
  61. */
  62. privatevoidlocalImage(){
  63. try{
  64. //本地檔案處理
  65. Stringstr="file:///android_asset/icon.png";
  66. MyWebView.loadUrl(str);
  67. }catch(Exceptionex){
  68. ex.printStackTrace();
  69. }
  70. }
  71. /**
  72. *顯示本地網頁檔案
  73. */
  74. privatevoidlocalHtml(){
  75. try{
  76. //本地檔案處理(如果檔名中有空格需要用+來替代)
  77. MyWebView.loadUrl("file:///android_asset/test.html");
  78. }catch(Exceptionex){
  79. ex.printStackTrace();
  80. }
  81. }
  82. /**
  83. *顯示本地圖片和文字混合的Html內容
  84. */
  85. privatevoidlocalHtmlImage(){
  86. try{
  87. Stringdata="<HTML>在模擬器2.1上測試,這是<IMGsrc=\"APK'>file:///android_asset/igg.jpg\"/>APK裡的圖片";
  88. //SDK1.5本地檔案處理(不能顯示圖片)
  89. //MyWebView.loadData(URLEncoder.encode(data,encoding),mimeType,encoding);
  90. //SDK1.6及以後版本
  91. //MyWebView.loadData(data,mimeType,encoding);
  92. //本地檔案處理(能顯示圖片)
  93. MyWebView.loadDataWithBaseURL(null,data,mimeType,encoding,null);
  94. }catch(Exceptionex){
  95. ex.printStackTrace();
  96. }
  97. }
  98. }

執行 localHtmlImage(...) 這個方法的結果:


在上面的所有方法中,模擬器2.1下 呼叫 LoadData 方法總是出現亂碼。我想應該是2.1已經不在用它了吧。直接用LoadDataWithBaseURL 方法最簡單,不再牽涉編碼的轉換。

記住:顯示本地檔案時 必須使用APK'>file:///作為字首。