在网上看了许多关于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.}
package com.webviewdemo;
import java.net.URLEncoder;
import android.app.Activity;
import android.os.Bundle;
import android.webkit.WebView;
public class WebViewDemo extends Activity {
private WebView MyWebView;
static final String mimeType = "text/html";
static final String encoding = "utf-8";
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
//
MyWebView = (WebView) findViewById(R.id.MyWebview);
// this.webHtml();
// this.webImage();
// this.localHtmlZh();
// this.localImage();
// this.localHtml();
this.localHtmlImage();
}
/**
* 直接网页显示
*/
private void webHtml() {
try {
MyWebView.loadUrl("http://www.google.com");
} catch (Exception ex) {
ex.printStackTrace();
}
}
/**
* 直接网络图片显示
*/
private void webImage() {
try {
MyWebView .loadUrl("http://www.google.com.hk/intl/zh-CN/images/logo_cn.gif");
} catch (Exception ex) {
ex.printStackTrace();
}
}
/**
* 中文显示
*/
private void localHtmlZh() {
try {
String data = "<html>在模拟器 2.1 上测试</html>";
// utf-8编码处理(在SDK1.5模拟器和真实设备上都将出现乱码,SDK1.6上能正常显示)
// MyWebView.loadData(data, mimeType, encoding);
// 对数据进行编码处理(SDK1.5版本)
MyWebView.loadData(URLEncoder.encode(data, encoding), mimeType, encoding);
// MyWebView.loadDataWithBaseURL(null, data, mimeType, encoding, null);
} catch (Exception ex) {
ex.printStackTrace();
}
}
/**
* 显示本地图片文件
*/
private void localImage() {
try {
// 本地文件处理
String str = "file:///android_asset/icon.png";
MyWebView.loadUrl(str);
} catch (Exception ex) {
ex.printStackTrace();
}
}
/**
* 显示本地网页文件
*/
private void localHtml() {
try {
// 本地文件处理(如果文件名中有空格需要用+来替代)
MyWebView.loadUrl("file:///android_asset/test.html");
} catch (Exception ex) {
ex.printStackTrace();
}
}
/**
* 显示本地图片和文字混合的Html内容
*/
private void localHtmlImage() {
try {
String data = "<HTML>在模拟器 2.1 上测试,这是<IMG src=\"APK'>file:///android_asset/igg.jpg\"/>APK里的图片";
// SDK1.5本地文件处理(不能显示图片)
//MyWebView.loadData(URLEncoder.encode(data, encoding), mimeType, encoding);
// SDK1.6及以后版本
//MyWebView.loadData(data, mimeType, encoding);
// 本地文件处理(能显示图片)
MyWebView.loadDataWithBaseURL(null, data, mimeType, encoding, null);
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
运行 localHtmlImage(...) 这个方法的结果:
在上面的所有方法中,模拟器2.1下 调用 LoadData 方法总是出现乱码。我想应该是2.1已经不在用它了吧。直接用LoadDataWithBaseURL 方法最简单,不再牵涉编码的转换。
分享到:
相关推荐
本文将详细介绍如何在Android平台上使用WebView组件加载本地资源,主要包括三个重要的方法:loadUrl、loadData和loadDataWithBaseURL。了解这些方法将帮助开发者更有效地将网页内容嵌入到Android应用中,从而提供...
注意,加载本地资源时,路径一定要正确,对于`assets`目录下的资源,需要以`file:///android_asset/`开头。对于`res`目录下的资源,可以使用`android.resource://[package_name]/[resource_type]/[resource_id]`格式...
三、加载本地资源 1. 加载本地HTML文件:使用`loadDataWithBaseURL()`方法加载本地HTML文件。首先,将HTML文件放入assets或res/raw目录下,然后加载。 ```java String ...
最后,关于性能优化,使用`WebView`加载本地资源时,应考虑缓存策略。可以设置`WebSettings`的缓存模式,如`LOAD_CACHE_ELSE_NETWORK`,在网络不畅时优先使用缓存。另外,开启硬件加速可以提升WebView的渲染性能: ...
综上所述,本文深入探讨了如何在Android应用中使用WebView加载本地HTML页面,并通过JavaScript事件桥接实现原生应用与HTML页面的交互。这不仅提高了用户体验,也使得应用的功能更加丰富和灵活。通过熟练掌握这些技术...
1. Android WebView加载HTML Android的WebView可以通过调用`loadData()`或`loadDataWithBaseURL()`方法加载HTML字符串,或者使用`loadUrl()`方法加载网络上的HTML资源。例如: ```java webView.loadUrl("file://...
本压缩包"安卓浏览器WebViewJSHTML5相关-androidwebview加载本地html.zip"提供了关于如何在Android中使用WebView加载本地HTML文件的相关示例和资料。 首先,我们要理解WebView的基本用法。在Android中,WebView是`...
在WebViewLoadDemo这个示例项目中,可能包含了上述所有操作的完整代码,你可以参考该项目学习和实践如何在Android应用中有效地使用WebView加载本地HTML文件。总的来说,理解并熟练掌握WebView的使用对于Android...
但在使用Android Studio进行开发时,由于其项目结构和构建工具有所不同,因此加载本地HTML文件的方式也会有所差异。本文将详细介绍如何在Android Studio中正确地加载本地HTML文件。 #### 二、准备工作 在开始之前...
这个"android使用webview加载网页"的主题涉及到多个知识点,以下将详细介绍这些内容。 首先,我们需要理解WebView的基本用法。在Android Studio中,我们可以通过在布局XML文件中添加`<WebView>`标签来创建一个...
本文将深入探讨如何使用Android的WebView来加载本地的网页源码,并展示一个简单的实例——Demo2。 首先,我们需要理解WebView的基本用法。WebView是Android SDK中的一个类,它提供了一个用于显示网页的视图。我们...
例如,我们可以设置为`LOAD_CACHE_ELSE_NETWORK`,这样在网络不可用时,WebView会尝试从本地缓存加载数据。 ```java WebSettings webSettings = webView.getSettings(); webSettings.setCacheMode(WebSettings.LOAD...
本文将深入探讨如何使用Android WebView加载网页,包括基本使用、配置设置、与JavaScript交互以及处理网络权限等问题。 一、WebView基础 1. 添加依赖 在Android Studio项目中,首先确保在`build.gradle`(Module)...
总之,通过WebView加载本地HTML文件,结合JavaScript和Android原生功能,我们可以实现丰富的交互体验。在这个例子中,我们学习了如何加载HTML文件、启用JavaScript、处理点击事件并弹出对话框。这只是一个基础示例,...
首先,加载PDF到Webview的基本步骤是通过WebView加载一个可以解析并显示PDF的URL。一个常见的方法是使用Google的PDF Viewer,它提供了一个在线的PDF渲染服务。我们可以通过以下代码将PDF文档的URL加载到Webview: `...
7. **WebView加载进度**: 可以监听`WebView`的加载进度,通过`setWebChromeClient`和`WebChromeClient`的`onProgressChanged`方法获取加载进度,并在UI上显示进度条。 8. **安全考虑**: 当加载本地HTML时,也要...
在某些场景下,我们可能需要在Webview中加载本地的图片资源,而不是网络上的图片。本篇文章将详细讲解如何在Android的Webview中通过img标签加载本地图片。 首先,我们要明确两个关键步骤: 1. **配置Webview设置**...
- 使用`setCacheMode()`可以配置WebView使用本地缓存,提高加载速度。 - 启用硬件加速:`webView.setLayerType(View.LAYER_TYPE_HARDWARE, null)`,提高渲染性能。 - 使用`WebView.setWebViewClient()`和`...
3. 性能优化:减少内存占用和提高加载速度是关键,可以使用`shouldInterceptRequest()`方法预加载资源,或者使用`WebView.setCacheMode()`设置缓存模式。 4. 用户体验:使用`WebView.setWebViewClient()`自定义...
// 加载本地资源 ``` ### 8. 处理回调 在某些场景下,可能需要从JavaScript回调Java。这可以通过`WebViewChromeClient`的`onJsPrompt()`或`onJsAlert()`方法实现,它们会在JavaScript弹出对话框时被调用。 ### 9...