栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 移动开发 > Android

android使用webwiew载入页面使用示例(Hybrid App开发)

Android 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

android使用webwiew载入页面使用示例(Hybrid App开发)

Hybrid App 是混合模式应用的简称,兼具 Native App 和 Web App 两种模式应用的优势,开发成本低,拥有 Web 技术跨平台特性。目前大家所知道的基于中间件的移动开发框架都是采用的 Hybrid 开发模式,例如国外的 PhoneGap、Titanium、Sencha,还有国内的 AppCan、Rexsee 等等。Hybrid App 开发模式正在被越来越多的公司和开发者所认同,相信将来会成为主流的移动应用开发模式。

Hybrid App 融合 Web App 的原理就是嵌入一个WebView组件,可以在这个组件中载入页面,相当于内嵌的浏览器,代码如下:

复制代码 代码如下:
import android.app.Activity;
import android.os.Bundle;
import android.webkit.WebSettings;
import android.webkit.WebView;

public class AActivity extends Activity{

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 创建WebView
        WebView webView= new WebView(this);
        // 切换到内容视图
        setContentView(webView);
        // 获取WebView配置
        WebSettings ws = webView.getSettings();
        // 启用Javascript
        ws.setJavascriptEnabled(true);
        // 载入assets目录下的一个页面
        webView.loadUrl("file:///android_asset/www/BoBox/index.html");
    }
}

还有另一种引入方式是在布局文件中添加 WebView 组件,代码如下:

复制代码 代码如下:

    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">   
            android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:id="@+id/webview"
        />       

复制代码 代码如下:
import android.app.Activity;
import android.os.Bundle;
import android.webkit.WebSettings;
import android.webkit.WebView;

public class BActivity extends Activity{

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.webview);
        // 查找WebView
        WebView webView = (WebView) findViewById(R.id.webview);
        // 获取WebView配置
        WebSettings ws = webView.getSettings();
        // 启用Javascript
        ws.setJavascriptEnabled(true);
        // 在载入assets目录下的一个页面
        webView.loadUrl("file:///android_asset/www/index.html");
    }
}

WebView 还有一个非常重要的方法——addJavascriptInterface,可以用来实现 Java 程序和 Javascript 程序的相互调用,代码如下:

复制代码 代码如下:
webView.addJavascriptInterface(new Object(){
    public void clickonAndroid(){
        mHandler.post(new Runnable(){
            public void run(){
                webView.loadUrl("javascript:wave()");
            }
        });
    }
}, "demo");

页面代码如下:

复制代码 代码如下:



    
        Click Me
    


这样,当你点击页面上 Click Me 按钮的时候就会调用 Java 代码中的 clickonAndroid 函数,clickonAndroid 函数中又调用页面中的 wave 方法。需要注意的是:这个接口在 Android 2.3 版本的模拟器中运行会导致 WebView 崩溃,目前还没有修复。这是一个非常简单的演示 Java 和 Javascript 相互调用的例子,在实际应用中可以在页面调用的 clickonAndroid 函数中再调用摄像头、通讯录、通知提醒等设备功能。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/164638.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号