Phonegap插件开发攻略
来源:互联网 发布:淘宝 金肉山 这么便宜 编辑:程序博客网 时间:2024/05/18 16:55
Phonegap的目的是实现跨移动平台的UI开发,是现在比较有潜力的方向。熟悉html开发且有兴趣往安卓方向发展的朋友可以多了解一下。
1. 动手前的准备工作
- 配置开发环境
- 阅读相关资料http://docs.phonegap.com/en/3.4.0/guide_hybrid_plugins_index.md.html#Plugin%20Development%20Guide
2. 开发步骤
phonegap插件由三部分组成源文件(src),js接口(www),以及描述文件(plugin.xml)。
2.1 关于源文件
源文件应该继承于CordovaPlugin,并重写一个excute方法。
2.2 关于描述文件
描述文件范例如下:
<-plugin xmlns="http://apache.org/cordova/ns/plugins/1.0" xmlns:rim="http://www.blackberry.com/ns/widgets" xmlns:android="http://schemas.android.com/apk/res/android" id="notification" version="1.0.0"> <-name>Custom<-/name> <-description>Custom Plugin<-/description> <-license>Apache 2.0<-/license> <-keywords>cordova,Custom<-/keywords> <-js-module src="www/test.js" name="send"> <-clobbers target="tpx" /> <-/js-module> <-platform name="android"> <-config-file target="res/xml/config.xml" parent="/*"> <-feature name="Custom" > <-param name="android-package" value="com.btt.plugin.test.Custom"/> <-/feature> <-/config-file> <-source-file src="src/android/Custom.java" target-dir="src/plugin" /> <-/platform><-/plugin>
其中比较重要的参数有id,js-module等,具体说明如下:
name:没有特殊含义。
id:该插件的标识,com.btt.plugin.custom.该名字可以随意取,没关系。(可以通过phonegap local plugin list命令查看)
js-module:指明js接口。name表示的是action的名字。clobbers是真正使用时的调用者。
platform:平台相关信息。feature name表示的是service name。value属性值必须为源文件入口(包名.类名 full_name_including_namespace)。
source-file:源文件路径。target-dir:目标文件路径,可自定义。若有多个源文件,应该写多行。
插件add以后,可以查看res/xml/config.xml文件的变化
<-feature name=""> <-param name="android-package" value="" />
2.3 关于js接口
插件的执行可直接通过cordova.exec(function(winParam) {},function(error) {},"Custom","send",params);语句执行的。也可通过js接口来执行:
var exec = require('cordova/exec'); exports = {send: function(callback) {var params = [];params.push("android toast"); params.push("博思"); //真正调用的是cordova.exec(...);exec(callback, function(error){alert(error.code + ' ' + error.message);}, "Custom", "send", params);}};
2.4 相关指令
查看已成功安装的插件列表: phonegap local plugin list
添加本地插件: phonegap local plugin add path(e.g D:\phonegap\plugins\com.btt.plugin.test)
移除本地插件: phonegap local plugin remove id
3 其它相关
3.1 关于插件的实例化
插件在被js调用的时候才创建实例,一种情况下例外:
<-feature name="Echo"> <-param name="android-package" value="" /> <-param name="onload" value="true" />
3.1 关于线程
插件的执行接口并不是运行在WebView主线程中,而是运行在WebCore线程中,当需要与UI进行交互,可以通过一下手段:
cordova.getActivity().runOnUiThread(new Runnable() { public void run() { ... callbackContext.success(); // Thread-safe. } });或 cordova.getThreadPool().execute(new Runnable() { public void run() { ... callbackContext.success(); // Thread-safe. } });
苹果拒绝使用PhoneGap开发的iPhone软件
转载请标明出处:http://blog.csdn.net/tpxwantpxwan/article/details/38844375
- Phonegap插件开发攻略
- Phonegap Android插件开发攻略
- phonegap插件开发API
- phonegap插件开发讲解
- PhoneGap 3.4插件开发
- Phonegap iOS 插件开发
- PhoneGap插件开发流程
- IOS下Phonegap 插件开发
- 开发第一个phonegap插件
- PhoneGap插件开发示例(iOS)
- phonegap 2.9版本插件开发
- PhoneGap 12 插件开发指南
- PhoneGap插件开发示例(iOS)
- PhoneGap入门 iOS 插件开发
- phoneGap(cordova)插件开发学习
- 自己动手开发phonegap插件之《phonegap拨打电话插件》
- phoneGap开发IOS,JS调用IOS方法/phoneGap插件开发
- [Phonegap+Sencha Touch] 移动开发64 Phonegap/Cordova 插件开发
- python dict 数据
- JSP内置对象比较与分析(http://mynote.iteye.com/blog/1103102)
- 布尔型变量的初始化问题
- POJ 2155——Matrix(树套树,二维树状数组,二维线段树)
- POJ 2378.1655.3107 (树形DP 删点类树形DP)
- Phonegap插件开发攻略
- WebView自定义背景
- 25个增强iOS应用程序性能的提示和技巧(中级篇)
- JAVA 获取 FULL url
- poj1847 - Tram (最短路径问题) (Dijkstra)
- 骁龙805支持4K显示 内存带宽翻倍是亮点
- ORA-24247: 网络访问被访问控制列表 (ACL) 拒绝
- 什么是字符串常量池
- 主机安全加固--升级openssh及openssl