参考自
https://blog.csdn.net/huachao1001/article/details/51810328
https://blog.csdn.net/huachao1001/article/details/51819972
https://blog.csdn.net/tscyds/article/details/78082861
在Android项目当中,Google官方使用Gradle来对其进行构建。所以这就使得我们可以通过自定义的Gradle插件来修改编译后的class文件。修改class文件的字节码可以使得我们来做一些用日常思路比较麻烦的事情,例如:
- 对于关键节点的插桩做性能监控。
- 修改第三方依赖。
等等(其实我只用到了插桩做了一个简单的性能监控)
新建一个Gradle Module
Gradle Module从引用方式上可以分为两种
- 一种是只能在本工程中使用的Groovy插件
- 另一种是可以将其打包发布出去使用的Groovy插件
两种方式相同的部分
由于在AS中没有“新建Gradle Plugin”这种选项,
所以我们可以选择新建Java Module或者是Android Module。
如果是新建一个Android Module,则需要将文件夹中的内容悉数删除,只留下build.gradle文件和src/main目录。之后在src/main目录下新建一个groovy目录即可。
(总之最后的目录结构是这个样子即可)
以下是两种方式的不同部分
只能在本工程中使用的Groovy插件
将这个Module的module name命名为buildSrc(这个Module的名称必须为buildSrc)
可以将其打包发布的Groovy插件
可以打包发布的Groovy在Module的命名上并没有什么特殊的要求。在新建完成groovy目录之后,在main目录下新建resources/META-INF目录。在META-INF中新建一个“.properties”文件。这个文件的名称就是日后在apply plugin中使用的名称。
例如将其命名为"pluginTest.properties"那么在需要引用这个插件的Gradle中就要写成
apply plugin: 'pluginTest'
在这里有一些坑,“.properties”和“.groovy”比较容易在引用的时候报not found,这里在AS当中必须将扩展名显式的写入到文件名当中,比如“pluginTest.properties”,和“Test.groovy”
在编写完成后在插件的Gradle中配置以下的脚本,可以将其发布至本地repo中
uploadArchives {
repositories.mavenDeployer {
repository(url: uri('../repo')) //仓库的路径,此处是项目根目录下的 repo 的文件夹
pom.groupId = 'example.asus.Test2Groovy' //groupId ,自行定义,一般是包名
pom.artifactId = 'Test2Groovy' //artifactId ,自行定义
pom.version = '1.0' //version 版本号
}
}
然后执行uploadArchives(双击一下执行,还是比较方便的)
在工程中引用
只能在本工程中使用的Groovy插件
在引用的时候只需要在app下的build.gradle中配置
apply plugin: example.asus.test.Plugin_perormanceAnalysis
格式为:包名+Plugin的类名
即可(注意没有引号)
打包发布的Groovy插件
(之前试过很多种方法,但是我只试出来一种可以用到的,仅做以记录,希望诸位多多指教)
在app下的build.gradle中末尾加入
repositories {
jcenter()
google()
maven {
url uri('../repo')
}
}
buildscript {
repositories {
jcenter()
google()
maven {
//仓库的路径,此处是项目根目录下的 repo 的文件夹
url uri('../repo')
}
}
dependencies {
//这里是包名:Plugin所在的类名:版本号
classpath 'example.asus.Test2Groovy:Test2Groovy:1.0'
}
}
apply plugin: 'pluginTest'