Cordova 构建 Android 混合应用

写在前面

如今,HyBridApp开发的框架有很多,本文将阐述如何在Mac平台下,使用 Appache Cordova 框架构建Android混合应用。

需要的工具

cordova-android(下载链接)

用于混合应用的创建、运行等。

Android Studio(下载链接)

应用编辑环境。

plugman(下载链接)

用于管理项目中的插件。安装、卸载等。

创建混合应用

命令行创建应用

命令格式:create 应用名 包名

create HybridAndroidApp cn.sample.hybridandroidapp

应用创建成功输出:

Creating Cordova project for the Android platform:
Path: HybridAndroidApp
Package: cn.sample.hybridandroidapp
Name: Hello_Cordova
Activity: MainActivity
Android target: android-23
Android project created with cordova-android@5.2.0-dev

项目目录结构图:

在项目目录下命令行下载所需插件

plugman install --platform android --project . --plugin cordova-plugin-whitelist
plugman install --platform android --project . --plugin cordova-plugin-device
plugman install --platform android --project . --plugin nl.x-services.plugins.toast

下载好的插件以文件夹方式放在cordova/plugins/目录下(新建的Cordova项目不存在plugins目录,会自动在下载插件时自动新建)。同时,在src目录下,也会自动生成插件对应的包及Java文件。

将项目导入Android Studio并成功运行

调用Android原生API

Cordova插件

Cordova插件是一个引入到Cordova项目里的一个包(目录),它为Cordova webview与运行平台创建了一个连接,使得它们可以进行通信。

自定义插件

插件目录结构图

plugin.xml 文件内容解析

    <?xml version="1.0" encoding="UTF-8"?>

    <!--
          id:用于唯一标识插件,Android一般用插件所在java包名表示,例:cordova-aplugin-toast;
              这个id会生成插件目录(CordovaProject/cordova/plugins/cordova-aplugin-toast)。
     version:自定义。
    -->
    <plugin xmlns="http://apache.org/cordova/ns/plugins/1.0"
        id=""
          version="">

    <!-- 插件名 -->
    <name></name>

    <!-- 插件描述 -->
    <description>Cordova Device Plugin</description>

    <!-- 一般就这个 -->
    <license>Apache 2.0</license>
    <!-- 一般就这个 -->
    <keywords>cordova,device</keywords>

    <!-- 公共JS接口引用,各个平台都需要引入,为cordova-plugin-device下的接口 -->
    <js-module src="www/device.js" name="device">
        <clobbers target="device" />
    </js-module>

    <!-- 平台名(android、ios、windows、osx等),如果插件适用于多个平台,那么有多少个平台就需要多少个<platform>标签-->
    <platform name="">
        <!-- CordovaProject/res/xml/config.xml文件中会加入以下信息,让平台知道这个插件的存在 -->
        <!-- 固定值 -->
        <config-file target="config.xml" parent="/*">
            <!-- 插件名 -->
            <feature name="">
                <!--
                     name:格式为:平台名-package,例如:android-package、ios-package、wp-package等
                     value:插件全类名(Android)
                -->
                <param name="" value=""/>
                <!-- param标签可有多个,例如:<param name="onload" value="true"/>(启动应用时加载这个插件)等 -->

            </feature>
        </config-file>

        <!-- 源文件引入 -->
        <!-- android
             src:java文件在当前插件目录中的路径,例:src/android/HybridBridge.java
             target-dir:Cordova项目中引入路径,即放在项目中src下的哪个包中。例:src/cn/sample/hybrid
         -->
        <source-file src="" target-dir=""/>

        <!-- ios
            <header-file src="src/ios/CDVDevice.h" />
            <source-file src="src/ios/CDVDevice.m" />
        -->

    </platform>
    </plugin>

plugin.xml文件官方介绍点这里

编写js接口(需要node.js 知识)

cordova.exec 方法参数说明

cordova.exec(
// 调用成功的回调函数
function(winParam) {  }, 
// 调用失败的回调函数 
function(error){ },
// 服务名,Android平台对应类名  
"ToastPlugin", 
// 类中方法名 
"show", 
// 方法需要的参数,以数组形式传递
["firstArgument", "secondArgument", 42, false]
);

简单js接口示例

var ToastPlugin{
show:function(showCont,successCallback,failCallback){ 
     cordova.exec(successCallback,fialCallback,"ToastPlugin","show",[showCont]); } 
} 
module.exports = ToastPlugin;

编写对应平台本地接口(与平台相关)

Android平台接口编写示例

 // 直接在项目中对应目录下编写这个接口,这样可以自动导包。
 // 编写好后复制到存放插件的对应目录即可,可参见自定义插件目录
    pulbic class ToastPlugin{
        
        // action:需要执行的操作,区分不同事件
        // args:需要的参数
        // back:回调对象
        @override
        public boolean execute(String action,JSONArray args,CallbackContext back) throws JSONException{
            
            if (args == null || args.length() < 1 || args.get(0) == null){
                
                back.error("fail");
                return false;
                
            };

            Activity aty = cordova.getActivity();
            Toast.makeText(aty,args.get(0).toString(),Toast.LENGTH_LONG).show();
            back.success("success!");
            return true;
        
        }
        
    
    }

插件管理

plugman 安装插件

plugman install --platform <ios|amazon-fireos|android|blackberry10|wp8> --project <directory> --plugin <name|url|path> [--plugins_dir <directory>] [--www <directory>] [--variable <name>=<value> [--variable <name>=<value> ...]]

--platform:平台
--plugin:插件路径、网络地址、插件id都可以。
--project:cordova项目路径。
例:

plugman install --platform android --plugin /Users/sharp/DevTools/Cordova-Android/cordova-custom-plugin/ToastPlugin --project .

plugman 卸载插件

plugman uninstall --platform <ios|amazon-fireos|android|blackberry10|wp8> --project <directory> --plugin <id> [--www <directory>] [--plugins_dir <directory>]

--platform:平台。
--plugin:需要卸载的插件id。
--project:cordova项目路径。
例:

plugman uninstall --platform android --plugin cordova-aplugin-toast --project .

Web端编写

Web 文件存放目录

项目/aseets

编写Html页面对应js文件

    var app = {
        
        // app default function start
        // Application Constructor  
        initialize: function() {
            this.bindEvents();
        },
        
        // Bind Event Listeners
        //
        // Bind any events that are required on startup. Common events are:
        // 'load', 'deviceready', 'offline', and 'online'.
        bindEvents: function() {
            document.addEventListener('deviceready', this.onDeviceReady, false);
        },
        
        // deviceready Event Handler
        //
        // The scope of 'this' is the event. In order to call the 'receivedEvent'
        // function, we must explicitly call 'app.receivedEvent(...);'
        onDeviceReady: function() {
            // 为指定元素添加监听 
            // 例:document.getElementById("your id").addEventListener("click", app.showToast);
            app.receivedEvent('deviceready');
        },
        
        // Update DOM on a Received Event
        receivedEvent: function(id) {
            var parentElement = document.getElementById(id);
            var listeningElement = parentElement.querySelector('.listening');
            var receivedElement = parentElement.querySelector('.received');

            listeningElement.setAttribute('style', 'display:none;');
            receivedElement.setAttribute('style', 'display:block;');

            console.log('Received Event: ' + id);
        },
        // app default function end
        
        // your function start here

    }

    app.initialize();

Html 页面

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="utf-8">
    <title>title</title>
    
    <!-- PhoneGap Libray-->
    <script type="text/javascript" src="cordova.js"></script>
    <!-- Your js file-->
    </head>
    
    <body>
        // your html body
    </body>
    
    </html>

调用原生接口执行顺序

js点击函数 > js接口 > 原生接口 > 回调函数

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 195,653评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,321评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,833评论 0 324
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,472评论 1 266
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,306评论 4 357
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,274评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,658评论 3 385
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,335评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,638评论 1 293
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,697评论 2 312
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,454评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,311评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,699评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,986评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,254评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,647评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,847评论 2 335

推荐阅读更多精彩内容