Android IDE Plugin ViewInject

2024-06-24 06:58
文章标签 android ide plugin viewinject

本文主要是介绍Android IDE Plugin ViewInject,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言
目前为止,Android使用的插件的已经很多了,但是自己在这块确实空白的,之前写过了ViewInject博客了,在优化findViewById之后,考虑到不需要手写问题的情况下,采用插件辅助来开发,网上目前已经有了ButterKnife的辅助的插件,为自己开发ViewInject插件,个人建议不要光看我写的一部分我用到的方法,需要你自己看IDE Plugin API刚好这段时间有空闲时间。

使用
在使用本插件之前,请使用https://blog.csdn.net/u012127961/article/details/70195693
插件下载
插件项目
插件导入方法

技术
IDE Plugin API : http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/publishing_plugin.html

(1)创建插件项目(http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/creating_plugin_project.html)
这里写图片描述
(2)创建Action (http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/creating_an_action.html)
这里写图片描述
(3)获取当前项目、编辑器、文档对象

@Overridepublic void actionPerformed(AnActionEvent e) {Project project = e.getProject();Editor editor = e.getData(CommonDataKeys.EDITOR);Document document = editor.getDocument();}

(4)显示提示信息

Messages.showMessageDialog("信息内容", "提示", Messages.getInformationIcon());

(5)获取鼠标选中文字

        SelectionModel selectionMode = editor.getSelectionModel();String selectText = selectionMode.getSelectedText();

(6)获取当前打开的文件

 PsiFile psiFile = e.getData(LangDataKeys.PSI_FILE);//e--->AnActionEvent String content = psiFile.getViewProvider().getContents().toString();//文件内容

(7)文件写入信息

        Document document = editor.getDocument();WriteCommandAction.runWriteCommandAction(project, new Runnable() {@Overridepublic void run() {document.insertString(xx, xxxxx);}});

(8)替换文字

        Document document = editor.getDocument();SelectionModel selectionModel = editor.getSelectionModel();int start = selectionModel.getSelectionStart();int end = selectionModel.getSelectionEnd();WriteCommandAction.runWriteCommandAction(project, () ->document.replaceString(start, end, "Replacement"));selectionModel.removeSelection();

(9)获取当前类

protected PsiClass getTargetClass(Editor editor, PsiFile file) {int offset = editor.getCaretModel().getOffset();PsiElement element = file.findElementAt(offset);if (element == null) {return null;} else {PsiClass target = (PsiClass) PsiTreeUtil.getParentOfType(element, PsiClass.class);return target instanceof SyntheticElement ? null : target;}
}

(10)获取ElementFactory

ElementFactory ElementFactory = JavaPsiFacade.getElementFactory(project);

(11)类操作

PsiClass psiClass = getTargetClass(editor, psiFile);
//添加字段  --- [其他方式可以更改createFieldFromText这里,还可以对方法、包都可以操作]
psiClass.add(JavaPsiFacade.getElementFactory(project).createFieldFromText("private Editext etxtUser;", psiClass));

ViewInject Plugin

import com.intellij.openapi.actionSystem.AnAction;
import com.intellij.openapi.actionSystem.AnActionEvent;
import com.intellij.openapi.actionSystem.CommonDataKeys;
import com.intellij.openapi.actionSystem.LangDataKeys;
import com.intellij.openapi.command.WriteCommandAction;
import com.intellij.openapi.editor.Document;
import com.intellij.openapi.editor.Editor;
import com.intellij.openapi.editor.SelectionModel;
import com.intellij.openapi.project.Project;
import com.intellij.openapi.ui.Messages;
import com.intellij.psi.PsiFile;
import com.intellij.psi.PsiFileSystemItem;
import com.intellij.psi.PsiManager;
import com.intellij.psi.search.FilenameIndex;
import com.intellij.psi.search.GlobalSearchScope;
import com.intellij.psi.xml.XmlFile;
import com.intellij.psi.xml.XmlTag;
import org.apache.http.util.TextUtils;import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;public class ViewInject extends AnAction {@Overridepublic void actionPerformed(AnActionEvent e) {Project project = e.getProject();Editor editor = e.getData(CommonDataKeys.EDITOR);Document document = editor.getDocument();//获取选中文字SelectionModel selectionMode = editor.getSelectionModel();String selectText = selectionMode.getSelectedText();if (TextUtils.isEmpty(selectText)) {Messages.showMessageDialog("Select the layout name, such as: R.layout. Aty_main, and select aty_main", "提示", Messages.getInformationIcon());return;}//当前文件PsiFile psiFile = e.getData(LangDataKeys.PSI_FILE);String currentContent = psiFile.getViewProvider().getContents().toString();String current[] = currentContent.split("\n");StringBuffer packageSb = new StringBuffer();packageSb.append("import android.widget.*;");packageSb.append("\n");packageSb.append("import com.android.annotation.ViewInject;");packageSb.append("\n");StringBuffer sbPackage = new StringBuffer();for (int i = 0; i < current.length; i++) {if (current[i].contains("import")) {break;} else {sbPackage.append(current[i] + "\n");}}WriteCommandAction.runWriteCommandAction(project, new Runnable() {@Overridepublic void run() {document.insertString(sbPackage.length(), packageSb.toString());}});List<Map<String, String>> list = findViewIdByXmlName(project, selectText);StringBuffer fieldSb = new StringBuffer("\n");for (int i = 0; i < list.size(); i++) {Map<String, String> map = list.get(i);String id = map.get("id");String name = map.get("name");fieldSb.append("    @ViewInject(R.id." + id + ")");fieldSb.append("\n");fieldSb.append("    private " + name + " " + id + ";");fieldSb.append("\n");}StringBuffer sbTop = new StringBuffer();for (int i = 0; i < current.length; i++) {sbTop.append(current[i] + "\n");if (current[i].contains("{")) {break;}}WriteCommandAction.runWriteCommandAction(project, new Runnable() {@Overridepublic void run() {document.insertString(sbTop.length() + packageSb.toString().length(), fieldSb.toString());}});}@Overridepublic void update(AnActionEvent e) {super.update(e);//Get required data keysfinal Project project = e.getProject();final Editor editor = e.getData(CommonDataKeys.EDITOR);//Set visibility only in case of existing project and editor and if some text in the editor is selectede.getPresentation().setEnabled(project != null && editor != null);}/*** 全局搜索xml文件** @param project 项目* @param xmlName xml名字* @return*/private List<Map<String, String>> findViewIdByXmlName(Project project, String xmlName) {List<Map<String, String>> idList = new ArrayList<>();PsiFileSystemItem[] items = FilenameIndex.getFilesByName(project, xmlName + ".xml", GlobalSearchScope.allScope(project), false);if (items.length == 1) {XmlFile xmlFile = (XmlFile) PsiManager.getInstance(project).findFile(items[0].getVirtualFile());XmlTag tag = xmlFile.getRootTag();findViewByXmlTag(project, tag, idList);}return idList;}private List<Map<String, String>> findViewByXmlTag(Project project, XmlTag tag, List<Map<String, String>> idList) {putMap(project, tag, idList);XmlTag[] xmlTags = tag.getSubTags();for (int i = 0; i < xmlTags.length; i++) {XmlTag xmlTag = xmlTags[i];putMap(project, xmlTag, idList);XmlTag[] subTags = xmlTag.getSubTags();if (subTags.length != 0) {for (int j = 0; j < subTags.length; j++) {findViewByXmlTag(project, subTags[j], idList);}}}return idList;}private void putMap(Project project, XmlTag xmlTag, List<Map<String, String>> idList) {if (xmlTag.getAttributeValue("android:id") != null) {Map<String, String> map = new HashMap<>();map.put("name", xmlTag.getName());map.put("id", xmlTag.getAttributeValue("android:id").replace("@+id/", ""));idList.add(map);}if (xmlTag.getName().equals("include") && xmlTag.getAttributeValue("layout") != null) {String name = xmlTag.getAttributeValue("layout").replace("@layout/", "");idList.addAll(findViewIdByXmlName(project, name));}}}

这篇关于Android IDE Plugin ViewInject的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android Kotlin 高阶函数详解及其在协程中的应用小结

《AndroidKotlin高阶函数详解及其在协程中的应用小结》高阶函数是Kotlin中的一个重要特性,它能够将函数作为一等公民(First-ClassCitizen),使得代码更加简洁、灵活和可... 目录1. 引言2. 什么是高阶函数?3. 高阶函数的基础用法3.1 传递函数作为参数3.2 Lambda

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

Android App安装列表获取方法(实践方案)

《AndroidApp安装列表获取方法(实践方案)》文章介绍了Android11及以上版本获取应用列表的方案调整,包括权限配置、白名单配置和action配置三种方式,并提供了相应的Java和Kotl... 目录前言实现方案         方案概述一、 androidManifest 三种配置方式

Android WebView无法加载H5页面的常见问题和解决方法

《AndroidWebView无法加载H5页面的常见问题和解决方法》AndroidWebView是一种视图组件,使得Android应用能够显示网页内容,它基于Chromium,具备现代浏览器的许多功... 目录1. WebView 简介2. 常见问题3. 网络权限设置4. 启用 JavaScript5. D

Android如何获取当前CPU频率和占用率

《Android如何获取当前CPU频率和占用率》最近在优化App的性能,需要获取当前CPU视频频率和占用率,所以本文小编就来和大家总结一下如何在Android中获取当前CPU频率和占用率吧... 最近在优化 App 的性能,需要获取当前 CPU视频频率和占用率,通过查询资料,大致思路如下:目前没有标准的

Maven pom.xml文件中build,plugin标签的使用小结

《Mavenpom.xml文件中build,plugin标签的使用小结》本文主要介绍了Mavenpom.xml文件中build,plugin标签的使用小结,文中通过示例代码介绍的非常详细,对大家的学... 目录<build> 标签Plugins插件<build> 标签<build> 标签是 pom.XML

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

Android里面的Service种类以及启动方式

《Android里面的Service种类以及启动方式》Android中的Service分为前台服务和后台服务,前台服务需要亮身份牌并显示通知,后台服务则有启动方式选择,包括startService和b... 目录一句话总结:一、Service 的两种类型:1. 前台服务(必须亮身份牌)2. 后台服务(偷偷干

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤