IOC框架设计----Butterknife

2024-04-20 19:48
文章标签 设计 框架 ioc butterknife

本文主要是介绍IOC框架设计----Butterknife,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是IOC?
核心思想就是:
IOC是原来由程序代码中主动获取的资源,转变由第三方获取,并使原来的代码被动接收的方式,以达到解耦的效果,称为控制翻转。
举个生活中的例子:
你–>穿衣服—>出门 (ioc以前)
你—》一个眼神—>女朋友给你拿衣服,再给你穿上—>出门 (ioc以后)

采用APT注解处理器,替我们写代码。
在这里插入图片描述
app、注解、注解处理器之间的关系:
在这里插入图片描述
注解处理器写法:
1、AnnotationCompiler 继承 AbstractProcessor 重写process方法

public class AnnotationCompiler extends AbstractProcessor {

2、类上加注解@AutoService(processor.class)

@AutoService(Processor.class)
public class AnnotationCompiler extends AbstractProcessor {

3、类里 定义一个用于生成文件的对象
Filer filer; 可以直接get到filer

 //1.定义一个用于生成文件的对象Filer filer;@Overridepublic synchronized void init(ProcessingEnvironment processingEnvironment) {super.init(processingEnvironment);filer=processingEnvironment.getFiler();}

定义一个当前APT处理所有模块中哪些注解

 //2.需要确定当前APT处理所有模块中哪些注解@Overridepublic Set<String> getSupportedAnnotationTypes() {Set<String> types=new HashSet<>();types.add(BindView.class.getCanonicalName());
//        types.add(Override.class.getCanonicalName());return types;}

支持的JDK的版本

 }//3.支持的JDK的版本@Overridepublic SourceVersion getSupportedSourceVersion() {return SourceVersion.latestSupported();}

4、在process方法里开始写文件:
通过roundEnviroment,获取到所有activity中用了我们指定注解的元素。


/*** 在这个方法中,我们去生成IBinder的实现类* @param set* @param roundEnvironment* @return*/@Overridepublic boolean process(Set<? extends TypeElement> set, RoundEnvironment roundEnvironment) {//得到程序中所有写了BindView注解的元素的集合
//类元素(TypeElement)
//可执行元素(ExecutableElement)
//属性元素(VariableElement)Set<? extends Element> elementsAnnotatedWith = roundEnvironment.getElementsAnnotatedWith(BindView.class);

定义一个map <activity名,list<控件类型>>

 //定义一个MAP用来分类Map<String, List<VariableElement>> map=new HashMap<>();
 //开始分类存入MAP中for (Element element : elementsAnnotatedWith) {VariableElement variableElement=(VariableElement)element;//获取activity的名字String activityName=variableElement.getEnclosingElement().getSimpleName().toString();List<VariableElement> elementList=map.get(activityName);//如果等于空,就新创建一个listif(elementList==null){elementList=new ArrayList<>();map.put(activityName,elementList);}//创建了就add进去elementList.add(variableElement);}

运行到这就已经完成了分类工作

准备开始写文件

             //        public class MainActivity_ViewBinding implements IBinder<com.example.dn_butterknife.MainActivity>{writer.write("public class "+activityName+"_ViewBinding implements IBinder<"+packageName+"."+activityName+">{\n");//            @Overridewriter.write("@Override\n");//            public void bind(com.example.dn_butterknife.MainActivity target) {writer.write("public void bind("+packageName+"."+activityName+" target){\n");// target.tvText=(android.widget.TextView)target.findViewById(2131165325);for (VariableElement variableElement : elementList) {//获取控件的名字String variableName=variableElement.getSimpleName().toString();//获取IDint id=variableElement.getAnnotation(BindView.class).value();//获取控件的类型TypeMirror typeMirror=variableElement.asType();writer.write("target."+variableName+"=("+typeMirror+")target.findViewById("+id+");\n");}writer.write("\n}}");}catch(Exception e){e.printStackTrace();}finally{if(writer!=null){try {writer.close();} catch (IOException e) {e.printStackTrace();}}}}}

完整代码:

/*** 这个类就是APT*/
@AutoService(Processor.class)
public class AnnotationCompiler extends AbstractProcessor {//1.定义一个用于生成文件的对象Filer filer;@Overridepublic synchronized void init(ProcessingEnvironment processingEnvironment) {super.init(processingEnvironment);filer=processingEnvironment.getFiler();}//2.需要确定当前APT处理所有模块中哪些注解@Overridepublic Set<String> getSupportedAnnotationTypes() {Set<String> types=new HashSet<>();types.add(BindView.class.getCanonicalName());
//        types.add(Override.class.getCanonicalName());return types;}//3.支持的JDK的版本@Overridepublic SourceVersion getSupportedSourceVersion() {return SourceVersion.latestSupported();}/*** 在这个方法中,我们去生成IBinder的实现类* @param set* @param roundEnvironment* @return*/@Overridepublic boolean process(Set<? extends TypeElement> set, RoundEnvironment roundEnvironment) {//得到程序中所有写了BindView注解的元素的集合//类元素(TypeElement)//可执行元素(ExecutableElement)//属性元素(VariableElement)Set<? extends Element> elementsAnnotatedWith=roundEnvironment.getElementsAnnotatedWith(BindView.class);//定义一个MAP用来分类Map<String, List<VariableElement>> map=new HashMap<>();//开始分类存入MAP中for (Element element : elementsAnnotatedWith) {VariableElement variableElement=(VariableElement)element;//获取activity的名字String activityName=variableElement.getEnclosingElement().getSimpleName().toString();List<VariableElement> elementList=map.get(activityName);if(elementList==null){elementList=new ArrayList<>();map.put(activityName,elementList);}elementList.add(variableElement);}//运行到这就已经完成了分类工作if(map.size()>0){//开始写入文件Writer writer=null;//每一个activity都要生成一个对应的文件Iterator<String> iterator = map.keySet().iterator();while(iterator.hasNext()){String activityName=iterator.next();List<VariableElement> elementList=map.get(activityName);//获取包名TypeElement enclosingElement=(TypeElement)elementList.get(0).getEnclosingElement();String packageName=processingEnv.getElementUtils().getPackageOf(enclosingElement).toString();try{//生成文件//包名.MainActivity_ViewBindingJavaFileObject sourceFile = filer.createSourceFile(packageName + "." + activityName + "_ViewBinding");writer=sourceFile.openWriter();//        package com.example.dn_butterknife;writer.write("package "+packageName+";\n");//        import com.example.dn_butterknife.IBinder;writer.write("import "+packageName+".IBinder;\n");//        public class MainActivity_ViewBinding implements IBinder<com.example.dn_butterknife.MainActivity>{writer.write("public class "+activityName+"_ViewBinding implements IBinder<"+packageName+"."+activityName+">{\n");//            @Overridewriter.write("@Override\n");//            public void bind(com.example.dn_butterknife.MainActivity target) {writer.write("public void bind("+packageName+"."+activityName+" target){\n");// target.tvText=(android.widget.TextView)target.findViewById(2131165325);for (VariableElement variableElement : elementList) {//获取控件的名字String variableName=variableElement.getSimpleName().toString();//获取IDint id=variableElement.getAnnotation(BindView.class).value();//获取控件的类型TypeMirror typeMirror=variableElement.asType();writer.write("target."+variableName+"=("+typeMirror+")target.findViewById("+id+");\n");}writer.write("\n}}");}catch(Exception e){e.printStackTrace();}finally{if(writer!=null){try {writer.close();} catch (IOException e) {e.printStackTrace();}}}}}return false;}
}

这篇关于IOC框架设计----Butterknife的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/921166

相关文章

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

Spring IOC的三种实现方式详解

《SpringIOC的三种实现方式详解》:本文主要介绍SpringIOC的三种实现方式,在Spring框架中,IOC通过依赖注入来实现,而依赖注入主要有三种实现方式,构造器注入、Setter注入... 目录1. 构造器注入(Cons编程tructor Injection)2. Setter注入(Setter

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC

Spring核心思想之浅谈IoC容器与依赖倒置(DI)

《Spring核心思想之浅谈IoC容器与依赖倒置(DI)》文章介绍了Spring的IoC和DI机制,以及MyBatis的动态代理,通过注解和反射,Spring能够自动管理对象的创建和依赖注入,而MyB... 目录一、控制反转 IoC二、依赖倒置 DI1. 详细概念2. Spring 中 DI 的实现原理三、

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF