如何使用 JavaBeans 集合数据集填充图表数据?

How to populate chart data with JavaBeans collection dataSet?

我已经创建了一个工作 jrxml 报告,其中显示了一个 table 由 Java bean 的集合 (List) 的数据集填充的数据集。

现在我想使用相同的数据集来创建图表(初学者的基本条形图)。每个 bean 包含 4 个值,我想在条形图上显示它们:月份、正常时间、旅行时间和加班时间。我希望每个 bean 每个月都会生成一组 3 条形图,所以最终图表将包含从下到上增长的 12x3 条形图,月份的名称将作为 3 条形图组下的标签,每个组从左到右依次排列。

不幸的是,创建此图表似乎比我想象的要难得多。至少与创建 table 相比,它似乎是完全不同的。我不确定 Jasper Studio 的图表向导是否正常工作。至少它不允许我在图表数据系列对话框中添加任何系列:如果我按添加绝对没有任何反应 - 没有打开对话框,没有错误消息,什么都没有,没有任何提示我出了什么问题。

主要问题是我没有找到将数据集数据连接到图表的方法。

在尝试将图表嵌入到我的主报表中之后,我尝试将它也添加到一个新的子报表中,该子报表仅为用作图表容器而创建。我将主报表数据集作为数据源传递给子报表,并尝试将其用作子报表图表中的主数据集。 dataset/chart 连接仍然不走运,f.e。如果我按下添加按钮,仍然没有任何反应。

您可以在下面看到我正在使用的简单 bean。第一个,WorkingHoursReport 是我传递来报告为 JRBeanCollectionDataSource 的 bean。我相信该 bean 最有趣的字段是 WorkingHours-beans 列表。该列表中始终有 12 项:每个月一项。这是我目前使用数据源表达式传递给我的 table 元素的列表:new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($F{workingHours})。

WorkingHoursReport.java:

public class WorkingHoursReport extends CommonReport {
    private int year;
    private List<WorkingHours> workingHours;
}

WorkingHours.java:

public class WorkingHours {

    private int month = 0;
    private double hoursNormal = 0;
    private double hoursTravel = 0;
    private double hoursOvertime = 0;
    private double hoursTotal = 0;
    private double hoursTotalCumulative = 0;
 }

在尝试创建我的第一个图表时,我很自然地尝试使用与我已经在我的 table 中成功使用的定义数据源完全相同的命令将数据填充到图表:

new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($F{workingHours}).

不幸的是,至少 jasper studio 图表创建向导似乎没有与数据建立任何连接(没有打开对话框,根据文档,我应该能够 select 数据字段图表 ).

考虑到您使用的是 java bean,需要汇总数据然后同时拥有系列(小时)和类别(月),这就是我解决您的问题的方法。不要将它连接到您的 table 数据源,而是为其创建一个特定的数据源。

创建特定图表 bean

public class ChartData {
    private String serie;
    private String category;
    private double value;

    public ChartData(String serie, String category, double value) {
        super();
        this.serie = serie;
        this.category = category;
        this.value = value;
    }
    .... getter and setters         
}

用数据填充图表 bean

循环您的数据集(列表)并填充 ChartData 列表,您可能需要一张地图来查找同一个月并添加到小时数。我不会向您展示这个,而是静态创建它们以展示示例

List<ChartData> cList = new ArrayList<ChartData>();
cList.add(new ChartData("hoursNormal","month1", 12.3)); //The use of resources or static text is beyond this example
cList.add(new ChartData("hoursTravel","month1", 3.2));
cList.add(new ChartData("hoursOvertime","month1", 1.3));
cList.add(new ChartData("hoursNormal","month2", 16.4));
cList.add(new ChartData("hoursTravel","month2", 5.2));
cList.add(new ChartData("hoursOvertime","month2", 4.1));

通过参数map将List作为数据源传递

Map<String, Object> paramMap = new HashMap<String, Object>();
paramMap.put("CHART_DATASET", new JRBeanCollectionDataSource(cList));

显示图表

现在我们可以使用传递给参数 $P{CHART_DATASET}

subDatasettitlesummary 波段中显示图表
<?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="working_hours" pageWidth="595" pageHeight="842" whenNoDataType="AllSectionsNoDetail" columnWidth="555" leftMargin="20" rightMargin="20" topMargin="20" bottomMargin="20" uuid="1a12c021-57e2-4482-a273-56cbd3f78a17">
    <subDataset name="chartDataSet" uuid="119b7f0e-01ef-4e2b-b628-d76f51e83768">
        <field name="serie" class="java.lang.String"/>
        <field name="category" class="java.lang.String"/>
        <field name="value" class="java.lang.Double"/>
    </subDataset>
    <parameter name="CHART_DATASET" class="net.sf.jasperreports.engine.data.JRBeanCollectionDataSource" isForPrompting="false"/>
    <summary>
        <band height="142" splitType="Stretch">
            <barChart>
                <chart>
                    <reportElement x="80" y="0" width="337" height="142" uuid="c8f4dc5d-47e7-489b-b27e-09976d90994a"/>
                    <chartTitle/>
                    <chartSubtitle/>
                    <chartLegend/>
                </chart>
                <categoryDataset>
                    <dataset>
                        <datasetRun subDataset="chartDataSet" uuid="abec2dce-b670-4e84-b71f-469d954dbcb5">
                            <dataSourceExpression><![CDATA[$P{CHART_DATASET}]]></dataSourceExpression>
                        </datasetRun>
                    </dataset>
                    <categorySeries>
                        <seriesExpression><![CDATA[$F{serie}]]></seriesExpression>
                        <categoryExpression><![CDATA[$F{category}]]></categoryExpression>
                        <valueExpression><![CDATA[$F{value}]]></valueExpression>
                    </categorySeries>
                </categoryDataset>
                <barPlot>
                    <plot/>
                    <itemLabel/>
                    <categoryAxisFormat>
                        <axisFormat/>
                    </categoryAxisFormat>
                    <valueAxisFormat>
                        <axisFormat/>
                    </valueAxisFormat>
                </barPlot>
            </barChart>
        </band>
    </summary>
</jasperReport>

JasperSoft Studio 中的设置

享受结果