DynamicJasper: как убрать строку, если она пуста - PullRequest
3 голосов
/ 26 июня 2010

Я создаю отчет с DynamicJasper, я хочу удалить строку отчета, когда строка пуста. Я знаю, как это сделать в JasperReports.

Но кто-нибудь может мне подсказать, как убрать пустую строку через DynamicJasper с помощью кода Java.

1 Ответ

3 голосов
/ 08 февраля 2012

Я не нашел простого способа решения этой проблемы с помощью DynamicJasper API.

Но это можно решить с помощью DJ.

Это исходный код основного класса для построения отчета.

public class BasicReportTest {

    private JasperPrint m_jasperPrint;
    private JasperReport m_jasperReport;
    private Map m_params = new HashMap();
    private DynamicReport m_dynamicReport;

    public DynamicReport buildReport() throws Exception {
        Style detailStyle = new Style();
        detailStyle.setBorder(Border.THIN);
        detailStyle.setBlankWhenNull(true);

        Style headerStyle = new Style();
        headerStyle.setFont(Font.COURIER_NEW_BIG_BOLD);
        headerStyle.setBorder(Border.THIN);
        headerStyle.setHorizontalAlign(HorizontalAlign.CENTER);
        headerStyle.setVerticalAlign(VerticalAlign.MIDDLE);
        headerStyle.setFont(Font.ARIAL_BIG);

        FastReportBuilder drb = new FastReportBuilder();
        drb.addColumn("State", "state", String.class.getName(), 30, detailStyle, headerStyle)
                .addColumn("Branch", "branch", String.class.getName(), 30, detailStyle, headerStyle)
                .addColumn("Item", "item", String.class.getName(), 50, detailStyle, headerStyle)
                .addColumn("Amount", "amount", Float.class.getName(), 60, detailStyle, headerStyle)
                .setTitle("The report with empty rows")
                .setUseFullPageWidth(true);

        DynamicReport dr = drb.build();
        return dr;
    }

    public void testReport() throws Exception {
        m_dynamicReport = buildReport();

        JRDataSource dataSource = getDataSource();

        m_jasperReport = DynamicJasperHelper.generateJasperReport(m_dynamicReport, 
                getLayoutManager(), m_params);

        m_jasperPrint = JasperFillManager.fillReport(m_jasperReport, m_params, dataSource);

        exportReport();
    }

    protected LayoutManager getLayoutManager() {
        return new CustomLayoutManager();
    }

    /*... Some code ... */

    public static void main(String[] args) throws Exception {
        BasicReportTest test = new BasicReportTest();
        test.testReport();
    }
}

Эта строка кода detailStyle.setBlankWhenNull(true); дает нам возможность показать значение null пустым в textField.Это как если бы мы использовали выражение

<textField isBlankWhenNull="true">

в jrxml файле.

Но нам также нужно «сгенерировать» xml-код следующим образом:

<textField isBlankWhenNull="true">
    <reportElement ... isRemoveLineWhenBlank="true"/>

Как я уже упоминал выше, DJ не содержит никакого открытого метода (оболочки) для вызова JRElement.setRemoveLineWhenBlank (boolean isRemoveLineWhenBlank) метода.

Вот почему я использовал настроенный класс LayoutManager - в моем примере это класс CustomLayoutManager.

Вот его исходный код:

public class CustomLayoutManager extends ClassicLayoutManager {

    @Override
    protected void transformDetailBandTextField(AbstractColumn column, JRDesignTextField textField) {
        super.transformDetailBandTextField(column, textField);
        if (column.getStyle().isBlankWhenNull()) {
            textField.setRemoveLineWhenBlank(true);
        }
    }
}

Я переопределил метод transformDetailBandTextField, который движок DJ использует для построения диапазона Detail.

...