当上述组件未在jasper中显示时,如何使用positionType将组件上拉?

时间:2018-08-27 03:27:11

标签: jasper-reports

如果上述组件拉伸,则组件上的

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>

以上代码仅显示第二个静态文本组件,而不显示第一个。因为第一个中的printWhenExpressionfalse

现在,我希望第二个组件代替第一个组件显示,但不显示。结果,我在那里得到了空间。

如何删除空白?

1 个答案:

答案 0 :(得分:1)

JasperReports documentation强调我的观点

  

positionType =“ Float”-如果元素被其上方的其他元素向下推动,则该元素将在其父部分中浮动。它会尝试保留与位于其上方的相邻元素之间的距离

第二个reportElement不会向上移动到第一个reportElement所在的位置,因为它保留了它们之间的距离。下图所示距离:

Empty space

如果您希望reportElement 2取代reportElement 1,那么您的解决方案是删除此空间!

解决方案A

删除空间,但保留第二个reportElement的位置(如果存在)。增加reportElement 1的高度。

Increase height

解决方案B

通过将reportElement 2向上移动来移除空间,如果它是textField(动态文本),则在reportElement 1溢出时,可以在reportElement 1上使用isStretchWithOverflow="true"来将reportElement 2向下推。

Move up