在编写PhoneGap插件时,要传递多个参数,需要将参数保存在一个参数数组中,然后PhoneGap会自动将参数数组保存在JSONArray数据中;如果要获取返回值,需要编写回调方法将返回值通过参数传递到回调方法中,示例代码如下:
myplugin.js: /** * 构造方法 */ function MyPlugin() {
};
/** * 字符串相加 * * @param str1, str2 */ MyPlugin.prototype.addStr = function(successCallback, failureCallback, str1, str2) { PhoneGap.exec(successCallback, failureCallback, "MyPlugin", "addStr", [str1, str2]); };
/** * 加载MyPlugin对象 */ PhoneGap.addConstructor(function() { PhoneGap.addPlugin("myPlugin", new MyPlugin()); }); |
然后在Java代码中调用JSONArray的getString(int index)方法获取JSONArray中的参数,通过index指定参数的索引就可以取得多个参数了;在Java代码中,返回值是保存在PluginResult对象中的,PluginResult保存了状态和返回值。如果状态为OK,则回调successCallback方法,并将返回值传递到该方法中;如果状态为JSON_EXCEPTION,则回调failureCallback方法,并将错误信息传递到该方法中。示例代码如下:
MyPlugin.java: package com.litsoft.phonegap;
import org.apache.cordova.api.PluginResult; import org.json.JSONArray; import org.json.JSONException;
import com.phonegap.api.Plugin;
public class MyPlugin extends Plugin{
@Override public PluginResult execute(String action, JSONArray args, String callbackId) { PluginResult.Status status = PluginResult.Status.OK; String result = "";
try { if(action.equals("addStr")){ result = addStr(args.getString(0), args.getString(1)); }else{ status = PluginResult.Status.INVALID_ACTION; }
return new PluginResult(status, result); } catch (JSONException e) { return new PluginResult(PluginResult.Status.JSON_EXCEPTION); } }
/** * 两个字符串相加 * * @param str1 * @param str2 * @return */ private String addStr(String str1, String str2){ return str1 + str2; }
}
|
最后在html中调用插件中的方法,通过调用addStr方法就可以将两个输入框的值传递到后台Java代码中运行,后台Java将返回值存储在PluginResult对象中,通过编写回调方法successCallback就可以获取返回值了。示例代码如下:
Index.html: <!DOCTYPE HTML> <html> <head> <title>PhoneGap</title> <script type="text/javascript" charset="utf-8" src="cordova.js"> </script> <script type="text/javascript" charset="utf-8" src="myplugin.js"> </script> <script type="text/javascript" charset="UTF-8">
function add(){ var str1 = document.getElementById("str1Id").value; var str2 = document.getElementById("str2Id").value; window.plugins.myPlugin.addStr(successCallback, failureCallback, str1, str2); } //成功时回调的方法 function successCallback(data){ document.getElementById("resultId").value = data; } //失败时返回的方法 function failureCallback(data){ alert("error:"+ data); } </script> </head> <body> <input type="text" id="str1Id"/> <br /> <input type="text" id="str2Id" /> <br /> <input type="text" id="resultId" /> <input type="button" value="add" οnclick="add();" /> </body> </html> |