it-swarm.com.ru

Отчеты Jasper - выравнивание динамических текстовых полей и их меток по горизонтали

Я использую отчет Jasper 5.2, iReport 5.2 и экспортирую отчет в форматах RTF и PDF.

В своем отчете я хочу добавить несколько текстовых полей вместе с их (статическими текстовыми) метками, выровненными по горизонтали, как 

         Name:  $F{name}
          Age:  $F{age}
Date of Birth:  $F{dateOfBirth}

Но я не могу выровнять их. Это то что я пробовал

  • Тип позиции: float (для всего статического текста и полей)
  • Тип растяжения: без растяжения (для всего статического текста и полей)
  • Растянуть с переполнением: True (для всех динамических текстовых полей)

На рисунке показано, что я получаю и чего хочу .. Более того, содержимое моего текстового поля является динамическим, то есть размер содержимого может изменяться. enter image description here

Я прочитал много форумов, но не смог найти решение, пожалуйста, предложите.

Спасибо

17
Ali

Это легко сделать с помощью контейнера - элемента Frame.

Вы должны поместить Frame с Position Type как Float и поместить в них оба staticText (label) и textField.

Для textField я установил Position Type как Float Stretch With Overlfow как true .

Пример

Файл jrxml:

<?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="textfields_allign" language="groovy" pageWidth="595" pageHeight="842" whenNoDataType="AllSectionsNoDetail" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="d855bf18-5e9b-4060-8caa-3fdd08abce3b">
    <parameter name="name" class="Java.lang.String"/>
    <parameter name="id" class="Java.lang.String"/>
    <parameter name="date" class="Java.lang.String"/>
    <title>
        <band height="69" splitType="Stretch">
            <frame>
                <reportElement uuid="314bfd5b-7b0a-42f4-aca3-e61f0283f126" positionType="Float" x="213" y="1" width="243" height="20"/>
                <staticText>
                    <reportElement uuid="e07201bb-a677-4dc9-a332-f94e6eca2722" positionType="Float" x="0" y="0" width="100" height="20" isPrintWhenDetailOverflows="true"/>
                    <textElement/>
                    <text><![CDATA[Name]]></text>
                </staticText>
                <textField isStretchWithOverflow="true">
                    <reportElement uuid="66c93a44-9015-4ae9-bf05-b68b2420f3ef" positionType="Float" x="121" y="0" width="100" height="20" isPrintWhenDetailOverflows="true"/>
                    <textElement/>
                    <textFieldExpression><![CDATA[$P{name}]]></textFieldExpression>
                </textField>
            </frame>
            <frame>
                <reportElement uuid="8311a483-955e-4280-a9ac-513d7d34495b" positionType="Float" x="213" y="21" width="243" height="20"/>
                <staticText>
                    <reportElement uuid="da404b4e-7908-40ae-8e1b-38e19d9ddc7f" positionType="Float" x="0" y="0" width="100" height="20" isPrintWhenDetailOverflows="true"/>
                    <textElement/>
                    <text><![CDATA[ID]]></text>
                </staticText>
                <textField isStretchWithOverflow="true">
                    <reportElement uuid="e0e312e8-cd2f-48af-8ae8-df95c6195488" positionType="Float" x="121" y="0" width="100" height="20" isPrintWhenDetailOverflows="true"/>
                    <textElement/>
                    <textFieldExpression><![CDATA[$P{id}]]></textFieldExpression>
                </textField>
            </frame>
            <frame>
                <reportElement uuid="8ff2baf9-b0ec-4c8a-b54a-9edd08b200cc" positionType="Float" x="213" y="41" width="243" height="20"/>
                <staticText>
                    <reportElement uuid="b8d97db0-250a-43c8-a2f3-2fa3668c5d15" positionType="Float" x="0" y="0" width="100" height="20" isPrintWhenDetailOverflows="true"/>
                    <textElement/>
                    <text><![CDATA[Date]]></text>
                </staticText>
                <textField isStretchWithOverflow="true">
                    <reportElement uuid="4daa4d17-28be-4ac8-8e1e-2efbeec5f690" positionType="Float" x="121" y="0" width="100" height="20" isPrintWhenDetailOverflows="true"/>
                    <textElement/>
                    <textFieldExpression><![CDATA[$P{date}]]></textFieldExpression>
                </textField>
            </frame>
        </band>
    </title>
</jasperReport>

Дизайн отчета в iReport:

enter image description here

Результат будет (через предварительный просмотр iReport):

enter image description here

31
Alex K

Чтобы завершить решение Алекса К.: с помощью Jaspersoft Studio не забудьте установить для свойства статического текста «тип растяжения» значение «относительно самого высокого объекта».

3
user6236201

В Jasper Reports 3.6 и более поздних версиях (включая 5.2) есть возможность использовать несколько полос детализации. Вы можете поместить первые два блока Name и текст «Sally Admison ...» в первую группу. Ниже будет ваш Patient ID и "1234567890Blah ...", а ниже будет еще одна полоса подробностей с Date of Birth. Это даст вам результаты, которые вы хотите.

Не обращайтесь к моему посту здесь , так как это для более старой версии 3.5 Jasper Reports. Эта версия не позволяет вам использовать несколько групп, и мне пришлось жить с одной отдельной группой деталей. Это не так с 5.2. Вы можете повеселиться с несколькими деталями полос. Наслаждайтесь!

2
Rachcha

Просто увеличьте ширину вашей панели данных, чтобы разобраться с проблемами выравнивания.

0
user3449721