positionType="Float"
会自行拉低。但如果上述组件缩小/不显示,则不会向上移动。
下面是使用的版本:
<dependency>
<groupId>net.sf.jasperreports</groupId>
<artifactId>jasperreports-fonts</artifactId>
<version>6.0.0</version>
</dependency>
将重现上述问题的代码:
<?xml version="1.0" encoding="UTF-8"?>
<!-- Created with Jaspersoft Studio version 6.6.0.final using JasperReports Library version 6.6.0 -->
<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="sample" pageWidth="595" pageHeight="842" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="acaa0a15-dc0f-462c-8d16-14f0b7325696">
<property name="com.jaspersoft.studio.data.defaultdataadapter" value="One Empty Record"/>
<summary>
<band height="500" splitType="Prevent">
<staticText>
<reportElement positionType="Float" x="0" y="19" width="381" height="41" isRemoveLineWhenBlank="true" uuid="9547d877-993c-4bb4-becc-cf70a0cc1bc2">
<printWhenExpression><![CDATA[false]]></printWhenExpression>
</reportElement>
<text><![CDATA[Text11111111111111111111]]></text>
</staticText>
<staticText>
<reportElement positionType="Float" x="0" y="150" width="381" height="41" isRemoveLineWhenBlank="true" uuid="9e7dbe2e-2fed-41c8-82ce-c0c6886c8eda">
<printWhenExpression><![CDATA[true]]></printWhenExpression>
</reportElement>
<text><![CDATA[Text22222222222222222222]]></text>
</staticText>
</band>
</summary>
</jasperReport>
以上代码仅显示第二个静态文本组件,而不显示第一个。因为第一个中的printWhenExpression
是false
。
现在,我希望第二个组件代替第一个组件显示,但不显示。结果,我在那里得到了空间。
如何删除空白?
答案 0 :(得分:1)
从JasperReports documentation强调我的观点
positionType =“ Float”-如果元素被其上方的其他元素向下推动,则该元素将在其父部分中浮动。它会尝试保留与位于其上方的相邻元素之间的距离。
第二个reportElement不会向上移动到第一个reportElement所在的位置,因为它保留了它们之间的距离。下图所示距离:
如果您希望reportElement 2取代reportElement 1,那么您的解决方案是删除此空间!
删除空间,但保留第二个reportElement的位置(如果存在)。增加reportElement 1的高度。
通过将reportElement 2向上移动来移除空间,如果它是textField(动态文本),则在reportElement 1溢出时,可以在reportElement 1上使用isStretchWithOverflow="true"
来将reportElement 2向下推。