[摘要] 在基於J2EE平台的信息系統中,具有豐富表現能力的Java Applet是界面層的一種重要形式。但Java API對打印的支持比較弱,打印輸出復雜的單據和報表需要大量工作。本文介紹的系統通過引入一個ActiveX控件--Cell插件--來解決這個問題。該系統中,由Java Applet完成界面表現,由Cell插件完成打印輸出,兩者之間通過Sun公司的一套接口API互相通信。
一、Java Applet與Ocx控件的交互
1.1從Java Applet訪問Java Script方法和Ocx控件
Sun公司在JDK中提供了一套從Java Applet訪問Java Script的API,由此可以實現Java Applet訪問Html頁面中的DOM對象的機制。該API以一個Jar文件的形式提供:%JAVA_HOME%jrelibjaws.jar,其中%JAVA_HOME%是你安裝JDK的目錄。將該jar文件加入到環境變量classpath中,就可以用它實現從Java Applet到Java Script的調用了。下面是一段調用Java Script中的方法的代碼實例:
import netscape.javascript.*;
import java.applet.*;
import java.awt.*;
class MyApplet extends Applet {
public void init() {
JSObject win = JSObject.getWindow(this);
JSObject doc = (JSObject) win.getMember("document");
win.call("f", null);
}
}
在上面的代碼中,win.call(“f”, null)調用了JavaScript中的方法f()。
1.2從JavaScript訪問Java Applet
當使用Java Plugin1.4.x運行Java Applet時,只需把Java Applet中的方法視為Java Plugin這個控件的方法,直接在Java Script中進行調用即可。下面用一個簡單的例子進行說明:
(1) 在載入Java Plugin的Object標簽中,用參數ID指定一個名字:
(2) 在HTML頁面上增加一個按鈕,點擊它時從Java Script調用Java Applet中的方法:
onClick="calculate" language="JavaScript">
(3) 假定你的Java Applet是MyApplet.java,它有一個public方法method1(),那麼就可以用如下的Java Script代碼直接調用該方法:
二、Cell插件簡介
華表的Cell插件是一個功能非常類似於Excel的、用於Web開發的ActiveX控件。它可以在Windows的浏覽器中顯示、編輯、打印表格。
三、系統實現
1.1 系統架構
圖一是系統的配置示意圖。由圖可見,這是一個典型的三層應用系統。在本系統中,Java Applet和Cell插件部署在Web Server上,在運行時,它們被下載到客戶端,運行在浏覽器中。
圖二是系統的運行示意圖。由圖可見,運行在客戶機上的Java Applet通過Web Server上的Servlet訪問應用服務器上的EJB,與後台交互。Java Applet作為表示層,在客戶機上顯示界面。
當需要打印輸出時,Java Applet將數據和顯示格式設置到華表插件中,並調用華表插件的打印與覽和打印方法,完成打印功能。
1.2 用Cell插件實現Java界面的打印
1.2.1在HTML頁面上嵌入華表的Cell插件
為了在Applet界面中調用華表的Cell插件,我們首先在HTML頁面上隱藏了一個Cell插件:
通過指定Cell插件的高度和寬度都為0,從而達到隱藏Cell插件的目的。
1.2.2 在Applet中提供兩個調用接口方法
下面是一個Applet的代碼實例,其中提供了callCellMethod()和callJavaScriptMethod()兩個接口方法,分別可用來調用Cell插件的方法和JavaScript的方法:
public class MyApplet extends javax.swing.JApplet {
private JSObject win = null;
private JSObject cell = null;
public Object callCellMethod(String name, Object[] params) {
return getCell().call(name, params);
}
public Object callJavaScript(String name, Object[] params) {
return getJSwin().call(name, params);
}
private JSObject getCell() {
if (cell == null) {
try {
JSObject doc = (JSObject)getJSwin().getMember("document");
JSObject all = (JSObject)doc.getMember("all");
cell = (JSObject)all.call("item", new Object[]{"DCellWeb1"});
}
catch (Exception e) {
e.printStackTrace();
}
}
return cell;
}
private netscape.javascript.JSObject getJSwin() {
if (win == null) {
win = netscape.javascript.JSObject.getWindow(this);
}
return win;
}
}
通過getCell()這個方法,可以在Java Applet中直接獲得用JSObject表示的Cell插件,從而可以直接調用它的方法。例如,在Java Applet中向Cell插件的一個單元格寫入數據,可以如下調用:
Integer row = new Integer(1);
Integer column = new Integer(1);
Integer page = new Integer(0);
callCellMethod("SetCellString", new Object[]{column, row, page, “str”});
其中SetCellString是Cell插件提供的接口方法。這樣就實現了從Java Applet到華表的Cell插件的調用。
五、結論
在這個應用系統中,我們只利用Cell插件的打印預覽和打印兩項功能,不用它做屏幕顯示。所有打印格式和數據都在Java Applet中預備好,按單元格向Cell插件設置格式和數據,由Cell插件完成分頁和打印功能。
這是一種表現與數據分離的方式:Java Applet中只組織打印數據,所有打印的表現工作交給Cell插件完成,因此能夠大大降低工作量。
Cell插件除打印功能外,還具有輸入、顯示、編輯、圖表等非常強大的功能,可以制作出非常復雜的報表。利用Cell插件,還可以將數據導出為Excel或PDF等格式的文件。
六、參考文獻
1. Cell插件文檔:http://www.cellsoft.cc
2. Java Plugin 文檔:http://java.sun.com/j2se/1.4.1/docs/guide/plugin/