|
1、引言
Eclipse是一個開放源代碼的、基于Java的可擴展的開發(fā)平臺。就其本身而言,它只是一個框架、一組服務,用于通過插件來構建開發(fā)環(huán)境。當我 們提到Eclipse的時候,許多Java開發(fā)者的第一反應就是那個性能良好,界面漂亮,Debug功能奇佳的Java集成開發(fā)平臺。 無可否認,Eclipse常常作為一款優(yōu)秀的IDE(Integrated Development Environment,集成開發(fā)環(huán)境)出現(xiàn)在開發(fā)者面前的。它不僅僅是Java的IDE,還可以是C語言的IDE、Python的IDE——只要開發(fā)出 相應語言的插件,Eclipse就可以成為任何語言的IDE。但是,這些嚴格來說都是Eclipse RCP的應用。真正的Eclipse,是一個提供了一個完善的插件機制RCP(Rich Client Platform,胖客戶端平臺)平臺;它以SWT/JFace作為界面元素組件,提供給用戶一個名為Workbench的UI平臺;加上它本身優(yōu)秀的插 件機制,它能夠構造出擴展能力強、性能優(yōu)秀、并能提供給用戶良好UI體驗的服客戶端平臺。 2、Eclipse RCP簡介 Eclipse RCP是一項位于Eclipse平臺核心的功能。大多數(shù)人想到Eclipse時,會想到Java集成開發(fā)環(huán)境(IDE)。如果將Eclipse中關于 IDE的內(nèi)容剝?nèi)ィO碌木褪且粋€提供基本工作臺功能的核心,包括對可移動以及可疊加的窗口組件(編輯器和視圖)、菜單、工具欄、按鈕、表格、樹形結構等 等的支持,而這個核心就是Eclipse RCP。 個人理解Eclipse RCP就是由插件開發(fā)轉向桌面應用開發(fā),構建最小化的Eclipse平臺(8M)運行你的桌面應用,不必再為程序框架煩心,擺脫失敗的AWT和Swing,讓程序擁有專業(yè)級效果,而實現(xiàn)又很簡單、很優(yōu)雅。 RCP提供了豐富的界面控件,這使得基于 Java 開發(fā)桌面應用也變得容易了很多,雖然仍然不能和基于VB、Delphi進行相比。對于開發(fā)者而言,盡管使用 RCP 也是為了開發(fā)桌面應用,但 RCP 給開發(fā)者帶來的更多的感覺是在它充分發(fā)揮了插件化系統(tǒng)的優(yōu)勢, RCP 可以視為基于 OSGi(Open Service Gateway Initiative) 構建插件化系統(tǒng)的最佳實踐的指導,從 RCP 的設計中,可以學習到如何將應用做到模塊化、將應用做到動態(tài)化,甚至還可以學習到如何自動生成界面這樣的設計思想。 RCP 可以看做是基于 OSGi 做插件化應用系統(tǒng)的最佳實踐,其中的不少設計方法甚至都可以整理成為基于 OSGi 做插件化應用系統(tǒng)的設計模式,讓我們進入 RCP 之旅,揭開面紗,一探其本質吧!相信大家在了解了 RCP 的設計思想,看過其代碼后,不得不對 RCP 表示崇高的敬意,大師之作,不同凡響。 Eclipse RCP為應用程序開發(fā)人員提供了: ◆應用程序和特性的一致且本地的外觀; Eclipse RCP項目用SWT圖形庫和工具包取代了Java標準中的AWT和Swing。SWT直接調用了操作系統(tǒng)的圖形庫,從而使得Java應用程序的LOOK & Feel 與操作系統(tǒng)的習慣完全一致;更為重要的是,對本地方法的直接調用大幅度的提高了基于SWT 的Java應用程序的運行速度。SWT 的缺點主要在于兩點:(1) 不是Java語言標準; (2) 支持的平臺太少。 3、Eclipse RCP體系結構 一個Eclipse RCP可分為如下五個部分,如下圖所示:
(1)Wrokbench工作臺 (2)Workspace工作區(qū) (3)Help幫助系統(tǒng) (4)Team團隊支持系統(tǒng) (5)Platform Runtime運行平臺 【文章相關內(nèi)容】 第一頁:Eclipse RCP體系結構 第二頁:Eclipse RCP功能簡介 #p# Eclipse最明顯的一大優(yōu)點就是即插即用、即刪即無。在構建插件化的應用系統(tǒng)的時候,我們通常希望做到以下三點: (1)通過增加插件來動態(tài)擴展系統(tǒng)功能,包括功能的入口等,最重要的就是不要因為增加了新的插件,而導致對原插件的修改,做到即插即用, OSGi 本身提供了基于插件動態(tài)擴展系統(tǒng)功能的支持,但是否可以真的做到即插即用,是否可以不導致對原插件的修改,這個還是要看設計者的功力; (2)通過刪除插件來動態(tài)移除系統(tǒng)功能,包括功能的入口等,最重要的就是要讓插件的卸載不影響到系統(tǒng)的運行,這個和 1 里面所說的情況也是一樣的, OSGi 是可以支持這樣的要求,但應用系統(tǒng)是否能做到還是看設計者的功力; (3)通過增加或更新插件來動態(tài)改變系統(tǒng)行為。 RCP基于OSGi來保證其插件化以及動態(tài)化可實現(xiàn)的情況下,還定義了擴展點的機制,而正是因為擴展點的機制,使得 RCP 在設計角度上能夠更好的達到我們構建插件化應用系統(tǒng)的前兩個目標,同時 RCP 通過其對桌面應用支撐的設計為我們展示了擴展點的最佳實踐方法,將界面按照對象的思想進行劃分,在劃分的過程中根據(jù)職責形成插件,暴露出擴展點,最后形成 了像樹一樣的結構體系,如圖所示:
這種設計方法最佳的一個地方就在于充分的做到了真正的即插即用、即刪即無的情況,典型的例子就是在 RCP 中可以通過擴展實現(xiàn) Perspective ,將這個插件安裝上后就可以在 RCP 中看到這個 Perspective ,刪除這個插件后 RCP 中自然就看不到這個 Perspective 了。 從 RCP 的結構體系上,可以看出 RCP 在基于擴展點的設計思想上是怎么去設計的,它的設計思路采取的就是從頂至下、按照職責進行劃分、形成插件的方法,插件中需要支持動態(tài)擴展的部分則做成擴展點,從而形成一個非常容易擴展的開發(fā)平臺。 即插即用、即刪即無的支持使得系統(tǒng)可以很好的以插件的方式來進行組裝,做系統(tǒng)的時候就象在種樹,先把系統(tǒng)的根撒下,讓根長出主干,在主干上培育出枝 葉,枝葉上結出果實,整顆樹就這么培育成了,當不需要了某個果實的時候,把它摘下來吃了,當不需要了某顆枝葉的時候,把那顆枝葉砍了,而這都不會影響到主 干,當希望樹上形成別的果實的時候,甚至都可以接上不同的枝葉,讓它長出不一樣的果實。 4、總結 目前,基于Eclipse開發(fā)的插件非常多,涉及到軟件領域的各個方面。但是,基于Eclipse RCP開發(fā)的獨立軟件并不常見,其中比較著名的幾款Eclipse RCP軟件有: JLabrary:開源的CMS系統(tǒng),用Eclipse RCP實現(xiàn)客戶端; 感興趣的讀者可以下載這些軟件的源代碼進行學習。另外Eclipse本身也具有十分詳細的RCP開發(fā)幫助文檔(都是英文的),充分利用這些資源將大大加快Eclipse RCP開發(fā)。 【文章相關內(nèi)容】 第一頁:Eclipse RCP體系結構 第二頁:Eclipse RCP功能簡介 【相關文章】 |
|
|
來自: LibraryPKU > 《Java UI》