繁体   English   中英

如何根据数据集中的值在JasperStudio中的barChart中设置条形颜色?

[英]How to set color of bar in barChart in JasperStudio based on value in dataset?

我在子报表中创建一个barChart。 我通过了完全通过代码(nodeJS)构造的数据集,并且效果很好。

现在,我必须始终将相同的颜色(在barChart中的条形图)赋予相同的元素。 barChart中的元素数量是动态的,因此我不能将其静态化(我以前做过)。

例如:

  • 项目1始终为黑色;
  • 项目2始终为蓝色;
  • 项目3始终为粉红色。

等等。 当然,有时只有第3项,因此通常会为其分配标准系列“ 0”颜色。 但是我需要该项目始终是粉红色的,无论它是第一个项目,还是第三个项目,依此类推。

我来过这里,但我不知道该怎么走。 我找到了一些答案,但是他们没有达到我想要的

package com.efarmgroup.sina.sios4.jasper;


import java.awt.Color;
import net.sf.jasperreports.engine.JRChart;
import net.sf.jasperreports.engine.JRChartCustomizer;
import org.jfree.chart.JFreeChart;
import org.jfree.data.category.*;
import org.jfree.chart.renderer.category.*;
import java.util.HashMap;



public class customColorSeries implements JRChartCustomizer {


    @Override
    public void customize(JFreeChart chart, JRChart jasperChart) {

        //This is the list of the object. Each of them should have a standard color
        Object[] objectList = {"BULLONERIA", "FONDAZIONE o BASAMENTO", "SPALLE", "PILE", "PULVINI", "TRAVI",
                            "TRAVERSI", "IMPALCATI", "CORDOLI", "ARCHI", "APPARECCHI SPECIALI", "SISTEMAZIONE IDRAULICA",
                            "MURO", "APPOGGI", "BARRIERA", "GIUNTI", "Portale", "Piedritto sinistro", "Paramento sinistro",
                            "Volta", "Paramento destro", "Piedritto destro", "Sovrastruttura stradale",
                            "By Pass / Nicchia", "Elementi accessori"};



        // Category Plot: most commonly used to display bar chart
        // BarRenderer: create bar charts from data in a category dataset

        BarRenderer renderer = (BarRenderer) chart.getCategoryPlot().getRenderer();

        // Method required for reading the dataset.
        // Table of values that can be accessed using row and column keys.
        CategoryDataset cd = chart.getCategoryPlot().getDataset();

        // Row gives the series expression
        int rc = cd.getRowCount();
        for (int i = 0; i < rc; i++) {

            //Here I should retrieve the the value of the dataset to perform a simple if
        }
    }

}


这是子数据集的简单示例

evolution_data: 
  [

     { Building_ID: 1,
       Building_Code: 'F010',
       Building_Name: 'Quiliano',
       Evaluation: 50,
       Object_Name: 'APPOGGI',
       Span_Code: 1,
       seriesOrder: 0,
       color: '#FC6D79' },
     { Building_ID: 1,
       Building_Code: 'F010',
       Building_Name: 'Quiliano',
       Evaluation: 8,
       Object_Name: 'BARRIERA',
       Span_Code: 1,
       seriesOrder: 0,
       color: '#FC6D79' },
     { Building_ID: 1,
       Building_Code: 'F010',
       Building_Name: 'Quiliano',
       Evaluation: 5,
       Object_Name: 'APPOGGI',
       Span_Code: 2,
       seriesOrder: 1,
       color: '#A64186' },
     { Building_ID: 1,
       Building_Code: 'F010',
       Building_Name: 'Quiliano',
       Evaluation: 3,
       Object_Name: 'BARRIERA',
       Span_Code: 2,
       seriesOrder: 1,
       color: '#A64186' },
     { Building_ID: 1,
       Building_Code: 'F010',
       Building_Name: 'Quiliano',
       Evaluation: 0,
       Object_Name: 'APPOGGI',
       Span_Code: 3,
       seriesOrder: 2,
       color: '#9758C4' },
     { Building_ID: 1,
       Building_Code: 'F010',
       Building_Name: 'Quiliano',
       Evaluation: 0,
       Object_Name: 'BARRIERA',
       Span_Code: 3,
       seriesOrder: 2,
       color: '#9758C4' }]

颜色应基于数据集中的“ Object_Name”字段。

我的问题解决了,这是我的解决方案:

public class customColorSeries  extends JRAbstractChartCustomizer  {

    @Override
    public void customize(JFreeChart chart, JRChart jasperChart) {

        BarRenderer renderer = (BarRenderer) chart.getCategoryPlot().getRenderer();
        CategoryDataset catDS = chart.getCategoryPlot().getDataset();
        com.fasterxml.jackson.databind.node.ArrayNode seriesColor = (ArrayNode) getParameterValue("seriesColor_P");
        HashMap<String, String> customMap = new HashMap<>();

        for (int z = 0; z < seriesColor.size(); z++) {  
            customMap.put(seriesColor.get(z).get("Object_Name").textValue(), seriesColor.get(z).get("Color").textValue());
        }

        for (int i = 0; i < catDS.getRowCount(); i++) {
            if(customMap.containsKey(catDS.getRowKey(i).toString())) {
                renderer.setSeriesPaint(i, Color.decode(customMap.get(catDS.getRowKey(i).toString())));
            }
        }
    }        
}

我发送一个对象数组,其中每个对象都是这样构建的

{Object_Name: 'APPOGGI', Color: '#ff0000'} 
{Object_Name: 'SPALLE', Color: '#f2ca79'}

等等....

作为子报表的参数。 然后,我使用databind和HashMap对其进行处理并在最后渲染它。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM