前几天写了一个PhoneGap插件,这个插件的功能很简单,就是开启viewport设置。不过与其它插件相比,有好几个有意思的地方,仔细读了PhoneGap的源码才搞定。这里记录一下PhoneGap插件开发的流程,以及开发这个插件遇到的问题。

0.先安装android sdk, node.js,phonegap和plugman。请参考用PhoneGap编译CanTK

1.用plugman创建一个插件:

  1. plugman create --name ViewPort --plugin_id com.tangide.viewport --plugin_version 1.0.0

2.编写JAVA代码: src/android/ViewPort.java

  1. package com.tangide.viewport;
  2. import android.util.Log;
  3. import org.json.JSONArray;
  4. import org.json.JSONObject;
  5. import org.json.JSONException;
  6. import android.webkit.WebSettings;
  7. import org.apache.cordova.CordovaWebView;
  8. import org.apache.cordova.CordovaInterface;
  9. import org.apache.cordova.CordovaPlugin;
  10. import org.apache.cordova.CallbackContext;
  11. public class ViewPort extends CordovaPlugin {
  12. private static final String LOG_TAG = "ViewPort";
  13. @Override
  14. public void initialize(CordovaInterface cordova, CordovaWebView webView) {
  15. final CordovaWebView wv = webView;
  16. super.initialize(cordova, webView);
  17. webView.post(new Runnable() {
  18. @Override
  19. public void run() {
  20. WebSettings ws = wv.getSettings();
  21. ws.setUseWideViewPort(true);
  22. ws.setLoadWithOverviewMode(true);
  23. wv.reload();
  24. Log.d(LOG_TAG, "ViewPort Enabled");
  25. }
  26. });
  27. }
  28. @Override
  29. public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {
  30. Log.d(LOG_TAG, "No Method In This Plugin");
  31. return false;
  32. }
  33. }

这里比较有意思的是,我们的插件并不提供接口,而是在初始化是做些设置。所以initialize函数才是重点,但是遇到两个问题:

一是APP启动时并没有调用插件的initialize函数,仔细研究PhoneGap插件加载流程后才知道需要在plugin.xml里加一项设置。

二是在initialize函数里调用WebSettings出错,原因是初始化线程不是WebView的UI线程。这个问题通过webView.post来解决。

3.修改JS包装插件函数。本插件的JS是www/ViewPort.js,我们不需要提供接口。

4.修改 plugin.xml


  1. <plugin id="com.tangide.viewport" version="1.0.0" xmlns="http://apache.org/cordova/ns/plugins/1.0" xmlns:android="http://schemas.android.com/apk/res/android">
  2. <name>ViewPort</name>
  3. <description>This plugin enable the meta viewport in html</description>
  4. <author>Li XianJing</author>
  5. <license>MIT</license>
  6. <keywords>Meta, Android, ViewPort, DPI, Width</keywords>
  7. <repo>https://github.com/drawapp8/ViewPort.git</repo>
  8. <issue>https://github.com/drawapp8/ViewPort/issues</issue>
  9. <engines>
  10. <engine name="cordova" version=">=3.0.0"/>
  11. </engines>
  12. <js-module name="ViewPort" src="www/ViewPort.js">
  13. <clobbers target="cordova.plugins.ViewPort" />
  14. </js-module>
  15. <!-- Android -->
  16. <platform name="android">
  17. <config-file target="res/xml/config.xml" parent="/*">
  18. <feature name="ViewPort">
  19. <param name="android-package" value="com.tangide.viewport.ViewPort" />
  20. <param name="onload" value="true" />
  21. </feature>
  22. </config-file>
  23. <config-file target="AndroidManifest.xml" parent="/*"></config-file>
  24. <source-file src="src/android/ViewPort.java" target-dir="src/com/tangide/viewport/" />
  25. </platform>
  26. </plugin>

这里值得关注的是下面这行代码,它让APP在启动时就执行插件initialize函数:

  1. <param name="onload" value="true" />

5.把它放到github上。

6.发布插件到http://plugins.cordova.io 上。

  1. plugman adduser lixianjing
  2. plugman publish

PhoneGap插件开发流程的更多相关文章

  1. wordpress插件开发流程梳理

    1.声明一个插件 首先我们必须明白,wordpress的插件可以是单文件,也可以是多文件,css/html都不是必须的,以下举例暂且在单文件模式下 比如我们要创建一个名为 hellophp的插件,那我 ...

  2. jira的插件开发流程实践

    怎么开头呢,由于自己比较懒,博客一直不怎么弄,以后克己一点,多传点自己遇到的问题和经历上来,供自己以后记忆,也供需要的小伙伴少走点弯路吧 最近公司项目需要竞标一个运维项目,甲方给予了既定的几种比较常用 ...

  3. 老司机带你解读jQuery插件开发流程

    jquery插件开发模式 jquery插件一般有三种开发方式: 通过$.extend()来扩展jQuery 通过$.fn 向jQuery添加新的方法 通过$.widget()应用jQuery UI的部 ...

  4. wordpress插件开发流程梳理-二

    开发插件的最佳实践 避免命名冲突 当您的插件对变量,函数或类使用相同的名称作为另一个插件时,会发生命名冲突. 幸运的是,您可以使用以下方法避免命名冲突. 程序性 默认情况下,所有变量,函数和类都在全局 ...

  5. cordova自定义插件开发流程

    cordova自定义插件开发:1.cordova安装:npm install -g cordova2.plugman安装:npm install -g plugman3.cordova创建工程:cor ...

  6. npapi插件开发流程与实例

    近期做NPAPI插件,网上的介绍还是比较多,但就是没有一个完整的例子,FQ也没找到,难得NPAPI要走向陌路了?就不去深究额,先解决目前遇到的问题. 现状:已有Activex(仅兼容IE32/64位浏 ...

  7. CKeditor插件开发流程(二)SyntaxHighlighter

    CKEditor整合SyntaxHighlighter实现代码高亮显示 1,版本说明 CKEditor:ckeditor_4.0.1_standard.zipSyntaxHighlighter:syn ...

  8. CKeditor插件开发流程(一)

    1.放在多文件中 第一步:config.js中 config.extraPlugins = '插件名称';//注册插件,extraPlugins只允许出现一次,你如果之前有新增别的插件,那么用逗号分隔 ...

  9. gitbook 入门教程之小白都能看懂的 Gitbook 插件开发全流程

    什么是插件 Gitbook 插件是扩展 GitBook 功能(电子书和网站)的最佳方式. 只要是 Gitbook 默认没有提供的功能,基于插件机制都可以自行扩展,是插件让 Gitbook 变得更加强大 ...

随机推荐

  1. duilib\utils\utils.h(251) : error C2504: “VARIANT”: 未定义基类

    转载:http://blog.csdn.net/SP_daiyq/article/details/44542939?locationNum=3 创建win32应用程序的工程文件,删除不需要的代码,只留 ...

  2. C#处理控制台关闭事件

    应用场景 我们开发的控制台应用,在运行阶段很有可能被用户Ctrl+C终止或是被用户直接关闭.如果我们不希望用户通过Ctrl+C终止我们的程序,就需要对Ctrl+C或关闭事件作处理. 处理方法 在.ne ...

  3. css选择器选择顺序是从右往左的,为什么?

    https://segmentfault.com/q/1010000000713509 为什么 CSS 选择器解析的时候是从右往左? CSS 的后代选择器本身就是一种在标准里面不那么推荐的方式. 首先 ...

  4. MySQL(二) —— 数据类型与操作数据表

    数据类型 数据类型是指列.存储过程参数.表达式和局部变量的数据特征,它决定了数据的存储格式,代表了不同的信息类型. 整型:TYNINT(-2^7 ~ 2^7-1); SMALLINT(-2^15 ~ ...

  5. JAVA开发-我的第一个webScan扫描器

    写的第一句话就是感谢shack2,参考了他的代码知道原来有的解耦可以这样写,但是又在他的基础上改写了很多. 代码分享给大写,下面是程序的截图,我把他取名为:HadesWebScan   ps:Wind ...

  6. 让WinForm窗体的大小固定,不能调整大小

    窗体FormBorderStyle属性设置为:FixedSingle,再把最大化禁用就可以了

  7. 移动h5自适应布局

    问题一,分辨率Resolution适配:不同屏幕宽度,html元素宽高比和字体大小,元素之间的距离自适应,使用rem单位. 问题二,单位英寸像素数PPI适配:使用rem单位,文字会发虚.段落文字,使用 ...

  8. iOS - OC NSSize 尺寸

    前言 结构体,这个结构体用来表示事物的宽度和高度. typedef CGSize NSSize; struct CGSize { CGFloat width; CGFloat height; }; t ...

  9. mysql 性能问题的解决

    场景:模拟一天的数据,每个10秒,遍历1000个设备,每个设备模拟一个实时数据,总的数据量为:24*60*60/10*1000 = 864万条记录.-------------------------- ...

  10. JSP连接数据库的两种方式:Jdbc-Odbc桥和Jdbc直连(转)

    学JSP的同学都要知道怎么连数据库,网上的示例各有各的做法,弄得都不知道用谁的好.其实方法千变万化,本质上就两种:Jdbc-Odbc桥和Jdbc直连. 下面先以MySQL为例说说这两种方式各是怎么连的 ...