Cordova入門系列(四)自定義Cordova插件--showToast

前三篇Cordova入門系列,簡(jiǎn)單講解了Cordova,以及如何調(diào)用Cordova插件,今天我們講解一下如何自己做一個(gè)插件。

自定義插件,就是自己寫一些安卓java代碼,然后和js代碼以及配置文件,封裝成一個(gè)cordova插件。通過js代碼,調(diào)用安卓java代碼,從而實(shí)現(xiàn)調(diào)用原生的東西。只不過這些調(diào)用原生的行為是我們?yōu)榱宋覀冏约禾囟ǖ男枨髮懙?,而不是Cordova官方的。。。

自定義插件的結(jié)構(gòu):

|---pluginName
    |---src
      |---android
        |---XXX.java

|---ios
    |---www
      |---xxx.js
    |---plugin.xml

我們今天做一個(gè)名字叫showToast的插件,用戶點(diǎn)擊的時(shí)候,會(huì)調(diào)用安卓原生的Toast去顯示。目錄結(jié)構(gòu)如下:

image

先看showToast.js

<pre style="margin: 0px; padding: 0px; white-space: pre-wrap; word-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;">cordova.define("myPlugins.showToast", function(require, exports, module) { var exec = require('cordova/exec'); var myFunc = function(){}; // arg1:成功回調(diào)
// arg2:失敗回調(diào)
// arg3:將要調(diào)用類配置的標(biāo)識(shí),要在feature中配置的
// arg4:調(diào)用的原生方法名
// arg5:參數(shù),json格式
myFunc.prototype.show=function(success, fail) {
exec(success, fail, "ShowToast", "show", []);
}; var showtoast = new myFunc();
module.exports = showtoast;
});</pre>

再看ShowToast.java

<pre style="margin: 0px; padding: 0px; white-space: pre-wrap; word-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;">package myPlugin; import org.apache.cordova.CallbackContext; import org.apache.cordova.CordovaPlugin; import org.json.JSONArray; import org.json.JSONException; import android.app.Activity; import android.widget.Toast; public class ShowToast extends CordovaPlugin {

@Override public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {
    Activity activity = cordova.getActivity(); if("show".equals(action)) {
        Toast.makeText(activity, "this is my plugin showToast", Toast.LENGTH_SHORT).show();
    }

    callbackContext.success("toast success"); return true;
}

}</pre>
  plugin.xml

<pre style="margin: 0px; padding: 0px; white-space: pre-wrap; word-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;"><?xml version="1.0" encoding="UTF-8"?>
<plugin xmlns="http://apache.org/cordova/ns/plugins/1.0" xmlns:android="http://schemas.android.com/apk/res/android" id="myPlugins.showToast" version="0.0.1">
<name>showToast</name>
<description>this is the plugin witch use js to call Toast</description>

<js-module src="www/showToast.js">
    <clobbers target="myPlugins.showToast"/>
</js-module>

<platform name="android">
    <source-file src="src/android/ShowToast.java" target-dir="src/myPlugin"/>

    <config-file target="res/xml/config.xml" parent="/*">
        <feature name="ShowToast">
            <param name="android-package" value="myPlugin.ShowToast"/>
        </feature>
    </config-file>

    <config-file target="AndroidManifest.xml" parent="/*">
        <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    </config-file>
</platform>

</plugin></pre>

安裝這個(gè)插件到項(xiàng)目中,cordova plugin add “插件的路徑”

然后調(diào)用:

<pre style="margin: 0px; padding: 0px; white-space: pre-wrap; word-wrap: break-word; font-family: "Courier New" !important; font-size: 12px !important;">myPlugins.showToast.show(
function(msg){
console.log(msg);
}, function(msg){
console.log(msg);
}
);</pre>

轉(zhuǎn)自:http://www.cnblogs.com/lishuxue/p/6479483.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容