通过iReport可以方便的设计Jasperreport报表,其中的子报表功能给报表设计带来很大的便利,不过iReport的Guide中对subreport的设计描述并不详尽,通过摸索后做了一些总结。
一、在主报表中关于子报表元素的设计属性
下面两图为子报表(subreport)的属性Dialog
[img]http://dl.iteye.com/upload/picture/pic/71754/b51762cf-aaa7-3c9b-9c3b-83e69ae1b1a7.jpg[/img]
[img]http://dl.iteye.com/upload/picture/pic/71758/bd6b2447-336e-330d-a390-0021297db26a.jpg[/img]
a) Parameters Map Expression表示子报表的参数引入从主报表的参数“paramsub2”中获得,“paramsub2”的类型为“java.util.Map”;
b) Connection DataSource Expression表示子报表的数据源从何获得,我的子报表数据源从主报表的参数“datasetsub2”中获得,“datasetsub2”的属性为“net.sf.jasperreports.engine.data.JRBeanCollectionDataSource”;
c)“Subreport Expression”是很重要的设置项,可以采用字符串类型表示子报表的路径,来引导主报表加载子报表的jasper文件,我还是喜欢直接从主报表的参数中获得子报表的jasper对象。如上图设置。
二、子报表中的设置项
[img]http://dl.iteye.com/upload/picture/pic/71756/1b49134f-980d-3dbb-b172-99187f3dcfac.jpg[/img]
子报表中的参数设置和变量设置和设计单独的报表无异,不同处只在于加载时通过主报表加载,即先将报表参数传给主报表(如上图的“paramsub2”),然后由主报表传给子报表。
有一点要注意,在报表设置中,“如果没有数据时”选项中,如果设置为NoPages则在没有datasource传入时,该子报表在主报表中不显示。
开始通常不注意该参数,但在调试中使用空数据时没有看到子报表输出,一直不明原因,导致走了弯路。
注意:在报表中用到的参数、字段、变量都要在菜单栏“查看--字段/变量/参数”中对应设置,以及字段、变量的类型要和javabean中传入的类型匹配,
如图:
[img]http://dl.iteye.com/upload/picture/pic/71760/55908939-4155-3721-9ec2-0104313e39ac.jpg[/img]
[img]http://dl.iteye.com/upload/picture/pic/71764/a0d3babd-a97c-38ab-8ced-26609c9bff60.jpg[/img]
三、代码
JasperReport jasperReport = (JasperReport) JRLoader.loadObject(reportFile.getPath()); //主报表
JasperReport sub0jasperRep = (JasperReport) JRLoader.loadObject(subreport0File.getPath()); //子报表;
Map m = new HashMap(); //主报表的参数;
Map submap = new HashMap(); //子报表的参数;
m.put("sub2",sub0jasperRep); //将子报表的jasper传入主报表的参数"sub2";
//将子报表的datasource传给主报表的参数"datasetsub2";
m.put("datasetsub2",new JRBeanCollectionDataSource(sub2datasource));
//将子报表的参数表submap通过主报表的参数"paramsub2"传入;
m.put("paramsub2",submap);
//主报表装载参数和数据源;
JasperPrint jasperPrint = JasperFillManager.fillReport(jasperReport, m, new JRBeanCollectionDataSource(dataset));
如此基本完成子报表和主报表的载入。 |
|