jasperreports中文学习入门教程:[5]报表设计
jasperreports中文学习入门教程:[5]编译报表设计
工具/原料
jasperreports报表
方法/步骤
我们在前面的章节中产生的JasperReport模板(JRXML文件)。这个文件不能直接用于生成报告。它必须被编译成JasperReport的“本地二进制"格式,称为Jasperfile。在编制我们把JasperDesign对象转换成JasperReport的对象:
![jasperreports中文学习入门教程:[5]报表设计](https://exp-picture.cdn.bcebos.com/025d87c0affce186eb1cf4c61f1fbee435daeb8b.jpg)
接口net.sf.jasperreports.engine.design.JRCompiler编译过程中起着核心的 一部分。这个接口有根据用于报表表达式语言,它可以只要编译器可以实现在 运行时计算它被用Java编写的,Groovy,JavaScript的或任何其他脚本语言的 几个实现。我们可以通过以下两种方式编译JRXML文件:
1. 提供编程编译。
2. 编译通过ANT任务。
JRXML提供编程编译
JasperReports的API提供了一个门面类 net.sf.jasperreports.engine.JasperCompileManager用于编译 JasperReport。这个类包含几个公共静态方法编制的报告模板。模板的源可以 从文件,输入流,内存中的对象。
![jasperreports中文学习入门教程:[5]报表设计](https://exp-picture.cdn.bcebos.com/bfa52adaf05e4a23af42a2a91dd818196020e28b.jpg)
<queryString>
<![CDATA[]]>
</queryString>
<field name="country" class="java.lang.String">
<fieldDescription><![CDATA[country]]></fieldDescription>
</field>
<field name="name" class="java.lang.String">
<fieldDescription><![CDATA[name]]></fieldDescription>
</field>
<columnHeader>
<band height="23">
<staticText>
<reportElement mode="Opaque" x="0" y="3" width="535"
height="15" backcolor="#70A9A9" />
<box>
<bottomPen lineWidth="1.0" lineColor="#CCCCCC" />
</box>
<textElement />
<text><![CDATA[]]> </text>
</staticText>
<staticText>
<reportElement x="414" y="3" width="121" height="15" />
<textElement textAlignment="Center"
verticalAlignment="Middle">
<font isBold="true" />
</textElement>
<text><![CDATA[Country]]></text>
</staticText>
<staticText>
<reportElement x="0" y="3" width="136" height="15" />
<textElement textAlignment="Center"
verticalAlignment="Middle">
<font isBold="true" />
</textElement>
<text><![CDATA[Name]]></text>
</staticText>
</band>
</columnHeader>
<detail>
<band height="16">
<staticText>
<reportElement mode="Opaque" x="0" y="0" width="535"
height="14" backcolor="#E5ECF9" />
<box>
<bottomPen lineWidth="0.25" lineColor="#CCCCCC" />
</box>
<textElement />
<text><![CDATA[]]> </text>
</staticText>
<textField>
<reportElement x="414" y="0" width="121" height="15" />
<textElement textAlignment="Center"
verticalAlignment="Middle">
<font size="9" />
</textElement>
<textFieldExpression class="java.lang.String">
<![CDATA[$F{country}]]>
</textFieldExpression>
</textField>
<textField>
<reportElement x="0" y="0" width="136" height="15" />
<textElement textAlignment="Center"
verticalAlignment="Middle" />
<textFieldExpression class="java.lang.String">
<![CDATA[$F{name}]]>
</textFieldExpression>
</textField>
同为比较常用的报表工具,FineReport在报表实现过程中所需的代码量远少于jasperreport,大部分的报表代码细节被隐藏,呈现出的是可视化的设计过程,在FineReport中,报表的设计完成之后不需要经过编译步骤即可看到报表,以自由报表的设计为例,示例如下:
1. 概述
内置的数据库中有一张雇员表,他有很多字段,这些字段都要显示在报表中,如果把它显示在报表的一行上,看起来会很拥挤,如果报表中要显示图片字段,把图片和非图片字段都显示在报表的同一行上,会严重的影响报表的美观,这个时候就可以做成自由格式的报表。如下面的订单统计自由报表:
![jasperreports中文学习入门教程:[5]报表设计](https://exp-picture.cdn.bcebos.com/19587f20a7cd0c6e26c15e07fed7997bbaf4dd8b.jpg)
可以看到,自由报表不像网格式报表或者分组报表那样规则,其特点是数据库表中的一条记录不是分布在一行上,而是散放在多行上,记录分块或者分页显示,以提高报表的可读性和美观性。
2. 制作步骤
2.1 新建工作簿,添加数据集
新建工作薄,添加数据集ds1,SQL语句为SELECT * FROM [订单]。
2.2 表样设计
自由格式报表相当随意,按照需要的样式在对应单元格中拖入数据列即可,如下图所示:
![jasperreports中文学习入门教程:[5]报表设计](https://exp-picture.cdn.bcebos.com/983aa5f4da5872da3a7a3dbb0056ad042f68d48b.jpg)
2.3 父格设置
由于数据列不在同一行上,因此不会自动形成父子关系,我们希望客户ID、订购日期等数据列能附属于订单ID而扩展,同时报表标题及数据列标题也会跟随订单ID的扩展而复制。
将B1、B2至B6单元格,父格设为订单ID单元格。
同样,C3至C6单元格,也设置父格为订单ID单元格。预览即上图效果。
注:根据父子格原理,D3至E6可以不另设父格,因为他们会自动将C3至C6单元格为左父格。
2.4 保存报表并发布