Java 中jasperReport实现动态列打印的实现代码
以下代码中注释说明很清楚,希望能帮助到大家,大家参考下。
示例代码:
public ActionResult projectPrint() {
String[] printValue = null;
// 从页面中获得要查询的字段
String reqPrintValue = getRequest().getParameter("printValue");
// 没有选择则默认全打印
if (null == reqPrintValue || StringUtils.isEmpty(reqPrintValue)) {
printValue = new String[] { "pnumber", "pname", "pdepart", "pdecision", "pthrow", "plastmonth", "pfund", "ploan" };
} else {
printValue = reqPrintValue.split(",");
}
// 查询统计数据
List projectList = getEntityManager().queryPrintProjectInfo(printValue);
// 将数据转换为Map对象,换化成Map对象
List reportDataList = new ArrayList();
for (int i = 0; i < projectList.size(); i++) {
Object[] personStr = projectList.get(i);
Map reportData = new HashMap();
for (int j = 0; j < personStr.length; j++) {
reportData.put("field_" + j, String.valueOf(personStr[j]));
}
reportDataList.add(reportData);
}
int columCount = 0;// 数据列
int fieldCount = 0;// 字段列数(因为pname比较长所以想让pname比其它的列长些,故设计这个变量)
int pnameCount = -1;// 记录下pname的序号
for (int i = 0; i < printValue.length; i++) {
// pthrow下面有两列
if ("pthrow".equals(printValue[i])) {
columCount = columCount + 2;
fieldCount = fieldCount + 2;
// ploan下面也有两列
} else if ("ploan".equals(printValue[i])) {
columCount = columCount + 2;
fieldCount = fieldCount + 2;
// 故意让pname也占两列
} else if ("pname".equals(printValue[i])) {
pnameCount = i;// 记录下pname的序号
columCount = columCount + 1;
fieldCount = fieldCount + 2;
} else {
// 其它的列都占一个单位
columCount = columCount + 1;
fieldCount = fieldCount + 1;
}
}
InputStream is = null;
try {
// 从资源文件中读取报表
is = this.getClass().getResourceAsStream("/reports/project.jrxml");
JasperDesign jasperDesign = (JasperDesign) JRXmlLoader.load(is);
Map styleMap = jasperDesign.getStylesMap();
// column header 对应的样式
JRDesignStyle theaderStyle = (JRDesignStyle) styleMap.get("theader");
// column detail 对应的样式
JRDesignStyle tbodyStyle = (JRDesignStyle) styleMap.get("tboby");
// pagefoot 对应的样式
JRDesignStyle tfootStyle = (JRDesignStyle) styleMap.get("tfoot");
int _START_X_ = 20;// x轴的起始位置
int startX = _START_X_; // x轴的起始位置
// 单列的宽度
// 535是jasepreReport报表column最大的宽度
int columnWidth = 535 / fieldCount;
// 20,24,15是报表中已设置的,一定与之相同
final int columnHeadBandHeight = 20;
final int detailHeight = 24;
final int pagefootHeight = 15;
// 设置报表字段
for (int idx = 0; idx < columCount; idx++) {
JRDesignField field = new JRDesignField();
field.setName("field_" + idx);
field.setValueClass(java.lang.String.class);
jasperDesign.addField(field);
}
JRDesignBand columnHeadBand = (JRDesignBand) jasperDesign.getColumnHeader();
// 绘制表头
for (int idx = 0; idx < printValue.length; idx++) {
if ("pnumber".equals(printValue[idx])) {
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
staticText.setWidth(columnWidth);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(2 * columnHeadBandHeight);
staticText.setText("序号");
columnHeadBand.addElement(staticText);
startX += columnWidth;
} else if ("pname".equals(printValue[idx])) {
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
// 项目名称的宽度是其它的宽度的2倍
staticText.setWidth(columnWidth * 2);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(2 * columnHeadBandHeight);
staticText.setText("项目名称");
columnHeadBand.addElement(staticText);
startX += columnWidth * 2;
} else if ("pdepart".equals(printValue[idx])) {
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
staticText.setWidth(columnWidth);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(2 * columnHeadBandHeight);
staticText.setText("部门");
columnHeadBand.addElement(staticText);
startX += columnWidth;
} else if ("pdecision".equals(printValue[idx])) {
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
staticText.setWidth(columnWidth);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(2 * columnHeadBandHeight);
staticText.setText("已决策");
columnHeadBand.addElement(staticText);
startX += columnWidth;
} else if ("pthrow".equals(printValue[idx])) {
// 投审会下面有两列
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
staticText.setWidth(columnWidth * 2);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("投审会");
columnHeadBand.addElement(staticText);
staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
columnHeadBand.addElement(staticText);
staticText.setWidth(columnWidth);
staticText.setY(columnHeadBandHeight);
staticText.setX(startX);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("12月初");
staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
columnHeadBand.addElement(staticText);
staticText.setWidth(columnWidth);
staticText.setY(columnHeadBandHeight);
staticText.setX(startX + columnWidth);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("12月中");
columnHeadBand.addElement(staticText);
startX += 2 * columnWidth;
} else if ("plastmonth".equals(printValue[idx])) {
// 投决会下面有一列
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
staticText.setWidth(columnWidth);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("投决会");
columnHeadBand.addElement(staticText);
staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
columnHeadBand.addElement(staticText);
staticText.setWidth(columnWidth);
staticText.setY(columnHeadBandHeight);
staticText.setX(startX);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("12月下");
columnHeadBand.addElement(staticText);
startX += columnWidth;
} else if ("pfund".equals(printValue[idx])) {
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
staticText.setWidth(columnWidth);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(2 * columnHeadBandHeight);
staticText.setText("基金投资额");
columnHeadBand.addElement(staticText);
startX += columnWidth;
} else if ("ploan".equals(printValue[idx])) {
// 投贷协同额下面有两列
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
staticText.setWidth(columnWidth * 2);
staticText.setY(0);
staticText.setX(startX);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("投贷协同额");
columnHeadBand.addElement(staticText);
staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
columnHeadBand.addElement(staticText);
staticText.setWidth(columnWidth);
staticText.setY(columnHeadBandHeight);
staticText.setX(startX);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("金额");
staticText = new JRDesignStaticText();
staticText.setStyle(theaderStyle);
columnHeadBand.addElement(staticText);
staticText.setWidth(columnWidth);
staticText.setY(columnHeadBandHeight);
staticText.setX(startX + columnWidth);
staticText.setHeight(columnHeadBandHeight);
staticText.setText("入库情况");
columnHeadBand.addElement(staticText);
startX += 2 * columnWidth;
}
}
// 绘制Detail部门
startX = _START_X_;
JRDesignBand columnDetailBand = (JRDesignBand) jasperDesign.getDetail();
for (int idx = 0; idx < columCount; idx++) {
JRDesignTextField textField = new JRDesignTextField();
textField.setStretchWithOverflow(true);
textField.setX(startX);
textField.setY(0);
if (pnameCount == idx) {
textField.setWidth(2 * columnWidth);
startX += 2 * columnWidth;
} else {
textField.setWidth(columnWidth);
startX += columnWidth;
}
textField.setHeight(detailHeight);
textField.setPositionType(JRElement.POSITION_TYPE_FLOAT);
textField.setStyle(tbodyStyle);
textField.setBlankWhenNull(true);
JRDesignExpression expression = new JRDesignExpression();
expression.setValueClass(java.lang.String.class);
expression.setText("$F{field_" + idx + "}");
textField.setExpression(expression);
columnDetailBand.addElement(textField);
}
JRDesignBand pageFootBand = (JRDesignBand) jasperDesign.getPageFooter();
// 合计数据,本应统计的
List pageCountList = new ArrayList();
Object[] obj = new String[] { "合计", "15299", "", "", "67121", "92420", "155877", };
pageCountList.add(obj);
obj = new String[] { "", "", "", "XXX小计", "", "24473", "16470", };
pageCountList.add(obj);
obj = new String[] { "", "", "", "WWW小计", "", "7289", "1674", };
pageCountList.add(obj);
obj = new String[] { "", "", "", "ZZZ小计", "", "32700", "13000", };
pageCountList.add(obj);
obj = new String[] { "", "", "", "YYY小计", "", "12733", "120733", };
pageCountList.add(obj);
obj = new String[] { "", "", "", "AAA小计", "", "2225", "120733", };
pageCountList.add(obj);
obj = new String[] { "", "", "", "BBB小计", "", "3000", "0", };
pageCountList.add(obj);
int footWidth = 535 / 7;
for (int p = 0; p < pageCountList.size(); p++) {
for (int k = 0; k < 7; k++) {
Object[] ob = pageCountList.get(p);
JRDesignStaticText staticText = new JRDesignStaticText();
staticText.setStyle(tfootStyle);
staticText.setWidth(footWidth);
staticText.setY(pagefootHeight * p);
staticText.setX(k * footWidth + _START_X_);
staticText.setHeight(pagefootHeight);
staticText.setText(String.valueOf(ob[k]));
pageFootBand.addElement(staticText);
}
}
// 编译报表
JasperReport jasperReport = JasperCompileManager.compileReport(jasperDesign);
String type = this.getRequest().getParameter("type");//pdf格式
JasperUtils.prepareReport(jasperReport, type);
// 报表数据源
JRDataSource dataSource = new JRBeanCollectionDataSource(reportDataList);
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, null, dataSource);
HttpServletResponse response = this.getResponse();
JasperUtils.export(jasperPrint, response, getRequest(), type);
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
public static void export(JasperPrint jasperPrint, HttpServletResponse response, HttpServletRequest request,
String type) throws IOException {
if (EXCEL_TYPE.equals(type)) {
exportExcel(jasperPrint, response, request);
} else if (PDF_TYPE.equals(type)) {
exportPDF(jasperPrint, response, request);
} else if (HTML_TYPE.equals(type)) {
exportHTML(jasperPrint, response, request);
} else {
exportPrint(jasperPrint, response, request);
}
}
public static void exportExcel(JasperPrint jasperPrint, HttpServletResponse response, HttpServletRequest request)
throws IOException {
response.setContentType("application/vnd.ms-excel");
String filename = DownloadHelper.encodeFilename("未命名.xls", request);
response.setHeader("Content-disposition", "attachment;filename=" + filename);
ServletOutputStream ouputStream = response.getOutputStream();
JRXlsExporter exporter = new JRXlsExporter();
exporter.setParameter(JRExporterParameter.JASPER_PRINT, jasperPrint);
exporter.setParameter(JRExporterParameter.OUTPUT_STREAM, ouputStream);
exporter.setParameter(JRXlsExporterParameter.IS_REMOVE_EMPTY_SPACE_BETWEEN_ROWS, Boolean.TRUE);
exporter.setParameter(JRXlsExporterParameter.IS_ONE_PAGE_PER_SHEET, Boolean.FALSE);
exporter.setParameter(JRXlsExporterParameter.IS_WHITE_PAGE_BACKGROUND, Boolean.FALSE);
try {
exporter.exportReport();
} catch (JRException e) {
e.printStackTrace();
}
ouputStream.flush();
ouputStream.close();
}
public static void exportPDF(JasperPrint jasperPrint, HttpServletResponse response, HttpServletRequest request)
throws IOException {
response.setContentType("application/pdf");
String filename = DownloadHelper.encodeFilename("未命名.pdf", request);
response.setHeader("Content-disposition", "attachment;filename=" + filename);
ServletOutputStream ouputStream = response.getOutputStream();
try {
JasperExportManager.exportReportToPdfStream(jasperPrint, ouputStream);
} catch (JRException e) {
e.printStackTrace();
}
ouputStream.flush();
ouputStream.close();
}
如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!