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

Eclipse插件終極攻略:安裝實例

開發(fā) 后端
本文為Eclipse插件開發(fā)基礎(chǔ)教程:終極攻略的第二部分,將詳細介紹Eclipse插件的安裝實例。

本文為日文文獻《Eclipse 3.4 対応 Eclipse 3.4 プラグイン開発 徹底攻略》第二部分的譯文,在前文中給各位午飯奉獻了《Eclipse插件***攻略:基本概念介紹》,在這個部分里我們將講一下“Eclipse插件開發(fā)安裝實例”。

51CTO推薦專題:Eclipse平臺應(yīng)用與開發(fā)詳解

1.生成插件工程

通過選擇[文件]->[新建]->[工程...]啟動[新工程(New Project)]向?qū)?。在插件開發(fā)的時候我們就不能選擇通常的java工程了,要選擇新建一個插件工程。

選擇[插件工程(Plug-in Project)]后點擊[下一步(Next)](圖2-1)。下一步,輸入一個適當(dāng)?shù)捻椖棵?圖2-2)。習(xí)慣上項目名和插件的ID是相同的。插件ID和java包的命名方式相同,必須一個世界范圍***的名稱。在這里用cn.sf.amateras.sample作為項目名稱(=插件ID)。點擊[下一步(Next)]。

生成插件工程 
圖2-1 生成插件工程

輸入插件信息 
圖2-2 輸入插件信息

輸入[插件ID]、[插件版本]、[插件屬性(插件作者)](圖2-3)等信息。[插件ID]會被自動設(shè)成之前輸入的[工程名]。沒有其他特別的設(shè)定的話繼續(xù)點擊[下一步(Next)]。

輸入生成工程必要的信息 
圖2-3 輸入生成工程必要的信息

模板選擇 
圖2-4 模板選擇

輸入模板信息 
圖2-5 輸入模板信息

根據(jù)選擇的模板生成的插件在(圖2-5)的畫面可以修改一些信息。如果沒有特別需要設(shè)定的地方點擊[完成(Finish)],生成工程。

PDE透視圖

插件工程生成后,就會切換到PDE(插件開發(fā))透視圖。工程此時根據(jù)選擇的[Hello,World]模板生成了插件的源代碼,并且打開了manifest編輯器。

 
圖2-6 PDE(插件開發(fā))透視圖

#p#

2. 插件的動作

接下來我們看一下插件的動作。manifest編輯器的[概要]頁面右側(cè)[啟動Eclipse應(yīng)用(Luanch an Eclipse application)](圖2-7)。點擊后,會啟用一個新的Eclipse實例。這個新的實例被稱為[運行時工作臺]。運行工作臺可以以嵌入當(dāng)前正在開發(fā)的插件的狀態(tài)啟動,以使開發(fā)者可以對插件的動作進行確認。

啟動運行時工作臺 
圖2-7 啟動運行時工作臺

啟動的運行時工作臺,會在菜單欄上增加一個新的菜單項。這個菜單項就是插件的代碼追加上去的。在工具欄上也增加了一個相應(yīng)的按鈕。

工具欄上的按鈕和菜單項目效果相同,都會出現(xiàn)一個[Hello,Eclipse World]的對話框。

Eclipse版的Hello World就完成了。確認完這些動作后,就可以關(guān)閉當(dāng)前的運行時工作臺了。

示例中新增的菜單項和工具欄按鈕以及相應(yīng)的動作 
圖2-8 示例中新增的菜單項和工具欄按鈕以及相應(yīng)的動作

MANIFEST.MF和plugin.xml

一個插件包含MANIFEST.MF和plugin.xml兩個配置文件。MANIFEST.MF是OSGi的handler配置文件,記錄了插件ID、名稱、作者、和其他插件的依賴關(guān)系等。plugin.xml記錄了插件的擴展和擴展點的定義等信息。

Eclipse3.1以前由于還沒有采用OSGi技術(shù),插件的所有信息都記錄在plugin.xml里。所以應(yīng)用在Eclipse3.1以前版本的插件如果要應(yīng)用于Eclipse3.1和以后版本時要注意遵守OSGi的配置文件定義規(guī)范。

#p#

3. PDE的功能

PDE(插件開發(fā)環(huán)境·Plugin Development Enviromment)提供了插件開發(fā)的各種功能。因為插件的開發(fā)使用java語言,所以也會使用到j(luò)ava編碼工具JDT。

Manifest編輯器

PDE提供的功能中最重要的就是Manifest編輯器。編輯器可以為插件的兩個配置文件提供圖形化的編輯功能。

編輯器的配置項目非常多,可以通過編輯器下面的tab頁切換設(shè)定畫面。

Manifest編輯器 
圖2-9 Manifest編輯器

表1 Manifest編輯器各tab頁

頁面 說明
Overview 可以設(shè)定插件的概要信息。生成用于發(fā)布的文檔以及啟動運行時工作臺。
Dependencies 設(shè)定插件間的依賴關(guān)系。
Runtime 可以設(shè)置導(dǎo)出包和ClassPath。
Extensions 管理當(dāng)前插件對擴展點的擴展。
Extension Points 管理當(dāng)前插件的擴展點。
Build 生成工程時的各種設(shè)定。
MANIFEST.MF 顯示MANIFEST.MF的源代碼
plugin.xml 顯示plugin.xml的源代碼
build.properties 顯示build.properties的源代碼

在Overview以外的tab頁上部會顯示一些快捷鍵按鈕,使用這些按鈕也可以進行啟動運行時工作臺,導(dǎo)出等操作。

 
圖2-10 編輯器上部

下面介紹一下PDE題供的幾種視圖。在[Window]->[Show View]中可以找到?jīng)]有被顯示的視圖。

[插件(Plug-ins)]視圖

所有的插件列表,包含當(dāng)前工作區(qū)內(nèi)正在開發(fā)的插件。打開插件節(jié)點可以顯示插件下包含的資源,但是以jar包提供出來的插件就顯示不出來了。

在插件節(jié)點上點擊右鍵選擇[打開依賴關(guān)系(Open Dependencies)]可以打開后面要介紹的[依賴關(guān)系]視圖,表現(xiàn)插件間的依賴關(guān)系。右鍵菜單中也可以把選中的插件作為一個工程引入到當(dāng)前工作區(qū)內(nèi)。

[依賴關(guān)系(Plug-in Dependencies)]視圖

表現(xiàn)了插件間的依賴關(guān)系。可以分別表示當(dāng)前插件依賴的插件和依賴當(dāng)前插件的插件。

[插件注冊(Plug-in Registry)]視圖

當(dāng)前工作臺加載的所有插件列表。打開插件節(jié)點,顯示插件提供的擴展和擴展點、依賴關(guān)系等。

[錯誤Log(Error Log)]視圖

錯誤Log視圖雖然不是PDE提供的功能,但是在插件開發(fā)的時候非常有用。它可以表現(xiàn)當(dāng)前工作臺內(nèi)發(fā)生的錯誤,并且在錯誤上雙擊既可以導(dǎo)向到錯誤發(fā)生的地方。

Plugin-in Selection Spy

同時按下alt+shift+F1

Plugin-in Selection Spy是從Eclipse3.4開始加入的新功能,能夠顯示當(dāng)前焦點所在的編輯器、視圖、向?qū)?、對話框等的?nèi)部信息。把已有的插件作為參考,進行插件開發(fā),使用這個功能是再合適不過了。

#p#

4. 解讀示例插件的代碼

讓我們回到插件工程來,看一看插件工程生成的代碼。首先看一下plugin.xml的代碼。

代碼2-1 plugin.xml

  1. <?xml version="1.0" encoding="UTF-8"?> 
  2. <?eclipse version="3.4"?> 
  3. <plugin> 
  4.    <extension 
  5.          point="org.eclipse.ui.actionSets"> ①  
  6.       <actionSet 
  7.             label="Sample Action Set" 
  8.             visible="true" 
  9.             id="cn.sf.amateras.sample.actionSet"> 
  10.          <menu 
  11.                label="Sample &Menu" 
  12.                id="sampleMenu"> 
  13.             <separator 
  14.                   name="sampleGroup"> 
  15.             </separator> 
  16.          </menu> 
  17.          <action 
  18.                label="&Sample Action" 
  19.                icon="icons/sample.gif" 
  20.                class="cn.sf.amateras.sample.actions.SampleAction"   
  21.                tooltip="Hello, Eclipse world" 
  22.                menubarPath="sampleMenu/sampleGroup" 
  23.                toolbarPath="sampleGroup" 
  24.                id="cn.sf.amateras.sample.actions.SampleAction"> 
  25.          </action> 
  26.       </actionSet> 
  27.    </extension> 
  28. </plugin> 

為了在菜單欄增加一個項目,文件中使用了extension元素。①的id指定了擴展點的名稱org.eclipse.ui.actionSets。extension里的內(nèi)容根據(jù)擴展點而不同。示例插件中包含了actionSet、menu、action等元素。

②中的class屬性指定了cn.sf.amateras.sample.actions.SampleAction類作為響應(yīng)菜單或者工具欄按鈕的action類。

代碼2-2 SampleAction.java

  1. package cn.sf.amateras.sample.actions;  
  2.    
  3. import org.eclipse.jface.action.IAction;  
  4. import org.eclipse.jface.viewers.ISelection;  
  5. import org.eclipse.ui.IWorkbenchWindow;  
  6. import org.eclipse.ui.IWorkbenchWindowActionDelegate;  
  7. import org.eclipse.jface.dialogs.MessageDialog;  
  8.    
  9. /**  
  10.  * Our sample action implements workbench action delegate.  
  11.  * The action proxy will be created by the workbench and  
  12.  * shown in the UI. When the user tries to use the action,  
  13.  * this delegate will be created and execution will be  
  14.  * delegated to it.  
  15.  * @see IWorkbenchWindowActionDelegate  
  16.  */  
  17. public class SampleAction implements IWorkbenchWindowActionDelegate {  
  18.     private IWorkbenchWindow window;  
  19.     /**  
  20.      * The constructor.  
  21.      */  
  22.     public SampleAction() {  
  23.     }  
  24.    
  25.     /**  
  26.      * The action has been activated. The argument of the  
  27.      * method represents the 'real' action sitting  
  28.      * in the workbench UI.  
  29.      * @see IWorkbenchWindowActionDelegate#run  
  30.      */  
  31.     public void run(IAction action) {   //......①  
  32.         MessageDialog.openInformation(  
  33.             window.getShell(),  
  34.             "Sample",  
  35.             "Hello, Eclipse world");  
  36.     }  
  37.    
  38.     /**  
  39.      * Selection in the workbench has been changed. We  
  40.      * can change the state of the 'real' action here  
  41.      * if we want, but this can only happen after  
  42.      * the delegate has been created.  
  43.      * @see IWorkbenchWindowActionDelegate#selectionChanged  
  44.      */  
  45.     public void selectionChanged(IAction action, ISelection selection) {  
  46.     }  
  47.    
  48.     /**  
  49.      * We can use this method to dispose of any system  
  50.      * resources we previously allocated.  
  51.      * @see IWorkbenchWindowActionDelegate#dispose  
  52.      */  
  53.     public void dispose() {  
  54.     }  
  55.    
  56.     /**  
  57.      * We will cache window object in order to  
  58.      * be able to provide parent shell for the message dialog.  
  59.      * @see IWorkbenchWindowActionDelegate#init  
  60.      */  
  61.     public void init(IWorkbenchWindow window) {  
  62.         this.window = window;  
  63.     }  
  64. }  
  65.  

①run()方法內(nèi)記錄了action執(zhí)行時的處理。利用MessageDialog.openInformation方法打開了一個對話框。

咱們再看看生成的另外一個類--Activator類。這個類對插件的生命周期進行了管理,被稱為插件類。

代碼2-3 Activator.java

  1. package cn.sf.amateras.sample;  
  2.    
  3. import org.eclipse.jface.resource.ImageDescriptor;  
  4. import org.eclipse.ui.plugin.AbstractUIPlugin;  //....①  
  5. import org.osgi.framework.BundleContext;  
  6.    
  7. /**  
  8.  * The activator class controls the plug-in life cycle  
  9.  */  
  10. public class Activator extends AbstractUIPlugin {  
  11.    
  12.     // The plug-in ID  
  13.     public static final String PLUGIN_ID = "cn.sf.amateras.sample"; //$NON-NLS-1$  
  14.    
  15.     // The shared instance  
  16.     private static Activator plugin;  
  17.        
  18.     /**  
  19.      * The constructor  
  20.      */  
  21.     public Activator() {  
  22.     }  
  23.    
  24.     /*  
  25.      * (non-Javadoc)  
  26.      * @see org.eclipse.ui.plugin.AbstractUIPlugin#start(org.osgi.framework.BundleContext)  
  27.      */  
  28.     public void start(BundleContext context) throws Exception {//....③  
  29.         super.start(context);  
  30.         plugin = this;  
  31.     }  
  32.    
  33.     /*  
  34.      * (non-Javadoc)  
  35.      * @see org.eclipse.ui.plugin.AbstractUIPlugin#stop(org.osgi.framework.BundleContext)  
  36.      */  
  37.     public void stop(BundleContext context) throws Exception {//....④  
  38.         plugin = null;  
  39.         super.stop(context);  
  40.     }  
  41.    
  42.     /**  
  43.      * Returns the shared instance  
  44.      *  
  45.      * @return the shared instance  
  46.      */  
  47.     public static Activator getDefault() {//....②  
  48.         return plugin;  
  49.     }  
  50.    
  51.     /**  
  52.      * Returns an image descriptor for the image file at the given  
  53.      * plug-in relative path  
  54.      *  
  55.      * @param path the path  
  56.      * @return the image descriptor  
  57.      */  
  58.     public static ImageDescriptor getImageDescriptor(String path) {  
  59.         return imageDescriptorFromPlugin(PLUGIN_ID, path);  
  60.     }  
  61. }  
  62.  

示例中的插件類繼承自AbstractUIPlugin(①)。如果沒有UI的插件繼承AbstractUIPlugin的父類Plugin就可以了。

插件類的方法如下表所示:

getDefault() 取得插件類的實例的方法。插件類是單例的,所以這個方法作為一個靜態(tài)方法提供。
start() 插件開始時的處理。
stop() 插件停止時的處理。
getLog() log輸出時取得ILog用的方法。
getImageRegistry() 取得管理插件內(nèi)圖像的ImageRegistry類。
getPerferenceStore() 取得保存插件設(shè)定的IPerferenceStore類。
getDialogSettings() 取得保存對話框設(shè)定的IDialogSettings類。
getWorkbench() 取得IWorkbench的實例。

以上就是根據(jù)[Hello World]模板生成的插件的代碼講解,在PDE中為我們準備了很多的模板,大家可以都試試看。

感謝大家關(guān)注51CTO《Eclipse插件開發(fā)基礎(chǔ)教程:***攻略》。如果您對Eclipse有什么新的使用心得可以發(fā)Email:zhousn@51cto.com,51CTO將與您一起分享!

【編輯推薦】

  1. Eclipse插件***攻略:測試插件
  2. Eclipse插件***攻略:基本概念介紹
  3. Eclipse插件大全 挑選最牛的TOP30
  4. Eclipse插件的安裝方法三則
  5. Eclipse插件開發(fā)中實現(xiàn)刷新和重編譯
責(zé)任編輯:佚名 來源: 博客園
相關(guān)推薦

2010-08-17 13:41:46

Eclipse插件

2010-08-16 16:23:00

Eclipse插件

2011-03-10 10:32:45

2009-06-10 16:41:51

Links安裝Ecli

2009-09-17 09:44:31

Flex for ec

2009-06-04 20:45:11

Eclipse插件安裝Eclipse插件使用

2009-06-05 14:36:28

Eclipse插件安裝Eclipse教程

2023-06-12 17:54:50

2009-09-29 10:01:59

Eclipse插件安裝

2010-08-02 17:04:43

Flex for ec

2011-12-28 10:26:56

Javaeclipse

2010-05-31 09:59:15

Eclipse安裝SV

2009-09-20 16:41:16

CCIE

2010-06-09 11:05:52

Eclipse UML

2010-05-17 09:19:03

Subversion

2009-06-01 16:27:59

eclipse cdteclipse cdtc++

2010-06-12 14:19:00

Eclipse UML

2009-06-04 20:26:45

2009-08-07 10:00:00

在Eclipse中安裝

2013-07-03 17:41:10

eclipse
點贊
收藏

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