uni原生插件开发流程全一览——Component扩展

uni-app是啥,套用官方的话,它是一个使用 Vue.js 开发所有前端应用的框架,开发者编写一套代码,可发布到iOS、Android、H5、以及各种小程序(微信/支付宝/百度/头条/QQ/钉钉/淘宝)、快应用等多个平台。

当你使用uni-app来对项目进行开发时,免不了使用各种各样的插件,官方的插件市场(https://ext.dcloud.net.cn)虽有上千款,但是一个项目如果是高度自定义的话,那难免对插件的功能有着特定的需求,这时就需要自己开发原生插件来满足需要了。

官方早早注意到了这点,对原生插件开发的定义也很贴合实际:当HBuilderX中提供的能力无法满足App功能需求,需要通过使用Andorid/iOS原生开发实现时,可使用App离线SDK开发原生插件来扩展原生能力。

但是不可否认的是,官方给出的文档还是过于跳脱简洁。对老手而言,上手似乎没有什么难度,对新手就不怎么友好了。

所以重点就又来了,本次演示uni原生插件安卓开发流程,以Component扩展为例,绝对是从头到尾的“一条龙服务”,当然为了更好的理解开发思路,文章还是依照官方文档来的。

下面步入正题。

第一步,开发环境的准备

JAVA环境配置(JDK1.8):

以windows10为例,cmd进入自己电脑命令提示符,输入java -version查看自己的jdk版本,官方文档中提示jdk版本应在1.7及以上,最优1.8,如果达不到标准,自行下载相关版本配置好环境变量即可。

jdk下载路径:

https://www.oracle.com

https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html

AndroidStudio配置(version4.0):

验证AndroidStudio是否配置成功,具体流程可参照《HBuildeX安卓离线打包教程》相关图文第一步。若测试项目能够显示“Hello World!”并且无报错,代表项目成功跑起,AndroidStudio基本配置完成。

AndroidStudio下载路径:

https://developer.android.google.cn/studio/index.html

http://www.android-studio.org/

App离线SDK下载(SDK2.7.9):

在DCloud官网下载好安卓离线SDK,解压以待使用。

Android离线SDK下载路径:

https://nativesupport.dcloud.net.cn/AppDocs/download/android

官方uni原生插件开发教程(android)网址:

https://nativesupport.dcloud.net.cn/NativePlugin/course/android

第二步,创建自定义项目与引入官方项目

打开AndroidStudio,在菜单栏选择File>New>New Project,创建自定义项目。

因为第一步代表AndroidStudio已经测试完成,能够正常使用,所以我们直接创建No Activity项目,点击Next

填写项目名、包名,以及Minimum API Level(有疑惑可参照《HBuilderX安卓离线打包》图文第一步)

项目创建完毕,为了更好的使用,我们把它转到Project视图。

接下来创建要开发的模块,本文在Module和Component 扩展中选择Component 扩展为例。

点击File>New>New Module...

选择Android Library,点击Next

自定义Library名和包名(这里是com.test.testplugin)点击Finish

创建完毕后如图所示

接下来导入官方提供的uni插件原生项目,里面的东西我们待会儿要用到

File>New>Import Project...

项目在官方的离线SDK中,我是直接把它拷到AndroidStudio默认存放路径了,这样方便导入。

如图,点击OK

导入成功,我们参照里面的uniplugin_component模块

配置刚刚创建的testplugin的build.gradle(testplugin)信息

如图,将dependencies下默认生成的依赖注释掉,添加uni-app所需库依赖

compileOnly  'com.android.support:recyclerview-v7:28.0.0'

compileOnly  'com.android.support:support-v4:28.0.0'

compileOnly  'com.android.support:appcompat-v7:28.0.0'

再添加后续用到的json解析库

compileOnly 'com.alibaba:fastjson:1.1.46.android'

可能因为版本问题添加依赖库时会报红

鼠标移到上面有如下提示:

版本28(适用于Android Pie及更低版本)是旧版支持库的最后一个版本,因此我们建议您在使用Android Q并向前迁移时迁移到AndroidX库。 IDE可以帮助您:重构>迁移到AndroidX。

官方文档中提到过现在还不支持AndroidX,所以还是要使用V4和V7包,解决办法直接如上图红色方框圈中处使用快捷键(Alt+Shift+Enter)添加noinspection GradleCompatible注释即可,也可手动点击红色方框圈中左边位置添加。

接下来导入uniapp-release.aar插件,它是扩展module主要依赖库(此时也可以把离线打包用到的另外三个插件一起导入)

app>libs目录下导入插件,如图

回到刚刚创建的testplugin的build.gradle(testplugin)中,接下来进行导入aar需要的配置操作

添加

repositories {   

    flatDir {

            dirs 'libs' 

    }

}

到dependencies{}上方,注意,不要把它放到android{}里了

在dependencies内添加

compileOnly fileTree(dir: '../app/libs', include: ['uniapp-release.aar'])

上述配置全览

点击Sync Now或者Sync Project with Gradle Files进行同步处理(同步失败或过慢请参照uni-app离线打包图文)

官方文档提醒:

工程gradle配置的为gradle-4.6-all版本,使用的是新版本的依赖方式。如果您使用的是老版本的gradle,可根据以下链接进行修改依赖方式。

https://blog.csdn.net/wangliblog/article/details/81366095

第三步,原生插件的开发

以扩展Component为例,参照官方UniPlugin-Hello-AS工程中的uniplugin_component模块,如图创建类TestComponent

AndroidStudio4.0于本月28号更新,这变化太大我都没转过来弯,上官网找文档发现最新文档还是3.6版本的,都还没同步过来,晕死。

TestComponent需要继承WXComponent类,创建默认带参构造方法

构造方法里默认调用父类有参构造方法

weex注意事项:

week版本大于等于0.19.0和小于它操作是不同的,新版本中的WXDomObjectJava代码被移除,详情可见:

https://weex.apache.org/zh/guide/extend/extend-android.html#component-扩展

既然以Component为例,我们先来看看它的用途:

既然是内嵌某个原生ui组件,那么下面以TextView为例对类TestComponent进行操作:

如图为WXComponent指定泛型TextView,在initComponentHostView()方法里定义View,同时返回类型也要改为TextView。

设置属性方法,setText()设置文本,setSize()设置字体型号,setColor()设置字体颜色

自定义组件方法clearText()清除TextView文本

并使用Component自定义发送方法fireEvent()反馈信息

核心代码完毕

接下来在本地注册插件

在app>src>main目录下创建assets文件夹

回车

在app>src>main>assets目录下创建dcloud_uniplugins.json文件,我们也可以拷贝刚刚导入官方的项目中的json文件,对其稍作修改。

对dcloud_uniplugins.json中的内容做出适当修改

参照相关说明

接下来是对插件的注册

因为当前只举了Component扩展的一个例子,所以要删除掉多余元素,完成后如图

注册方法有两种,第二种参见官方文档或者公众号Module扩展图文,无特殊操作建议采用第一种注册方式.

注册完毕,开始打包插件

Gradle>testplugin>Tasks>other目录下找到assembleRelease,双击等待系统编译出扩展Component的aar文件

注意:官方文档中是选择Gradle--->插件Component--->Tasks--->build--->assembleRelease编译Component的aar文件,在新版本的AndroidStudio中,assembleReleaseassembleDebug被转移到other目录下。

成功后在testplugin>build>outputs>aar目录下就可以找到相关插件了

第四步,HBuilderX导入和使用本地插件

如图,创建uni-app默认项目TestComponent

参照官方文档中的目录规范

将刚才打包的插件放到nativeplugins>插件文件夹名称(我的是Test-Component)>android目录下,没有相关目录就一步步创建。

创建package.json——uni原生插件描述文件,放到插件文件夹名称目录下,与android文件夹并列

package.json官方描述文档:

https://nativesupport.dcloud.net.cn/NativePlugin/course/package

按照要求填写相关信息

注意:插件标识id必须在对应android和ios节点下plugins中进行注册,与name字段值一致。name下的class是注册插件的类名,也要填对。

这里因为只有android插件,就把ios节点全部删掉,在这里直接注释的话是无效的。

还有要注意的一点:插件标识id一定要与插件文件夹名称一致,不然在云打包时会提示插件不合法:该插件在nativePlugins目录下不存在

在manifest.json下配置App原生插件

勾选确认

parameters信息根据需求配置(我的属于胡填)

接下来注意了:

虽然这里只是测试项目,但为了更好的规范,我们还是使用nvue来继续进行Component扩展的测试

在项目pages目录下创建自定义文件夹,创建完毕后在内创建nvue文件用于测试

测试文件test.nvue创建完毕,我们先不急着改动,首先在项目下找到pages.json文件,在里面配置刚刚创建的文件信息,不然后面没法正常使用

pages.json官方文档:

https://uniapp.dcloud.io/collocation/pages

再对pages>index目录下的index.vue文件做出一定的修改,以满足需求

如图,点击按钮跳转test.nvue页面

接下来对test.nvue文件做出一定更改,以便后续测试开发的原生插件。

如图,利用

<Test-Component/>标签来引用插件,ref与myTextClick()中this.$refs.testa.clearText()调用自定义方法相关联,text、sixe、color分别设置属性值,onEnd是通过 @事件名="方法名" 添加事件来使用fireEvent()

第五步,运行项目的三种方式

通过在线打包制作自定义基座来运行

在HBuilderX里选定项目

运行(R)>运行到手机或模拟器(N)>制作自定义调试基座(P)

配置App云端打包信息

在这里使用了自有证书,这是之前图文中创建的,密码123456

下面选中了打自定义调试基座(iOS的safari调试需要用苹果开发证书打包),因为是要测试,所以不要点到打正式包上了

云端打包

提交到云端服务器

打包完成

打包成功后需要在下图位置确保开启自定义调试基座功能:

可以在项目unpackage下看到打包后的测试apk文件

启动模拟器,运行

模拟器启动成功

进入测试项目,点击按钮跳转test.nvue界面

发现Text-Component插件成功被引用,点击“点击清理”按钮进行下一步测试

清理完成及结果反馈

测试成功

附加

如果Component扩展模块做出了更改,顺着Gradle>testplugin>Tasks>other目录

选择assembleDebug或者assembleRelease双击等待系统编译成aar文件

编译完成后,在testplugin>build>outputs>aar中找到相关文件,复制粘贴到相关目录下,替换之前的插件

再进行云打包基座调试即可

利用HBuilderX来调试的好处在于能够随时对项目中的vue或者nvue文件做出适当的修改,并实时在模拟器上进行差量更新,这样非常方便。

但当插件内容等发生变化时,直接把相关文件粘贴在项目内是无法同步更新的,需要再次打包,而云打包的次数又有限制,有时需要排队等候,所以离线打包方法还是很有必要了解的。下面再为大家介绍两种运行方式,都是通过离线打包的方式来运行的。

因为通过离线打包制作自定义基座来运行通过AndroidStudio来运行条件基本一致,所以前期先把共同条件配置好(与Android离线打包高度相似)

配置运行条件

①引入打包资源

进入下载好后的安卓离线SDK文件夹,在目录

2.7.9\Android-SDK@2.7.9.80210_20200528\SDK\libs

下找到

lib.5plus.base-release.aar

android-gif-drawable-release@1.2.17.aar

miit_mdid_1.0.10.aar

uniapp-release.aar

四个文件,复制到自定义的新文件夹方便使用

在目录

2.7.9\Android-SDK@2.7.9.80210_20200528\SDK\assets

下找到data文件夹,打开可以发现下图几个文件。

可以发现,较上上版本2.6.16少了dcloud1.dat和dcloud2.dat两个文件

官方文档中给出了说明:dcloud1.dat、dcloud2.dat为uni-app所需资源,2.7.0之后已不再需要,升级时需要删除,可以减少apk大小。

返回上一级,复制data文件夹如上一步操作,为了方便与四个文件放到一起。

如图,在发行(P)选项>原生APP-本地打包(L)中选择生成本地打包App资源(R)

显示导出成功,顺着路径将自己项目id名的文件夹拷贝,放到上一步自定义的文件夹下,方便使用。

这里我的项目id是__UNI__2B9747D,就把它放到如图位置

打开AndroidStudio,如下图将

lib.5plus.base-release.aar

android-gif-drawable-release@1.2.17.aar

miit_mdid_1.0.10.aar

三个文件复制粘贴到libs目录下

(第二步添加依赖时已经导入uniapp-release.aar了)

如下图在build.gradle(app)中添加引用资源

implementation fileTree(dir: 'libs', include: ['*.aar'])

implementation "com.android.support:support-v4:28.0.0"

implementation "com.android.support:appcompat-v7:28.0.0"

implementation 'com.android.support:recyclerview-v7:28.0.0'

implementation 'com.facebook.fresco:fresco:1.13.0'

implementation "com.facebook.fresco:animated-gif:1.13.0"

implementation 'com.github.bumptech.glide:glide:4.9.0'

implementation 'com.alibaba:fastjson:1.1.46.android'

自带的依赖进行注释

添加

接下来在

android{

...

        }

内添加

aaptOptions {

additionalParameters '--auto-add-overlay' 

ignoreAssetsPattern "!.svn:!.git:.*:!CVS:!thumbs.db:!picasa.ini:!*.scc:*~"

}

再回到build.gradle(app)页面最上边,配置app版本号。

compileSdkVersion为编译版本,buildToolsVersion为构建工具版本,applicationId为创建时的包名,minSdkVersion为兼容最小的版本号,targetSdkVersion为目标版本,有兴趣的可以百度一下三者之间的区别和联系。

注意,官方文档中标注“App离线SDK minSdkVersion最低支持19,小于19在部分4.4以下机型上将无法正常使用。”

versionCode需要设定一个数值,一般初始值为1,更新版本时versionCode的值需要做出更改,每次都要比前一个设置的值大,否则无法正常安装。

versionName一般填写主版本号次版本号和修正号,如图中的“1.0.0”为最初版本号,其余的可以自行查阅。

然后同步处理

同步完成

把刚刚转移到自定义文件夹下的data文件夹拷贝到app>src>main>assets目录文件夹下。

继续在刚刚创建的assets文件夹下创建apps文件夹,把刚刚进行本地打包资源处理后的文件(我的是__UNI__2B9747D)拷贝到apps文件夹下。

②配置AndroidManifest.xml

app>src>main下配置AndroidManifest.xml文件

将其修改为(就改一下标签,以便内部添加内容)

然后继续下一步,添加内容到application节点(建议复制官方文档里的,下面的复制粘贴后排版会比较乱)。

<activity     

android:name="io.dcloud.PandoraEntry"      android:configChanges="orientation|keyboardHidden|keyboard|navigation"     

android:label="@string/app_name"     

android:launchMode="singleTask"     

android:hardwareAccelerated="true"     

android:theme="@style/TranslucentTheme"     

android:screenOrientation="user"      android:windowSoftInputMode="adjustResize" >     

<intent-filter>         

<action android:name="android.intent.action.MAIN" />         

<category android:name="android.intent.category.LAUNCHER" />

</intent-filter> 

</activity> 

<activity     

android:name="io.dcloud.PandoraEntryActivity"     

android:launchMode="singleTask"     

android:configChanges="orientation|keyboardHidden|screenSize|mcc|mnc|fontScale|keyboard"     

android:hardwareAccelerated="true"     

android:permission="com.miui.securitycenter.permission.AppPermissionsEditor"     

android:screenOrientation="user"     

android:theme="@style/DCloudTheme"     

android:windowSoftInputMode="adjustResize">     

<intent-filter>         

<category android:name="android.intent.category.DEFAULT" />     

<category android:name="android.intent.category.BROWSABLE" />

<action android:name="android.intent.action.VIEW" />       

<data android:scheme="h56131bcf" />     

</intent-filter> 

</activity>

添加完成后如下图

AndroidManifest.xml配置完毕

本次顺序发生变化,主要是放在①的位置会因为依赖还没添加缘故报红,不美观,当然顺序不影响后续使用,根据自己喜好来调整就成

③引入本地原生插件

在build.gradle(app)下添加

implementation project(':testplugin')

用来引入本地插件(我的插件名是testplugin,注意根据自己插件名改动)

在dependencies{}上方添加

repositories {

flatDir {

dirs 'libs'

}

}

注意:跟第二步情况一样不要把它放在android{}内

同步处理

④自定义基座的配置

在app目录下,将assets下apps文件夹中的manifest.json文件和data文件夹中的dcloud_control.xml文件打开,确保manifest.json中的id和dcloud_control.xml中的appid一致(不一致会出现白屏等状况)。

并设置根节点的debugsyncDebugtrue

条件配置完毕

名称配置

app>src>main>res>values配置strings.xml文件,打开xml文件,与刚刚引入本地打包资源的里的manifest.json文件比较,发现名字不一致,遂把strings.xml里的name改为“TestComponent”。

(注:manifest.json文件在

assets>apps>__UNI__2B9747D

>www目录下)

通过离线打包制作自定义基座来运行

开始打debug包,方法Ⅰ

如图,在Gradle>app>Tasks>other目录下找到assembleDebug或者assembleRelease,双击等待系统编译完成

编译完成后,在app>build>outputs>apk文件夹下即可找到debug和release相关apk文件

开始打debug包,方法Ⅱ

如图,在菜单栏Build > Build Bundle(s)/APK (s)下选择Build APK(s),等待系统编译

编译完成,在app>build>outputs>apk>debug路径下即可找到相关apk文件

如此,debug打包完成

将app-debug.apk文件复制到项目unpackage>debug目录下,如果里面存在android_debug.apk文件,就先删除掉,再将app-debug.apk文件名称改为android_debug即可(也可先更名,粘贴进去直接复制替换掉

运行(R)>运行手机或模拟器(N)>运行相关设备,成功运行

测试结果如下图:

测试成功

通过AndroidStudio来运行

切换到模拟器选项

点击Run 'app'运行

项目成功打开,测试结果如下:

实机测试

打包流程不再赘述,有疑问可参考以前图文,包括在AndroidStudio内进行app图标设置等

测试成功

附:如果运行时报device support x86 but apk only supports armeabi-v7a错误,进入到build.gradle(app)中,在

android{

defaultConfig {

//要导入地方

    }

}

内导入

ndk {

abiFilters 'x86','armeabi-v7a'

}

即可(否则64位处理器手机无法加载so文件)

图例

Android studio添加第三方库和so:

https://blog.csdn.net/anhenzhufeng/article/details/78913341

总结

uni原生插件开发流程—Component扩展演示就到这里啦,本次演示相较Module演示来说稍有改变,在内容上对一些细节加以补充,在第五步配置运行条件里对其中的顺序做出了调整,因为采用了nvue,所以在pages.json里也做了配置,并对最后的实机演示安卓离线打包过程采取省略式处理。总体而言,Component扩展演示难度比Module扩展稍高。

本次演示以Component扩展举例,官方的Demo里还有uniplugin_richalert一个例子没有举,等待后续补充。如果时间充足的话,视频演示会在后续放出。

最后

uni原生插件开发流程—Component扩展演示就到这里啦,教程已经足够完善,如果需要Demo或者演示视频的话,请转到公众号紫色云间(微信号:ziseyunjian)通过菜单栏HBuilderX专区直接选择,有更多内容哦。

整理不易,觉得可以的话欢迎关注或收藏,如果还有什么问题直接在下面回复即可,公众号也行,要是我不会的话...还请当做从来没见过我o(╥﹏╥)o

拜拜~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342