从 0 到 1 开发一个 IntelliJ IDEA 插件

Java
250
0
0
2024-01-06

写 Java 代码的时候,经常会涉及到重复性的操作,这个时候就会想要是有这样一个插件就好了,如果是大家都会遇到的场景, IDE 或许已经提供了,再不然也有可能有人编写了相关的插件。

要是这个操作是你们的编码环境特有的,那就只能自己写工具了。所以这里来学学如何编写 IDEA 插件,让自己的编程环境更加强大,更好的进行装逼。

开发环境

开发IDEA插件有以下这些依赖:

  • IntelliJ IDEA Community Edition
  • IntelliJ IDEA Community Edition 源码
  • Plugin DevKit 插件
  • IntelliJ Platform SDK

你可能已经安装了Ultimate版本,但是你还是需要安装IDEA的社区版本。因为商业版是闭源的,所以在调试时无法调试核心代码。

社区版的安装包里是不包含源码的,所以我们需要手动从 github 上clone一份:

git clone –depth 1 git://git.jetbrains.org/idea/community.git idea

关于从源码运行IDEA的方法参考:Check Out And Build Community Edition

添加 IDEA JDK

虽然不知道原因,但是根据Check Out And Build Community Edition,我们需要建立一个IDEA jdk 来运行插件:

从 0 到 1 开发一个 IntelliJ IDEA 插件

除非你在Mac上使用官方JDK,否则你需要手动添加 /lib/tools.jar 到 classpath 中。

配置 IntelliJ Platform SDK

打开 File | Project Structure 新建一个 IntelliJ Platform SDK:

从 0 到 1 开发一个 IntelliJ IDEA 插件

Java SDK 选择我们刚刚建立的 IDEA jdk:

从 0 到 1 开发一个 IntelliJ IDEA 插件

然后我们可以把下载的 IDEA 社区版源码添加到源码路径中,这样在调试时,就可以调试 IDEA 自身的代码了:

从 0 到 1 开发一个 IntelliJ IDEA 插件

从 0 到 1 开发一个 IntelliJ IDEA 插件

第一个插件

我们来编写一个最简单的插件来学习编写一个插件的完整步骤。

新建工程

选择IntellJ Platform Plugin,然后Project SDK指定刚刚新建的 plugin sdk:

从 0 到 1 开发一个 IntelliJ IDEA 插件

新建的插件项目:

从 0 到 1 开发一个 IntelliJ IDEA 插件

插件根目录下有两个目录src和resources。src是插件代码目录,resource是插件资源目录,其中META-INF/plugin.xml是插件的描述文件,就像Java web项目的web.xml一样。

plugin.xml 默认的内容如下:

<idea-plugin>

<id> com.your.company.unique.plugin.id </id>

<name> Plugin display name here </name>

<version> 1.0 </version>

<vendor email = “support@yourcompany.com” url = “#34; >YourCompany </vendor>

<description> <![CDATA[

Enter short description for your plugin here.<br>

<em>most HTML tags may be used</em>

]]> </description>

<change-notes> <![CDATA[

Add change notes here.<br>

<em>most HTML tags may be used</em>

]]>

</change-notes>

<!– please see for description –>

<idea-version since-build = “145.0” />

<!– please see

on how to target different products –>

<!– uncomment to enable plugin in all products

<depends>com.intellij.modules.lang</depends>

–>

<extensions defaultExtensionNs = “com.intellij” >

<!– Add your extensions here –>

</extensions>

<actions>

<!– Add your actions here –>

</actions>

</idea-plugin>

新建一个 Action

插件扩展 IDEA 最常见的方式就是在菜单栏或者工具栏中添加菜单项,用户通过点击菜单项来触发插件功能。IDEA 提供了 AnAction 类,这个类有一个虚方法 actionPerformed,这个方法会在每次菜单被点击时调用。

新建一个自定义的 Action 有两个步骤:

1. 继承 AnAction 类,在 actionPerformed 方法中实现插件逻辑

2. 注册 action,有两种方式,通过代码注册和通过 plugin.xml 注册

我们先写一个简单的Action类:

public class TextBoxes extends AnAction {

// 如果通过Java代码来注册,这个 构造函数 会被调用,传给父类的 字符串 会被作为菜单项的名称

// 如果你通过plugin.xml来注册,可以忽略这个构造函数

public TextBoxes () {

// 设置菜单项名称

super ( “Text _Boxes” );

// 还可以设置菜单项名称,描述,图标

// super(“Text _Boxes”,”Item description”,IconLoader.getIcon(“/Mypackage/icon.png”));

}

public void actionPerformed (AnActionEvent event) {

Project project = event.getData(PlatformDataKeys.PROJECT);

String txt= Messages.showInputDialog(project, “What is your name?” , “Input your name” , Messages.getQuestionIcon());

Messages.showMessageDialog(project, “Hello, ” + txt + “!n I am glad to see you.” , “Information” , Messages.getInformationIcon());

}

}

然后我们在plugin.xml中注册这个Action:

<actions>

< group id= “MyPlugin.SampleMenu” text= “_Sample Menu” description= “Sample menu” >

< add -to- group group -id= “MainMenu” anchor= “last” />

<action id= “Myplugin.Textboxes” class = “Mypackage.TextBoxes” text= “Text _Boxes” description= “A test menu item” />

</ group >

</actions>

这里我们新建了一个菜单组,其中 text 字符串的下划线表示这个字母作为快捷键。这个菜单显示的效果如下:

除了手动新建Action,IDEA还提供了快速新建的方法,在代码目录上点击新建,可以看到Action:

可以在这个面板中填写你要新建的Action信息,IDEA会帮你新建类,还有在plugin.xml中帮你注册:

运行插件

运行插件特别简单,和运行普通Java代码一样,点击运行或者调试的按钮,就会启动一个新的IDEA实例,这个实例中插件是生效的。

点击 Text Boxes 就可以看到插件的效果了。

参考资料

  • Setting Up a Development Environment
  • How to make an IntelliJ IDEA plugin in less than 30 minutes

本文独立博客地址:从零开始编写IntelliJ IDEA插件 | 木杉的博客