Android中WebView载入本地HTML代码并实现Java与JavaScript交互的例子

正在开发一个地图程序, 相对于用XML写安卓界面, 我更愿意用这个偷懒的办法,
就是不用Android自带的MapView, 而是使用之前就已经比较熟悉的Google Maps JavaScript API,
在Android的WebView中载入HTML代码, 利用Android提供的强大的Java与Js的交互功能,
用网页作为界面来开发程序,同时也可以用Js回调机器的本地功能比如GPS等.

下面提供一个演示的例子,代码如下:

1 package com.aloong.map;
2
3 import android.app.Activity;
4 import android.os.Bundle;
5 import android.os.Handler;
6 import android.webkit.WebSettings;
7 import android.webkit.WebView;
8
9 public class MyMap extends Activity {
10
11privatestaticStringTAG=MyMap.class.getName();
12privateWebViewmWebView;
13privateHandlermHandler;
14privateWebSettingsmWebSettings;
15
16/***//**Calledwhentheactivityisfirstcreated.*/
17@Override
18publicvoidonCreate(BundlesavedInstanceState){
19super.onCreate(savedInstanceState);
20setContentView(R.layout.main);
21
22mWebView=(WebView)this.findViewById(R.id.webview);
23mHandler=newHandler();
24
25//设置支持JavaScript等
26mWebSettings=mWebView.getSettings();
27mWebSettings.setJavaScriptEnabled(true);
28mWebSettings.setBuiltInZoomControls(true);
29mWebSettings.setLightTouchEnabled(true);
30mWebSettings.setSupportZoom(true);
31mWebView.setHapticFeedbackEnabled(false);
32//mWebView.setInitialScale(0);//改变这个值可以设定初始大小
33
34//重要,用于与页面交互!
35mWebView.addJavascriptInterface(newObject(){
36@SuppressWarnings("unused")
37publicvoidoneClick(finalStringlocX,finalStringlocY){//此处的参数可传入作为js参数
38mHandler.post(newRunnable(){
39publicvoidrun(){
40mWebView.loadUrl("javascript:shows('"+locX+"','"+locY+"')");
41}

42}
);
43}

44}
,"demo");//此名称在页面中被调用,方法如下:
45//<bodyonClick="window.demo.clickOnAndroid(event.pageX,event.pageY)">
46
47finalStringmimeType="text/html";
48finalStringencoding="utf-8";
49finalStringhtml="";//TODO从本地读取HTML文件
50
51mWebView.loadDataWithBaseURL("file:///sdcard/",html,mimeType,
52encoding,"");
53
54}

55}


运行以上代码,就可以在程序中打开自己写的html页面.并且实现Java与JavaScript的双向交互.
我们甚至可以在页面中使用JQuery之类的框架制作出很好看的效果,而这比写Android代码我觉得简单多了.

更多相关文章

  1. Android中布局的巧妙设计【android进化二十六】
  2. Android(安卓)NDK Hello + JNI 与 NDK区别
  3. Android(安卓)使用OpenCV的三种方式(Android(安卓)Studio)
  4. Android高手进阶教程(二十五)之---Android(安卓)中的AIDL!!!
  5. Android(安卓)富文本编辑器RichEdit,完整demo
  6. 移植 C/C++ 代码至 Android(安卓)平台经验总结
  7. Android底部弹出iOS7风格对话选项框
  8. Android中布局的巧妙设计【android进化二十六】
  9. Android(安卓)正移植到C#

随机推荐

  1. php png失真的原因及解决办法
  2. php没有文件被上传的实例分析及解决办法
  3. 画人物肤色怎么上色?动漫男生皮肤上色教程
  4. 阿里云ECS服务器(G5)安装配置docker
  5. 使用 curl 扩展获取其他服务器资源
  6. PHP扩展之kafka安装应用案例详解
  7. 小白如何练习线稿?画漫画线稿技巧
  8. PHP autoload机制案例详解
  9. laravel的用户修改密码与绑定邮箱的详细
  10. 【Linux】apt软件管理和远程登录