<%@ page contentType="text/html;charset=GBK"%>
<%@ taglib uri="/tags/web-html" prefix="html"%>
<%@ taglib uri="/tags/web-tianhe" prefix="templates"%>
<%@ page import="java.math.BigDecimal"%>
<%@ page import="java.util.List"%>
<%@ page import="java.util.Map"%>
<%@ page import="java.util.Date"%>
<script language="Jscript">
function setfilename()
{
filen="jsp/hr/personnel/Personnelreport.cll";
return filen;
}
function filldata()
{
<%
List bodyList=(List)request.getAttribute("bodyList"); //表體數據
Map headTailMap=(Map)request.getAttribute("headTailMap"); //表頭表尾數據
int len = bodyList.size();
String title= (String) headTailMap.get("title");//標題
String userName=(String)headTailMap.get("userName");//制表人
String date=(String)headTailMap.get("dateId");//制表時間
%>
sheet = <%=0%>;
content_col=1;
//設置某頁行數
CellRpt.SetRows(<%=len+4+1%>,sheet);//設置某頁行數(行數,頁號)
CellRpt.SetCols(15,sheet);//設置某頁列數(列數,頁號)
CellRpt.PrintSetOrient(1);//設置進紙方式為橫放
CellRpt.MergeCells(1,1,15,1);//將指定區域的單元格組合(區域起始點列號,行號,區域結束點列號,行號)
CellRpt.SetCellFontStyle(1,1,sheet,2);//設置指定單元格的字體風格(列號,行號,頁號,字體風格)
CellRpt.SetCellFontSize(1,1,sheet,20);//設置單元格字體大小(列號,行號,頁號,字號)
CellRpt.SetCellAlign(1,1,sheet,36);//設置指定單元格的對齊方式(列號,行號,頁號,參數)
CellRpt.S(1,1,sheet,"<%=title%>");
CellRpt.MergeCells(1,2,1,2);
CellRpt.SetCellFontStyle(1,2,sheet,3);
CellRpt.SetCellFontSize(1,2,sheet,10);
CellRpt.SetCellAlign(1,2,sheet,36);
CellRpt.S(1,2,sheet,"部門");
CellRpt.MergeCells(2,2,2,2);
CellRpt.SetCellFontStyle(2,2,sheet,3);
CellRpt.SetCellFontSize(2,2,sheet,10);
CellRpt.SetCellAlign(2,2,sheet,36);
CellRpt.S(2,2,sheet,"姓名");
CellRpt.MergeCells(3,2,3,2);
CellRpt.SetCellFontStyle(3,2,sheet,3);
CellRpt.SetCellFontSize(3,2,sheet,10);
CellRpt.SetCellAlign(3,2,sheet,36);
CellRpt.S(3,2,sheet,"性別");
CellRpt.MergeCells(4,2,4,2);
CellRpt.SetCellFontStyle(4,2,sheet,3);
CellRpt.SetCellFontSize(4,2,sheet,10);
CellRpt.SetCellAlign(4,2,sheet,36);
CellRpt.S(4,2,sheet,"年齡");
CellRpt.MergeCells(5,2,5,2);
CellRpt.SetCellFontStyle(5,2,sheet,3);
CellRpt.SetCellFontSize(5,2,sheet,10);
CellRpt.SetCellAlign(5,2,sheet,36);
CellRpt.S(5,2,sheet,"政治面貌");
CellRpt.MergeCells(6,2,6,2);
CellRpt.SetCellFontStyle(6,2,sheet,3);
CellRpt.SetCellFontSize(6,2,sheet,10);
CellRpt.SetCellAlign(6,2,sheet,36);
CellRpt.S(6,2,sheet,"學歷");
CellRpt.MergeCells(7,2,7,2);
CellRpt.SetCellFontStyle(7,2,sheet,3);
CellRpt.SetCellFontSize(7,2,sheet,10);
CellRpt.SetCellAlign(7,2,sheet,36);
CellRpt.S(7,2,sheet,"專業技術名稱");
CellRpt.MergeCells(8,2,8,2);
CellRpt.SetCellFontStyle(8,2,sheet,3);
CellRpt.SetCellFontSize(8,2,sheet,10);
CellRpt.SetCellAlign(8,2,sheet,36);
CellRpt.S(8,2,sheet,"職業技能名稱");
CellRpt.MergeCells(9,2,9,2);
CellRpt.SetCellFontStyle(9,2,sheet,3);
CellRpt.SetCellFontSize(9,2,sheet,10);
CellRpt.SetCellAlign(9,2,sheet,36);
CellRpt.S(9,2,sheet,"出生日期");
CellRpt.MergeCells(10,2,10,2);
CellRpt.SetCellFontStyle(10,2,sheet,3);
CellRpt.SetCellFontSize(10,2,sheet,10);
CellRpt.SetCellAlign(10,2,sheet,36);
CellRpt.S(10,2,sheet,"入職時間");
CellRpt.MergeCells(11,2,11,2);
CellRpt.SetCellFontStyle(11,2,sheet,3);
CellRpt.SetCellFontSize(11,2,sheet,10);
CellRpt.SetCellAlign(11,2,sheet,36);
CellRpt.S(11,2,sheet,"家庭地址");
CellRpt.MergeCells(12,2,12,2);
CellRpt.SetCellFontStyle(12,2,sheet,3);
CellRpt.SetCellFontSize(12,2,sheet,10);
CellRpt.SetCellAlign(12,2,sheet,36);
CellRpt.S(12,2,sheet,"辦公電話");
CellRpt.MergeCells(13,2,13,2);
CellRpt.SetCellFontStyle(13,2,sheet,3);
CellRpt.SetCellFontSize(13,2,sheet,10);
CellRpt.SetCellAlign(13,2,sheet,36);
CellRpt.S(13,2,sheet,"移動電話");
CellRpt.MergeCells(14,2,14,2);
CellRpt.SetCellFontStyle(14,2,sheet,3);
CellRpt.SetCellFontSize(14,2,sheet,10);
CellRpt.SetCellAlign(14,2,sheet,36);
CellRpt.S(14,2,sheet,"員工狀態");
content_row=3;
<%
BigDecimal sumEmpNum = new BigDecimal(bodyList.size());
for(int i = 0;i < bodyList.size();i++){
Map bodyMap = (Map) bodyList.get(i);
String orgName = (String)bodyMap.get("ORGAN_NAME");//部門
String empName = (String)bodyMap.get("EMP_NAME");//員工姓名
String sex = (String)bodyMap.get("SEX");//性別
String policital = (String)bodyMap.get("POLICITAL_STATUS");//政治面貌
String edu = (String)bodyMap.get("EDUCATION");//學歷
String tName = (String)bodyMap.get("NAME");//專業技術名稱
String skillName = (String)bodyMap.get("SKILL_POST_NAME");//職業技能名稱
String birthday = (String)bodyMap.get("BIRTHDAY");//生日
String entryDay = (String)bodyMap.get("ENTRY_ENTERPRISE_DAT");//入職時間
String addr = (String)bodyMap.get("ADDRESS");//家庭住址
String officePhone = (String)bodyMap.get("OFFICE_PHONE");//辦公電話
String mobilePhone = (String)bodyMap.get("MOBILE_PHONE");//移動電話
String state = (String)bodyMap.get("STATE");//員工狀態
String ageStr = "";
if(sex == null || "".equals(sex)){
sex = "";
}else{
switch(Integer.parseInt(sex)){
case 0 : sex="男";break;
case 1 : sex="女";break;
}
}
if(policital == null || "".equals(policital)){
policital = "";
}else{
switch(Integer.parseInt(policital)){
case 1 : policital="工人";break;
case 2 : policital="農民";break;
case 3 : policital="知識分子";break;
case 4 : policital="群眾";break;
}
}
if(edu == null || "".equals(edu)){
edu = "";
}else{
switch(Integer.parseInt(edu)){
case 1 : edu="小學";break;
case 2 : edu="初中";break;
case 3 : edu="高中";break;
case 4 : edu="大學???;break;
case 5 : edu="大學本科";break;
case 6 : edu="碩士";break;
case 7 : edu="博士";break;
}
}
if(skillName == null || "".equals(skillName)){
skillName = "";
}else{
switch(Integer.parseInt(skillName)){
case 1 : skillName="企業人力資源管理";break;
case 2 : skillName="計算機操作";break;
case 3 : skillName="倉儲工";break;
case 4 : skillName="企業經營管理";break;
case 5 : skillName="秘書";break;
case 6 : skillName="物流管理";break;
case 7 : skillName="卷煙商品營銷";break;
case 8 : skillName="客戶服務管理";break;
case 9 : skillName="企業信息管理";break;
case 10 : skillName="汽車駕駛";break;
case 11 : skillName="營業員";break;
}
}
if(birthday == null || "".equals(birthday)){
birthday = "";
}else{
String yearBir = birthday.substring(0,4);
String dateNow = new Date().toString();
String yearNow = dateNow.substring(dateNow.length()-4,dateNow.length());
int ageInt = Integer.parseInt(yearNow) - Integer.parseInt(yearBir);
ageStr = String.valueOf(ageInt);
}
%>
content_col=1;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,33);
CellRpt.S(content_col,content_row,sheet,"<%=orgName%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,33);
CellRpt.S(content_col,content_row,sheet,"<%=empName%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,33);
CellRpt.S(content_col,content_row,sheet,"<%=sex%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=ageStr%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=policital%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=edu%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=tName%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=skillName%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=birthday%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=entryDay%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=addr%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=officePhone%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=mobilePhone%>");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=state%>");
content_row++;
<%
}
%>
content_col=1;
CellRpt.MergeCells(content_col,content_row,content_col,content_row);
CellRpt.SetCellFontStyle(content_col,content_row,sheet,0);
CellRpt.SetCellAlign(content_col,content_row,sheet,33);
CellRpt.S(content_col,content_row,sheet,"合計");
content_col++;
CellRpt.SetCellFontSize(content_col,content_row,sheet,10);
CellRpt.SetCellAlign(content_col,content_row,sheet,34);
CellRpt.S(content_col,content_row,sheet,"<%=sumEmpNum%>(人)");//總人數
content_row++;
CellRpt.MergeCells(1,content_row,3,content_row);
CellRpt.SetCellFontSize(1,content_row,sheet,10);
CellRpt.SetCellAlign(1,content_row,sheet,33);
CellRpt.S(1,content_row,sheet,"制表人:"+"<%=userName%>");
CellRpt.MergeCells(12,content_row,14,content_row);
CellRpt.SetCellFontSize(12,content_row,sheet,10);
CellRpt.SetCellAlign(12,content_row,sheet,34);
CellRpt.S(12,content_row,sheet,"制表日期:"+"<%=date%>");
var line_rowBegin=2; //從第二行開始
var line_rowEnd=CellRpt.getRows(sheet)-2; //畫到倒數第三行
var line_colBegin=1; //從第一列開始
var line_colEnd=CellRpt.getCols(sheet);//畫到最后一列
CellRpt.DrawGridLine(line_colBegin, line_rowBegin, line_colEnd,line_rowEnd, 0, 2,-1);//所有框畫細線
//打印設置
CellRpt.PrintRange(1,1,CellRpt.getCols(sheet),CellRpt.getRows(sheet));
CellRpt.PrintSetTopTitle(1,6);
CellRpt.PrintSetBottomTitle(content_row+1,content_row+1);
CellRpt.PrintSetOrient(1);//打印方向:1為橫向,0為縱向
}
</script>
從Widget和Control開始
Widget是Control的父類,而Control是我們使用的大多數部件的父類。
在org.eclipse.swt.widgets中定義了眾多的widget,甚至我們前面介紹的Shell也被當成widget的一種。
因為可用的widget如此之多,所以我大概沒有辦法全部一一介紹。在這一節中,我會介紹幾種常用的widget。相信善于觸類旁通的你通過這些極為簡略的介紹應該可以開始使用各種widget,在使用中不斷完善自己的認識。
首先我們來介紹Widget。它是一個抽象類,也是所有widget的父類。通過介紹這個類,我們可以得出這所有widget的一些共有特性。
Widget的方法中dispose()方法我們在以前曾經見到過,調用這個方法時候,所謂的接收者(receiver,譬如我們這樣寫:awidget.dispose(),那么awidget就是接收者,而這句話所處的對象稱為調用者)和接收者中所包含的其他widget會釋放它們所占用底層操作系統的資源。這也就是說你不必顯式地為程序中創建的每個widget進行dispose()調用,而只需要確保最外層的widget(比如Display)進行了dispose()就可以了。
另外還可以通過isDisposed()判斷是否該widget(接收者)已經進行了dispose。
Widget中的getStyle()方法得到widget的風格,而getDisplay()得到所處的Display對象。
此外Widget中還有兩個重要方法getData()和setData(),這兩個方法允許我們為一個widget附加其他的信息。特別是在你需要跨模塊傳遞widget的時候,這個功能顯得非常有用。比如如果一個文本框中顯示了一段文章中的某句話,如果我們同時希望把這整篇文章的題目和作者附加上的話可以這樣寫:
atext.setData("title","I Have A Dream");
atext.setData("author","Martin Luther King");
在程序的其他部分可以用atext.getData(“title”)得到這篇文章的題目,或者用atext.getData("author")得到作者。
在前面我們提到過,Control是今后我們所使用大部分widget的父類。
創建部件
和創建其他java object一樣,我們通過使用new操作符創建部件的實例。有一點比較特殊的可能你需要使用帶參數的構造函數進行new操作。類似下面的程序:
Text text=new Text(shell,SWT.CENTER);
這種方法適用于幾乎所有的widget,其中第一個參數是父widget,也就是指明了該widget需要被放置道另外哪一個widget之中,而第二個參數是這個widget的風格。
大小和位置
僅僅創建一個部件并不足以讓你看到它,因為一個部件初始的長和寬都是0。你還需要設定它的大小。你可以用setSize()或者setBounds()方法手動設定部件的大小,也可以讓系統自動調整部件的大小到一個合適的值,這個值也被成為首選尺寸(preferred size)。
可以通過調用pack()方法讓系統調整控件大小。如果你希望系統自動調整,那么你需要首先設定控件需要表達的內容。舉個例子來說,如果你的部件是一個文本框或者標簽,你應該首先設定它所要顯示的文本,這樣系統可以通過文本的長度計算。
對于部件的位置,同樣可以使用setLocation()或者setBounds()進行設定。
這里值得一提的是所謂的bounds,其實bounds可以看成是大小和尺寸的綜合。比如setBounds(int x, int y,int width,int height)的參數中,x和y描述的是位置信息,而width和height描述了大小。
隱藏與失效
通過部件的setVisible方法可以控制部件進行隱藏或是顯示。通過setEnabled方法可以控制部件是否有效。一個無效的部件不會對用戶的任何動作作出響應。這兩個方法的參數都是布爾型的。
提示文本
可以通過setToolTipText()方法設定部件的提示文本。
幾種常用的部件
Label
標簽用來顯示靜態的文本或者圖像。關于圖像和色彩我會在后面的部分進行介紹。
標簽可以使用SWT.CENTER, SWT.LEFT, SWT.RIGHT中的一種指明文本的對齊方式(居中對齊,左對齊,右對齊)。
你也可以通過設置標簽屬性為SWT. SEPARATOR 使標簽成為一條分隔符。
Text就是最簡單的文本框,與標簽一樣,我們可以通過設定它的風格來表示它的對齊方式(SWT.CENTER,SWT.LEFT,SWT.RIGHT),另外還有其他一些用于文本支持的方法,比如insert(),paster(),copy(),setSelection(),selectAll()等,這些方法在后面介紹swt事件模式會進行更詳細的介紹。
Button
在swt中,Button并不僅僅是按鈕。構造時候定義的風格不同,所體現出的外觀也不一樣。
如果風格定義成SWT.PUSH,它就是一個普通的按鈕。
如果定義為SWT.TOGGLE,它在被按下以后會保持按下的形狀(而不會彈起來),直到鼠標再次在上面按一下才會回復彈起的形狀。
如果風格定義為SWT.ARROW,它是一個帶箭頭的按鈕,箭頭的指向可以選擇SWT.LEFT,SWT.RIGHT,SWT.UP,SWT.DOWN中的一個。
如果定義為SWT.CHECK,它是一個復選框。
如果定義為SWT.RADIO,它是一個單選框。