使用自定义的Gradle插件

文章详细介绍了如何将自定义的Gradle插件添加到本地Maven仓库,并在项目中进行引用。首先需要在`settings.gradle`的`pluginManagement`中配置本地Maven库,然后在`build.gradle`文件中声明插件并使用`resolutionStrategy`来指定插件的具体模块。最后,在主模块中应用插件,并在插件类中添加功能,同步项目后即可看到插件已成功导入。
书接前文,当我们把自定义的插件发布到本地之后,应该要如何在我们自己的项目中使用到我们自己的插件呢。
1、首先我们需要在setting.gradle的插件管理中,配置本地maven库地址
pluginManagement {

    repositories {
        maven {
            url uri('./repos') //指定本地maven的路径,在项目根目录下
        }
        google()
        mavenCentral()
        gradlePluginPortal()

    }
}
2、在项目的build.gradle中添加我们自定义的插件
plugins {
    id 'com.android.application' version '7.4.1' apply false
    id 'com.android.library' version '7.4.1' apply false
    id 'org.jetbrains.kotlin.android' version '1.9.0' apply false
    id 'org.jetbrains.kotlin.jvm' version '1.6.10' apply false
    id 'com.zhpew.lib' version '1.0.0' apply false
}

此处如果不知道该怎么写才能正常导入,按照上面的写法, 最终会去找 com.zhpew.lib:com.zhpew.lib:1.0.0这个插件,不管怎么写好像都没有办法正常导入com.zhpew.lib:myGradlePlugin:1.0.0,所以需要在导入的时候加点操作。
3、在插件管理中,添加插件导入策略
pluginManagement {
    resolutionStrategy {
        eachPlugin {
            if (requested.id.id == 'com.zhpew.lib') {
                useModule "com.zhpew.lib:myGradlePlugin:${requested.version}"
            }
        }
    }
}
4、在主module中添加我们的插件
plugins {
    id 'com.android.application'
    id 'org.jetbrains.kotlin.android'
    id 'com.zhpew.lib'
}
这样,我们的自定义插件就已经加入到我们的项目中了
我们可以在apply中添加一些东西
class MyClass:Plugin<Project> {
    override fun apply(project: Project) {
        println("==================================================Hello world")
    }
}
然后重新publishing一下,sync一下项目,即可看到
> Configure project :app
==================================================Hello world

> Task :prepareKotlinBuildScriptModel UP-TO-DATE

BUILD SUCCESSFUL in 5s
表示我们的插件已经成功导入到项目中了!
Android Studio中编写自定义Gradle插件,可按以下步骤进行: 1. **创建Gradle Module**:这是编写自定义Gradle插件的起始步骤,需要手动创建相关目录,虽然相较于IDEA缺少开发插件辅助创建文件和目录,但手动创建的目录并不多且不复杂 [^1][^2]。 2. **配置开发语言**:在`build.gradle`中引用`apply plugin:'groovy'`,Groovy是自定义插件的开发语言,其中包含了各种功能类 [^3]。 3. **发布配置**: - 指定自定义Gradle插件的分组,如`group 'kim.hsl.plugin'`。 - 指定自定义Gradle插件的版本号,如`version '0.1'`。 - 自定义Gradle插件的名称,默认为工程名,也可在`publishing / publications`脚本块中自己指定。 - 应用`maven - publish`插件,用于将插件上传到远程仓库或者本地仓库中。 - 配置发布到远程/本地仓库的相关内容,示例代码如下: ```groovy // 指定自定义 Gradle 插件的分组 group 'kim.hsl.plugin' // 指定自定义 Gradle 插件的版本号 version '0.1' // 自定义 Gradle 插件的名称 , 默认为工程名 // 也可以在 publishing / publications 脚本块中 自己指定 // 用于将 插件上传到 远程仓库 或者 本地仓库 中 apply plugin: 'maven - publish' // 发布到 远程/本地仓库 相关配置 publishing { publications { // plugin 函数是随意命名的函数 plugin(MavenPublication) { // 配置上传内容 // components.java 是打包的 jar 包 from components.java // 指定自定义 Gradle 插件名称 artifactId 'plugin' } } } ``` [^4]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值