【轉】Eclipse Action 深入學習筆記

          Posted on 2009-05-07 18:53 eric_xu 閱讀(603) 評論(0)  編輯  收藏 所屬分類: Eclipse Plugin

          以前做插件用到的ActionSet都只是依葫蘆畫瓢,沒有真正理解它,現在開始好好學習學習,主要是看"Building Commercial-Quality Plug-ins"寫的

          Action
          的組成包括幾個部分,一個是在plugin.xml中的聲明,一個是在Eclipse UI中會用到的IAction實例化對象, 另一個是封裝在IActionDelegate中的action執行代碼. action的實例化是基于plugin.xml配置文件和IActionDelegate定義的,Eclipse可以先在界面上將action顯示出 來,直到用戶點擊了菜單或者工具條按鈕才會去真正的加載插件,這也就是所謂的Eclipse的延遲加載機制

          IActionDelegate
          有幾個子類需要說明一下:
          IActionDelegate2
          如果實現IActionDelegate需要一些其他的信息,而這些信息在IActionDelegate銷毀時需要同時被銷毀時, 它可以提供相關是生命周期事件方法來處理
          IEditorActionDelegate
          是跟editor相關的
          IObjectActionDelegate
          是跟上下文菜單相關的
          IViewActionDelegate
          是跟view相關的
          IWorkbenchWindowActionDelegate
          是跟menubartoolbar相關的

          Actions
          Eclipse中的其他東東一樣,也是通過擴展點org.eclipse.ui.actionSets來添加到Eclipse IDE的各個地方,actions的外在表現形式主要有menubar, toolbar, context menu這樣幾種

          actionSets的下級節點是actionSet, 它有幾個屬性,id,label都不用說了,還有一個visible屬性,表示在打開Eclipse時是否顯示該action,通常我們可以通過 Window > Customize Perspective...來設置action是否可見

          actionSet下可以添加menu節點, 它的id,label屬性不用說了,其中的path是用來指定菜單的顯示位置的,一般設置為additions

          action
          并不是直接添加到menu上的, 而是跟menu內部的group關聯的,所以我們必須先在menu下創建group,即新建groupMarker, name必須保證在當前menu下唯一, menu還有一種叫separatorgroup, separator group處添加的menu item會在這個組中的第一個菜單項上面添加一條水平線.groupMarker則不會有線, 當其他action要添加到該menu group下時,使用水平線進行分組就顯得非常必要

          group
          只是用來標識menu的位置,即指這個位置可以添加菜單項, 而不是實際的menu item, 實際的menu itemaction

          因為menu會有層次關系,所以actionSet中專門用一個menu節點來表現這種層次關系, toolbar則沒有這種情況,所以這里沒有提供toolbar節點

          actionSet下添加action就是最終我們要toolbar上顯示的按鈕和menubar上的menu item, 這里有幾個屬性, idlabel不用說了,menuBarPathmenu要顯示的位置, 比如"com.qualityeclipse.favorites.workbenchMenu/content",這個值就是actionSet+" /"+group name, toolbarPath 就是toolbar item的顯示位置, 比如"Normal/additions", 還有幾個屬性不常用到,但是有必要解釋一下

          allowLabelUpdate
          這個要在retarget屬性為true的時候有效,還不是很清楚

          class
          menubutton要執行的動作, 如果使用的是pulldown風格的action,還需要實現IWorkbenchWindowPulldownDelegate接口,它的構造函數是無 參數的,如果要傳遞參數,還需要是要實現IExecutableExtension 接口, 這個接口還不是很清楚

          definitionId
          這個是用來指定action對應的command唯一標識符的

          enablesFor
          是一個表達式,用來表示當前action是否可用

          retarget
          不是很理解

          state
          主要是針對style屬性為radiotoggle,表示當前action是否被選中

          style:
          默認是push,還有radio,表示一組menu中只能有一個被選中, toggle當它是checkbox好了, pulldown說明是子菜單項或者是下拉toolbar menu

          對于action所使用的圖標,我們可以從Eclipse下的plugins\org.eclipse.ui_3.1.2.jar plugins\org.eclipse.jdt.ui_3.1.2.jar得到一些gif的圖片

          Eclipse
          actionSet以及下級元素都是有id,而且他們可以通過一種path的方式來進行指定,比如 com.qualityeclipse.favorites.workbenchMenu/content,如果上一級節點是workbench menu bar或者是view content menu的話,那么它的上一級節點是不用指定的,只要指定group就好

          為了方便其他的插件的action能添加到該插件的actionSet, 在為插件定義group的時候, 會添加一個為additionsgroup, additionseclipse使用的一個默認標識符,用來表示其他actionmenu顯示的位置, class中它的對應常量是IWorkbenchActionConstants.MB_ADDITIONS, 比如我們定義了一個menu,指定其pathadditions, 這表示我們的menu將添加到window的左邊,因為這個就是workbench menubaradditons所在的位置, 如果指定的是window/additions, 那么將作為子菜單項添加到window

          當一個actionSet下定義的action跟另一個actionSet下定義的menu關聯的時候將發生Invalid Menu Extension (Path is invalid): some.action.id的異常, 為了避免這種問題,menu需要在兩個actionSet都定義

          toolbarPath
          的指定也跟menuBarPath有同樣的情況, 比如定義為Normal/additions, 這里的Normal指的是workbench toolbar, additions就是action要顯示的group位置

          action
          class屬性是封裝了執行動作的類,它實現了IWorkbenchWindowActionDelegate, 在它里面有幾個方法需要介紹一下, 一個是selectionChanged, 用來動態修改actionstate狀態值, 是否可用,以及actiontext屬性等, 比如對于enableFor屬性來說, 它根據選中對象的數量來判斷action是否可用, 但是通過selectionChanged可以通過當前選定的對象的情況來調用setEnable()方法從而更精確的控制action是否可用, 有時候當插件還沒有加載,在調用actionrun方法時會加載插件,這時可能在調用run()方法之前沒有調用selectedChange方法, 因此在run()方面里面需要寫一些防護性代碼,比如空值的判斷之類的, 另外run()是在主UI線程中執行的,因此,如果該執行耗時較長,需要將其放到后臺線程中執行.

          插件運行之后在menubartoolbar上看到定義的actionSet,可以試試下面的方法:
          Window > Customize Perspective... 下看看是不是actionSet沒有選中
          使用Window > Reset Perspective刷新當前視圖
          關閉重新打開當前視圖
          如果還沒有出來,可以在在run或者debug的設置中將"Clear workspace data before launching "選中, 然后再啟動運行

          雖然通過擴展點可以非常方便的在Eclipse上添加,但是這個玩意兒多了也不是什么好事, 可能會降低用戶體驗,因此需要進行控制, actionSet擴展點也有相關的設置來指定是否可見, 而且還可以調用IActionSetDescriptor.setInitiallyVisible() 來控制頂層菜單是否可見, 另一種解決辦法就是在首選項中提供一個checkbox讓用戶決定是否顯示頂層菜單,其編程實現就是在代碼中調用 IActionSetDescriptor.setInitiallyVisible() IWorkbenchPage.hideActionSet()來進行控制
          來自:http://hi.baidu.com/xianle/blog

           

          posts - 37, comments - 5, trackbacks - 0, articles - 0

          Copyright © eric_xu

          主站蜘蛛池模板: 松溪县| 金寨县| 内丘县| 沛县| 杭锦后旗| 军事| 化州市| 平山县| 九龙坡区| 洪泽县| 炎陵县| 巧家县| 扶风县| 宁波市| 枣庄市| 浦东新区| 绍兴县| 泌阳县| 象州县| 沅陵县| 华安县| 锡林浩特市| 凭祥市| 天台县| 临海市| 井陉县| 成都市| 龙泉市| 云林县| 靖边县| 诸暨市| 蒙自县| 弋阳县| 镇安县| 铁岭县| 金溪县| 会理县| 扎赉特旗| 红安县| 察雅县| 海晏县|