I'm generating a PDF using JasperReports from Java. I finally succeeded in making Jasper correctly paginate the report. The problem is that now I'm getting a blank page at the end of the report (the headers are printed, but the detail band is blank). The information passed for the detail band is all displayed, so there is no need for that page (what is more, there is an empty space at the end of the last page). I will attach the JXML at the end of the question, any help appreciated.
Thanks!
This is the content of the JXML file:
<?xml version="1.0" encoding="UTF-8"?>
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="tintoreria" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" isFloatColumnFooter="true">
<property name="ireport.zoom" value="1.0"/>
<property name="ireport.x" value="0"/>
<property name="ireport.y" value="288"/>
<parameter name="SUBREPORT_DIR" class="java.lang.String" isForPrompting="false">
<defaultValueExpression><![CDATA["C:\\work\\REPO-CTK\\lasastra-world\\core\\src\\main\\resources\\jasper\\tintoreria\\"]]></defaultValueExpression>
</parameter>
<parameter name="totalItems" class="java.lang.String"/>
<parameter name="nroPag" class="java.lang.String"/>
<parameter name="totalPag" class="java.lang.String"/>
<parameter name="supplier" class="java.lang.String"/>
<parameter name="creationDate" class="java.lang.String"/>
<parameter name="orderNumber" class="java.lang.String"/>
<parameter name="fechaPedido" class="java.lang.String"/>
<parameter name="datasourceParam" class="net.sf.jasperreports.engine.data.JRBeanCollectionDataSource"/>
<queryString>
<![CDATA[]]>
</queryString>
<pageHeader>
<band height="119" splitType="Stretch">
<rectangle radius="10">
<reportElement x="0" y="0" width="555" height="119" backcolor="#CCCCFF"/>
<graphicElement>
<pen lineWidth="1.75"/>
</graphicElement>
</rectangle>
<staticText>
<reportElement x="112" y="7" width="241" height="32"/>
<textElement>
<font size="24" isBold="true" isUnderline="true"/>
</textElement>
<text><![CDATA[Orden de compra]]></text>
</staticText>
<staticText>
<reportElement x="286" y="62" width="63" height="20"/>
<textElement>
<font size="12"/>
</textElement>
<text><![CDATA[Proveedor:]]></text>
</staticText>
<textField>
<reportElement x="355" y="62" width="189" height="20"/>
<textElement>
<font size="12"/>
</textElement>
<textFieldExpression><![CDATA[$P{supplier}]]></textFieldExpression>
</textField>
<staticText>
<reportElement x="281" y="42" width="72" height="20"/>
<textElement>
<font size="12"/>
</textElement>
<text><![CDATA[Orden Nro:]]></text>
</staticText>
<textField>
<reportElement x="355" y="42" width="189" height="20"/>
<textElement>
<font size="12"/>
</textElement>
<textFieldExpression><![CDATA[$P{orderNumber}]]></textFieldExpression>
</textField>
<staticText>
<reportElement x="268" y="83" width="85" height="20"/>
<textElement>
<font size="12"/>
</textElement>
<text><![CDATA[Fecha Pedido:]]></text>
</staticText>
<textField>
<reportElement x="355" y="83" width="189" height="20"/>
<textElement>
<font size="12"/>
</textElement>
<textFieldExpression><![CDATA[$P{creationDate}]]></textFieldExpression>
</textField>
</band>
</pageHeader>
<detail>
<band height="633" splitType="Stretch">
<subreport runToBottom="false">
<reportElement positionType="Float" stretchType="RelativeToBandHeight" mode="Transparent" x="0" y="0" width="555" height="633" isRemoveLineWhenBlank="true" isPrintInFirstWholeBand="true"/>
<dataSourceExpression><![CDATA[$P{datasourceParam}]]></dataSourceExpression>
<subreportExpression><![CDATA["purchaseorder_subreport1.jasper"]]></subreportExpression>
</subreport>
</band>
</detail>
<pageFooter>
<band height="50" splitType="Stretch">
<rectangle radius="10">
<reportElement positionType="Float" x="0" y="0" width="555" height="50" backcolor="#CCCCFF"/>
<graphicElement>
<pen lineWidth="1.75"/>
</graphicElement>
</rectangle>
<textField>
<reportElement positionType="Float" x="22" y="15" width="239" height="20"/>
<textElement>
<font size="13"/>
</textElement>
<textFieldExpression><![CDATA["Cantidad de items: " + $P{totalItems}]]></textFieldExpression>
</textField>
<textField>
<reportElement x="331" y="25" width="159" height="20"/>
<textElement textAlignment="Right"/>
<textFieldExpression><![CDATA["Pagina "+$V{PAGE_NUMBER}+" de "]]></textFieldExpression>
</textField>
<textField evaluationTime="Report">
<reportElement x="490" y="25" width="40" height="20"/>
<textElement/>
<textFieldExpression><![CDATA[" " + $V{PAGE_NUMBER}]]></textFieldExpression>
</textField>
</band>
</pageFooter>
</jasperReport>
And this is the subreport:
<?xml version="1.0" encoding="UTF-8"?>
<jasperReport xmlns="http://jasperreports.sourceforge.net/jasperreports" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://jasperreports.sourceforge.net/jasperreports http://jasperreports.sourceforge.net/xsd/jasperreport.xsd" name="tintoreria_subreport1" pageWidth="540" pageHeight="600" whenNoDataType="NoDataSection" columnWidth="540" leftMargin="0" rightMargin="0" topMargin="0" bottomMargin="0" isFloatColumnFooter="true" whenResourceMissingType="Empty">
<property name="ireport.zoom" value="1.5394743546921208"/>
<property name="ireport.x" value="131"/>
<property name="ireport.y" value="0"/>
<queryString>
<![CDATA[]]>
</queryString>
<field name="itemNumber" class="java.lang.String"/>
<field name="description" class="java.lang.String"/>
<field name="amount" class="java.lang.String"/>
<columnHeader>
<band height="22" splitType="Stretch">
<staticText>
<reportElement x="1" y="1" width="68" height="20"/>
<textElement>
<font size="12" isBold="true"/>
</textElement>
<text><![CDATA[Item]]></text>
</staticText>
<staticText>
<reportElement x="76" y="1" width="373" height="20"/>
<textElement>
<font size="12" isBold="true"/>
</textElement>
<text><![CDATA[ DescripciĆ³n]]></text>
</staticText>
<line>
<reportElement x="69" y="1" width="1" height="21"/>
</line>
<line>
<reportElement x="0" y="21" width="540" height="1"/>
</line>
<line>
<reportElement x="448" y="0" width="1" height="21"/>
</line>
<staticText>
<reportElement x="453" y="1" width="68" height="20"/>
<textElement>
<font size="12" isBold="true"/>
</textElement>
<text><![CDATA[Cantidad]]></text>
</staticText>
</band>
</columnHeader>
<detail>
<band height="13" splitType="Stretch">
<textField>
<reportElement x="1" y="0" width="68" height="12"/>
<textElement>
<font size="9"/>
</textElement>
<textFieldExpression><![CDATA[$F{itemNumber}]]></textFieldExpression>
</textField>
<textField>
<reportElement x="77" y="0" width="371" height="12"/>
<textElement>
<font size="9"/>
</textElement>
<textFieldExpression><![CDATA[$F{description}]]></textFieldExpression>
</textField>
<line>
<reportElement x="69" y="0" width="1" height="13"/>
</line>
<line>
<reportElement x="448" y="0" width="1" height="13"/>
</line>
<textField>
<reportElement x="453" y="1" width="75" height="12"/>
<textElement>
<font size="9"/>
</textElement>
<textFieldExpression><![CDATA[$F{amount}]]></textFieldExpression>
</textField>
</band>
</detail>
</jasperReport>
Best Answer
You should manually hide the bands after
Detail
.For example try hiding the
Summary
band by setting it'sPrint When Expression
toBoolean.FALSE
Note: not sure about the exact XML context, since I usually do it in iReport.