Android注解开发APT

文章目录

  • 简介
  • APT注解开发工具
    • 使用场景
    • 开发流程
      • 前情提要
        • 创建aar
        • 创建jar
      • 声明注解
      • 注解编译处理
        • gradle
        • Processor
          • process方法
          • 完整举例
    • 编译结果
  • 总结

简介

相信各位Android开发对注解这个东西并不陌生,毕竟在用Arouter的时候,注解@Route是基本要使用的注解。但这只是对注解的使用。
那么在日常开发中,如何去定义注解,并通过注解在编译期间去生成一些代码,这便是本文要介绍的APT技术。

APT注解开发工具

使用场景

对于一些格式相对固定的代码,可能并不希望开发者去花费时间去编写这些固定的代码。针对这种场景,就可以考虑使用注解开发。通过声明注解,给定相对应的参数,并在编译期生成这些固定的代码。

举个简单的例子,让我们来简化一下Arouter的流程:
场景描述:一个模块内有多个类需要路由,路由表维护了名称和类的全类名用于反射(简单来说就是有个map,key是路由名称,value时全类名),那么就可以通过名称获取到对应的类。

开发流程

注解开发通常涉及两个部分(最终产物是俩jar包):

  1. 注解声明部分, annotation
  2. 注解编译处理部分,compile

前情提要

这点很重要,在这吃过亏,耽误过一段时间
library的类型有aar和jar两种
aar和安卓相关,jar和java(kotlin)相关
aar可以引用jar,但jar不能引用aar

创建aar

在这里插入图片描述

创建jar

在这里插入图片描述

声明注解

注解的声明十分简单,没有什么坑,本文介绍场景都是对类的注解(其他的没研究,偷个懒)。

@Target(ElementType.TYPE)  
@Retention(RetentionPolicy.CLASS)  
public @interface MethodBridge {
   
     
    String subMethod();  
}

MethodBridge这就是一个注解的名称,String subMethod()定义了注解内部包含的属性,这在编译期会被用到。

OK注解声明部分就这么些玩意。

注解编译处理

这是注解开发的核心部分,所有注解处理的相关操作都是在这里执行的

gradle

首先,这玩意是需要在编译期生成代码的,所以kapt插件是得有的。我现在用的是ktx版本的gradle,语法如下:

plugins {  
    kotlin("kapt")  
}

依赖呢,直接抄作业就行:

dependencies {  
    implementation(fileTree("libs"){  
        include("*.jar,*.aar")  
    })  
    implementation("com.google.auto.service:auto-service:1.0-rc6")  
    kapt("com.google.auto.service:auto-service:1.0-rc6")  
}

注意一下这个dependencies里引一下上一节定义的annotation包,因为解析的就是这里的注解。

Processor

可以将这部分理解为注解处理器
大体结构为:

@AutoService(Processor.class)  
@SupportedSourceVersion(SourceVersion.RELEASE_8)  
public class MethodBridgeCompile extends AbstractProcessor {
   
     
  
    private String moduleName = "CommonBridgeModule";  
  
    Filer filer;  
    Messager messager;  
  
    @Override  
    public synchronized void init(ProcessingEnvironment processingEnv) {
   
     
        super.init(processingEnv);  
        messager = processingEnv.getMessager(); // 打印对象  
        filer = processingEnv.getFiler(); // 文件操作对象  
        messager.printMessage(Diagnostic.Kind.NOTE, "moduleName:::" + processingEnv.getOptions().get("BRIDGE_MODULE_NAME"));  
        if 
AndroidInject 是 Android 注解框架,以简化 Android 开发 目前完成的注解(持续增加中): @AINoTitle: 类注解, 只适用于Activity(需继承于AIActivity), 设置Activity不显示Title     @AIFullScreen: 类注解, 只适用于Activity(需继承于AIActivity), 设置Activity全屏     @AILayout: 类注解         value[int]: 用于设置该Activity的布局 ---- setContentView(resId);     @AIView: 属性注解         id[int]: 用于绑定控件 ---- findViewById(resId);(default identifier[R.id.{field name}] if did not set id)         clickMethod[String]: 用于设置控件点击事件的回调方法, 可选, 方法名称任意, 参数必须为(View view)         longClickMethod[String]: 用于设置控件长按的回调方法, 可选, 方法名任意, 参数必须为(View view)         itemClickMethod[String]: 用于设置控件item点击的回调方法, 可选, 方法名任意, 参数必须为(AdapterView, View, int, long)         itemLongClickMethod[String]: 用于设置控件item长按的回调方法, 可选, 方法名任意, 参数必须为(AdapterView, View, int, long)     @AIBean: 属性注解, 为该属性生成一个对象并注入, 该对象必须有个默认的不带参数的构造方法     @AISystemService: 属性注解,为该属性注入系统服务对象     @AIClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件点击事件的回调方法, 方法名称任意, 参数必须为(View view)     @AIItemClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件item点击事件的回调方法, 方法名称任意, 参数必须为(AdapterView, View, int, long)     @AILongClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件长按事件的回调方法, 方法名称任意, 参数必须为(View view)     @AIItemLongClick: 方法注解         value[int[], 所要绑定控件的id]: 用于绑定控件item长按事件的回调方法, 方法名称任意, 参数必须为(AdapterView, View, int, long)     @AIScreenSize: 属性注解         用于注入当前设备的屏幕大小(宽高)     @AIGet: 方法注解         value[String, 所要请求的url]:表示以GET来请求url         connTimeout[int, 连接超时时间]:连接一个url的连接等待时间         soTimeout[int, response返回超时时间]:连接上一个url,获取response的返回等待时间     @AIPost: 方法注解         value[String, 所要请求的url]:表示以Post来请求url         connTimeout[int, 连接超时时间]:连接一个url的连接等待时间         soTimeout[int, response返回超时时间]:连接上一个url,获取response的返回等待时间     @AIParam: 方法参数注解         value[String, 请求的参数别名]:注入@AIGet或@AIPost注解方法的请求参数     @AINetWorker: 属性注解         注入网络请求服务     @AIUpload: 方法注解         value[String, 所要请求的url]:表示要上传的url,默认用post请求(不需要使用@AIPost注解)         connTimeout[int, 连接超时时间]:连接一个url的连接等待时间         soTimeout[int, response返回超时时间]:连接上一个url,获取response的返回等待时间         注意:使用此注解的方法参数需要包含Collection或其子类型集合 或者包含File对象 来作为要上传的文件 使用fragment的注解,需要android-support-v4.jar的支持(以兼容低版本) 使用网络请求的注解,需要gson.jar的支持 使用文件上传的注解,需要httpmime.jar的支持
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值