TableModelExample可以簡化Swing
每篇關于 GUI 編程的文章都需要一個示例,本文當然也不例外。該示例的目的是指出使用 TMF 框架代替傳統 TableModel 設計的主要優勢所在。示例中的應用程序將在屏幕上顯示多個表,并且可以添加或刪除表,表中可以包含不同類型的信息( String 類型、 int 類型、 Boolean 類型和 BigDecimal 類型),而且最重要的是,其中還包含可配置的列信息,必須定期更改它們。
示例應用程序的代碼從 J2X 包中分離了出來,您可以 HR 文件夾的 src 目錄中找到源代碼。還可以雙擊 build/lib 文件中編譯好的 JAR 文件,通過 JRE 運行應用程序。
在示例應用程序中,有兩個類可以相互交換,一個叫作 TableModelFreeExample ,另一個叫作 TableModelExample 。這兩個類在應用程序中做的是同樣的事,使應用程序產生的行為也相同。但是,它們的設計不同,一個使用的是 TMF 框架,另外一個則使用傳統的 TableModel。您從它們身上注意到的***件事可能是 TMF 類 TableModelFreeExample ,該類由 63 行代碼構成,而在傳統 TableModel 版本 TableModelExample 中,它長達 285 行。
Evil HR Director 應用程序
我要使用的示例應用程序是 Evil HR Director 應用程序,它允許人力資源總監(可能很可怕,戴著眼鏡)在 JTable 中查看潛在雇員的列表,然后從表中選出雇傭的人。新雇傭的員工的資料會轉移到當前雇員使用的兩個 JTable 中;其中一個表包含個人信息,另外一個表包含財務信息。在當前雇員表中,總監可以隨意選擇解雇誰。您可以在圖 1 中看到該應用程序的 UI。
圖 1. Evil HR Director 應用程序
為了進一步證明 TMF 框架的簡單性,請看清單 6。這個清單只包含三行必需的代碼,就可以創建 Evil HR Director 應用程序中包含的三個表的模型。這些代碼可以在 TableModelFreeExample 中找到。
清單 1.在 Evil HR Director 應用程序中創建模型所需要的代碼
- TableUtilities.setViewToModel("demo/hr/resources/evil_hr_table.xml",
- "Hire", hireTable, candidates);
- TableUtilities.setViewToModel("demo/hr/resources/evil_hr_table.xml",
- "Personal", personalTable, employees);
- TableUtilities.setViewToModel("demo/hr/resources/evil_hr_table.xml",
- "Financial", financialTable, employees);
為了進行比較, TableModelExample 中包含用傳統 TableModel 方法為三個表格創建模型所需要的代碼。請查看示例包中的代碼。不過,我不想在這里列出所有代碼,因為它足足有 205 行!
演示 TMF 框架的靈活性
TMF 框架的巨大優勢之一,是它能更加容易地基于 JTable 的應用程序在其發布之后進行修改。為了證實這一點,讓我們來看兩個可能的場景,這兩個場景在使用 Evil HR Director 應用程序中每天都可能出現。在每個場景中,您都會看到框架是如何讓應用程序更加容易地適應不斷變化的用戶需求。
場景 1:公司的策略發生變化,規定在公司的應用程序中查看私人的婚姻信息是非法的。
TMF:最終用戶需要從 XML 配置文件中刪除 Married?married 。
傳統 TableModel:開發人員必須深入研究 Java 代碼,修改 getColumnName() ,讓它無法返回列名“Married?”;修改 getColumnCount() ,讓它返回的結果比以前返回的結果少一列;修改 getValueAt() ,不讓它返回 isMarried() 。然后開發人員必須重新編譯 Java 代碼,并重新部署應用程序。
場景 2:公司策略發生變化,公司覺得有必要在潛在雇員表中包含居住地所在的州的信息。
TMF:: 最終用戶需要將 Statestate 添加到 XML 配置文件中。
傳統 TableModel:開發人員必須深入研究 Java 代碼,修改 getColumnName() ,添加一個叫作 “State” 新列;修改 getColumnCount() ,讓它返回的列數加 1 ;修改 getValueAt() ,讓它返回 getState() 。然后開發人員必須重新編譯 Java 代碼,并重新部署應用程序。
您可以看到,當應用程序中的表發生變化時(尤其在碰到一個總是朝令夕改的老板時,更改更加頻繁),編輯 XML 文件要比重新部署整個應用程序容易得多。
使用代碼
在您飛奔過去刪除所有 TableModel 代碼之前,我想我還得占用您一分鐘解釋一下 j2x.zip 文件的內容,以及您怎樣才能在您自己的項目中使用它。(請記住,特定于 TMF 的代碼可以在 com.ibm.j2x.swing.table 包中找到;您還會在 J2X 包中找到我在以前的文章“Go state-of-the-art with IFrame.”中介紹的其他代碼。)
j2x.zip 文件包含兩上文件夾:
src—— 包含本文中使用的源代碼。在 src 文件夾中,還有兩個文件夾:一個是 HR,包含構成 Evil HR Director 應用程序的源代碼;另一個是 J2X,包含 J2X 項目中使用的所有源代碼。
build—— 包含 Evil HR Director 應用程序和 J2X 項目編譯后的類文件。該文件夾中的 lib 文件夾則包含 HR 應用程序和 J2X 項目的 JAR 文件。
lib.zip 文件包含以下文件夾:
lib—— 包含所有的第三方 JAR 文件,運行應用程序或者任何使用 J2X 項目的項目,需要使用這些文件。在這個文件夾中,您還會找到第三方項目的許可。
docs.zip 文件包含下列文件夾:
docs—— 包含 J2X 項目的所有 JavaDoc 信息。
要在應用程序中使用 J2X 包,則需要把 CLASSPATH 指向 build/lib 文件夾中的 j2x.jar 以及 lib 文件中包含的所有三個第三方 JAR 文件。第三方包的許可條款允許您重新發布本文包含的所有包,但是如果有興趣對這些包做些修改,請閱讀許可條款。
結束語
使用 TableModel Free 框架,就不用再編寫傳統 TableModel 了。TMF 框架改進了 JTable 和 TableModel 模型之間的 MVC 關系,更清楚地分離了它們。在日后的發布中,您甚至可以在不修改任何模型代碼的情況下,對組件進行熱交換。框架還允許您在模型發生變化時,自動更新視圖,從而消除傳統 TableModel 設計中所必需的視圖和模型之間的通信。
TMF 框架還會極大地減少開發 GUI 所需的時間,特別是在處理 JTable 時。幾年以前,我處理的一個應用程序中有 150 多個 JTable,每個表都來自同一個原始表模型,該應用程序可以作為示例。使用 TMF 框架,我們只用 150 行代碼就能解決問題;但是不幸的是,當時還沒有 TMF,所以我們***編寫了 15,000 行額外的代碼,才生成必需的表模型。這不但增加了開發時間,還增加了測試和調試的時間。
與使用傳統 TableModel 相比,使用 TMF 框架使您到了一個更加容易配置所有 JTable 的時代。請想像這樣一個 POS 應用程序:該應用程序被銷售給了 5 個不同的客戶,每個客戶都有一套特定的信息,所以每個用戶都想有一組顯示在 GUI 上的特定的列。如果沒有 TMF 框架,您就必須為每個客戶都生成一組特定的 TableModel —— 由此,也就生成了一組特定的應用程序。而使用可配置的 XML 文件,每個客戶都可以使用相同的應用程序,客戶所在地的業務分析師可以根據需要修改 XML 文件。請想像一下,這節約了多少開發和支持成本!
TableModel Free 框架解決了 Swing 開發人員社區的特定需求:減少了處理 JTable 時的開發時間和維護開銷,提高了它們對終端用戶的易用性。Swing 桌面正在回歸,使用像 TMF 框架這樣的工具,開發人員會發現可以更容易地使用 Swing 和開發 GUI 應用程序。您要做的***步就是用 TMF 框架的一行代碼代替您所有的 TableModel,把所有 TableModel 都永遠地拋到虛擬空間的黑洞中去吧。
【編輯推薦】