自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一時(shí)興起,自己動(dòng)手開發(fā)了個(gè)IDEA插件!

開發(fā) 前端
一個(gè)插件的開發(fā)、調(diào)試、安裝就完成了,理論上通過這個(gè)簡(jiǎn)單的例子就可以實(shí)現(xiàn)一些實(shí)際的功能了,因?yàn)槠渫暾故玖藬?shù)據(jù)輸入到數(shù)據(jù)獲取整個(gè)過程。

[[407214]]

前言

最近工作比較閑,自己琢磨點(diǎn)東西,一時(shí)興起想自己做個(gè)IDEA插件玩玩,說不定還能賣錢,哈哈。

版本工具

  • 說明JDK1.8
  • IDEA2020.1
  • 插件項(xiàng)目基于gradle構(gòu)建。
  • 知識(shí)背景:swing

達(dá)到什么目標(biāo)?

本實(shí)例實(shí)現(xiàn)一個(gè)Idea的插件,彈出一個(gè)表單Dialog,然后點(diǎn)擊按鈕,獲取表單里輸入的內(nèi)容,然后將內(nèi)容打印在表單的上方。

成品圖展示:

項(xiàng)目初始化

新建一個(gè)gradle項(xiàng)目,修改其build.gradle文件:

  1. plugins { 
  2.     id 'java' 
  3.     id 'org.jetbrains.intellij' version '0.4.14' //引入intellij的gradle插件 
  4.   
  5. group 'org.example' 
  6. version '1.0' //定義jar包/zip包的版本號(hào) 
  7.   
  8. sourceCompatibility = 1.8 //限制jdk的使用版本號(hào),這里限制到8,表示生成的idea插件只能運(yùn)行在jdk8以上的環(huán)境中 
  9.   
  10. repositories { 
  11.     mavenCentral() //遠(yuǎn)程倉庫 
  12.   
  13. dependencies { 
  14.     //這里引別的依賴包 
  15.     testCompile group'junit'name'junit', version: '4.12' 
  16.   
  17. // See https://github.com/JetBrains/gradle-intellij-plugin/ 
  18. intellij { 
  19.     // 這里是指打插件包的時(shí)候用idea什么版本的依賴包打 
  20.     // 比如這里用2019.3打包,如果你的插件實(shí)現(xiàn)源碼里用了2019.3不存在的依賴包或類,就會(huì)報(bào)錯(cuò) 
  21.     // 一般就填當(dāng)前IDEA的版本號(hào)即可 
  22.     version "2019.3" 
  23.   
  24. patchPluginXml { 
  25.   
  26.     //changeNotes里的內(nèi)容展示位置參考圖14 
  27.     changeNotes ""
  28.       1.0版本. 
  29.  
  30.       第1.0版本:初始化這個(gè)測(cè)試插件項(xiàng)目""
  31.   
  32.     // 這個(gè)意思是說當(dāng)前定義的這個(gè)插件最早支持到什么版本的IDEA 
  33.     // 這里配置sinceBuild=191,表示插件只能被版本號(hào)大于等于2019.1版本的IDEA安裝,低于這個(gè)版本的將拋無法兼容的錯(cuò)誤 
  34.     // ↑上方參考這篇問答:https://intellij-support.jetbrains.com/hc/en-us/community/posts/360003338799-Build-compatible-plugin 
  35.     sinceBuild "191" 

然后Idea的右邊欄gradle將會(huì)多出intellij選項(xiàng):

“這里說下runIde,它用來調(diào)試插件,運(yùn)行它會(huì)再次啟動(dòng)一個(gè)Idea,這個(gè)Idea會(huì)自動(dòng)安裝上你當(dāng)前定義的插件包,讓你用來調(diào)試。

新增plugin.xml

這個(gè)文件非常重要,它可以指定你定義的插件出現(xiàn)在IDEA的哪個(gè)位置,可以指定具體的處理邏輯,還可以定義插件名稱、子名稱等等。

這個(gè)文件位于MATE-INF下:

配置內(nèi)容為:

  1. <idea-plugin> 
  2.     <!--插件的id,注意不要跟其他插件重復(fù),這個(gè)id全局唯一,盡可能復(fù)雜些--> 
  3.     <id>plugin.test</id> 
  4.     <!--插件的名稱--> 
  5.     <name>PluginTest</name
  6.     <vendor email="xxxx@qq.com" url="http://www.bilibili.com">你公司的名字</vendor> 
  7.  
  8.     <!--插件的描述信息,支持html,展示的位置參考圖14--> 
  9.     <description><![CDATA[ 
  10.     Plugin Test<br> 
  11.     第一行:?jiǎn)渭冎皇莻€(gè)測(cè)試<br> 
  12.     第二行:都說了只是個(gè)測(cè)試(● ̄(エ) ̄●)<br> 
  13.     <a href='https://www.bilibili.com'>你猜猜這是哪個(gè)網(wǎng)站?</a> 
  14.     <em>v1.0</em> 
  15.     ]]></description> 
  16.      
  17.     <extensions defaultExtensionNs="com.intellij"
  18.         <!-- Add your extensions here --> 
  19.     </extensions> 
  20.  
  21.     <!--跟build.gradle里的sinceBuild一致即可,意義相同,必須配置--> 
  22.     <idea-version since-build="191"/> 
  23.  
  24.     <actions> 
  25.         <!--下面的group是分組,分組需要有一個(gè)唯一的id標(biāo)識(shí),text用來控制分組出現(xiàn)在IDEA時(shí)呈現(xiàn)的文案,description是描述,不會(huì)展現(xiàn)出來,簡(jiǎn)單描述下分組就行--> 
  26.         <group id="PluginTest" text="插件測(cè)試組" description="插件測(cè)試描述"
  27.             <!--add-to-group控制把該分組加到IDEA里,group-id用來描述加在哪個(gè)位置,MainMenu表示加在IDEA上方的主菜單欄里, 
  28.             anchor表示順序,last表示最后一個(gè),所以下面的配置可以描述為:將該插件加到IDEA上方主菜單欄的最后一位--> 
  29.             <add-to-group group-id="MainMenu" anchor="last"/> 
  30.             <!--這個(gè)用來指定一個(gè)分組下的觸發(fā)動(dòng)作,同樣的需要一個(gè)id,自定義;class就是用來處理這個(gè)動(dòng)作的邏輯類,具體的插件邏輯都會(huì)寫到對(duì)應(yīng)的action類里,text用來控制文案,description為描述--> 
  31.             <action id="Plugin.Test.Action" 
  32.                     class="plugin.test.FromAction" 
  33.                     text="表單測(cè)試" description="表單測(cè)試描述"/> 
  34.         </group
  35.     </actions> 
  36. </idea-plugin> 

然后定義一個(gè)Action類,記為FormAction,繼承AnAction,實(shí)現(xiàn)其抽象方法actionPerformed即可:

  1. public class FromAction extends AnAction { 
  2.     @Override 
  3.     public void actionPerformed(@NotNull AnActionEvent e) { 
  4.         //TODO 這里放插件邏輯 
  5.     } 

啟動(dòng)

現(xiàn)在雙擊runIde即可調(diào)出另外一個(gè)安裝了這個(gè)插件的IDEA界面,然后可以看運(yùn)行結(jié)果進(jìn)行調(diào)試。runIde還支持debug模式,不過運(yùn)行時(shí)要右擊選擇:

來看下調(diào)試IDEA的界面運(yùn)行效果:

定義Action

1. 定義會(huì)話框類

經(jīng)過上面三步的配置,插件的基本樣式已經(jīng)展示出來,但是點(diǎn)擊下方“表單測(cè)試”的action,并沒有什么用,因?yàn)槠浣壎ǖ腇ormAction類里沒有任何有意義的實(shí)現(xiàn)?,F(xiàn)在來實(shí)現(xiàn)開始的目標(biāo),點(diǎn)擊“表單測(cè)試”后,彈出一個(gè)自定義的表單會(huì)話框,然后點(diǎn)擊按鈕,獲取表單內(nèi)容后打印在會(huì)話框內(nèi)。

會(huì)話框(Dialog)需要定義一個(gè)繼承了IDEA的DialogWrapper抽象類的子類,這個(gè)子類就是自定義的會(huì)話框?qū)崿F(xiàn),所有的樣式定義、功能觸發(fā)都是放到這個(gè)子類里的,現(xiàn)定于如下子類:

  1. public class FormTestDialog extends DialogWrapper { 
  2.   
  3.     private String projectName; //假如需要獲取到項(xiàng)目名,作為該類的屬性放進(jìn)來 
  4.   
  5.     // DialogWrapper沒有默認(rèn)的無參構(gòu)造方法,所以需要重寫構(gòu)造方法,它提供了很多重載構(gòu)造方法, 
  6.     // 這里使用傳project類型參數(shù)的那個(gè),通過Project對(duì)象可以獲取當(dāng)前IDEA內(nèi)打開的項(xiàng)目的一些屬性, 
  7.     // 比如項(xiàng)目名,項(xiàng)目路徑等 
  8.     public FormTestDialog(@Nullable Project project) { 
  9.         super(project); 
  10.         setTitle("表單測(cè)試~~"); // 設(shè)置會(huì)話框標(biāo)題 
  11.         this.projectName = project.getName(); 
  12.     } 
  13.   
  14.     // 重寫下面的方法,返回一個(gè)自定義的swing樣式,該樣式會(huì)展示在會(huì)話框的最上方的位置 
  15.     @Override 
  16.     protected JComponent createNorthPanel() { 
  17.         return null
  18.     } 
  19.   
  20.     // 重寫下面的方法,返回一個(gè)自定義的swing樣式,該樣式會(huì)展示在會(huì)話框的最下方的位置 
  21.     @Override 
  22.     protected JComponent createSouthPanel() { 
  23.         return null
  24.     } 
  25.   
  26.     // 重寫下面的方法,返回一個(gè)自定義的swing樣式,該樣式會(huì)展示在會(huì)話框的中央位置 
  27.     @Override 
  28.     protected JComponent createCenterPanel() { 
  29.         return null
  30.     } 

2. 會(huì)話框模塊&類元素對(duì)照

找個(gè)實(shí)際的會(huì)話框?yàn)槔?,針?duì)上述中幾個(gè)方法所控制的會(huì)話框里的元素如下:

3. 會(huì)話框方法重定義

按照本文的實(shí)現(xiàn)目標(biāo),自定義的表單主體部分可以位于createCenterPanel里,然后表單的大標(biāo)題可以放到createNorthPanel里,提交按鈕可以放到createSouthPanel里,現(xiàn)在改寫如下:

  1. public class FormTestDialog extends DialogWrapper { 
  2.   
  3.     private String projectName; 
  4.       
  5.     //swing樣式類,定義在4.3.2 
  6.     private FormTestSwing formTestSwing = new FormTestSwing(); 
  7.   
  8.     public FormTestDialog(@Nullable Project project) { 
  9.         super(true); 
  10.         setTitle("表單測(cè)試~~"); //設(shè)置會(huì)話框標(biāo)題 
  11.         this.projectName = project.getName(); //獲取到當(dāng)前項(xiàng)目的名稱 
  12.         init(); //觸發(fā)一下init方法,否則swing樣式將無法展示在會(huì)話框 
  13.     } 
  14.   
  15.     @Override 
  16.     protected JComponent createNorthPanel() { 
  17.         return formTestSwing.initNorth(); //返回位于會(huì)話框north位置的swing樣式 
  18.     } 
  19.   
  20.     // 特別說明:不需要展示SouthPanel要重寫返回null,否則IDEA將展示默認(rèn)的"Cancel""OK"按鈕 
  21.     @Override 
  22.     protected JComponent createSouthPanel() { 
  23.         return formTestSwing.initSouth(); 
  24.     } 
  25.   
  26.     @Override 
  27.     protected JComponent createCenterPanel() { 
  28.         //定義表單的主題,放置到IDEA會(huì)話框的中央位置 
  29.         return formTestSwing.initCenter(); 
  30.     } 

4. 自定義swing樣式

下面是放置swing樣式的類:

  1. public class FormTestSwing { 
  2.   
  3.     private JPanel north = new JPanel(); 
  4.   
  5.     private JPanel center = new JPanel(); 
  6.   
  7.     private JPanel south = new JPanel(); 
  8.   
  9.     //為了讓位于底部的按鈕可以拿到組件內(nèi)容,這里把表單組件做成類屬性 
  10.     private JLabel r1 = new JLabel("輸出:"); 
  11.     private JLabel r2 = new JLabel("NULL"); 
  12.   
  13.     private JLabel name = new JLabel("姓名:"); 
  14.     private JTextField nameContent = new JTextField(); 
  15.   
  16.     private JLabel age = new JLabel("年齡:"); 
  17.     private JTextField ageContent = new JTextField(); 
  18.   
  19.     public JPanel initNorth() { 
  20.   
  21.         //定義表單的標(biāo)題部分,放置到IDEA會(huì)話框的頂部位置 
  22.   
  23.         JLabel title = new JLabel("表單標(biāo)題"); 
  24.         title.setFont(new Font("微軟雅黑", Font.PLAIN, 26)); //字體樣式 
  25.         title.setHorizontalAlignment(SwingConstants.CENTER); //水平居中 
  26.         title.setVerticalAlignment(SwingConstants.CENTER); //垂直居中 
  27.         north.add(title); 
  28.   
  29.         return north; 
  30.     } 
  31.   
  32.     public JPanel initCenter() { 
  33.   
  34.         //定義表單的主體部分,放置到IDEA會(huì)話框的中央位置 
  35.   
  36.         //一個(gè)簡(jiǎn)單的3行2列的表格布局 
  37.         center.setLayout(new GridLayout(3, 2)); 
  38.   
  39.         //row1:按鈕事件觸發(fā)后將結(jié)果打印在這里 
  40.         r1.setForeground(new Color(255, 47, 93)); //設(shè)置字體顏色 
  41.         center.add(r1); 
  42.         r2.setForeground(new Color(139, 181, 20)); //設(shè)置字體顏色 
  43.         center.add(r2); 
  44.   
  45.         //row2:姓名+文本框 
  46.         center.add(name); 
  47.         center.add(nameContent); 
  48.   
  49.         //row3:年齡+文本框 
  50.         center.add(age); 
  51.         center.add(ageContent); 
  52.   
  53.         return center; 
  54.     } 
  55.   
  56.     public JPanel initSouth() { 
  57.   
  58.         //定義表單的提交按鈕,放置到IDEA會(huì)話框的底部位置 
  59.   
  60.         JButton submit = new JButton("提交"); 
  61.         submit.setHorizontalAlignment(SwingConstants.CENTER); //水平居中 
  62.         submit.setVerticalAlignment(SwingConstants.CENTER); //垂直居中 
  63.         south.add(submit); 
  64.   
  65.         return south; 
  66.     } 

現(xiàn)在點(diǎn)擊下runIde按鈕,同樣的,在調(diào)試IDE里點(diǎn)擊“表單測(cè)試”,然后就會(huì)彈出如下表單框:

“除非有特殊情況需要自定義swing樣式,否則建議不加任何swing樣式,這樣自定義的swing界面是會(huì)隨著IDEA的主題改變而去自適應(yīng)的,比如將圖7中的調(diào)試IDE的主題設(shè)置成Darcula,自定義的表單也會(huì)自適應(yīng)的變成黑色背景:

5. 事件綁定

定義好了樣式,現(xiàn)在給“提交”按鈕綁定一個(gè)事件,現(xiàn)在改寫下FormTestSwing.initSouth方法:

  1. public JPanel initSouth() { 
  2.   
  3.     //定義表單的提交按鈕,放置到IDEA會(huì)話框的底部位置 
  4.   
  5.     JButton submit = new JButton("提交"); 
  6.     submit.setHorizontalAlignment(SwingConstants.CENTER); //水平居中 
  7.     submit.setVerticalAlignment(SwingConstants.CENTER); //垂直居中 
  8.     south.add(submit); 
  9.   
  10.     //按鈕事件綁定 
  11.     submit.addActionListener(e -> { 
  12.         //獲取到name和age 
  13.         String name = nameContent.getText(); 
  14.         String age = ageContent.getText(); 
  15.         //刷新r2標(biāo)簽里的內(nèi)容,替換為name和age 
  16.         r2.setText(String.format("name:%s, age:%s"name, age)); 
  17.     }); 
  18.   
  19.     return south; 

現(xiàn)在再來點(diǎn)擊下“提交”按鈕,就可以輸出表單內(nèi)容了:

6. 插件綁定類:FormAction

之前講過,這個(gè)類是插件的入口,結(jié)合上面定義好的表單Dialog,來看下它是怎么寫的:

  1. public class FromAction extends AnAction { 
  2.     @Override 
  3.     public void actionPerformed(@NotNull AnActionEvent e) { 
  4.         FormTestDialog formTestDialog = new FormTestDialog(e.getProject()); 
  5.         formTestDialog.setResizable(true); //是否允許用戶通過拖拽的方式擴(kuò)大或縮小你的表單框,我這里定義為true,表示允許 
  6.         formTestDialog.show(); 
  7.     } 

7. 插件的打包&安裝

截止到第四步,都只是在調(diào)試IDE里查看效果,如果一個(gè)插件開發(fā)完成后,需要被實(shí)際的IDEA安裝,這個(gè)時(shí)候就需要借助打包選項(xiàng)來打包你的插件,點(diǎn)擊下面的選項(xiàng)構(gòu)建插件:

構(gòu)建完成后,查看build包下的distributions目錄,里面的zip包就可以直接安裝進(jìn)你的IDEA:

然后選擇IDEA的Preferences下的plugins選項(xiàng),彈出如下框,按照?qǐng)D里的指示選擇zip包安裝即可:

然后安裝完成,重啟IDEA即可:

各個(gè)展示模塊對(duì)應(yīng)插件項(xiàng)目里配置的來源參考下圖:

重啟后出現(xiàn)了跟調(diào)試IDEA里一樣的菜單欄,選中后運(yùn)行成功:

總結(jié)

截止到這里,一個(gè)插件的開發(fā)、調(diào)試、安裝就完成了,理論上通過這個(gè)簡(jiǎn)單的例子就可以實(shí)現(xiàn)一些實(shí)際的功能了,因?yàn)槠渫暾故玖藬?shù)據(jù)輸入到數(shù)據(jù)獲取整個(gè)過程。

因?yàn)楣ぷ鳟?dāng)中需要寫一個(gè)代碼生成器,想要以一個(gè)IDEA插件的方式提供服務(wù),所以在這里做個(gè)記錄,防止以后再次用到時(shí)從零開始。

要有一定的swing基礎(chǔ),我在開發(fā)代碼生成器的時(shí)候,就是因?yàn)閟wing基礎(chǔ)太差,布局花了非常多的時(shí)間。

 

責(zé)任編輯:姜華 來源: 無聊學(xué)Java
相關(guān)推薦

2011-08-25 09:30:22

2021-04-26 07:31:22

SpringMVCweb框架

2015-09-01 09:49:28

2024-12-06 09:58:09

2017-03-02 13:31:02

監(jiān)控系統(tǒng)

2023-07-10 09:53:59

console開發(fā)插件

2010-07-23 10:23:05

Google機(jī)房

2017-02-14 10:20:43

Java Class解析器

2020-10-10 06:32:43

IDEA插件環(huán)境

2023-02-13 00:18:22

前端庫框架集合

2016-07-25 18:09:29

2015-06-02 10:24:43

iOS網(wǎng)絡(luò)請(qǐng)求降低耦合

2015-06-02 09:51:40

iOS網(wǎng)絡(luò)請(qǐng)求封裝接口

2025-03-11 01:28:16

2011-10-31 10:17:05

插件

2016-09-21 12:34:10

Chrome瀏覽器插件

2020-10-12 10:58:15

IDEA插件監(jiān)聽

2022-11-10 09:28:40

框架開發(fā)

2024-03-08 12:45:00

C#Web服務(wù)器

2022-04-18 19:02:53

chrome擴(kuò)展瀏覽器
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)