Android使用WebView加载本地资源

转载 2015年07月10日 12:01:23

Android使用WebVie

在网上看了许多关于WebView 的例子。但当自己做起来时,总是有些差别,是另一种体会。这节我就以 模拟器为2.1 为例来讲。

   WebView 主要调用三个方法:LoadUrl、LoadData、LoadDataWithBaseURL。

     1、LoadUrl        直接加载网页、图片并显示。(本地或是网络上的网页、图片、gif)

     2、LoadData     显示文字与图片内容 (模拟器1.5、1.6)

     3、LoadDataWithBase  显示文字与图片内容(支持多个模拟器版本)

下面来看看代码片段:

 

Java代码  收藏代码
  1. package com.webviewdemo;  
  2.   
  3. import java.net.URLEncoder;  
  4. import android.app.Activity;  
  5. import android.os.Bundle;  
  6. import android.webkit.WebView;  
  7.   
  8. public class WebViewDemo extends Activity {  
  9.   
  10.   private WebView     MyWebView;  
  11.   static final String mimeType = "text/html";  
  12.   static final String encoding = "utf-8";  
  13.   
  14.   /** Called when the activity is first created. */  
  15.   @Override  
  16.   public void onCreate(Bundle savedInstanceState) {  
  17.     super.onCreate(savedInstanceState);  
  18.     setContentView(R.layout.main);  
  19.     //  
  20.     MyWebView = (WebView) findViewById(R.id.MyWebview);  
  21.     // this.webHtml();  
  22.     // this.webImage();  
  23.     // this.localHtmlZh();  
  24.     // this.localImage();  
  25.     // this.localHtml();  
  26.     this.localHtmlImage();  
  27.   }  
  28.   
  29.   /** 
  30.    * 直接网页显示 
  31.    */  
  32.   private void webHtml() {  
  33.   
  34.     try {  
  35.       MyWebView.loadUrl("http://www.google.com");  
  36.     } catch (Exception ex) {  
  37.       ex.printStackTrace();  
  38.     }  
  39.   }  
  40.   
  41.   /** 
  42.    * 直接网络图片显示 
  43.    */  
  44.   private void webImage() {  
  45.     try {  
  46.       MyWebView .loadUrl("http://www.google.com.hk/intl/zh-CN/images/logo_cn.gif");  
  47.     } catch (Exception ex) {  
  48.       ex.printStackTrace();  
  49.     }  
  50.   }  
  51.   
  52.   /** 
  53.    * 中文显示 
  54.    */  
  55.   private void localHtmlZh() {  
  56.     try {  
  57.       String data = "<html>在模拟器 2.1 上测试</html>";  
  58.       // utf-8编码处理(在SDK1.5模拟器和真实设备上都将出现乱码,SDK1.6上能正常显示)  
  59.       // MyWebView.loadData(data, mimeType, encoding);  
  60.       // 对数据进行编码处理(SDK1.5版本)  
  61.       MyWebView.loadData(URLEncoder.encode(data, encoding), mimeType, encoding);  
  62.       // MyWebView.loadDataWithBaseURL(null, data, mimeType, encoding, null);  
  63.   
  64.     } catch (Exception ex) {  
  65.       ex.printStackTrace();  
  66.     }  
  67.   }  
  68.   
  69.   /** 
  70.    * 显示本地图片文件 
  71.    */  
  72.   private void localImage() {  
  73.     try {  
  74.       // 本地文件处理  
  75.       String str = "file:///android_asset/icon.png";  
  76.       MyWebView.loadUrl(str);  
  77.     } catch (Exception ex) {  
  78.       ex.printStackTrace();  
  79.     }  
  80.   }  
  81.   
  82.   /** 
  83.    * 显示本地网页文件 
  84.    */  
  85.   private void localHtml() {  
  86.     try {  
  87.       // 本地文件处理(如果文件名中有空格需要用+来替代)  
  88.       MyWebView.loadUrl("file:///android_asset/test.html");  
  89.     } catch (Exception ex) {  
  90.       ex.printStackTrace();  
  91.     }  
  92.   }  
  93.   
  94.   /** 
  95.    * 显示本地图片和文字混合的Html内容 
  96.    */  
  97.   private void localHtmlImage() {  
  98.     try {  
  99.       String data = "<HTML>在模拟器 2.1 上测试,这是<IMG src=\"APK'>file:///android_asset/igg.jpg\"/>APK里的图片";  
  100.       // SDK1.5本地文件处理(不能显示图片)  
  101.       //MyWebView.loadData(URLEncoder.encode(data, encoding), mimeType, encoding);  
  102.       // SDK1.6及以后版本  
  103.       //MyWebView.loadData(data, mimeType, encoding);  
  104.       // 本地文件处理(能显示图片)  
  105.       MyWebView.loadDataWithBaseURL(null, data, mimeType, encoding, null);  
  106.     } catch (Exception ex) {  
  107.       ex.printStackTrace();  
  108.     }  
  109.   }  
  110. }  

 

运行 localHtmlImage(...) 这个方法的结果:


在上面的所有方法中,模拟器2.1下 调用 LoadData 方法总是出现乱码。我想应该是2.1已经不在用它了吧。直接用LoadDataWithBaseURL 方法最简单,不再牵涉编码的转换。

记住:显示本地文件时 必须使用APK'>file:/// 作为前缀。

 

转自:http://hi.baidu.com/455611934/blog/item/027ffe5d17d8a652faf2c02c.html

 

w加载本地资源

本地html文件放置位置,android中加载本地Html文件

最近因为忙着项目上线的事,完全把写博客的事给忘了,先给自己三个 存放本地html文件:放在app/src/main/assets目录下,一般来说android studio项目下是没有assets文件...

android webview 网络页面从本地(assets)加载js库

转载:http://www.ithao123.cn/content-572804.html [摘要:项目中的碰到一面劣化题目,webview减载的页里比拟耗流量, 然则大局部的流量皆糟蹋...

Android的webview加载本地html、assert内html和网络URL&&& JS与移动端webview的相互交互

Android的webview加载本地html、assert内html和网络URL&&& JS与移动端webview的相互交互...

android加载本地asset文件夹下的h5界面

建一个和res文件夹平级的文件夹assets 把html页面放在文件夹下,然后再webview中加载 String fileUrl = "file:///android_asset/index...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Webview加载本地图片的方案对比

关于webview加载本地图片的四种方案,利用一个缓存系统+压缩模块+多线程工作来完成优化...

加载本地文件到 WebView 中

Android 的 WebView 提供了一系列非常灵活的API,可从多种源中加载文件。但是,由于同源规则限制了可向 web 浏览器加载数据的位置,在一些特定的情况下我们不得不重新调整 WebView...

Android的webview加载本地html、本apk内html和远程URL

首先在layout文件夹下的xml中 加入WebView控件   再在主文件中输入如下代码 public class TestDemo ext...

Android中WebView加载本地Html,与JavaScript与Android方法相互传值

最近在做项目中,要使用HightChart来实现心电图,于是,使用WebView加载本地html页面,但是数据是通过蓝牙设备采集的数据,用Java代码获取的数据,需要将数据传到JavaScript中去...

Android的webview加载本地html、assert内html和收集URL

1 //打开本包内asset目次下的test.html文件 2 wView.loadUrl(" file:///android_asset/test.html ");   3 //打开本地...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android使用WebView加载本地资源
举报原因:
原因补充:

(最多只允许输入30个字)