- 浏览: 933050 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
itzhongyuan:
java Random类详解 -
david_je:
你好,我看到你在C里面回调JAVA里面的方法是在native里 ...
Android NDK开发(1)----- Java与C互相调用实例详解 -
fykyx521:
请求锁是在 oncreate 释放实在ondestroy?? ...
Android如何保持程序一直运行 -
aduo_vip:
不错,总结得好!
Android读取assets目录下的资源 -
f839903061:
给的网址很给力哦!
Android 4.0.1 源码下载,编译和运行
使用WebView进行互联网程序开发有以下优点:
1、可以打开远程网址、也可以加载本地Html数据
2、可以搭建Java和Javascript交互桥梁
3、WebView控件可以高度定制。
下面我们通过几个例子来共同学习WebView的使用方法。
一、先做一个例子热热身看看效果,例子:通过WebView访问本博客 http://android.yaohuiji.com
1、先来一个简单的例子,新建一个项目Lesson29_WebView
2、因为要访问互联网所以先在AndroidManifest.xml中设定权限:
view sourceprint?01 <?xml version="1.0" encoding="utf-8"?>
02 <MANIFEST android:versionname="1.0" android:versioncode="1" package="android.basic.lesson29" xmlns:android="http://schemas.android.com/apk/res/android">
03 <APPLICATION android:label="@string/app_name" android:icon="@drawable/icon">
04 <ACTIVITY android:label="@string/app_name" android:name=".MainWebView">
05 <INTENT -filter>
06 <ACTION android:name="android.intent.action.MAIN" />
07 <CATEGORY android:name="android.intent.category.LAUNCHER" />
08 </INTENT>
09 </ACTIVITY>
10
11 </APPLICATION>
12 <USES android:minsdkversion="8" -sdk />
13 <USES android:name="android.permission.INTERNET" -permission />
14 </MANIFEST>
3、在res/layout/main.xml中放置一个输入框,一个按钮和一个WebView:
<?xml version="1.0" encoding="utf-8"?> 4、在Activity文件的OnCreate方法中默认载入一个百度页面,点击按钮时载入预设的网址http://android.yaohuiji.com : view sourceprint?01 package android.basic.lesson29;
02
03 import android.app.Activity;
04 import android.os.Bundle;
05 import android.view.View;
06 import android.webkit.WebView;
07 import android.widget.Button;
08 import android.widget.EditText;
09
10 public class MainWebView extends Activity {
11
12 WebView mWebView;
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 //定义UI组件
21 mWebView = (WebView) findViewById(R.id.WebView01);
22 Button b1 = (Button) findViewById(R.id.Button01);
23 final EditText et = (EditText) findViewById(R.id.EditText01);
24
25 //得到WebSetting对象,设置支持Javascript的参数
26 mWebView.getSettings().setJavaScriptEnabled(true);
27 //载入URL
28 mWebView.loadUrl("http://www.baidu.com");
29 //使页面获得焦点
30 mWebView.requestFocus();
31
32 //给按钮绑定单击监听器
33 b1.setOnClickListener(new View.OnClickListener() {
34
35 @Override
36 public void onClick(View v) {
37 //访问编辑框中的网址
38 mWebView.loadUrl(et.getText().toString());
39 }
40 });
41
42 }
43 }
5、运行程序,查看效果:
点击Go按钮,可以看到本博客出现,不过没有经过任何缩放处理,在接下里的例子我们继续研究,如何做更多的控制。
二、补充一点基础知识:关于WebSettings
1、先看一下WebView的继承关系,可以看到它不是在 android.widget包中,而是在android.webkit包中。
2、WebSettings : WebView组件有一个辅助类叫WebSettings,它管理WebView的设置状态。该对象可以通过WebView.getSettings()方法获得。下面举几个例子来说明WebSettings的用法:
//得到WebSettings对象,设置支持Javascript的参数
mWebView.getSettings().setJavaScriptEnabled(true);
//设置可以支持缩放
mWebView.getSettings().setSupportZoom(true);
//设置默认缩放方式尺寸是far
mWebView.getSettings().setDefaultZoom(WebSettings.ZoomDensity.FAR);
//设置出现缩放工具
mWebView.getSettings().setBuiltInZoomControls(true);
三、加载assets目录下的本地网页
WebView调用assets目录下的本地网页和图片等资源非常方便,使用形如
wv.loadUrl("file:///android_asset/html/test1.html");
的调用方法即可,代码在第四段落里。
在test1中点击链接也可以跳转到test2
四、使用 LoadData 方法加载内容
可以在Java文件中或者XML文件中定义HTML的片段,也可以在assets目录中存放HTML文件,然后使用LoadData加载其中的内容,展示出来。下面我们使用第三部分的网页来演示一下如何使用LoadData方法,并且看看他们之间的区别。
1、新建项目Lesson29_WebView2
2、新建2个Html文件在assets/html下,内容略去,res/layout/main.xml的内容也略去了,相信对你来说已经不成问题。
3、MainWebView2.java 的内容如下:
view sourceprint?01 package android.basic.lesson29;
02
03 import java.io.IOException;
04 import java.io.InputStream;
05
06 import org.apache.http.util.ByteArrayBuffer;
07 import org.apache.http.util.EncodingUtils;
08
09 import android.app.Activity;
10 import android.os.Bundle;
11 import android.view.View;
12 import android.webkit.WebView;
13 import android.widget.Button;
14
15 public class MainWebView2 extends Activity {
16 /** Called when the activity is first created. */
17 @Override
18 public void onCreate(Bundle savedInstanceState) {
19 super.onCreate(savedInstanceState);
20 setContentView(R.layout.main);
21
22 //定义UI组件
23 Button b1 = (Button) findViewById(R.id.Button01);
24 Button b2 = (Button) findViewById(R.id.Button02);
25
26 final WebView wv = (WebView) findViewById(R.id.WebView01);
27
28 //定义并绑定按钮单击监听器
29 b1.setOnClickListener(new View.OnClickListener() {
30 @Override
31 public void onClick(View v) {
32 //加载URL assets目录下的内容可以用 "file:///android_asset" 前缀
33 wv.loadUrl("file:///android_asset/html/test1.html");
34 }
35 });
36
37 //定义并绑定按钮单击监听器
38 b2.setOnClickListener(new View.OnClickListener() {
39 @Override
40 public void onClick(View v) {
41 String data = "";
42 try {
43 // 读取assets目录下的文件需要用到AssetManager对象的Open方法打开文件
44 InputStream is = getAssets().open("html/test2.html");
45 // loadData()方法需要的是一个字符串数据所以我们需要把文件转成字符串
46 ByteArrayBuffer baf = new ByteArrayBuffer(500);
47 int count = 0;
48 while ((count = is.read()) != -1) {
49 baf.append(count);
50 }
51 data = EncodingUtils.getString(baf.toByteArray(), "utf-8");
52 } catch (IOException e) {
53 e.printStackTrace();
54 }
55 // 下面两种方法都可以加载成功
56 wv.loadData(data, "text/html", "utf-8");
57 // wv.loadDataWithBaseURL("", data, "text/html", "utf-8", "");
58 }
59 });
60
61 }
62 }
4、运行程序单击第二个按钮,效果如下:
对比上面的例子,我们可以看到两个明显的区别,其一,图片没加载出来,其二链接失效,点击后无法加载test1.html 。
五、两个和WebView相关的重要对象:WebChromeClient 和 WebViewClient
和WebView相关的辅助对象,除了WebSettings以外还有WebChromeClient和WebViewClient。
接下来的这个例子内容比较丰富,虽然注释比较清晰,但是您一次消化起来还是比较困难的,因此您需要的是一点点耐心,多看几遍,最重要的是自己至少敲代码敲一遍。
1、在上面的例子中继续增加内容,增加 test3.html 的内容:
view sourceprint?01 <HTML xmlns="http://www.w3.org/1999/xhtml">
02
03 <HTML xmlns="http://www.w3.org/1999/xhtml">
04 <HEAD>
05
06 <SCRIPT type=text/JavaScript>
07 function alertFuction(){
08 var a=1;
09 var b=2
10 alert(a+b);
11 }
12 function confirmFuction(){
13 confirm("你确定要删除吗?")
14 }
15 </SCRIPT>
16
17 对话框测试
18 <INPUT onclick=alertFuction() value=提醒对话框 type=button>
19 <INPUT onclick=confirmFuction() value=选择对话框 type=button>
20
21 <A href="test1.html">上一页</A>
2、MainWebView3.java的内容,请注意注释内容:
view sourceprint?001 package android.basic.lesson29;
002
003 import java.io.FileOutputStream;
004
005 import android.app.Activity;
006 import android.app.AlertDialog;
007 import android.app.AlertDialog.Builder;
008 import android.content.DialogInterface;
009 import android.graphics.Bitmap;
010 import android.graphics.Canvas;
011 import android.graphics.Picture;
012 import android.os.Bundle;
013 import android.view.KeyEvent;
014 import android.view.View;
015 import android.webkit.JsPromptResult;
016 import android.webkit.JsResult;
017 import android.webkit.WebChromeClient;
018 import android.webkit.WebView;
019 import android.webkit.WebViewClient;
020 import android.widget.Button;
021 import android.widget.Toast;
022
023 public class MainWebView3 extends Activity {
024
025 /** Called when the activity is first created. */
026 @Override
027 public void onCreate(Bundle savedInstanceState) {
028 super.onCreate(savedInstanceState);
029 setContentView(R.layout.main);
030
031 // 定义UI组件
032 Button b1 = (Button) findViewById(R.id.Button01);
033 Button b2 = (Button) findViewById(R.id.Button02);
034 Button b3 = (Button) findViewById(R.id.Button03);
035
036 final WebView wv = (WebView) findViewById(R.id.WebView01);
037
038 // 覆盖默认后退按钮的作用,替换成WebView里的查看历史页面
039 wv.setOnKeyListener(new View.OnKeyListener() {
040
041 @Override
042 public boolean onKey(View v, int keyCode, KeyEvent event) {
043 if (event.getAction() == KeyEvent.ACTION_DOWN) {
044 if ((keyCode == KeyEvent.KEYCODE_BACK) && wv.canGoBack()) {
045 wv.goBack();
046 return true;
047 }
048 }
049 return false;
050 }
051 });
052
053 // 设置支持Javascript
054 wv.getSettings().setJavaScriptEnabled(true);
055
056 // 定义并绑定按钮单击监听器
057 b1.setOnClickListener(new View.OnClickListener() {
058 @Override
059 public void onClick(View v) {
060 // 加载URL assets目录下的内容可以用 "file:///android_asset" 前缀
061 wv.loadUrl("file:///android_asset/html/test1.html");
062 }
063 });
064
065 // 定义并绑定按钮单击监听器
066 b2.setOnClickListener(new View.OnClickListener() {
067 @Override
068 public void onClick(View v) {
069 // 加载URL assets目录下的内容可以用 "file:///android_asset" 前缀
070 wv.loadUrl("file:///android_asset/html/test3.html");
071 }
072 });
073
074 // 定义并绑定按钮单击监听器
075 b3.setOnClickListener(new View.OnClickListener() {
076 @Override
077 public void onClick(View v) {
078 Picture pic = wv.capturePicture();
079 int width = pic.getWidth();
080 int height = pic.getHeight();
081 if (width > 0 && height > 0) {
082 Bitmap bmp = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
083 Canvas canvas = new Canvas(bmp);
084 pic.draw(canvas);
085 try {
086 String fileName = "sdcard/" + System.currentTimeMillis() + ".png";
087 FileOutputStream fos = new FileOutputStream(fileName);
088
089 if (fos != null) {
090 bmp.compress(Bitmap.CompressFormat.PNG, 90, fos);
091 fos.close();
092 }
093 Toast.makeText(getApplicationContext(), "截图成功,文件名是:" + fileName, Toast.LENGTH_SHORT).show();
094 } catch (Exception e) {
095 e.printStackTrace();
096 }
097 }
098 }
099 });
100
101 // 创建WebViewClient对象
102 WebViewClient wvc = new WebViewClient() {
103
104 @Override
105 public boolean shouldOverrideUrlLoading(WebView view, String url) {
106 Toast.makeText(getApplicationContext(), "WebViewClient.shouldOverrideUrlLoading", Toast.LENGTH_SHORT)
107 .show();
108 // 使用自己的WebView组件来响应Url加载事件,而不是使用默认浏览器器加载页面
109 wv.loadUrl(url);
110 // 记得消耗掉这个事件。给不知道的朋友再解释一下,Android中返回True的意思就是到此为止吧,事件就会不会冒泡传递了,我们称之为消耗掉
111 return true;
112 }
113
114 @Override
115 public void onPageStarted(WebView view, String url, Bitmap favicon) {
116 Toast.makeText(getApplicationContext(), "WebViewClient.onPageStarted", Toast.LENGTH_SHORT).show();
117 super.onPageStarted(view, url, favicon);
118 }
119
120 @Override
121 public void onPageFinished(WebView view, String url) {
122 Toast.makeText(getApplicationContext(), "WebViewClient.onPageFinished", Toast.LENGTH_SHORT).show();
123 super.onPageFinished(view, url);
124 }
125
126 @Override
127 public void onLoadResource(WebView view, String url) {
128 Toast.makeText(getApplicationContext(), "WebViewClient.onLoadResource", Toast.LENGTH_SHORT).show();
129 super.onLoadResource(view, url);
130 }
131
132 };
133
134 // 设置WebViewClient对象
135 wv.setWebViewClient(wvc);
136
137 // 创建WebViewChromeClient
138 WebChromeClient wvcc = new WebChromeClient() {
139
140 // 处理Alert事件
141 @Override
142 public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {
143 // 构建一个Builder来显示网页中的alert对话框
144 Builder builder = new Builder(MainWebView3.this);
145 builder.setTitle("计算1+2的值");
146 builder.setMessage(message);
147 builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() {
148 @Override
149 public void onClick(DialogInterface dialog, int which) {
150 result.confirm();
151 }
152 });
153 builder.setCancelable(false);
154 builder.create();
155 builder.show();
156 return true;
157 }
158
159 @Override
160 public void onReceivedTitle(WebView view, String title) {
161 MainWebView3.this.setTitle("可以用onReceivedTitle()方法修改网页标题");
162 super.onReceivedTitle(view, title);
163 }
164
165 // 处理Confirm事件
166 @Override
167 public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) {
168 Builder builder = new Builder(MainWebView3.this);
169 builder.setTitle("删除确认");
170 builder.setMessage(message);
171 builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() {
172
173 @Override
174 public void onClick(DialogInterface dialog, int which) {
175 result.confirm();
176 }
177
178 });
179 builder.setNeutralButton(android.R.string.cancel, new AlertDialog.OnClickListener() {
180
181 @Override
182 public void onClick(DialogInterface dialog, int which) {
183 result.cancel();
184 }
185
186 });
187 builder.setCancelable(false);
188 builder.create();
189 builder.show();
190 return true;
191 }
192
193 // 处理提示事件
194 @Override
195 public boolean onJsPrompt(WebView view, String url, String message, String defaultValue,
196 JsPromptResult result) {
197 // 看看默认的效果
198 return super.onJsPrompt(view, url, message, defaultValue, result);
199 }
200 };
201
202 // 设置setWebChromeClient对象
203 wv.setWebChromeClient(wvcc);
204 }
205 }
3、运行程序,查看结果:
1、可以打开远程网址、也可以加载本地Html数据
2、可以搭建Java和Javascript交互桥梁
3、WebView控件可以高度定制。
下面我们通过几个例子来共同学习WebView的使用方法。
一、先做一个例子热热身看看效果,例子:通过WebView访问本博客 http://android.yaohuiji.com
1、先来一个简单的例子,新建一个项目Lesson29_WebView
2、因为要访问互联网所以先在AndroidManifest.xml中设定权限:
view sourceprint?01 <?xml version="1.0" encoding="utf-8"?>
02 <MANIFEST android:versionname="1.0" android:versioncode="1" package="android.basic.lesson29" xmlns:android="http://schemas.android.com/apk/res/android">
03 <APPLICATION android:label="@string/app_name" android:icon="@drawable/icon">
04 <ACTIVITY android:label="@string/app_name" android:name=".MainWebView">
05 <INTENT -filter>
06 <ACTION android:name="android.intent.action.MAIN" />
07 <CATEGORY android:name="android.intent.category.LAUNCHER" />
08 </INTENT>
09 </ACTIVITY>
10
11 </APPLICATION>
12 <USES android:minsdkversion="8" -sdk />
13 <USES android:name="android.permission.INTERNET" -permission />
14 </MANIFEST>
3、在res/layout/main.xml中放置一个输入框,一个按钮和一个WebView:
<?xml version="1.0" encoding="utf-8"?> 4、在Activity文件的OnCreate方法中默认载入一个百度页面,点击按钮时载入预设的网址http://android.yaohuiji.com : view sourceprint?01 package android.basic.lesson29;
02
03 import android.app.Activity;
04 import android.os.Bundle;
05 import android.view.View;
06 import android.webkit.WebView;
07 import android.widget.Button;
08 import android.widget.EditText;
09
10 public class MainWebView extends Activity {
11
12 WebView mWebView;
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 //定义UI组件
21 mWebView = (WebView) findViewById(R.id.WebView01);
22 Button b1 = (Button) findViewById(R.id.Button01);
23 final EditText et = (EditText) findViewById(R.id.EditText01);
24
25 //得到WebSetting对象,设置支持Javascript的参数
26 mWebView.getSettings().setJavaScriptEnabled(true);
27 //载入URL
28 mWebView.loadUrl("http://www.baidu.com");
29 //使页面获得焦点
30 mWebView.requestFocus();
31
32 //给按钮绑定单击监听器
33 b1.setOnClickListener(new View.OnClickListener() {
34
35 @Override
36 public void onClick(View v) {
37 //访问编辑框中的网址
38 mWebView.loadUrl(et.getText().toString());
39 }
40 });
41
42 }
43 }
5、运行程序,查看效果:
点击Go按钮,可以看到本博客出现,不过没有经过任何缩放处理,在接下里的例子我们继续研究,如何做更多的控制。
二、补充一点基础知识:关于WebSettings
1、先看一下WebView的继承关系,可以看到它不是在 android.widget包中,而是在android.webkit包中。
2、WebSettings : WebView组件有一个辅助类叫WebSettings,它管理WebView的设置状态。该对象可以通过WebView.getSettings()方法获得。下面举几个例子来说明WebSettings的用法:
//得到WebSettings对象,设置支持Javascript的参数
mWebView.getSettings().setJavaScriptEnabled(true);
//设置可以支持缩放
mWebView.getSettings().setSupportZoom(true);
//设置默认缩放方式尺寸是far
mWebView.getSettings().setDefaultZoom(WebSettings.ZoomDensity.FAR);
//设置出现缩放工具
mWebView.getSettings().setBuiltInZoomControls(true);
三、加载assets目录下的本地网页
WebView调用assets目录下的本地网页和图片等资源非常方便,使用形如
wv.loadUrl("file:///android_asset/html/test1.html");
的调用方法即可,代码在第四段落里。
在test1中点击链接也可以跳转到test2
四、使用 LoadData 方法加载内容
可以在Java文件中或者XML文件中定义HTML的片段,也可以在assets目录中存放HTML文件,然后使用LoadData加载其中的内容,展示出来。下面我们使用第三部分的网页来演示一下如何使用LoadData方法,并且看看他们之间的区别。
1、新建项目Lesson29_WebView2
2、新建2个Html文件在assets/html下,内容略去,res/layout/main.xml的内容也略去了,相信对你来说已经不成问题。
3、MainWebView2.java 的内容如下:
view sourceprint?01 package android.basic.lesson29;
02
03 import java.io.IOException;
04 import java.io.InputStream;
05
06 import org.apache.http.util.ByteArrayBuffer;
07 import org.apache.http.util.EncodingUtils;
08
09 import android.app.Activity;
10 import android.os.Bundle;
11 import android.view.View;
12 import android.webkit.WebView;
13 import android.widget.Button;
14
15 public class MainWebView2 extends Activity {
16 /** Called when the activity is first created. */
17 @Override
18 public void onCreate(Bundle savedInstanceState) {
19 super.onCreate(savedInstanceState);
20 setContentView(R.layout.main);
21
22 //定义UI组件
23 Button b1 = (Button) findViewById(R.id.Button01);
24 Button b2 = (Button) findViewById(R.id.Button02);
25
26 final WebView wv = (WebView) findViewById(R.id.WebView01);
27
28 //定义并绑定按钮单击监听器
29 b1.setOnClickListener(new View.OnClickListener() {
30 @Override
31 public void onClick(View v) {
32 //加载URL assets目录下的内容可以用 "file:///android_asset" 前缀
33 wv.loadUrl("file:///android_asset/html/test1.html");
34 }
35 });
36
37 //定义并绑定按钮单击监听器
38 b2.setOnClickListener(new View.OnClickListener() {
39 @Override
40 public void onClick(View v) {
41 String data = "";
42 try {
43 // 读取assets目录下的文件需要用到AssetManager对象的Open方法打开文件
44 InputStream is = getAssets().open("html/test2.html");
45 // loadData()方法需要的是一个字符串数据所以我们需要把文件转成字符串
46 ByteArrayBuffer baf = new ByteArrayBuffer(500);
47 int count = 0;
48 while ((count = is.read()) != -1) {
49 baf.append(count);
50 }
51 data = EncodingUtils.getString(baf.toByteArray(), "utf-8");
52 } catch (IOException e) {
53 e.printStackTrace();
54 }
55 // 下面两种方法都可以加载成功
56 wv.loadData(data, "text/html", "utf-8");
57 // wv.loadDataWithBaseURL("", data, "text/html", "utf-8", "");
58 }
59 });
60
61 }
62 }
4、运行程序单击第二个按钮,效果如下:
对比上面的例子,我们可以看到两个明显的区别,其一,图片没加载出来,其二链接失效,点击后无法加载test1.html 。
五、两个和WebView相关的重要对象:WebChromeClient 和 WebViewClient
和WebView相关的辅助对象,除了WebSettings以外还有WebChromeClient和WebViewClient。
接下来的这个例子内容比较丰富,虽然注释比较清晰,但是您一次消化起来还是比较困难的,因此您需要的是一点点耐心,多看几遍,最重要的是自己至少敲代码敲一遍。
1、在上面的例子中继续增加内容,增加 test3.html 的内容:
view sourceprint?01 <HTML xmlns="http://www.w3.org/1999/xhtml">
02
03 <HTML xmlns="http://www.w3.org/1999/xhtml">
04 <HEAD>
05
06 <SCRIPT type=text/JavaScript>
07 function alertFuction(){
08 var a=1;
09 var b=2
10 alert(a+b);
11 }
12 function confirmFuction(){
13 confirm("你确定要删除吗?")
14 }
15 </SCRIPT>
16
17 对话框测试
18 <INPUT onclick=alertFuction() value=提醒对话框 type=button>
19 <INPUT onclick=confirmFuction() value=选择对话框 type=button>
20
21 <A href="test1.html">上一页</A>
2、MainWebView3.java的内容,请注意注释内容:
view sourceprint?001 package android.basic.lesson29;
002
003 import java.io.FileOutputStream;
004
005 import android.app.Activity;
006 import android.app.AlertDialog;
007 import android.app.AlertDialog.Builder;
008 import android.content.DialogInterface;
009 import android.graphics.Bitmap;
010 import android.graphics.Canvas;
011 import android.graphics.Picture;
012 import android.os.Bundle;
013 import android.view.KeyEvent;
014 import android.view.View;
015 import android.webkit.JsPromptResult;
016 import android.webkit.JsResult;
017 import android.webkit.WebChromeClient;
018 import android.webkit.WebView;
019 import android.webkit.WebViewClient;
020 import android.widget.Button;
021 import android.widget.Toast;
022
023 public class MainWebView3 extends Activity {
024
025 /** Called when the activity is first created. */
026 @Override
027 public void onCreate(Bundle savedInstanceState) {
028 super.onCreate(savedInstanceState);
029 setContentView(R.layout.main);
030
031 // 定义UI组件
032 Button b1 = (Button) findViewById(R.id.Button01);
033 Button b2 = (Button) findViewById(R.id.Button02);
034 Button b3 = (Button) findViewById(R.id.Button03);
035
036 final WebView wv = (WebView) findViewById(R.id.WebView01);
037
038 // 覆盖默认后退按钮的作用,替换成WebView里的查看历史页面
039 wv.setOnKeyListener(new View.OnKeyListener() {
040
041 @Override
042 public boolean onKey(View v, int keyCode, KeyEvent event) {
043 if (event.getAction() == KeyEvent.ACTION_DOWN) {
044 if ((keyCode == KeyEvent.KEYCODE_BACK) && wv.canGoBack()) {
045 wv.goBack();
046 return true;
047 }
048 }
049 return false;
050 }
051 });
052
053 // 设置支持Javascript
054 wv.getSettings().setJavaScriptEnabled(true);
055
056 // 定义并绑定按钮单击监听器
057 b1.setOnClickListener(new View.OnClickListener() {
058 @Override
059 public void onClick(View v) {
060 // 加载URL assets目录下的内容可以用 "file:///android_asset" 前缀
061 wv.loadUrl("file:///android_asset/html/test1.html");
062 }
063 });
064
065 // 定义并绑定按钮单击监听器
066 b2.setOnClickListener(new View.OnClickListener() {
067 @Override
068 public void onClick(View v) {
069 // 加载URL assets目录下的内容可以用 "file:///android_asset" 前缀
070 wv.loadUrl("file:///android_asset/html/test3.html");
071 }
072 });
073
074 // 定义并绑定按钮单击监听器
075 b3.setOnClickListener(new View.OnClickListener() {
076 @Override
077 public void onClick(View v) {
078 Picture pic = wv.capturePicture();
079 int width = pic.getWidth();
080 int height = pic.getHeight();
081 if (width > 0 && height > 0) {
082 Bitmap bmp = Bitmap.createBitmap(width, height, Bitmap.Config.ARGB_8888);
083 Canvas canvas = new Canvas(bmp);
084 pic.draw(canvas);
085 try {
086 String fileName = "sdcard/" + System.currentTimeMillis() + ".png";
087 FileOutputStream fos = new FileOutputStream(fileName);
088
089 if (fos != null) {
090 bmp.compress(Bitmap.CompressFormat.PNG, 90, fos);
091 fos.close();
092 }
093 Toast.makeText(getApplicationContext(), "截图成功,文件名是:" + fileName, Toast.LENGTH_SHORT).show();
094 } catch (Exception e) {
095 e.printStackTrace();
096 }
097 }
098 }
099 });
100
101 // 创建WebViewClient对象
102 WebViewClient wvc = new WebViewClient() {
103
104 @Override
105 public boolean shouldOverrideUrlLoading(WebView view, String url) {
106 Toast.makeText(getApplicationContext(), "WebViewClient.shouldOverrideUrlLoading", Toast.LENGTH_SHORT)
107 .show();
108 // 使用自己的WebView组件来响应Url加载事件,而不是使用默认浏览器器加载页面
109 wv.loadUrl(url);
110 // 记得消耗掉这个事件。给不知道的朋友再解释一下,Android中返回True的意思就是到此为止吧,事件就会不会冒泡传递了,我们称之为消耗掉
111 return true;
112 }
113
114 @Override
115 public void onPageStarted(WebView view, String url, Bitmap favicon) {
116 Toast.makeText(getApplicationContext(), "WebViewClient.onPageStarted", Toast.LENGTH_SHORT).show();
117 super.onPageStarted(view, url, favicon);
118 }
119
120 @Override
121 public void onPageFinished(WebView view, String url) {
122 Toast.makeText(getApplicationContext(), "WebViewClient.onPageFinished", Toast.LENGTH_SHORT).show();
123 super.onPageFinished(view, url);
124 }
125
126 @Override
127 public void onLoadResource(WebView view, String url) {
128 Toast.makeText(getApplicationContext(), "WebViewClient.onLoadResource", Toast.LENGTH_SHORT).show();
129 super.onLoadResource(view, url);
130 }
131
132 };
133
134 // 设置WebViewClient对象
135 wv.setWebViewClient(wvc);
136
137 // 创建WebViewChromeClient
138 WebChromeClient wvcc = new WebChromeClient() {
139
140 // 处理Alert事件
141 @Override
142 public boolean onJsAlert(WebView view, String url, String message, final JsResult result) {
143 // 构建一个Builder来显示网页中的alert对话框
144 Builder builder = new Builder(MainWebView3.this);
145 builder.setTitle("计算1+2的值");
146 builder.setMessage(message);
147 builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() {
148 @Override
149 public void onClick(DialogInterface dialog, int which) {
150 result.confirm();
151 }
152 });
153 builder.setCancelable(false);
154 builder.create();
155 builder.show();
156 return true;
157 }
158
159 @Override
160 public void onReceivedTitle(WebView view, String title) {
161 MainWebView3.this.setTitle("可以用onReceivedTitle()方法修改网页标题");
162 super.onReceivedTitle(view, title);
163 }
164
165 // 处理Confirm事件
166 @Override
167 public boolean onJsConfirm(WebView view, String url, String message, final JsResult result) {
168 Builder builder = new Builder(MainWebView3.this);
169 builder.setTitle("删除确认");
170 builder.setMessage(message);
171 builder.setPositiveButton(android.R.string.ok, new AlertDialog.OnClickListener() {
172
173 @Override
174 public void onClick(DialogInterface dialog, int which) {
175 result.confirm();
176 }
177
178 });
179 builder.setNeutralButton(android.R.string.cancel, new AlertDialog.OnClickListener() {
180
181 @Override
182 public void onClick(DialogInterface dialog, int which) {
183 result.cancel();
184 }
185
186 });
187 builder.setCancelable(false);
188 builder.create();
189 builder.show();
190 return true;
191 }
192
193 // 处理提示事件
194 @Override
195 public boolean onJsPrompt(WebView view, String url, String message, String defaultValue,
196 JsPromptResult result) {
197 // 看看默认的效果
198 return super.onJsPrompt(view, url, message, defaultValue, result);
199 }
200 };
201
202 // 设置setWebChromeClient对象
203 wv.setWebChromeClient(wvcc);
204 }
205 }
3、运行程序,查看结果:
发表评论
-
Android使用binder访问service的方式
2013-08-23 09:42 16481. 我们先来看一个与本地service通信的例子。 pub ... -
android-Service和Thread的区别
2013-08-23 09:17 921servie是系统的组件,它由系统进程托管(servicema ... -
git介绍
2013-08-01 14:49 1051git介绍 使用Git的第一件事就是设置你的名字和email ... -
cocos2d-x学习之自动内存管理和常见宏
2013-07-29 15:41 9121.自动内存管理 1)概述 C++语言默认是 ... -
cocos2dx中利用xcode 调用java中的函数
2013-07-29 11:36 25351. 先把cocos2dx根目录中的 /Users/zhaos ... -
cocos2dx(v2.x)与(v1.x)的一些常用函数区别讲解
2013-07-29 10:35 1113第一个改动: CCLayer初始化 自定义Layer,类名 ... -
xcode与eclipse整合cocos2dx
2013-07-29 10:32 1224文档xcode版本是 204 1. 在xcode中创建coc ... -
git提交代码
2013-07-23 16:00 10631. 在本地创建一个Git的工作空间,在里面创建一个工程(如H ... -
Android.mk的用法和基础
2013-07-19 14:11 4359一个Android.mk file用来向编译系统描述你的源代码 ... -
eclipse配置NDK-Builder命令
2013-07-18 11:02 10421. 2. -
eclipse配置javah命令
2013-07-18 10:48 20231.找到javah命令所在的目录 我的为 /usr/bi ... -
Android SDL2.0 编译
2013-07-17 13:40 19751,下载: wget http://www.libsdl.o ... -
IntelliJ Idea 常用快捷键列表
2013-05-27 10:19 0Alt+回车 导入包,自动修 ... -
android应用后台安装
2013-05-21 12:02 1034android应用后台安装,静默安装的代码实现方法 http ... -
编译linux内核映像
2013-05-21 11:33 968a)准备交叉编译工具链 android代码树中有一个pr ... -
如何单独编译Android源代码中的模块
2013-05-21 11:29 999一. 首先在Android源代码 ... -
Ubuntu安装JDK6和JDK5
2013-05-19 19:04 1015sudo apt-get install sun-java6- ... -
java_jni详解_01
2013-05-08 17:15 962java中的jni 例子HelloWorld 准备过程: 1 ... -
下载android源码 中断解决原因
2013-05-07 15:51 1325解决方法 1. 浏览器登录https://android.go ... -
mac下编译ffmpeg1.1.4
2013-05-07 14:55 1368经过一番网上搜索 与 无数次的编译 终于成功了 下面献上编译 ...
相关推荐
Android WebView 使用方法总结 Android WebView 是一个非常强大的控件,允许开发者在 Android 应用程序中嵌入 Web 内容。下面是 Android WebView 使用方法总结的一些重要知识点: 一、WebViewClient 的使用 在 ...
【WebView_Demo】是一个以Android平台上的WebView组件为主题的示例项目。...这个项目对于学习和理解Android中的WebView使用方法非常有帮助,开发者可以通过分析源码,进一步提升在移动应用中集成网页内容的能力。
5. **性能优化**:启用缓存,使用`shouldOverrideUrlLoading()`避免不必要的重载,以及使用`WebView.setLayerType()`提高渲染性能。 总之,“WebView JS方法调用”是Android开发中一个常用且重要的技术,它能够实现...
在本示例中,“使用webview 封装使用了webrtc 打开摄像头的页面demo”意味着我们要在Webview中集成Webrtc,以便在Android应用中通过Web接口调用摄像头功能。 首先,我们需要了解Webview的基本用法。在...
- 对于复杂的网页,考虑使用原生网络库(如OkHttp)加载数据,再通过`loadData()`或`loadDataWithBaseURL()`方法加载到`WebView`中。 通过上述内容,开发者可以掌握`WebView`的基本使用和高级技巧,结合提供的博客...
WebView简单使用Demo通常会展示如何在Android应用中加载和展示一个网页,以及一些基本的交互功能。接下来,我们将深入探讨WebView的相关知识点。 1. **WebView的基本使用** - 首先,在布局文件(如`activity_main....
Android WebView组件加载网页时,可以使用多种方法。可以使用x.loadUrl("***")直接加载一个网页地址,或者使用x.loadDataWithBaseURL("", data, "text/html", "UTF-8", "")来加载本地的HTML内容。后者可以减少延迟,...
【WebView的使用详解】 在Android应用开发中,WebView是一个非常重要的组件,它允许开发者在应用程序内部展示网页内容,实现与网页的交互。本教程将深入探讨WebView的基本使用、配置、功能以及常见问题处理。 一、...
3. 适时释放资源:在不再使用WebView时,调用`destroy()`方法释放资源。 总的来说,WebView是Android开发中不可或缺的一部分,熟练掌握其使用和配置,能有效提升应用的功能性和用户体验。在实际开发中,应根据项目...
5. **监听WebView的加载事件**:为了处理可能的重定向或动态添加的cookie,你可以监听`WebViewClient`的`shouldInterceptRequest`方法,以便在每次请求前设置或更新cookie。 6. **处理隐私政策和权限**:由于涉及...
使用WebView的loadUrl()方法加载网页: ```java webView.loadUrl("http://www.example.com"); ``` 或者使用loadData()加载本地HTML字符串: ```java String htmlContent = "<html><body><h1>Hello, World!...
本文将深入探讨Android WebView的使用方法,包括如何打开指定网页、处理页面跳转、传递数据、支持JavaScript以及优化用户体验等方面。 1. 打开指定URL网页: 要加载一个网页,首先需要实例化WebView对象并设置其...
以下是关于Android WebView的使用方法和与JavaScript相互调用的详细说明。 首先,使用WebView之前需要在AndroidManifest.xml文件中添加网络权限,这是允许WebView访问互联网的必要步骤: ```xml ``` 接下来,...
在AndroidManifest.xml中,需要为使用WebView的Activity添加Internet权限: ```xml ``` 然后,在布局文件(如activity_main.xml)中添加WebView组件: ```xml <WebView android:id="@+id/web_view" android:...
5. **执行JavaScript**:使用WebView的evaluateJavascript()方法执行JavaScript代码,并获取回调结果。 6. **权限管理**:如果涉及到网络访问,需要在AndroidManifest.xml中声明INTERNET权限。 7. **安全考虑**:...
10. **销毁与内存管理**:当不再使用WebView时,记得调用`destroy()`方法来释放资源,防止内存泄漏。 以上就是WebView的基本使用和关键配置。在实际开发中,开发者还可以根据需求进一步探索其他高级特性,如设置...