这里有我发布的一个插件,是安卓防止点击抖动的
[简书地址]((https://www.jianshu.com/p/3f6e7dc06b23)
GITHUB地址
使用demo
该项目已开源,可以拉到文章底部查看使用方法。
技术背景:
安卓高级开发工程师
需求背景 :
利用Gradle强大的任务功能我们开发出了很多的插件,比如函数函数,无感插桩,热修复等,开发完后如果是公司内部使用,只需要发布到本地即可,但是如果你希望开源出去给大家使用就需要发布到云端,类似的有jitio,binatry等,这里我们直接用的Gradle自己的插件发布平台
文章开始
1.本地发布
本地发布比较简单,我们看一下build.gradle
的配置
apply plugin: 'maven'
apply plugin: 'groovy'
dependencies {
implementation 'com.android.tools.build:gradle:3.0.0'
implementation gradleApi()
implementation localGroovy()
}
repositories {
mavenLocal()
}
uploadArchives {
repositories.mavenDeployer {
pom.groupId = 'com.bigman.clickInject'
pom.artifactId = 'onclick'
pom.version = '1.0.0'
//发布到本地仓库
repository(url: uri('../repo'))
}
}
我们来分析一下这个里面配置的意义
implementation 'com.android.tools.build:gradle:3.0.0'
implementation gradleApi()
第一个gralde:3.0.0
将限制用户使用gradle的最低版本,所以尽可能降低一点版本,网上说其实不用配置这个,直接用第二行的gradleApi
即可,本人没进行测试,所以大家可以试试
uploadArchives {
repositories.mavenDeployer {
pom.groupId = 'com.bigman.clickInject'
pom.artifactId = 'onclick'
pom.version = '1.0.0'
//发布到本地仓库
repository(url: uri('../repo'))
}
}
然后是这里的uploadArchives
他是一个扩展,配置完之后我们可以在编辑器右侧看到这个任务,如下截图
这里这个配置就是配置本地上传的一个配置,我们点击上图的那个
uploadArchives
任务,他将在当前项目目录下生成一个repo仓库,如下截图本地仓库建立好就能使用他了,具体使用方法如下
首先在项目根目录的
build.gradle
配置这个maven本地仓库路径,然后同样在这个文件下配置如下:仔细观察的同学,会发现这个classpath和我们配置的
uploadArchives
的配置一一对应。最后是app模块的使用方法,如下,不同的插件不一样
好了本地上传讲完了,后面讲云端上传
2.云端发布
先讲讲心路历程,云端发布百度没找到,gradle官网只有java版的真的坑,折腾了一天才弄好。
1.先注册gradle平台账号,当然可以用github授权,注册地址在这里https://plugins.gradle.org/
2.然后把刚刚那个插件的build.gradle
改一下,改成如下
apply plugin: 'maven'
apply plugin: 'groovy'
//apply plugin: "com.gradle.plugin-publish"
dependencies {
implementation 'com.android.tools.build:gradle:3.0.0'
implementation gradleApi()
implementation localGroovy()
}
repositories {
mavenCentral()
jcenter()
}
buildscript {
repositories {
maven {
url "https://plugins.gradle.org/m2/"
}
}
dependencies {
classpath "com.gradle.publish:plugin-publish-plugin:0.10.1"
}
}
apply plugin: "com.gradle.plugin-publish"
version = "1.0.5" // 插件的版本号
group = "com.bigman" // 插件的组名
pluginBundle {
// website = 'http://www.gradle.org/'
// vcsUrl = 'https://github.com/gradle/gradle'
website = 'https://github.com/bigmanLau/ASM_DedounceClick_Android'
vcsUrl = 'https://github.com/bigmanLau/ASM_DedounceClick_Android'
description = 'A library to prevent debounce-click for android.' // 插件的描述
tags = ['asm', 'android','debounce','onclick'] //插件的tag。可以通过这个在插件门户上搜索
plugins {
greetingsPlugin {
id = 'com.bigman.clickInject' //插件的id,到时候apply的插件id
displayName = 'onclick'
}
}
}
这个配置有两个重要的地方
第一个地方就是这一块
这里指定了上传地址和插件版本,这样才能链接到gradle的插件官网
第二个地方就是这里
官网有说明,主要用于gradle官网的审核,第一个website是你的主页地址,vcsurl是你的项目地址,
其实就是让用户使用这个插件能找到官网说明文档和源码,如果没有,可以直接用github项目地址,这样才能通过gralde官网的审核,当然审核需要时间,只有审核通过了才能让别人使用你的插件。
最后就是使用插件了
当然这里的用法gradle官网会告诉你,比如我这个插件
结尾
好了大概说完,基本坑都踩完了。