我的简书同步发布:在AndroidStudio中自定义Gradle插件
转载请注明出处:【huachao1001的专栏:http://blog.csdn.net/huachao1001】
一直都想好好学习AndroidStudio中的gradle,总感觉不懂如何在AndroidStudio中自定义gradle插件的程序员就不是个好程序员,这次上网查了一下相关资料,做了一个总结~
AndroidStudio
中是没有新建类似Gradle Plugin
这样的选项的,那我们如何在AndroidStudio
中编写Gradle
插件,并打包出来呢?
- (1) 首先,你得新建一个
Android Project
- (2) 然后再新建一个
Module
,这个Module
用于开发Gradle
插件,同样,Module
里面没有gradle plugin
给你选,但是我们只是需要一个“容器”来容纳我们写的插件,因此,你可以随便选择一个Module
类型(如Phone&Tablet Module
或Android Librarty
),因为接下来一步我们是将里面的大部分内容删除,所以选择哪个类型的Module
不重要。- (3) 将
Module
里面的内容删除,只保留build.gradle
文件和src/main
目录。- 由于
gradle
是基于groovy
,因此,我们开发的gradle
插件相当于一个groovy
项目。所以需要在main
目录下新建groovy
目录- (4)
groovy
又是基于Java
,因此,接下来创建groovy
的过程跟创建java
很类似。在groovy
新建包名,如:com.hc.plugin
,然后在该包下新建groovy
文件,通过new->file->MyPlugin.groovy
来新建名为MyPlugin
的groovy
文件。- (5) 为了让我们的groovy类申明为gradle的插件,新建的groovy需要实现
org.gradle.api.Plugin
接口。如下所示:
package com.hc.plugin
import org.gradle.api.Plugin
import org.gradle.api.Project
public class MyPlugin implements Plugin<Project> {
void apply(Project project) {
System.out.println("========================");
System.out.println("hello gradle plugin!");
System.out.println("========================");
}
}
因为我本人对groovy
也不是特别熟悉,所以我尽可能的用Java
语言,使用System.out.println
而不是用groovy的pintln ""
,我们的代码里面啥也没做,就打印信息。
- (6) 现在,我们已经定义好了自己的
gradle
插件类,接下来就是告诉gradle
,哪一个是我们自定义的插件类,因此,需要在main
目录下新建resources
目录,然后在resources
目录里面再新建META-INF
目录,再在META-INF
里面新建gradle-plugins
目录。最后在gradle-plugins
目录里面新建properties文件,注意这个文件的命名,你可以随意取名,但是后面使用这个插件的时候,会用到这个名字。比如,你取名为com.hc.gradle.properties
,而在其他build.gradle文件中使用自定义的插件时候则需写成:
apply plugin: 'com.hc.gradle'
然后在com.hc.gradle.properties
文件里面指明你自定义的类
implementation-class=com.hc.plugin.MyPlugin
现在,你的目录应该如下:
- (7) 因为我们要用到
groovy
以及后面打包要用到maven
,所以在我们自定义的Module
下的build.gradle
需要添加如下代码:
apply plugin: 'groovy'
apply plugin: 'maven'
dependencies {
//gradle sdk
compile gradleApi()
//groovy sdk
compile localGroovy()
}
repositories {
mavenCentral()
}
前面我们已经自定义好了插件,接下来就是要打包到Maven库里面去了,你可以选择打包到本地,或者是远程服务器中。在我们自定义Module
目录下的build.gradle添加如下代码:
//group和version在后面使用自定义插件的时候会用到
group='com.hc.plugin'
version='1.0.0'
uploadArchives {
repositories {
mavenDeployer {
//提交到远程服务器:
// repository(url: "http://www.xxx.com/repos") {
// authentication(userName: "admin", password: "admin")
// }
//本地的Maven地址设置为D:/repos
repository(url: uri('D:/repos'))
}
}
}
其中,group
和version
后面会用到,我们后面再讲。虽然我们已经定义好了打包地址以及打包相关配置,但是还需要我们让这个打包task执行。点击AndroidStudio
右侧的gradle工具
,如下图所示:
可以看到有uploadArchives
这个Task
,双击uploadArchives
就会执行打包上传啦!执行完成后,去我们的Maven
本地仓库查看一下:
其中,com/hc/plugin
这几层目录是由我们的group
指定,myplugin
是模块的名称,1.0.0
是版本号(version
指定)。
接下来就是使用自定义的插件了,一般就是在app
这个模块中使用自定义插件,因此在app
这个Module
的build.gradle文件中,需要指定本地Maven
地址、自定义插件的名称以及依赖包名。简而言之,就是在app
这个Module
的build.gradle文件中后面附加如下代码:
buildscript {
repositories {
maven {//本地Maven仓库地址
url uri('D:/repos')
}
}
dependencies {
//格式为-->group:module:version
classpath 'com.hc.plugin:myplugin:1.0.0'
}
}
//com.hc.gradle为resources/META-INF/gradle-plugins
//下的properties文件名称
apply plugin: 'com.hc.gradle'
好啦,接下来就是看看效果啦!先clean project
(很重要!),然后再make project
.从messages
窗口打印如下信息:
好啦,现在终于运行了自定义的gradle插件啦!
前面我们讲了如何自定义gradle插件并且打包出去,可能步骤比较多。有时候,你可能并不需要打包出去,只是在这一个项目中使用而已,那么你无需打包这个过程。
只是针对当前项目开发的Gradle插件相对较简单。步骤之前所提到的很类似,只是有几点需要注意:
- 新建的Module名称必须为
BuildSrc
- 无需resources目录
目录结构如下所示:
其中,build.gradle
内容为:
apply plugin: 'groovy'
dependencies {
compile gradleApi()//gradle sdk
compile localGroovy()//groovy sdk
}
repositories {
jcenter()
}
SecondPlugin.groovy内容为:
package com.hc.second
import org.gradle.api.Plugin
import org.gradle.api.Project
public class SecondPlugin implements Plugin<Project> {
void apply(Project project) {
System.out.println("========================");
System.out.println("这是第二个插件!");
System.out.println("========================");
}
}
在app
这个Module
中如何使用呢?直接在app的build.gradle下加入
apply plugin: com.hc.second.SecondPlugin
clean
一下,再make project
,messages
窗口信息如下:
由于之前我们自定义的插件我没有在app
的build.gradle
中删除,所以hello gradle plugin
这条信息还会打印.
参考资料:http://kvh.io/cn/tags/EmbraceAndroidStudio/
献上源码:http://download.csdn.net/detail/huachao1001/9565654