jasperreport初级教程:[5]编译报表设计
jasperreport初级教程:[5]编译报表设计
工具/原料
jasperreport报表
方法/步骤
我们在前面的章节中产生的JasperReport模板(JRXML文件)。这个文件不能直接用于生成报告。它必须被编译成JasperReport的“本地二进制"格式,称为Jasperfile。在编制我们把JasperDesign对象转换成JasperReport的对象:
![jasperreport初级教程:[5]编译报表设计](https://exp-picture.cdn.bcebos.com/f385f299594304017d0242f6d66b04d148290550.jpg)
接口net.sf.jasperreports.engine.design.JRCompiler编译过程中起着核心的一部分。这个接口有根据用于报表表达式语言,它可以只要编译器可以实现在运行时计算它被用Java编写的,Groovy,JavaScript的或任何其他脚本语言的几个实现。我们可以通过以下两种方式编译JRXML文件:
1. 提供编程编译。
2. 编译通过ANT任务。
JRXML提供编程编译
JasperReports的API提供了一个门面类net.sf.jasperreports.engine.JasperCompileManager用于编译JasperReport。这个类包含几个公共静态方法编制的报告模板。模板的源可以从文件,输入流,内存中的对象。
该jrxml文件(jasper_report_template.jrxml)的内容如下。它被保存在目
![jasperreport初级教程:[5]编译报表设计](https://exp-picture.cdn.bcebos.com/5c2a1ad149299a8802efb45167eeadbcbf2f7f50.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>
预览编译报表模板
net.sf.jasperreports.view.JasperDesignViewer 正如在前面的章节中讨论可用来预览编译报告模板以及JRXML模板。
为了进一步推动,让我们添加一个新的目标viewDesign上述build.xml文件,这将让我们先看盾编译报告。下面是修改后build.xml:导入文件 - baseBuild.xml做好环境设置,并应放置在同一目录中的build.xml。
<?xml version="1.0" encoding="UTF-8"?>
<project name="JasperReportTest" default="viewDesign" basedir=".">
<import file="baseBuild.xml" />
<target name="viewDesign" description="Design viewer is launched
to preview the compiled report design.">
<java classname="net.sf.jasperreports.view.JasperDesignViewer"
fork="true">
<arg value="-F${file.name}.jasper" />
<classpath refid="classpath" />
</java>
</target>
</project>
让我们执行命令:ant(viewDesign是默认的目标),在命令提示符下。 JasperDesignViewer窗口打开显示Jasper文件如下:
![jasperreport初级教程:[5]编译报表设计](https://exp-picture.cdn.bcebos.com/bf6e59704618dfdaa7c7673289214f5792567750.jpg)
同为比较常用的报表工具,FineReport在报表实现过程中所需的代码量远少于jasperreport,大部分的报表代码细节被隐藏,呈现出的是可视化的设计过程,在FineReport中,报表的设计完成之后不需要经过编译步骤即可看到报表,以自由报表的设计为例,示例如下:
自由报表—自定义父子格
. 概述
内置的数据库中有一张雇员表,他有很多字段,这些字段都要显示在报表中,如果把它显示在报表的一行上,看起来会很拥挤,如果报表中要显示图片字段,把图片和非图片字段都显示在报表的同一行上,会严重的影响报表的美观,这个时候就可以做成自由格式的报表。如下面的订单统计自由报表:
![jasperreport初级教程:[5]编译报表设计](https://exp-picture.cdn.bcebos.com/52fae62064fb960b7ddd59d58fa355e982ae6c50.jpg)
2. 制作步骤
2.1 新建工作簿,添加数据集
新建工作薄,添加数据集ds1,SQL语句为SELECT * FROM [订单]。
2.2 表样设计
自由格式报表相当随意,按照需要的样式在对应单元格中拖入数据列即可,如下图所示:
![jasperreport初级教程:[5]编译报表设计](https://exp-picture.cdn.bcebos.com/e996472ae3efe07841cd8302b96c576698cf6550.jpg)
.3 父格设置
由于数据列不在同一行上,因此不会自动形成父子关系,我们希望客户ID、订购日期等数据列能附属于订单ID而扩展,同时报表标题及数据列标题也会跟随订单ID的扩展而复制。
将B1、B2至B6单元格,父格设为订单ID单元格。
同样,C3至C6单元格,也设置父格为订单ID单元格。预览即上图效果。
注:根据父子格原理,D3至E6可以不另设父格,因为他们会自动将C3至C6单元格为左父格。
2.4 保存报表并发布