IDEA Plugins

开发环境

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

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

本地可能已经安装了Ultimate版本,但是还是需要安装IDEA的社区版本。因为商业版是闭源的,所以在调试时无法调试核心代码。
社区版的安装包里是不包含源码的,所以需要手动从github上clone一份:

  1. 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 来运行插件:
开发一个 IntelliJ IDEA 插件 - 图1
除非在Mac上使用官方JDK,否则需要手动添加 /lib/tools.jar 到classpath中。

配置 IntelliJ Platform SDK

打开 File | Project Structure 新建一个 IntelliJ Platform SDK:
开发一个 IntelliJ IDEA 插件 - 图2
Java SDK 选择刚刚建立的 IDEA jdk:
开发一个 IntelliJ IDEA 插件 - 图3
然后可以把下载的 IDEA 社区版源码添加到源码路径中,这样在调试时,就可以调试 IDEA 自身的代码了:
开发一个 IntelliJ IDEA 插件 - 图4
开发一个 IntelliJ IDEA 插件 - 图5

第一个插件

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

新建工程

选择IntellJ Platform Plugin,然后Project SDK指定刚刚新建的plugin sdk:
开发一个 IntelliJ IDEA 插件 - 图6
新建的插件项目:
开发一个 IntelliJ IDEA 插件 - 图7
插件根目录下有两个目录src和resources。src是插件代码目录,resource是插件资源目录,其中META-INF/plugin.xml是插件的描述文件,就像Java web项目的web.xml一样。
plugin.xml 默认的内容如下:

  1. <idea-plugin>
  2. <id>com.your.company.unique.plugin.id</id>
  3. <name>Plugin display name here</name>
  4. <version>1.0</version>
  5. <vendor email="support@yourcompany.com" url="http://www.yourcompany.com">YourCompany</vendor>
  6. <description><![CDATA[
  7. Enter short description for your plugin here.<br>
  8. <em>most HTML tags may be used</em>
  9. ]]></description>
  10. <change-notes><![CDATA[
  11. Add change notes here.<br>
  12. <em>most HTML tags may be used</em>
  13. ]]>
  14. </change-notes>
  15. <!-- please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/build_number_ranges.html for description -->
  16. <idea-version since-build="145.0"/>
  17. <!-- please see http://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/plugin_compatibility.html
  18. on how to target different products -->
  19. <!-- uncomment to enable plugin in all products
  20. <depends>com.intellij.modules.lang</depends>
  21. -->
  22. <extensions defaultExtensionNs="com.intellij">
  23. <!-- Add your extensions here -->
  24. </extensions>
  25. <actions>
  26. <!-- Add your actions here -->
  27. </actions>
  28. </idea-plugin>

新建一个 Action

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

  1. 继承 AnAction 类,在 actionPerformed 方法中实现插件逻辑
  2. 注册 action,有两种方式,通过代码注册和通过 plugin.xml 注册

先写一个简单的Action类:

  1. public class TextBoxes extends AnAction {
  2. // 如果通过Java代码来注册,这个构造函数会被调用,传给父类的字符串会被作为菜单项的名称
  3. // 如果你通过plugin.xml来注册,可以忽略这个构造函数
  4. public TextBoxes() {
  5. // 设置菜单项名称
  6. super("Text _Boxes");
  7. // 还可以设置菜单项名称,描述,图标
  8. // super("Text _Boxes","Item description",IconLoader.getIcon("/Mypackage/icon.png"));
  9. }
  10. public void actionPerformed(AnActionEvent event) {
  11. Project project = event.getData(PlatformDataKeys.PROJECT);
  12. String txt= Messages.showInputDialog(project, "What is your name?", "Input your name", Messages.getQuestionIcon());
  13. Messages.showMessageDialog(project, "Hello, " + txt + "!\n I am glad to see you.", "Information", Messages.getInformationIcon());
  14. }
  15. }

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

  1. <actions>
  2. <group id="MyPlugin.SampleMenu" text="_Sample Menu" description="Sample menu">
  3. <add-to-group group-id="MainMenu" anchor="last" />
  4. <action id="Myplugin.Textboxes" class="Mypackage.TextBoxes" text="Text _Boxes" description="A test menu item" />
  5. </group>
  6. </actions>

这里新建了一个菜单组,其中 text 字符串的下划线表示这个字母作为快捷键。这个菜单显示的效果如下:
开发一个 IntelliJ IDEA 插件 - 图8
除了手动新建Action,IDEA还提供了快速新建的方法,在代码目录上点击新建,可以看到Action:
开发一个 IntelliJ IDEA 插件 - 图9
可以在这个面板中填写要新建的Action信息,IDEA会新建类,还有在plugin.xml中注册:
开发一个 IntelliJ IDEA 插件 - 图10

运行插件

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