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

时间:2016-03-04 15:49:13

标签: charts jasper-reports jaspersoft-studio

我已经创建了一个有效的jrxml报告,该报告显示了一个由Java bean集合(List)的数据集填充的表。

现在我想使用相同的数据集来创建Chart(初学者的基本条形图)。每个bean包含4个值,我想在条形图上显示:月份,正常时间,旅行时间和加班时间。我希望每个豆子每个月会产生一组3个条形图,所以最后图表将包含从下到上逐渐增长的12x3条形图,这个月的名称将作为3个条形组下的标签,每组从左到右分别位于另一组。

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

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

尝试将图表嵌入到主报表后,我尝试将其添加到仅为了充当图表容器而创建的新子报表中。我将主报表数据集作为数据源传递给子报表,并尝试将其用作子报表图表中的主数据集。数据集/图表连接仍然没有运气,例如。如果我按下添加按钮,仍然没有任何反应。

下面你可以看到我正在使用的简单豆子。首先,WorkingHoursReport是我传递给JRBeanCollectionDataSource报告的bean。我相信那个bean最有趣的领域是WorkingHours-beans列表。该列表上总共有12个项目:每个月一个。这是我目前使用数据源表达式传递给我的表元素的列表: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;
 }

在尝试创建我的第一个图表的过程中,我自然而然地尝试使用用于定义数据源的相同命令将数据填充到图表中,因为我已经成功使用了我的表:

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

不幸的是,似乎至少jasper工作室图表创建向导没有得到任何数据连接(没有对话框打开的地方,根据文档,我应该能够选择数据字段来绘制图表)。

1 个答案:

答案 0 :(得分:8)

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

创建特定的图表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));

通过参数地图

将List作为数据源传递
Map<String, Object> paramMap = new HashMap<String, Object>();
paramMap.put("CHART_DATASET", new JRBeanCollectionDataSource(cList));

显示图表

现在,我们可以使用参数title

传递的summarysubDataset$P{CHART_DATASET}频段中显示图表
<?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中的设置

Studio

享受结果

Result