【2021/12/31】uniapp之安卓原生插件开发教程

uniapp之安卓原生插件开发教程

image

准备

  1. hbuilderX,下载
  2. app离线SDK,下载
  3. Andorid Studio,安卓官方中文社区
  4. 证书(可以自己准备,也可以使用android Studio生成)

插件功能简介

  • 加法功能,我们把插件名称起名为leruge-add,方法是add,参数是ab

过程

  1. HbuilderX创建一个项目


    image
  2. pages/index/index.vue中随便写一个按钮,然后调用我们的原生插件leruge-add,代码如下
    image
<template>
    <view>
        <button @click="add">加法</button>
    </view>
</template>

<script>
    export default {
        methods: {
            add() {
                // 引入原生插件 leruge-add
                let lerugeAdd = uni.requireNativePlugin("leruge-add")
                // 调用
                lerugeAdd.add({
                    a: 1,
                    b: 2
                }, res => {
                    uni.showToast({
                        title: JSON.stringify(res),
                        icon: 'none'
                    })
                })
            }
        }
    }
</script>

<style>
</style>
  1. 申请Appkey,在开发者中心,点击刚才创建的app
    image
  2. Android包名和IOS Bundled都填写成com.android.UniPlugin
  3. SHA1签名自行百度如何获取吧,这里就不错详细讲解了,教程
  4. 点击保存,生成appkey


    image
  5. 解压我们下载好的APP离线SDK,下载地址
    image
  6. 打开Android Studio,open选择UniPlugin-Hello-AS
    image

    image
  7. 我个人习惯project模式,所以切换一下


    image
  8. 把我们刚才申请的appkey填写到app/src/main/AndroidManifest.xml中,因为开发的是安卓,所以appkey肯定也是安卓的
    image
  9. 把我们的证书放到app目录下,我的证书名字叫leruge.keystore
    image
  10. 配置证书,在app/build.gradlesigningConfigs选项中
    image
  11. 右键UniPlugin-Hello-AS,创建Module
    image
  12. 填写插件信息


    image
  13. 配置leruge_add/build.gradle,复制例子uniplugin_module/build.gradle
    image
  14. leruge_add/src/main/java/com/example/leruge/add创建类AddModule
    image
  15. 实现加法,代码如下


    image
package com.example.leruge.add;

import com.alibaba.fastjson.JSONObject;

import io.dcloud.feature.uniapp.annotation.UniJSMethod;
import io.dcloud.feature.uniapp.bridge.UniJSCallback;
import io.dcloud.feature.uniapp.common.UniModule;

public class AddModule extends UniModule {

    @UniJSMethod
    public void add(JSONObject json, UniJSCallback callback) {
        int a = json.getIntValue("a");
        int b = json.getIntValue("b");
        JSONObject res = new JSONObject();
        res.put("code", 1);
        res.put("result", a + b);
        callback.invoke(res);
    }
}
  1. 注册插件,在app/src/main/assets/dcloud_uniplugins.json文件中添加,如下
    image
  2. 到HbuilderX生成本地打包资源


    image
  3. 把生成的本地打包资源复制到app/src/main/assets/apps目录下
    image

    image
  4. 配置appid,在app/src/main/assets/data/dcloud_control.xml中配置
    image
  5. 添加插件project引用,在app/build.gradle中添加组件
    image
  6. 测试,手机或者虚拟设备连接以后,点击运行进行测试


    image
  7. 测试成功以后就生成uniapp插件,点击Android Studio右侧的Gradle,依次选择leruge_add/Tasks/other/assembleRelease,双击生成aar包,生成的包在leruge_add/build/outputs/aar目录下
  8. 创建跟插件相同名字的文件夹leruge_add,在leruge_add下创建android文件夹和package.json文件
  9. aar包放到android文件夹下,package.json最小配置即可,也可以按照实际情况配置
    image
{
    "name": "leruge-add",
    "id": "leruge-add",
    "version": "1.0.1",
    "description": "加法",
    "_dp_type":"nativeplugin",
    "_dp_nativeplugin":{
        "android": {
            "plugins": [
                {
                    "type": "module",
                    "name": "lerug-add",
                    "class": "com.example.leruge.add.AddModule"
                }
            ],
            "integrateType": "aar"
        }
    }
}
  1. 是作为本地插件使用,还是上传到插件市场都是可以的

结束语

到此为止,安卓原生插件开发就已经完成了

留言

点击留言

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

推荐阅读更多精彩内容