服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - IntelliJ IDEA插件之开发两种方式创建插件工程

IntelliJ IDEA插件之开发两种方式创建插件工程

2021-10-19 18:15bugstack虫洞栈小傅哥 Java教程

对于码农这一行业的编程学习生涯来说,会遇到很多的不会,不会搭建IDEA工程、不会写老师的案例、不会完成书中的效果、不会做项目的需求、不会实现复杂的逻辑、不会抽象工程的结构等等。

IntelliJ IDEA插件之开发两种方式创建插件工程

一、前言

并不是所有的不会,都是真不会!

对于码农这一行业的编程学习生涯来说,会遇到很多的不会,不会搭建IDEA工程、不会写老师的案例、不会完成书中的效果、不会做项目的需求、不会实现复杂的逻辑、不会抽象工程的结构等等。但这些不会当中并不是所有的不会,都因为太复杂学不会,而是很大一部分内容因为找不到好的资料、没有清晰的文档、缺少完整的案例,导致不知道所以不会。

正好最近在折腾IDEA插件开发的时候,市面的资料确实不多,也没有成体系完整的开发指导手册,所以就遇到了很多不知道就不会的事情,需要一点点查询搜索源码、验证API接口,最终把各项功能实现,当然在这个过程中也确实踩了不少坑!

好!沉淀下来,接下来在这个专栏会把一些关于 IDEA 插件开发用到的各项知识做成案例输出出来,一方面可以让自己缕清所有的知识项,另一方面也可以帮助到更多的有需要的研发人员使用。

二、需求目的

可能你会想什么场景会需要用到插件开发,其实插件开发算是一种通用的解决方案,由服务平台定义标准让各自使用方进行自需的扩展。

这就像我们非常常用的 P3C 代码检查插件、代码审计插件、脚手架工程创建插件、自动化API提取插件、单元测试统计插件等等,这些都是在 IDEA 代码开发平台扩展出来的各项功能插件。

插件也可以说是一种解决方案,其实与你在代码编程时使用人家已经定义好的标准结构和功能下,扩展出自己的功能时是一样的。而这种方式也可以非常好的解决一些属于代码开发期间不易于放到代码提测后问题场景,并能及时提醒研发人员作出响应的修改处理。

三、环境说明

  • IntelliJ Platform Plugin JDK 不是自己安装的JDK1.8等,只有插件JDK才能开发插件
  • IntelliJ IDEA 2019.3.1 x64 如果你是其他版本,会涉及到 插件工程创建后版本修改
  • gradle-5.2.1 与 2019 IDEA 版本下的插件开发匹配,如果遇到一些环境问题可以参考我们开篇介绍

在官方文档 https://plugins.jetbrains.com/docs/intellij/disposers.html 介绍开发 IDEA 插件的工程方式有两种,分别是模板方式和 Gradle 工程方式。这里我们分别演示下不同方式下工程的创建和所涉及到知识点内容的介绍,虽然两种方式都能创建 IDEA 插件工程,但更推荐使用 Gradle 方式。

四、模板方式创建

1. 创建引导

  1. New -> Project -> IntelliJ Platform Plugin 

IntelliJ IDEA插件之开发两种方式创建插件工程

2. 工程结构

guide-idea-plugin-create-project-by-platform

├── resources

│ └── META-INF

│ └── plugin.xml

└── src

└── cn.bugstack.guide.idea.plugin

└── MyAction.java

源码:https://github.com/fuzhengwei/guide-idea-plugin-create-project-by-platform

  • plugin.xml 插件配置:开发描述、版本信息、Action事件入口、扩展信息(数据存放等)
  • src 具体的事件、UI窗体、工程逻辑代码开发
  • 另外类似 MyAction 的创建并不是直接创建普通类,而是通过 New -> Plugin DevKit -> Action 的方式进行创建,因为这样的创建方式可以在 plugin.xml 中自动添加 action 配置。当然如果你要是自己手动创建普通类那样创建 Action 类,则需要自己手动处理配置信息。

3. plugin.xml 配置

  1. <idea-plugin> 
  2.   <id>cn.bugstack.guide.idea.plugin</id> 
  3.   <name>CreateProjectByPlatform</name
  4.   <version>1.0</version> 
  5.   <vendor email="184172133@qq.com" url="https://bugstack.cn">小傅哥</vendor> 
  6.  
  7.   <description><![CDATA[ 
  8.       基于IDEA插件模板方式创建测试工程<br> 
  9.       <em>1. 学习IDEA插件工程搭建</em> 
  10.       <em>2. 验证插件基础功能实现</em> 
  11.     ]]></description> 
  12.  
  13.   <change-notes><![CDATA[ 
  14.       插件开发学习功能点<br> 
  15.       <em>1. 工程搭建</em> 
  16.       <em>2. 菜单读取</em> 
  17.       <em>3. 获取配置</em> 
  18.       <em>4. 回显页面</em> 
  19.     ]]> 
  20.   </change-notes> 
  21.  
  22.   <!-- please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/build_number_ranges.html for description --> 
  23.   <idea-version since-build="173.0"/> 
  24.  
  25.   <!-- please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/plugin_compatibility.html 
  26.        on how to target different products --> 
  27.   <depends>com.intellij.modules.platform</depends> 
  28.  
  29.   <extensions defaultExtensionNs="com.intellij"
  30.     <!-- Add your extensions here --> 
  31.   </extensions> 
  32.  
  33.   <actions> 
  34.     <!-- Add your actions here --> 
  35.     <action id="MyAction" class="cn.bugstack.guide.idea.plugin.MyAction" text="MyAction" description="MyAction"
  36.       <add-to-group group-id="FileMenu" anchor="first"/> 
  37.     </action
  38.  
  39.   </actions> 
  40.  
  41. </idea-plugin> 

这里重点看 actions 其他上面的工程信息、版本描述、个人资料都按照自己的信息填写就行,不会影响插件运行。

actions 下是关于所有事件入口的配置,也就是你希望让你的 IDEA 插件在 IDEA 窗体中什么地方展示,以及配置快捷键等。这里的配置说明是在 FileMenu 下的第一个入口即为你的插件。

4. MyAction 事件入口

  1. ![1-04](https://bugstack.cn/assets/images/middleware/guide-idea-plugin-1-04.png)![1-04](https://bugstack.cn/assets/images/middleware/guide-idea-plugin-1-04.png)public class MyAction extends AnAction { 
  2.  
  3.     @Override 
  4.     public void actionPerformed(AnActionEvent e) { 
  5.         Project project = e.getData(PlatformDataKeys.PROJECT); 
  6.         PsiFile psiFile = e.getData(CommonDataKeys.PSI_FILE); 
  7.         String classPath = psiFile.getVirtualFile().getPath(); 
  8.  
  9.         Messages.showMessageDialog(project, "guide-idea-plugin-create-project-by-platform: " + classPath, "Hi IDEA Plugin", Messages.getInformationIcon()); 
  10.     } 
  11.  
  • 在 MyAction 事件入口中获取 Project 工程信息、PsiFile 文件信息,以及对应的类路径。
  • 最后在 Messages.showMessageDialog 下打印,这样把鼠标放到工程类下,在点这个按钮的时候就可以看到类的路径弹窗了。

5. 运行测试

运行过程

  • 点击 Plugin 绿色箭头,和正常启动程序一样
  • 这个时候它会打开一个新的 IDEA 工程,并在这个工程中默认安装你开发好的插件
  • 在新打开的 IDEA 插件工程中,选中工程类后,点击 File -> MyAction

运行结果

IntelliJ IDEA插件之开发两种方式创建插件工程

通过测试运行效果可以看到,已经可以打出工程下类的路径信息了。你也可以尝试把Action的入口放到其他按钮下进行测试

五、Gradle 方式创建

1. 创建引导

New -> Project -> Gradle 选中 Java & IntelliJ Platform Plugin

IntelliJ IDEA插件之开发两种方式创建插件工程

2. 工程结构

  1. guide-idea-plugin-create-project-by-gradle 
  2. ├── .gradle 
  3. └── src 
  4.     ├── main 
  5.     │   └── java 
  6.     │    └── cn.bugstack.guide.idea.plugin  
  7.     │        └── MyAction.java     
  8.     ├── resources 
  9.     │   └── META-INF 
  10.     │       └── plugin.xml  
  11.     ├── build.gradle   
  12.     └── gradle.properties 

源码:https://github.com/fuzhengwei/guide-idea-plugin-create-project-by-gradle

  • 与模板方式创建 Gradle 主要差异在 build.gradle、gradle.properties 内容的配置,这两个文件主要是处理 Gradle 相关信息的,其中 gradle.properties 用于配置 JVM Xmx 参数的,避免下载耗费资源较大崩溃。
  • plugin.xml 配置插件入口等内容,MyAction 是事件入口。

3. build.gradle 配置

  1. plugins { 
  2.     id 'java' 
  3.     id 'org.jetbrains.intellij' version '0.6.3' 
  4.  
  5. group 'cn.bugstack.guide.idea.plugin' 
  6. version '1.0-SNAPSHOT' 
  7.  
  8. sourceCompatibility = 1.8 
  9.  
  10. repositories { 
  11.     mavenCentral() 
  12.  
  13. dependencies { 
  14.     testCompile group'junit'name'junit', version: '4.12' 
  15.  
  16. // See https://github.com/JetBrains/gradle-intellij-plugin/ 
  17. intellij { 
  18.     version '2019.3.1' 
  19. patchPluginXml { 
  20.     changeNotes ""
  21.       <![CDATA[ 
  22.       插件开发学习功能点<br> 
  23.       <em>1. 工程搭建</em> 
  24.       <em>2. 菜单读取</em> 
  25.       <em>3. 获取配置</em> 
  26.       <em>4. 回显页面</em> 
  27.     ]]>""

gradle 与 maven 的使用配置上,还是可以相通的找到一些类似的地方的,如果没有使用过 gradle 也是可以使用的。

这里需要注意 plugins 中 id 'org.jetbrains.intellij' version '0.6.3' 默认创建工程的版本有点高,与 gradle 5.x 不匹配。不过你可以尝试调试合适版本进行使用

4. MyAction 事件入口

  1. public class MyAction extends AnAction { 
  2.  
  3.     @Override 
  4.     public void actionPerformed(AnActionEvent e) { 
  5.         Project project = e.getData(PlatformDataKeys.PROJECT); 
  6.         PsiFile psiFile = e.getData(CommonDataKeys.PSI_FILE); 
  7.         String classPath = psiFile.getVirtualFile().getPath(); 
  8.  
  9.         Messages.showMessageDialog(project, "guide-idea-plugin-create-project-by-gradle: " + classPath, "Hi IDEA Plugin", Messages.getInformationIcon()); 
  10.     } 
  11.  

这里与模板方式创建的案例是一样的,为了区别两个插件测试,我们这里打印了工程的名称。当然你也可以使用 project.getName() 获取工程名称。

5. 运行测试

Gradle 测试运行相当于是运行 :runIde ,也是和普通的代码调试一样。

运行结果

IntelliJ IDEA插件之开发两种方式创建插件工程

通过测试运行效果可以看到,已经可以打出工程下类的路径信息了。

六、总结

整篇内容的学习还是蛮简单的,哪怕你之前没开发过 IDEA 插件,按照这样的套路往下折腾也是可以完成插件开发的。类似这样的知识内容只是平时常做业务开发所以接触的也不多,乍一听上去还是很陌生的,不过有这样的资料就可以上手了。

本章节初步介绍 IDEA 插件的方式和一个非常简单的基本功能,后续我们在 Gradle 创建插件的基础上,继续开发其他案例功能,逐步学习 IDEA 插件开发用到的各项技巧用于完成所需要解决的问题。

在学习的过程中可以自行尝试扩展一些其他组件入口,打印不同的工程信息。就像你使用的一些的插件一样,帮助你生成get、set,或者提取采集接口信息,也包括你写了多少行代码,思考它们是如何实现的。

原文链接:https://mp.weixin.qq.com/s/YcpHDgQsQ2L2Ft33EaR8fQ

延伸 · 阅读

精彩推荐
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7472021-02-04