专栏首页一个番茄说Cordova插件开发——滑动手势解锁(iOS篇)

Cordova插件开发——滑动手势解锁(iOS篇)

第一次正儿八经的参与Cordova的项目,想写下些文字,以便日后需要的时候能够帮助自己快速回忆起来,同时也希望能够帮到需要的朋友。

你需要具备什么?

  • 对Cordova有一定程度的了解。
  • 一定的移动端开发能力。
  • 一定的前端知识,基本的css\js\html这些是逃不掉的。
  • 开发环境的支持,你需要安装Cordova、plugman、Xcode、Android Studio等工具。

为什么需要开发插件

我们知道Cordova其实就是用了一个web的壳而已,我们可以利用插件来和native打交道。 简单来说,我认为之所以需要插件的支持,一是为了更好的用户体验,比如一个转场动画,可能利用原生代码来实现效果会更好;二是为了利用原生设备的能力,比如你需要用到GPS、蓝牙等等。

在我的业务场景中,我需要给我的应用加上手势解锁的功能。我想了两种方案,一种是纯前端的方案,即在web页面中嵌入一段js,它负责锁屏界面的显示解锁等功能,是在原有的页面中盖上一层canvas(Demo在此);第二种是用插件的方式,原生代码去控制锁屏的显示等等。

综合考虑体验和合理度等情况之后我决定用第二种方式,但是为了节省时间,我只是用插件实现了逻辑部分,解锁的界面为了省事儿还是用canvas直接画的。

如何写插件

初始化一个插件只需要一条命令就可以搞定了: plugman create --name cordovaGestureLock --plugin_id cordova-plugin-gesture-lock --plugin_version 1.0.0

命令执行后就可以创建了一个新的插件目录,如下图:

插件目录

默认会包含src和www目录,plugin.xml是插件的描述文件,比如这个插件的版本号、作者、关键字等等,完整的说明在这里

下面的截图是我插件的plugin.xml:

plugin.xml

插件的id是cordova-plugin-gesture-lock,如果你的插件发布了的话,可以在这里搜索插件的id。这里我增加了ios的platform,里面指定了插件的头文件和源文件路径,这样在安装插件的时候才会复制到你的应用里去。

然后跳到www目录中的cordovaGestureLock.js文件去,我修改之后的代码变成了这样:

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

exports.showGestureLock = function(arg0, success, error) {
    exec(success, error, "cordovaGestureLock", "showGestureLock", [arg0]);
};

它默认给你生成的方法名叫coolMethod,你把它替换成你插件里暴露出来的方法就好了。

这段代码干了什么呢,它向js的context里暴露了一个叫做showGestureLock的方法,它最终会唤醒你的本地插件来执行。你可以像调用一个普通的js函数一样去调用它。

接下来到了重头部分了,原生代码开发者欢呼的时刻到了,直接上代码吧:

#import <Foundation/Foundation.h>
#import <Cordova/CDV.h>
#import <Cordova/CDVPlugin.h>

@interface GestureLock : CDVPlugin
- (void)showGestureLock:(CDVInvokedUrlCommand*)command;
@end


...
@implementation GestureLock
{
   NSTimeInterval _showGestureLockInterval;
   NSUserDefaults *_userDefault;
}

- (void)pluginInitialize {
   _showGestureLockInterval = 5 * 60;
   _userDefault = [NSUserDefaults standardUserDefaults];
   [self registNotificationHandler];
}

- (void)showGestureLock:(CDVInvokedUrlCommand*)command {
   [self showGestureLockIfNeeded];
}
...

简单来说,我们的插件需要提供暴露给js的方法,也就是这里的showGestureLock。然后在我的代码里,因为我希望我的应用去监听一系列的事件,比如应用被激活等。所以我需要注册一些通知,Cordova提供了一个叫做pluginInitialize的方法,给你一个时机在插件初始化的时候做些事情,比如我这里的注册通知。 在默认的情况下,只有在插件被用到的时候才会被初始化,但是在我前面xml文件里,我有一行代码: <param name="onload" value="true" /> 它让插件在启动的时候就被加载了,因为我想插件一直监听事件。

在我的例子中,我不需要从js中传递参数到native来,所以我的这个函数写的特别简单。而实际command里是可以带js传递过来的参数的,你可以从里面取到你想要的参数。处理完了之后你还可以构造CDVPluginResult来传递结果到js中。

如何使用插件

完成插件的开发之后自然是把它使用起来,只需要简单的一条命令搞定,比如我这里: cordova plugin add https://github.com/billwang1990/CordovaGestureLock.git --save 我这里用的是我仓库的地址,你也可以指向你本地的地址。

如果要删除一个插件的话也很简单,直接告诉它你需要删除的插件的id就好了: cordova plugin rm cordova-plugin-gesture-lock --save

添加完插件之后,你再去看你项目config.xml文件就会发现已经多了一个插件了,接下来你就可以在你的项目中使用它了,蛮方便的。 最后完成的Demo在这里。代码写得比较乱,看看就好了。

写在最后

接下来的关于安卓的插件,我会在我开始做的时候再进行记录。

Cordova的插件开发还算简单,比较有意思的问题是它如何实现的插件?即如何让js和native进行通信的,其实在iOS这边主要是利用其runtime来实现的,我一年半前写了一个做了个简单版的bridge来干了类似的事情,有兴趣的可以查看我之前的一篇文章并留言讨论。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 开篇——讲给小白听的比特币

    第一次听到比特币的时候大概是好几年前了,当时第一反应是难不成又出了个什么纪念币或者哪个傻逼国家自己印了新的货币出来。带着好奇心试图去了解清楚到底这是个什么东西,...

    100000798482
  • 移动开发流水线建立以及自动化测试

    工业时代流水线的发明将生产任务的效率大大提升。同样,在软件开发过程中流水线的建立也能帮助我们更好的产出、提升效率。

    100000798482
  • Functional Testing in iOS

    下面的Test Pyramid摘自Martin Fowler的 文章,越高层次产生的用户价值会更高且更慢,越低层次的产生的价值更低且更快,你所写的任何一行单元测...

    100000798482
  • 零基础ASP.NET Core MVC插件式开发

    一个项目随着业务模块的不断增加,系统会越来越庞大。如果参与开发的人员越多,管理起来难度也很大。面对这样的情况,首先想到的是模块化插件式开发,根据业务模块,拆分成...

    梁规晓
  • IntelliJ IDEA 18 周岁,吐血推进珍藏已久的必装插件

    IntelliJ IDEA是目前最好最强最智能的Java IDE,前几天,他刚刚年满18岁。

    用户1655470
  • 从Elasticsearch的插件实现机制见:如何在Java中实现一个插件化系统

    此外,笔者还对Java的流行插件框架PF4J进行的简单的了解,发现其实现方式和ES比较相似:都是由ClassLoader实现,感兴趣的读者可以自行了解。

    franyang
  • 【Chromium中文文档】插件架构

    背景 在阅读这个文档前,你应当熟悉Chromium的多进程架构。 概述 插件是浏览器不稳定的主要来源。插件也会在渲染器没有实际运行时,让进程沙箱化。因为进程是第...

    梦里茶
  • IOS 越狱插件介绍与一点经验

    总体来说,如果你的系统是13.5的话(尚未升级到13.5.1),实际上整个流程比Android的Root还要简单。因为Iphone是我的主力机,为了避免不必要的...

    xuing
  • 推荐一些typecho好用的插件

    搭建typecho必须推荐几款好用的插件,因为typecho本身轻量,轻量导致舍弃了很多功能,所以必须使用一些插件来实现一些功能。 比如我现在在用的就是这些。

    月萌
  • 【插件开发】—— 2 插件入门

      最近由于特殊需要,开始学习插件开发。 以前接触java也算有些时日,但是一直不知道有插件开发这样一种技术路径,本想着这开发工具都给你备好了,直接用不就行了...

    用户1154259

扫码关注云+社区

领取腾讯云代金券