Package net.sf.jasperreports.charts.fill

Source Code of net.sf.jasperreports.charts.fill.JRFillTimeSeriesDataset

/*
* JasperReports - Free Java Reporting Library.
* Copyright (C) 2001 - 2009 Jaspersoft Corporation. All rights reserved.
* http://www.jaspersoft.com
*
* Unless you have purchased a commercial license agreement from Jaspersoft,
* the following license terms apply:
*
* This program is part of JasperReports.
*
* JasperReports is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* JasperReports is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with JasperReports. If not, see <http://www.gnu.org/licenses/>.
*/
package net.sf.jasperreports.charts.fill;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import net.sf.jasperreports.charts.JRTimeSeries;
import net.sf.jasperreports.charts.JRTimeSeriesDataset;
import net.sf.jasperreports.charts.util.TimeSeriesLabelGenerator;
import net.sf.jasperreports.engine.JRChartDataset;
import net.sf.jasperreports.engine.JRExpressionCollector;
import net.sf.jasperreports.engine.JRRuntimeException;
import net.sf.jasperreports.engine.design.JRVerifier;
import net.sf.jasperreports.engine.fill.JRCalculator;
import net.sf.jasperreports.engine.fill.JRExpressionEvalException;
import net.sf.jasperreports.engine.fill.JRFillChartDataset;
import net.sf.jasperreports.engine.fill.JRFillObjectFactory;

import org.jfree.data.general.Dataset;
import org.jfree.data.time.RegularTimePeriod;
import org.jfree.data.time.TimeSeries;
import org.jfree.data.time.TimeSeriesCollection;

/**
* @author Flavius Sana (flavius_sana@users.sourceforge.net)
* @version $Id: JRFillTimeSeriesDataset.java 3938 2010-08-19 14:59:36Z teodord $
*/
public class JRFillTimeSeriesDataset extends JRFillChartDataset implements JRTimeSeriesDataset
{

  /**
   *
   */
  protected JRFillTimeSeries[] timeSeries;
 
  private List seriesNames;
  private Map seriesMap;
  private Map labelsMap;
  private Map itemHyperlinks;
 
 
  public JRFillTimeSeriesDataset(
    JRTimeSeriesDataset timeSeriesDataset,
    JRFillObjectFactory factory
    )
  {
    super( timeSeriesDataset, factory );
   
    JRTimeSeries[] srcTimeSeries = timeSeriesDataset.getSeries();
    if( srcTimeSeries != null && srcTimeSeries.length > 0)
    {
      timeSeries = new JRFillTimeSeries[srcTimeSeries.length];
      for (int i = 0; i < timeSeries.length; i++)
      {
        timeSeries[i] = (JRFillTimeSeries)factory.getTimeSeries(srcTimeSeries[i]);
      }
    }
  }
 
  public JRTimeSeries[] getSeries()
  {
    return timeSeries;
  }
 
  protected void customInitialize()
  {
    seriesNames = null;
    seriesMap = null;
    labelsMap = null;
    itemHyperlinks = null;
  }
 
  protected void customEvaluate(JRCalculator calculator) throws JRExpressionEvalException
  {
    if(timeSeries != null && timeSeries.length > 0)
    {
      for (int i = 0; i < timeSeries.length; i++)
      {
        timeSeries[i].evaluate( calculator );
      }
    }
  }
 
 
  protected void customIncrement()
  {
    if (timeSeries != null && timeSeries.length > 0)
    {
      if (seriesNames == null)
      {
        seriesNames = new ArrayList();
        seriesMap = new HashMap();
        labelsMap = new HashMap();
        itemHyperlinks = new HashMap();
      }

      for (int i = 0; i < timeSeries.length; i++)
      {
        JRFillTimeSeries crtTimeSeries = timeSeries[i];
       
        Comparable seriesName = crtTimeSeries.getSeries();
        if (seriesName == null)
        {
          throw new JRRuntimeException("Time series name is null.");
        }

        TimeSeries series = (TimeSeries)seriesMap.get(seriesName);
        if(series == null)
        {
          series = new TimeSeries(seriesName.toString(), getTimePeriod());
          seriesNames.add(seriesName);
          seriesMap.put(seriesName, series);
        }
       
        RegularTimePeriod tp =
          RegularTimePeriod.createInstance(
            getTimePeriod(),
            crtTimeSeries.getTimePeriod(),
            getTimeZone()
            );

        series.addOrUpdate(tp, crtTimeSeries.getValue());

        if (crtTimeSeries.getLabelExpression() != null)
        {
          Map seriesLabels = (Map)labelsMap.get(seriesName);
          if (seriesLabels == null)
          {
            seriesLabels = new HashMap();
            labelsMap.put(seriesName, seriesLabels);
          }
         
          seriesLabels.put(tp, crtTimeSeries.getLabel());
        }
       
        if (crtTimeSeries.hasItemHyperlink())
        {
          Map seriesLinks = (Map) itemHyperlinks.get(seriesName);
          if (seriesLinks == null)
          {
            seriesLinks = new HashMap();
            itemHyperlinks.put(seriesName, seriesLinks);
          }
          seriesLinks.put(tp, crtTimeSeries.getPrintItemHyperlink());
        }
      }
    }
  }
 
  public Dataset getCustomDataset()
  {
    TimeSeriesCollection dataset = new TimeSeriesCollection(getTimeZone());
    if (seriesNames != null)
    {
      for(int i = 0; i < seriesNames.size(); i++)
      {
        Comparable seriesName = (Comparable)seriesNames.get(i);
        dataset.addSeries((TimeSeries)seriesMap.get(seriesName));
      }
    }
    return dataset;
  }


  public Class getTimePeriod() {
    return ((JRTimeSeriesDataset)parent).getTimePeriod();
  }

  public void setTimePeriod(Class timePeriod) { 
  }

  /**
   *
   */
  public byte getDatasetType() {
    return JRChartDataset.TIMESERIES_DATASET;
  }
 
 
  public Object getLabelGenerator(){
    return new TimeSeriesLabelGenerator(labelsMap);//FIXMETHEME this and other similar implementations should be able to return null and chart themes should be protected agains null;
  }
 
 
  /**
   *
   */
  public void collectExpressions(JRExpressionCollector collector)
  {
    collector.collect(this);
  }

 
  public Map getItemHyperlinks()
  {
    return itemHyperlinks;
  }
 
 
  public boolean hasItemHyperlinks()
  {
    boolean foundLinks = false;
    if (timeSeries != null && timeSeries.length > 0)
    {
      for (int i = 0; i < timeSeries.length && !foundLinks; i++)
      {
        foundLinks = timeSeries[i].hasItemHyperlink();
      }
    }
    return foundLinks;
  }


  public void validate(JRVerifier verifier)
  {
    verifier.verify(this);
  }


}
TOP

Related Classes of net.sf.jasperreports.charts.fill.JRFillTimeSeriesDataset

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.