手把手教你5分鐘從零開發一款簡易的IDEA外掛!專案經驗/畢設不愁了!

JavaGuide發表於2020-11-19

我這個人沒事就喜歡推薦一些好用的 IDEA 外掛給大家。這些外掛極大程度上提高了我們的生產效率以及編碼舒適度。

不知道大家有沒有想過自己開發一款 IDEA 外掛呢?

我自己想過,但是沒去嘗試過。剛好有一位讀者想讓我寫一篇入門 IDEA 開發的文章,所以,我在週末就花了一會時間簡單瞭解一下。

不過,這篇文章只是簡單帶各位小夥伴入門一下 IDEA 外掛開發,個人精力有限,暫時不會深入探討太多。如果你已經有 IDEA 外掛開發的相關經驗的話,這篇文章就可以不用看了,因為會浪費你 3 分鐘的時間。

好的廢話不多說!我們們直接開始!

01 新建一個基於 Gradle 的外掛專案

這裡我們基於 Gradle 進行外掛開發,這也是 IntelliJ 官方的推薦的外掛開發解決方案。

第一步,選擇 Gradle 專案型別並勾選上相應的依賴。

選擇 Gradle 專案型別並勾選上相應的依賴

第二步,填寫專案相關的屬性比如 GroupId、ArtifactId。

填寫專案相關的屬性

第三步,靜靜等待專案下載相關依賴。

第一次建立 IDEA 外掛專案的話,這一步會比較慢。因為要下載 IDEA 外掛開發所需的 SDK 。

02 外掛專案結構概覽

新建完成的專案結構如下圖所示。

外掛專案結構概覽

這裡需要額外注意的是下面這兩個配置檔案。

plugin.xml :外掛的核心配置檔案。通過它可以配置外掛名稱、外掛介紹、外掛作者資訊、Action 等資訊。

<idea-plugin>
    <id>github.javaguide.my-first-idea-plugin</id>
    <!--外掛的名稱-->
    <name>Beauty</name>
    <!--外掛的作者相關資訊-->
    <vendor email="koushuangbwcx@163.com" url="https://github.com/Snailclimb">JavaGuide</vendor>
    <!--外掛的介紹-->
    <description><![CDATA[
     Guide哥程式碼開發的第一款IDEA外掛<br>
    <em>這尼瑪是什麼垃圾外掛!!!</em>
    ]]></description>

    <!-- please see https://www.jetbrains.org/intellij/sdk/docs/basics/getting_started/plugin_compatibility.html
         on how to target different products -->
    <depends>com.intellij.modules.platform</depends>

    <extensions defaultExtensionNs="com.intellij">
        <!-- Add your extensions here -->
    </extensions>

    <actions>
        <!-- Add your actions here -->
    </actions>
</idea-plugin>

build.gradle :專案依賴配置檔案。通過它可以配置專案第三方依賴、外掛版本、外掛版本更新記錄等資訊。

plugins {
    id 'java'
    id 'org.jetbrains.intellij' version '0.6.3'
}

group 'github.javaguide'
// 當前外掛版本
version '1.0-SNAPSHOT'

repositories {
    mavenCentral()
}

// 專案依賴
dependencies {
    testCompile group: 'junit', name: 'junit', version: '4.12'
}

// See https://github.com/JetBrains/gradle-intellij-plugin/
// 當前開發該外掛的 IDEA 版本
intellij {
    version '2020.1.2'
}
patchPluginXml {
    // 版本更新記錄
    changeNotes """
      Add change notes here.<br>
      <em>most HTML tags may be used</em>"""
}

沒有開發過 IDEA 外掛的小夥伴直接看這兩個配置檔案內容可能會有點蒙。所以,我專門找了一個 IDEA 外掛市場提供的現成外掛來說明一下。小夥伴們對照下面這張圖來看下面的配置檔案內容就非常非常清晰了。

外掛資訊

這就非常貼心了!如果這都不能讓你點贊,我要這文章有何用!

03 手動建立 Action

我們可以把 Action 看作是 IDEA 提高的事件響應處理器,通過 Action 我們可以自定義一些事件處理邏輯/動作。比如說你點選某個選單的時候,我們進行一個展示對話方塊的操作。

第一步,右鍵java目錄並選擇 new 一個 Action

第二步,配置 Action 相關資訊比如展示名稱。

在這裡插入圖片描述

建立完成之後,我們的 plugin.xml<actions>節點下會自動生成我們剛剛建立的 Action 資訊:

<actions>
    <!-- Add your actions here -->
    <action id="test.hello" class="HelloAction" text="Hello" description="IDEA外掛入門">
      <add-to-group group-id="ToolsMenu" anchor="first"/>
    </action>
</actions>

並且 java 目錄下為生成一個叫做 HelloAction 的類。並且,這個類繼承了 AnAction ,並覆蓋了 actionPerformed() 方法。這個 actionPerformed 方法就好比 JS 中的 onClick 方法,會在你點選的時候被觸發對應的動作。

我簡單對actionPerformed 方法進行了修改,新增了一行程式碼。這行程式碼很簡單,就是顯示 1 個對話方塊並展示一些資訊。

public class HelloAction extends AnAction {

    @Override
    public void actionPerformed(AnActionEvent e) {
        //顯示對話方塊並展示對應的資訊
        Messages.showInfoMessage("素材不夠,外掛來湊!", "Hello");
    }
}

另外,我們上面也說了,每個動作都會歸屬到一個 Group 中,這個 Group 可以簡單看作 IDEA 中已經存在的選單。

舉個例子。我上面建立的 Action 的所屬 Group 是 ToolsMenu(Tools) 。這樣的話,我們建立的 Action 所在的位置就在 Tools 這個選單下。

再舉個例子。加入我上面建立的 Action 所屬的 Group 是MainMenu (IDEA 最上方的主選單欄)下的 FileMenu(File) 的話。

<actions>
    <!-- Add your actions here -->
    <action id="test.hello" class="HelloAction" text="Hello" description="IDEA外掛入門">
      <add-to-group group-id="FileMenu" anchor="first"/>
    </action>
</actions>

我們建立的 Action 所在的位置就在 File 這個選單下。

04 驗收成果

點選 Gradle -> runIde 就會啟動一個預設了這個外掛的 IDEA。然後,你可以在這個 IDEA 上實際使用這個外掛了。

點選 runIde 就會啟動一個預設了這個外掛的 IDEA

效果如下:

點選 runIde 就會啟動一個預設了這個外掛的 IDEA

我們點選自定義的 Hello Action 的話就會彈出一個對話方塊並展示出我們自定義的資訊。

IDEA外掛HelloWorld

05 完善一下

想要弄點介面花裡胡哨一下, 我們還可以通過 Swing 來寫一個介面。

這裡我們簡單實現一個聊天機器人。程式碼的話,我是直接參考的我大二剛學 Java 那會寫的一個小專案(當時寫的程式碼實在太爛了!就很菜!)。

首先,你需要在圖靈機器人官網申請一個機器人。(其他機器人也一樣,感覺這個圖靈機器人沒有原來好用了,並且免費呼叫次數也不多

然後,簡單寫一個方法來請求呼叫機器人。由於程式碼比較簡單,我這裡就不放出來了,大家簡單看一下效果就好。

程式碼地址:https://github.com/Snailclimb/awesome-idea/tree/master/code/first-idea-plugin

06 深入學習

如果你想要深入學習的 IDEA 外掛的話,可以看一下官網文件:https://jetbrains.org/intellij/sdk/docs/basics/basics.html

這方面的資料還是比較少的。除了官方文件的話,你還可以簡單看看下面這幾篇文章:

07 後記

我們開發 IDEA 外掛主要是為了讓 IDEA 更加好用,比如有些框架使用之後可以減少重複程式碼的編寫、有些主題型別的外掛可以讓你的 IDEA 更好看。

我這篇文章的這個案例說實話只是為了讓大家簡單入門一下 IDEA 開發,沒有任何實際應用意義。如果你想要開發一個不錯的 IDEA 外掛的話,還要充分發揮想象,利用 IDEA 外掛平臺的能力。

早起肝文,還要早點出門!覺得不錯,大家三連一波鼓勵一下這“貨”? (純粹是為了押韻,不容易!年輕人講啥武德!哈哈哈!)

圖解計算機基礎+個人原創的 Java 面試手冊PDF版下載地址: 連結: https://pan.baidu.com/s/1S5VBDPzFSZO3p5uPNYdMzg 密碼: 56bs

相關文章