手把手教你5分鐘從零開發一款簡易的IDEA插件!項目經驗/畢設不愁了!
- 2020 年 11 月 19 日
- 筆記
我這個人沒事就喜歡推薦一些好用的 IDEA 插件給大家。這些插件極大程度上提高了我們的生產效率以及編碼舒適度。
不知道大家有沒有想過自己開發一款 IDEA 插件呢?
我自己想過,但是沒去嘗試過。剛好有一位讀者想讓我寫一篇入門 IDEA 開發的文章,所以,我在周末就花了一會時間簡單了解一下。
不過,這篇文章只是簡單帶各位小夥伴入門一下 IDEA 插件開發,個人精力有限,暫時不會深入探討太多。如果你已經有 IDEA 插件開發的相關經驗的話,這篇文章就可以不用看了,因為會浪費你 3 分鐘的時間。
好的廢話不多說!咱們直接開始!
01 新建一個基於 Gradle 的插件項目
這裡我們基於 Gradle 進行插件開發,這也是 IntelliJ 官方的推薦的插件開發解決方案。
第一步,選擇 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="[email protected]" url="//github.com/Snailclimb">JavaGuide</vendor>
<!--插件的介紹-->
<description><![CDATA[
Guide哥程式碼開發的第一款IDEA插件<br>
<em>這尼瑪是什麼垃圾插件!!!</em>
]]></description>
<!-- please see //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 //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 上實際使用這個插件了。
效果如下:
我們點擊自定義的 Hello Action 的話就會彈出一個對話框並展示出我們自定義的資訊。
05 完善一下
想要弄點介面花里胡哨一下, 我們還可以通過 Swing 來寫一個介面。
這裡我們簡單實現一個聊天機器人。程式碼的話,我是直接參考的我大二剛學 Java 那會寫的一個小項目(當時寫的程式碼實在太爛了!就很菜!)。
首先,你需要在圖靈機器人官網申請一個機器人。(其他機器人也一樣,感覺這個圖靈機器人沒有原來好用了,並且免費調用次數也不多)
然後,簡單寫一個方法來請求調用機器人。由於程式碼比較簡單,我這裡就不放出來了,大家簡單看一下效果就好。
程式碼地址://github.com/Snailclimb/awesome-idea/tree/master/code/first-idea-plugin 。
06 深入學習
如果你想要深入學習的 IDEA 插件的話,可以看一下官網文檔://jetbrains.org/intellij/sdk/docs/basics/basics.html 。
這方面的資料還是比較少的。除了官方文檔的話,你還可以簡單看看下面這幾篇文章:
07 後記
我們開發 IDEA 插件主要是為了讓 IDEA 更加好用,比如有些框架使用之後可以減少重複程式碼的編寫、有些主題類型的插件可以讓你的 IDEA 更好看。
我這篇文章的這個案例說實話只是為了讓大家簡單入門一下 IDEA 開發,沒有任何實際應用意義。如果你想要開發一個不錯的 IDEA 插件的話,還要充分發揮想像,利用 IDEA 插件平台的能力。
早起肝文,還要早點出門!覺得不錯,大家三連一波鼓勵一下這「貨」? (純粹是為了押韻,不容易!年輕人講啥武德!哈哈哈!)
圖解電腦基礎+個人原創的 Java 面試手冊PDF版下載地址: 鏈接: //pan.baidu.com/s/1S5VBDPzFSZO3p5uPNYdMzg 密碼: 56bs