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

net.sf.dynamicreports.report.base.grid.DRColumnTitleGroup Maven / Gradle / Ivy

Go to download

DynamicReports is an open source Java reporting library based on JasperReports. It allows to create dynamic report designs and it doesn't need a visual report designer. You can very quickly create reports and produce documents that can be displayed, printed or exported into many popular formats such as PDF, Excel, Word and others.

There is a newer version: 6.20.1
Show newest version
/**
 * DynamicReports - Free Java reporting library for creating reports dynamically
 *
 * Copyright (C) 2010 - 2016 Ricardo Mariaca
 * http://www.dynamicreports.org
 *
 * This file is part of DynamicReports.
 *
 * DynamicReports 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.
 *
 * DynamicReports 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 DynamicReports. If not, see .
 */

package net.sf.dynamicreports.report.base.grid;

import java.util.ArrayList;
import java.util.List;

import net.sf.dynamicreports.report.constant.ComponentDimensionType;
import net.sf.dynamicreports.report.constant.Constants;
import net.sf.dynamicreports.report.constant.ListType;
import net.sf.dynamicreports.report.definition.expression.DRIExpression;
import net.sf.dynamicreports.report.definition.expression.DRIPropertyExpression;
import net.sf.dynamicreports.report.definition.grid.DRIColumnGridComponent;
import net.sf.dynamicreports.report.definition.grid.DRIColumnTitleGroup;
import net.sf.dynamicreports.report.definition.style.DRIReportStyle;

import org.apache.commons.lang3.Validate;

/**
 * @author Ricardo Mariaca ([email protected])
 */
public class DRColumnTitleGroup implements DRIColumnTitleGroup {
	private static final long serialVersionUID = Constants.SERIAL_VERSION_UID;

	private DRColumnGridList list;

	private DRIExpression titleExpression;
	private DRIReportStyle titleStyle;
	private Integer titleWidth;
	private ComponentDimensionType titleWidthType;
	private Integer titleColumns;
	private Integer titleHeight;
	private ComponentDimensionType titleHeightType;
	private Integer titleRows;
	private Boolean titleStretchWithOverflow;
	private List titlePropertyExpressions;

	public DRColumnTitleGroup() {
		this.list = new DRColumnGridList(ListType.HORIZONTAL);
		titlePropertyExpressions = new ArrayList();
	}

	@Override
	public DRColumnGridList getList() {
		return list;
	}

	public void addComponent(DRIColumnGridComponent component) {
		list.addComponent(component);
	}

	@Override
	public DRIExpression getTitleExpression() {
		return titleExpression;
	}

	public void setTitleExpression(DRIExpression titleExpression) {
		this.titleExpression = titleExpression;
	}

	@Override
	public DRIReportStyle getTitleStyle() {
		return titleStyle;
	}

	public void setTitleStyle(DRIReportStyle titleStyle) {
		this.titleStyle = titleStyle;
	}

  /**
   * Returns the column title width.
   *
   * @return the column title width >= 0
   */
	@Override
	public Integer getTitleWidth() {
		return titleWidth;
	}

  /**
   * Sets the column title width.
   * @see net.sf.dynamicreports.report.builder.Units
   *
   * @param titleWidth the column title width >= 0
   * @exception IllegalArgumentException if titleWidth is < 0
   */
	public void setTitleWidth(Integer titleWidth) {
		if (titleWidth != null) {
			Validate.isTrue(titleWidth >= 0, "titleWidth must be >= 0");
		}
		this.titleWidth = titleWidth;
	}

	@Override
	public ComponentDimensionType getTitleWidthType() {
		return titleWidthType;
	}

	public void setTitleWidthType(ComponentDimensionType titleWidthType) {
		this.titleWidthType = titleWidthType;
	}

  /**
   * Returns the number of title columns.
   *
   * @return the number of title columns >= 0
   */
	@Override
	public Integer getTitleColumns() {
		return titleColumns;
	}

  /**
   * This method is used to define the width of a column title.
   * The width is set to the columns multiplied by width of the
   * character m for the font used
   *
   * @param titleColumns the number of columns >= 0
   * @exception IllegalArgumentException if columns is < 0
   */
	public void setTitleColumns(Integer titleColumns) {
		if (titleColumns != null) {
			Validate.isTrue(titleColumns >= 0, "titleColumns must be >= 0");
		}
		this.titleColumns = titleColumns;
	}

  /**
   * Returns the column title height.
   *
   * @return the column title height >= 0
   */
	@Override
	public Integer getTitleHeight() {
		return titleHeight;
	}

  /**
   * Sets the column title height.
   * @see net.sf.dynamicreports.report.builder.Units
   *
   * @param titleHeight the column title height >= 0
   * @exception IllegalArgumentException if titleHeight is < 0
   */
	public void setTitleHeight(Integer titleHeight) {
		if (titleHeight != null) {
			Validate.isTrue(titleHeight >= 0, "titleHeight must be >= 0");
		}
		this.titleHeight = titleHeight;
	}

	@Override
	public ComponentDimensionType getTitleHeightType() {
		return titleHeightType;
	}

	public void setTitleHeightType(ComponentDimensionType titleHeightType) {
		this.titleHeightType = titleHeightType;
	}

  /**
   * Returns the number of title rows.
   *
   * @return the number of title rows >= 0
   */
	@Override
	public Integer getTitleRows() {
		return titleRows;
	}

  /**
   * This method is used to define the height of a column title.
   * The height is set to the rows multiplied by height of the font
   *
   * @param titleRows the number of rows >= 0
   * @exception IllegalArgumentException if rows is < 0
   */
	public void setTitleRows(Integer titleRows) {
		if (titleRows != null) {
			Validate.isTrue(titleRows >= 0, "titleRows must be >= 0");
		}
		this.titleRows = titleRows;
	}

	@Override
	public Boolean getTitleStretchWithOverflow() {
		return titleStretchWithOverflow;
	}

	public void setTitleStretchWithOverflow(Boolean titleStretchWithOverflow) {
		this.titleStretchWithOverflow = titleStretchWithOverflow;
	}

	@Override
	public List getTitlePropertyExpressions() {
		return titlePropertyExpressions;
	}

	public void addTitlePropertyExpression(DRIPropertyExpression propertyExpression) {
		Validate.notNull(propertyExpression, "propertyExpression must not be null");
		this.titlePropertyExpressions.add(propertyExpression);
	}

	public void setTitlePropertyExpressions(List titlePropertyExpressions) {
		this.titlePropertyExpressions = titlePropertyExpressions;
	}
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy