最新开班
课程名称 报名截止 报名人数
高中起点学习班 即将开班 热招中
企业委培订制班 即将开班 热招中
私人名师辅导班 即将开班 热招中
待业速找工作班 即将开班 热招中
专家大课堂
accp
accp
男生
女生学什么好?女生学什么有前途?
高中落榜怎么办?高中生可以学软件么?
专职、再就业,让你的生涯不再与苦累相伴。
联系方式
地图

免费咨询:400-696-8028

报名电话:0731-88122069

学校地址:长沙市开福区金霞跨境产贸城北大青鸟校区

Android与JavaScript方法相互调用

 在Android中通过WebView控件,可以实现要加载的页面与Android方法相互调用,我们要实现WebView中的addJavas criptInterface方法,这样html才能调用android方法,在这里我个人觉得有点和DWR相似。

为了让大家容易理解,我写了*个简单的Demo,具体步骤如下:

第步:新建*个Android工程,命名为WebViewDemo(这里我在assets里定义了*个html页面)。

第二步:修改main.xml布局文件,增加了*个WebView控件还有Button控件,代码如下:

1
<?xml version="1.0" encoding="utf-8"?>

第三步:在assets目录下新建*个demo.html文件,代码如下(这里不知道为何多了mce:这几个东东,<s cript></s cript>这样是对的):

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<html>
        <mce:s cript language="javas cript"><!--
      
                function fillContent(){
                        document.getElementById("content").innerHTML =
                             "This Content is showed by Android invoke Javas cript function.";
                }
             
// --></mce:s cript> 
  <body>
        <p><a onClick="window.demo.startMap()" href="">Start GoogleMap</a></p>
        <p id="content"></p>
        <p>A Demo ----Android and Javas cript invoke each other.</p>
        <p>Author:Frankiewei</p>
  </body>
</html>

第四步:修改主核心程序WebViewDemo.java,代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
package com.tutor.webwiewdemo;
import android.app.Activity;
import android.content.ComponentName;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.widget.Button;
public class WebViewDemo extends Activity {
        private WebView mWebView;
        private Button mButton;
        public void onCreate(Bundle savedInstanceState) {
                super.onCreate(savedInstanceState);
                setContentView(R.layout.main);
                setupViews();
        }
        //初始化
        private void setupViews() {
                mWebView = (WebView) findViewById(R.id.webview);
                WebSettings mWebSettings = mWebView.getSettings();
                //加上这句话才能使用javas cript方法
                mWebSettings.setJavas criptEnabled(true);
                //增加接口方法,让html页面调用
                mWebView.addJavas criptInterface(new Object() {
                        //这里我定义了*个打开地图应用的方法
                        public void startMap() {
                                Intent mIntent = new Intent();
                                ComponentName component = new ComponentName(
                                                "com.google.android.apps.maps",
                                                "com.google.android.maps.MapsActivity");
                                mIntent.setComponent(component);
                                startActivity(mIntent);
                        }
                }, "demo");
                //加载页面
                mWebView.loadUrl("file:///android_asset/demo.html");
                mButton = (Button) findViewById(R.id.button);
                //给button添加事件响应,执行Javas cript的fillContent()方法
                mButton.setOnClickListener(new Button.OnClickListener() {
                        public void onClick(View v) {
                                mWebView.loadUrl("javas cript:fillContent()");
                        }
                });
        }
}

第五步:运行上述工程,查看效果。


*界面                           点击按钮时,html内容改变


点击html的startGoogleMap启动地图应用

上一篇:软件测试的起源和由来
下一篇:Android批量插入数据效率对比

长沙科泰
长沙科泰
长沙科泰IT教育