Android Gradle入门到精通(二)

2021-12-17  本文已影响0人  过期的薯条

1.背景

上节学完了Gradle的基础知识,这节学习下Gradle的自定义插件。自定义插件主要分为三种方式:

在工作中,这几种方式都见到别人使用过。学习完这章之后,我们可以定义一些插件给别人使用,配合apt能实现很多有意思的场景。

2.正题

2.1 自定义.gradle文件

实现目标:自定义一个拓展,然后在apk打包的时候,将拓展信息读取出来

class Address{
    public String nation
    public String city;
}
class MyPlugin{
    public String name;
    public Address address=new Address();
    // 配置方法
    void addressConfig(Action<Address> action) {
        action.execute(address) // 直接执行 action 参数的 execute 方法,并传入扩展对象
    }
}

project.getExtensions().create("myPlugin",MyPlugin)

//所有配置加载完毕之后
project.afterEvaluate {
    project.tasks.getByName("assembleDebug").doLast {
        MyPlugin mMyPlugin= project.getExtensions().getByName("myPlugin");
        println "name: "+mMyPlugin.name+"   "+mMyPlugin.address.city+"  "+mMyPlugin.address.nation
    }
}

ps:注意 project.tasks.getByName("assembleDebug") 要在 project.afterEvaluate中。不然 会提示找不到 名为 “assembleDebug”的task。

之后build.gradle中:

myPlugin {
    name = "wxy"
    addressConfig {
        nation = "湖北"
        city = "武汉"
    }
}

打印结果:

> Task :app:assembleDebug
name: wxy   武汉  湖北

2.2 创建 java buildSrc module

apply plugin: 'groovy'  //必须
apply plugin: 'maven'

dependencies {
    implementation gradleApi() //必须
    implementation localGroovy() //必须
    //如果要使用android的API,需要引用这个,实现Transform的时候会用到
    //implementation 'com.android.tools.build:gradle:3.3.0'
}
sourceSets {
    main {
        groovy {
            srcDir 'src/main/groovy'
        }
        java {
            srcDir "src/main/groovy"
        }
        resources {
            srcDir 'src/main/resources'
        }
    }
}

repositories {
    //google()
    jcenter()
    mavenCentral() //必须
}
package com.heytap.tv
import org.gradle.api.Plugin
import org.gradle.api.Project

class MyPlugin implements Plugin<Project> {
    @Override
    void apply(Project target) {
        println(" hello world ")
    }
}

apply plugin: 'com.heytap'

之后重新构建下,就能引入buildSrc中自定义的 gradle


2.3 创建独立的java module ,并发布到本地或服务器

image.png
def group='com.heytap.plugin' //组
def version='1.0.0' //版本
def artifactId='myplugin2' //唯一标示

//将插件打包上传到本地maven仓库  ,uploadArchives 可以在AppExtension 查询到
uploadArchives {
    repositories {
        mavenDeployer {
            pom.groupId = group
            pom.artifactId = artifactId
            pom.version = version
            //指定本地maven的路径,在项目根目录下
            repository(url: uri('../repos'))   //插件路径,最终以jar形式结尾
        }
    }
}
image-20211118202810571.png
        ....
        maven {
            url uri('./repos') //指定本地maven的路径,在项目根目录下
        }
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:4.1.1'
        classpath 'com.heytap.plugin:myplugin2:1.0.0'   //自定义的gradle插件路径
    }
}

在 app的 build.gradle 中:

apply plugin : "com.heytap.demo"

运行结果:

image-20211118202810571.png

以上就是 自定义插件的基本内容

总结:

上一篇下一篇

猜你喜欢

热点阅读