Cordova 構(gòu)建 Android 混合應(yīng)用

寫在前面

如今旨剥,HyBridApp開發(fā)的框架有很多芒涡,本文將闡述如何在Mac平臺(tái)下泽篮,使用 Appache Cordova 框架構(gòu)建Android混合應(yīng)用坊秸。

需要的工具

cordova-android(下載鏈接)

用于混合應(yīng)用的創(chuàng)建、運(yùn)行等选脊。

Android Studio(下載鏈接)

應(yīng)用編輯環(huán)境杭抠。

plugman(下載鏈接)

用于管理項(xiàng)目中的插件。安裝恳啥、卸載等偏灿。

創(chuàng)建混合應(yīng)用

命令行創(chuàng)建應(yīng)用

命令格式:create 應(yīng)用名 包名

create HybridAndroidApp cn.sample.hybridandroidapp

應(yīng)用創(chuàng)建成功輸出:

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

項(xiàng)目目錄結(jié)構(gòu)圖:

在項(xiàng)目目錄下命令行下載所需插件

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項(xiàng)目不存在plugins目錄,會(huì)自動(dòng)在下載插件時(shí)自動(dòng)新建)钝的。同時(shí)菩混,在src目錄下忿墅,也會(huì)自動(dòng)生成插件對(duì)應(yīng)的包及Java文件。

將項(xiàng)目導(dǎo)入Android Studio并成功運(yùn)行

調(diào)用Android原生API

Cordova插件

Cordova插件是一個(gè)引入到Cordova項(xiàng)目里的一個(gè)包(目錄)沮峡,它為Cordova webview與運(yùn)行平臺(tái)創(chuàng)建了一個(gè)連接疚脐,使得它們可以進(jìn)行通信。

自定義插件

插件目錄結(jié)構(gòu)圖

plugin.xml 文件內(nèi)容解析

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

    <!--
          id:用于唯一標(biāo)識(shí)插件邢疙,Android一般用插件所在java包名表示棍弄,例:cordova-aplugin-toast;
              這個(gè)id會(huì)生成插件目錄(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>

    <!-- 一般就這個(gè) -->
    <license>Apache 2.0</license>
    <!-- 一般就這個(gè) -->
    <keywords>cordova,device</keywords>

    <!-- 公共JS接口引用呼畸,各個(gè)平臺(tái)都需要引入,為cordova-plugin-device下的接口 -->
    <js-module src="www/device.js" name="device">
        <clobbers target="device" />
    </js-module>

    <!-- 平臺(tái)名(android颁虐、ios蛮原、windows、osx等)另绩,如果插件適用于多個(gè)平臺(tái)儒陨,那么有多少個(gè)平臺(tái)就需要多少個(gè)<platform>標(biāo)簽-->
    <platform name="">
        <!-- CordovaProject/res/xml/config.xml文件中會(huì)加入以下信息,讓平臺(tái)知道這個(gè)插件的存在 -->
        <!-- 固定值 -->
        <config-file target="config.xml" parent="/*">
            <!-- 插件名 -->
            <feature name="">
                <!--
                     name:格式為:平臺(tái)名-package,例如:android-package笋籽、ios-package蹦漠、wp-package等
                     value:插件全類名(Android)
                -->
                <param name="" value=""/>
                <!-- param標(biāo)簽可有多個(gè),例如:<param name="onload" value="true"/>(啟動(dòng)應(yīng)用時(shí)加載這個(gè)插件)等 -->

            </feature>
        </config-file>

        <!-- 源文件引入 -->
        <!-- android
             src:java文件在當(dāng)前插件目錄中的路徑车海,例:src/android/HybridBridge.java
             target-dir:Cordova項(xiàng)目中引入路徑笛园,即放在項(xiàng)目中src下的哪個(gè)包中。例: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文件官方介紹點(diǎn)這里

編寫js接口(需要node.js 知識(shí))

cordova.exec 方法參數(shù)說明

cordova.exec(
// 調(diào)用成功的回調(diào)函數(shù)
function(winParam) {  }, 
// 調(diào)用失敗的回調(diào)函數(shù) 
function(error){ },
// 服務(wù)名,Android平臺(tái)對(duì)應(yīng)類名  
"ToastPlugin", 
// 類中方法名 
"show", 
// 方法需要的參數(shù)侍芝,以數(shù)組形式傳遞
["firstArgument", "secondArgument", 42, false]
);

簡單js接口示例

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

編寫對(duì)應(yīng)平臺(tái)本地接口(與平臺(tái)相關(guān))

Android平臺(tái)接口編寫示例

 // 直接在項(xiàng)目中對(duì)應(yīng)目錄下編寫這個(gè)接口研铆,這樣可以自動(dòng)導(dǎo)包。
 // 編寫好后復(fù)制到存放插件的對(duì)應(yīng)目錄即可州叠,可參見自定義插件目錄
    pulbic class ToastPlugin{
        
        // action:需要執(zhí)行的操作棵红,區(qū)分不同事件
        // args:需要的參數(shù)
        // back:回調(diào)對(duì)象
        @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:平臺(tái)
--plugin:插件路徑、網(wǎng)絡(luò)地址留量、插件id都可以。
--project:cordova項(xiàng)目路徑哟冬。
例:

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:平臺(tái)楼熄。
--plugin:需要卸載的插件id。
--project:cordova項(xiàng)目路徑浩峡。
例:

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

Web端編寫

Web 文件存放目錄

項(xiàng)目/aseets

編寫Html頁面對(duì)應(yīng)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() {
            // 為指定元素添加監(jiān)聽 
            // 例: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>

調(diào)用原生接口執(zhí)行順序

js點(diǎn)擊函數(shù) > js接口 > 原生接口 > 回調(diào)函數(shù)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末可岂,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子翰灾,更是在濱河造成了極大的恐慌缕粹,老刑警劉巖稚茅,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異平斩,居然都是意外死亡亚享,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門绘面,熙熙樓的掌柜王于貴愁眉苦臉地迎上來欺税,“玉大人,你說我怎么就攤上這事揭璃⊥碓洌” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵瘦馍,是天一觀的道長歼秽。 經(jīng)常有香客問我,道長情组,這世上最難降的妖魔是什么燥筷? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮呻惕,結(jié)果婚禮上荆责,老公的妹妹穿的比我還像新娘。我一直安慰自己亚脆,他們只是感情好做院,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著濒持,像睡著了一般键耕。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上柑营,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天屈雄,我揣著相機(jī)與錄音,去河邊找鬼官套。 笑死酒奶,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼陕截,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼绢要!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎严望,沒想到半個(gè)月后摆尝,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體温艇,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年堕汞,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了勺爱。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡臼朗,死狀恐怖邻寿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情视哑,我是刑警寧澤绣否,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站挡毅,受9級(jí)特大地震影響蒜撮,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜跪呈,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一段磨、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧耗绿,春花似錦苹支、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至究反,卻和暖如春寻定,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背精耐。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來泰國打工狼速, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人卦停。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓向胡,卻偏偏與公主長得像,于是被迫代替她去往敵國和親惊完。 傳聞我的和親對(duì)象是個(gè)殘疾皇子僵芹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容