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

Vka*_*Vka 4 charts jasper-reports jaspersoft-studio

我已经创建了一个工作的jrxml报告,该报告显示了一个由ListJava bean 的collection()数据集填充的表.

现在我想使用相同的数据集来创建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;
}
Run Code Online (Sandbox Code Playgroud)

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;
 }
Run Code Online (Sandbox Code Playgroud)

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

new net.sf.jasperreports.engine.data.JRBeanCollectionDataSource($F{workingHours}).
Run Code Online (Sandbox Code Playgroud)

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

Pet*_*erg 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         
}
Run Code Online (Sandbox Code Playgroud)

用数据填充图表bean

循环数据集(List)并填充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));
Run Code Online (Sandbox Code Playgroud)

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

Map<String, Object> paramMap = new HashMap<String, Object>();
paramMap.put("CHART_DATASET", new JRBeanCollectionDataSource(cList));
Run Code Online (Sandbox Code Playgroud)

显示图表

现在我们可以使用传递参数在titlesummary带中显示图表subDataset$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>
Run Code Online (Sandbox Code Playgroud)

JasperSoft Studio中的设置

工作室

享受结果

结果