All Downloads are FREE. Search and download functionalities are using the official Maven repository.

net.sf.jasperreports.engine.fill.JRFiller Maven / Gradle / Ivy

There is a newer version: 7.0.0
Show newest version
/*
 * JasperReports - Free Java Reporting Library.
 * Copyright (C) 2001 - 2014 TIBCO Software Inc. 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 .
 */
package net.sf.jasperreports.engine.fill;

import java.sql.Connection;
import java.util.Map;

import net.sf.jasperreports.engine.DefaultJasperReportsContext;
import net.sf.jasperreports.engine.JRDataSource;
import net.sf.jasperreports.engine.JRException;
import net.sf.jasperreports.engine.JRParameter;
import net.sf.jasperreports.engine.JRPropertiesUtil;
import net.sf.jasperreports.engine.JRRuntimeException;
import net.sf.jasperreports.engine.JasperPrint;
import net.sf.jasperreports.engine.JasperReport;
import net.sf.jasperreports.engine.JasperReportsContext;
import net.sf.jasperreports.engine.type.SectionTypeEnum;


/**
 * @author Teodor Danciu ([email protected])
 */
public final class JRFiller
{

	/**
	 * The default locale used to fill reports.
	 * 
	 * 

* The property is overridden by the value of the {@link JRParameter#REPORT_LOCALE} parameter. * By default, the system/JVM locale is used. *

* * @see JRParameter#REPORT_LOCALE */ public static final String PROPERTY_DEFAULT_LOCALE = JRPropertiesUtil.PROPERTY_PREFIX + "default.locale"; /** * The default time zone used to fill reports. * *

* The property is overridden by the value of the {@link JRParameter#REPORT_TIME_ZONE} parameter. * By default, the system/JVM time zone is used. *

* * @see JRParameter#REPORT_TIME_ZONE */ public static final String PROPERTY_DEFAULT_TIMEZONE = JRPropertiesUtil.PROPERTY_PREFIX + "default.timezone"; /** * */ public static JasperPrint fill( JasperReportsContext jasperReportsContext, JasperReport jasperReport, Map parameters, Connection conn ) throws JRException { ReportFiller filler = createReportFiller(jasperReportsContext, jasperReport); JasperPrint jasperPrint = null; try { jasperPrint = filler.fill(parameters, conn); } catch(JRFillInterruptedException e) { throw new JRException("The report filling thread was interrupted.", e); } return jasperPrint; } /** * */ public static JasperPrint fill( JasperReportsContext jasperReportsContext, JasperReport jasperReport, Map parameters, JRDataSource dataSource ) throws JRException { ReportFiller filler = createReportFiller(jasperReportsContext, jasperReport); JasperPrint jasperPrint = null; try { jasperPrint = filler.fill(parameters, dataSource); } catch(JRFillInterruptedException e) { throw new JRException("The report filling thread was interrupted.", e); } return jasperPrint; } /** * Fills a report. *

* The data source used to fill the report is determined in the following way: *

    *
  • If a non-null value of the {@link net.sf.jasperreports.engine.JRParameter#REPORT_DATA_SOURCE REPORT_DATA_SOURCE} * has been specified, it will be used as data source.
  • *
  • Otherwise, if the report has a query then a data source will be created based on the query and connection * parameter values.
  • *
  • Otherwise, the report will be filled without a data source.
  • *
* * @param jasperReport the report * @param parameters the fill parameters * @return the filled report * @throws JRException */ public static JasperPrint fill( JasperReportsContext jasperReportsContext, JasperReport jasperReport, Map parameters ) throws JRException { ReportFiller filler = createReportFiller(jasperReportsContext, jasperReport); try { JasperPrint jasperPrint = filler.fill(parameters); return jasperPrint; } catch (JRFillInterruptedException e) { throw new JRException("The report filling thread was interrupted.", e); } } /** * */ //FIXMEBOOK deprecate? public static JRBaseFiller createFiller(JasperReportsContext jasperReportsContext, JasperReport jasperReport) throws JRException { return createBandReportFiller(jasperReportsContext, jasperReport); } protected static JRBaseFiller createBandReportFiller(JasperReportsContext jasperReportsContext, JasperReport jasperReport) throws JRException { JRBaseFiller filler = null; switch (jasperReport.getPrintOrderValue()) { case HORIZONTAL : { filler = new JRHorizontalFiller(jasperReportsContext, jasperReport); break; } case VERTICAL : { filler = new JRVerticalFiller(jasperReportsContext, jasperReport); break; } } return filler; } public static ReportFiller createReportFiller(JasperReportsContext jasperReportsContext, JasperReport jasperReport) throws JRException { ReportFiller filler; SectionTypeEnum sectionType = jasperReport.getSectionType(); sectionType = sectionType == null ? SectionTypeEnum.BAND : sectionType; switch (sectionType) { case BAND: filler = createBandReportFiller(jasperReportsContext, jasperReport); break; case PART: { filler = new PartReportFiller(jasperReportsContext, jasperReport); break; } default: throw new JRRuntimeException("Unknown report section type " + jasperReport.getSectionType()); } return filler; } /** * @deprecated Replaced by {@link #fill(JasperReportsContext, JasperReport, Map, Connection)}. */ public static JasperPrint fillReport( JasperReport jasperReport, Map parameters, Connection conn ) throws JRException { return fill(DefaultJasperReportsContext.getInstance(), jasperReport, parameters, conn); } /** * @deprecated Replaced by {@link #fill(JasperReportsContext, JasperReport, Map, JRDataSource)}. */ public static JasperPrint fillReport( JasperReport jasperReport, Map parameters, JRDataSource dataSource ) throws JRException { return fill(DefaultJasperReportsContext.getInstance(), jasperReport, parameters, dataSource); } /** * @deprecated Replaced by {@link #fill(JasperReportsContext, JasperReport, Map)}. */ public static JasperPrint fillReport(JasperReport jasperReport, Map parameters) throws JRException { return fill(DefaultJasperReportsContext.getInstance(), jasperReport, parameters); } /** * @deprecated Replaced by {@link #createFiller(JasperReportsContext, JasperReport)}. */ public static JRBaseFiller createFiller(JasperReport jasperReport) throws JRException { return createFiller(DefaultJasperReportsContext.getInstance(), jasperReport); } private JRFiller() { } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy