1.在项目根目录下(我的是com.chl),添加一个文件夹,在文件夹里添加src、www两个子文件夹和plugin.xml文件。在www目录下,创建test.js。在src文件夹下添加android子目录(--为了区分平台,android/ios...--),在android目录下添加chl文件夹(--包名--),在chl目录下添加TestPlugin.java文件。

2.打开test.js文件,添加getName方法:

  var exec = require("cordova/exec");

  var test = {

    /**

     * getName方法

     * @param successCallback:成功的回调函数
     * @param errorCallback:失败的回调函数

     */

    getName: function(successCallback, errorCallback){

      /**

       * 调用TestPlugin.java

       * action = getName

       */

      cordova.exec(successCallback, errorCallback, "TestPlugin", "getName", []);

    }

  }

  module.exports = test;

打开TestPlugin.java文件:

  package chl;

  import org.apache.cordova.CordovaPlugin;

  import org.apache.cordova.CallbackContext;

  import org.json.JSONArray;

  import org.json.JSONException;

  public class TestPlugin extends CordovaPlugin {

    public static final String ACTION_GET_NAME = "getName";

    @Override

    public boolean execute(String action, JSONArray args, CallbackContext callbackContext) throws JSONException {

      try{

        if(ACTION_GET_NAME.equals(action)){

          callbackContext.success("张三");

          return true;

        }

        callbackContext.error("action是不getName");

        return false;

      }catch(Exception e){

        System.out.println("异常信息: " + e.getMessage());

        callbackContext.error(e.getMessage());

        return false;

      }

    }

  }

打开plugin.xml配置插件:

<?xml version="1.0" encoding="UTF-8"?>

<plugin xmlns="http://www.phonegap.com/ns/plugins/1.0"

    xmlns:android="http://schemas.android.com/apk/res/android"

    id="cordova-plugin-chenhlTest" version="1.0.0"><!-- id为插件的名称,插件安装后会在plugins目录下出现cordova-plugin-chenhlTest文件夹 -->

  <name>chenhlTest</name>

  <description>my test plugin ...</description><!-- 描述 -->

  <license>no license ...</license>

  <engines>

    <engine name="cordova" version=">=3.0.0" /><!-- 适用版本 -->

  </engines>

  <js-module src="www/test.js" name="Test">

    <clobbers target="cordova.plugins.chenhlTest" /><!-- 调用时的名称 -->

  </js-module>

  <platform name="android"><!-- 以下是android平台配置信息 -->

    <source-file src="src/android/chl/TestPlugin.java" target-dir="src/chl" /><!-- java源代码 -->

    <config-file target="res/xml/config.xml" parent="/*">

      <feature name="TestPlugin">

        <param name="android-package" value="chl.TestPlugin"/><!-- 指向src/android/chl/TestPlugin.java文件 -->

      </feature>

    </config-file>

    <config-file target="AndroidManifest.xml">

      <!--<uses-permission android:name="android.permission.READ_PHONE_STATE" />--><!-- android权限 -->

    </config-file>

  </platform>

</plugin>

至此代码写完了,接下来就是安装插件。

3.安装插件

打开cmd,并进到项目的根目录。

执行命令:

  cordova plugin add chenhl

  注:chenhl就是最先创建的文件夹名称

正确执行完命令后,就可以在项目的plugins目录下,看到cordova-plugin-chenhlTest插件了。

4.调用插件

在页面上添加按钮

  <button class="button-full button button-positive" ng-click="pluginTest();">测试自定义插件</button>

在对应的controller:

  $scope.pluginTest=function(){

    //cordova.plugins.chenhlTest:plugin.xml文件中配置在clobbers中的

    cordova.plugins.chenhlTest.getName(function(name){

      alert(name);

    }, function(err){

      alert(err);

    });

  }

5.测试结果

自定cordova插件笔记demo的更多相关文章

  1. bootstrap-paginator 分页插件笔记

    [MVC]bootstrap-paginator 分页插件笔记   bootstrap-paginator基于bootstrap框架,使用起来非常简单.官网:http://harttle.github ...

  2. ionic实战系列(二):使用cordova插件

    本章主要关注cordova的各种插件,利用好手机(移动设备)的原生功能.首先cordova是一个将web网页内嵌到原生app的平台(核心功能),然后cordova拥有的插件系统扩展了核心功能. Cor ...

  3. 自定义 Cordova插件(基础篇)

    cordova自定义插件 注意:存放自定义cordova插件目录不能有空格可能会报错 cordova的安装 下载node.js,安装完成后你可以在命令行中使用node和npm. 安装cordova使用 ...

  4. 自定义 Cordova插件详解

    一.Cordova的基础点 在混合式应用中,我们通过现有的Cordova插件,可以轻松的在 H5 上调用手机native的功能.现有的Cordova插件能满足平时大部分的开发需求,然而,有时候找不到合 ...

  5. 自定义Cordova插件(基础篇)

    cordova自定义插件 注意:存放自定义cordova插件目录不能有空格可能会报错 cordova的安装 下载node.js,安装完成后你可以在命令行中使用node和npm. 安装cordova使用 ...

  6. 自定义Cordova插件详解

    一.Cordova的基础点 在混合式应用中,我们通过现有的Cordova插件,可以轻松的在 H5 上调用手机native的功能.现有的Cordova插件能满足平时大部分的开发需求,然而,有时候找不到合 ...

  7. Android H5混合开发(2):自定义Cordova插件

    前言 Cordova虽然定义了很多基础的插件,供H5端使用原生设备的功能. 但是,如果业务相关的功能,需要提供给H5端使用,那么,就需要我们自定义插件了. 这个"自定义"不是指由A ...

  8. (转)JQM 日期插件 mobiscroll Demo

    (原)http://www.wglong.com/main/artical!details?id=11  JQM 日期插件 mobiscroll Demo 2013-04-25 / 分类:Jquery ...

  9. 【No.4 Ionic】修改 cordova 插件

    在使用 cordova 过程 使用的插件 有可能不能满足个人需求,就需要修改,下面就直接说说步骤 插件结构 我用 cordova-plugin-inappbrowser 插件 讲解 在目录中有个 sr ...

随机推荐

  1. hihoCoder#1121

    刚开始学习C语言,准备在做hiho的题目的过程中来学习,在此进行记录,如果代码中有错误或者不当的地方还请指正. 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 大家好,我 ...

  2. Informatica Lookup Transformation组件的Connect 与Unconnected类型用法

    Informatica Lookup Transformation组件的Connect 与Unconnected类型用法及区别:下面是通一个Lookup在不同Mapping中的使用: 1. Conne ...

  3. 我是一只IT小小鸟读后感

    当老师推荐我读这本书的时候,并不想看,因为我不喜欢机械的东西,然而阅读几章后,对这本书有了其他看法.不知不觉竟把它看完!看完这本<我是一只IT小小鸟>,我感触很深. 在书中我明白了很多,大 ...

  4. SQLserver CASE WHEN

    declare @shuzu int set @shuzu=1 select (case @shuzu when '1' then '444' when '2'then '555' end) as ' ...

  5. Entity Framework Linq 动态组合where条件

    public static class PredicateExtensions { public static Expression<Func<T, bool>> True&l ...

  6. Sprint 2(第一天)

    Sprint 2计划会议: 目标: 1.实现用户模块的权限控制,能够进行用户登录的功能 2.对菜单模块实现增加菜单列表详情,修改菜单列表详情,删除菜单列表详情,查询菜单列表详情的功能 3.实现菜品分类 ...

  7. php反射

    反射 //反射查找对象方法所在的文件名.$n_func = new ReflectionMethod($obj,$function);$filepath = $n_func->getFileNa ...

  8. 涵涵和爸爸习惯养成进度表(二)(May 30 - )

    规则说明 22天内,没有哭脸,不超过三个无表情脸,可以给一个奖励(动画书等) 涵涵违反规则,在爸爸和妈妈都同意的情况下,可以给无表情脸 爸爸违反规则,在妈妈和涵涵都同意的情况下,可以给无表情脸 获奖记 ...

  9. 曲线参数化的Javascript实现(理论篇)

    在关键帧动画的制作过程中,动画师在k物体运动的过程中,一般要确定2个参数: 1)运动轨迹(表示物体运动的路径): 2)速度曲线(表示物体随时间的速度变化). 对于运动轨迹通常选用一定的样条曲线,通过动 ...

  10. jenkins环境搭建

    1.官网下载jenkins的安装包,直接解压安装.jenkins-1.641.zip 2.修改jenkins端口,启动jenkins服务.E:\Program Files (x86)\Jenkins\ ...