按照我一慣得套路,我會先說一點廢話。PhoneGap和Cordova什麼關係?爲什麼有的地方叫Cordova而有的地方叫PhoneGap ?PhoneGap是一款HTML5平臺,經過它,開發商能夠使用HTML、CSS及JavaScript來開發本地移動應用程序。所以,目前開發商能夠只編寫一次應用程序,而後在6個主要的移動平臺和應用程序商店(app store)裏進行發佈,這些移動平臺和應用程序商店包括:iOS、Android、BlackBerry、webOS、bada以及Symbian。Apache Cordova是PhoneGap貢獻給Apache後的開源項目,是從PhoneGap中抽出的核心代碼,是驅動PhoneGap的核心引擎。大概意思也就是說:Cordova是由PhoneGap發展而來的,如今的Cordova就是當年的PhoneGap。因此下文中我來回的切換叫法,其實都是一個東西而已。 html
下面言歸正傳,如何在PhoneGap或者Cordova框架下實現JS調用Android原生代碼?(這裏就再也不囉嗦如何在Android程序中集成PhoneGap了) html5
1.在你的html5中config.js定義你的Plugin的名稱和方法。名爲MyPlugin,有兩個插件:一個爲自動更新(Update),一個爲密碼鎖定(PassLock) android
var MyPlugin = {
UpDate: function (success, fail, url) {
return PhoneGap.exec(function (args) {
success(args);
}, function (args) {
fail(args);
}, 'UpDate', 'Update', [url]);
},
PassLock: function (success, fail, url){
return PhoneGap.exec(function (args) {
success(args);
}, function (args) {
fail(args);
}, 'PassLock', 'PassLock', [url]);
}
};
web
2.在xml文件夾下的plugin裏註冊你的Plugin. app
<plugin name="UpDate" value="com.gapsh.plugin.UpdatePlugin"/>
<plugin name="PassLock" value="com.gapsh.plugin.PassLockPlugin"/>
框架
3.自定義你的Plugin類和處理方法.(這裏只貼出了自動更新插件的代碼,很簡單,只是做了一個跳轉) ide
public class UpdatePlugin extends Plugin {
@Override
public PluginResult execute(String arg0, JSONArray arg1, String arg2) {
/*
* 跳轉到UpdateActivity
*/
Intent intent = new Intent(ctx.getContext(),UpdateActivity.class);
ctx.startActivity(intent);
String result = "跳轉至UpdateActivity";
PluginResult pluginResult = new PluginResult(Status.OK, result);
return pluginResult;
}
} 工具
4.在你的JS中調用你的插件。 測試
//自動更新
upDate: function () {
//調用android原生的方法檢查並更新
MyPlugin.UpDate(function(){},function(){},'這裏是一個參數,我這裏不涉及參數的使用,因此隨便寫');
},
passLock: function(){
//調用android原生的方法進行密碼鎖定有關操做
MyPlugin.PassLock(function(){},function(){},'這裏是一個參數,我這裏不涉及參數的使用,所隨便寫');
},
url
5.測試,當你點擊你的某個按鈕或者連接執行你的update:function這個JS,而後在JS裏調用了MyPlugin下的Update插件,這個插件在config.js裏被定義,在plugin.xml中被註冊,插件具體執行的地方時UpdatePlugin裏的execute()方法。執行完這個方法後,你就已經調用了Android的原生代碼咯,固然我這裏是設置成了跳轉到另一個Activity.
所需工具打包下載:http://pan.baidu.com/share/link?shareid=1636341858&uk=2937351404
如何您有任何疑問,歡迎EmailToMe:junkedeng@163.com