jasperreports中文学习入门教程:[5]报表设计

2025-11-25 19:52:44

jasperreports中文学习入门教程:[5]编译报表设计

工具/原料

jasperreports报表

方法/步骤

   我们在前面的章节中产生的JasperReport模板(JRXML文件)。这个文件不能直接用于生成报告。它必须被编译成JasperReport的“本地二进制"格式,称为Jasperfile。在编制我们把JasperDesign对象转换成JasperReport的对象:

jasperreports中文学习入门教程:[5]报表设计

  接口net.sf.jasperreports.engine.design.JRCompiler编译过程中起着核心的  一部分。这个接口有根据用于报表表达式语言,它可以只要编译器可以实现在  运行时计算它被用Java编写的,Groovy,JavaScript的或任何其他脚本语言的  几个实现。我们可以通过以下两种方式编译JRXML文件:

  1. 提供编程编译。

  2. 编译通过ANT任务。

   JRXML提供编程编译

  JasperReports的API提供了一个门面类      net.sf.jasperreports.engine.JasperCompileManager用于编译    JasperReport。这个类包含几个公共静态方法编制的报告模板。模板的源可以   从文件,输入流,内存中的对象。

jasperreports中文学习入门教程:[5]报表设计

   <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]报表设计

可以看到,自由报表不像网格式报表或者分组报表那样规则,其特点是数据库表中的一条记录不是分布在一行上,而是散放在多行上,记录分块或者分页显示,以提高报表的可读性和美观性。

2. 制作步骤

2.1 新建工作簿,添加数据集

新建工作薄,添加数据集ds1,SQL语句为SELECT * FROM [订单]。

2.2 表样设计

自由格式报表相当随意,按照需要的样式在对应单元格中拖入数据列即可,如下图所示:

jasperreports中文学习入门教程:[5]报表设计

2.3 父格设置

由于数据列不在同一行上,因此不会自动形成父子关系,我们希望客户ID、订购日期等数据列能附属于订单ID而扩展,同时报表标题及数据列标题也会跟随订单ID的扩展而复制。

将B1、B2至B6单元格,父格设为订单ID单元格。

同样,C3至C6单元格,也设置父格为订单ID单元格。预览即上图效果。

注:根据父子格原理,D3至E6可以不另设父格,因为他们会自动将C3至C6单元格为左父格。

2.4 保存报表并发布



声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢