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

ar.com.fdvs.dj.domain.DJCrosstab Maven / Gradle / Ivy

Go to download

DynamicJasper (DJ) is an API that hides the complexity of Jasper Reports, it helps developers to save time when designing simple/medium complexity reports generating the layout of the report elements automatically. It creates reports dynamically, defining at runtime the columns, column width (auto width), groups, variables, fonts, charts, crosstabs, sub reports (that can also be dynamic), page size and everything else that you can define at design time. DJ keeps full compatibility with Jasper Reports since it's a tool that helps create reports programmatically in a easy way (it only interferes with the creation of the report design doing the layout of the elements). You can use the classic .jrxml files as templates while the content and layout of the report elements are handled by the DJ API. http://dynamicjasper.com

There is a newer version: 5.3.9
Show newest version
/*
 * DynamicJasper: A library for creating reports dynamically by specifying
 * columns, groups, styles, etc. at runtime. It also saves a lot of development
 * time in many cases! (http://sourceforge.net/projects/dynamicjasper)
 *
 * Copyright (C) 2008  FDV Solutions (http://www.fdvsolutions.com)
 *
 * This library 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 2.1 of the License, or (at your option) any later version.
 *
 * This library 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 this library; if not, write to the Free Software
 *
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 *
 *
 */

package ar.com.fdvs.dj.domain;

import ar.com.fdvs.dj.core.layout.CrossTabColorShema;
import ar.com.fdvs.dj.domain.constants.Border;
import ar.com.fdvs.dj.domain.entities.Entity;

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

public class DJCrosstab extends DJBaseElement {

	private static final long serialVersionUID = Entity.SERIAL_VERSION_UID;

	private List rows = new ArrayList();
	private List columns = new ArrayList();
	private List measures = new ArrayList();

	private DJLabel caption;
	
	private int height;
	private int width;

	private int bottomSpace = 10; //blank space AFTER the crosstab
	private int topSpace = 10; //blank space BEFORE the crosstab

	/**
	 * if true, the width will be the page width - margins
	 */
	private boolean useFullWidth = true;

	private DJDataSource datasource;

	private String mainHeaderTitle = "";

	private boolean automaticTitle = false;
	
	private boolean ignoreWidth;

	/**
	 * Default styles, can be overwritten by the column and row objects
	 */
	private Style headerStyle;
	
	
	private Style columnHeaderStyle;
	private Style columnTotalheaderStyle;
	private Style columnTotalStyle;

	private Style rowHeaderStyle;
	private Style rowTotalheaderStyle;
	private Style rowTotalStyle;
	
	private Style measureStyle;

	private int colorScheme = 0;

	private CrossTabColorShema ctColorScheme = null;

	/**
	 * If not null or NO_BORDER, all cells will have this border
	 */
	private Border cellBorder;

	/**
	 * From here on, pass-throug properties
	 */
	private int columnBreakOffset = 10;

	public int getColumnBreakOffset() {
		return columnBreakOffset;
	}
	public void setColumnBreakOffset(int columnBreakOffset) {
		this.columnBreakOffset = columnBreakOffset;
	}
	public Style getHeaderStyle() {
		return headerStyle;
	}
	public void setHeaderStyle(Style headerStyle) {
		this.headerStyle = headerStyle;
	}
	public List getRows() {
		return rows;
	}
	public void setRows(List rows) {
		this.rows = rows;
	}
	public List getColumns() {
		return columns;
	}
	public void setColumns(List columns) {
		this.columns = columns;
	}
	public int getHeight() {
		return height;
	}
	public void setHeight(int height) {
		this.height = height;
	}
	public int getWidth() {
		return width;
	}
	public void setWidth(int width) {
		this.width = width;
	}
	public List getMeasures() {
		return measures;
	}
	
	public void setMeasures(List measures) {
		this.measures = measures;
	}

	public DJCrosstabMeasure getMeasure(int index) {
		return measures.get(index);
	}
	public boolean isUseFullWidth() {
		return useFullWidth;
	}
	public void setUseFullWidth(boolean useFullWidth) {
		this.useFullWidth = useFullWidth;
	}
	public DJDataSource getDatasource() {
		return datasource;
	}
	public void setDatasource(DJDataSource datasource) {
		this.datasource = datasource;
	}
	public Border getCellBorder() {
		return cellBorder;
	}
	public void setCellBorder(Border cellBorder) {
		this.cellBorder = cellBorder;
	}
	public int getColorScheme() {
		return colorScheme;
	}
	public void setColorScheme(int colorScheme) {
		this.colorScheme = colorScheme;
	}
	public String getMainHeaderTitle() {
		return mainHeaderTitle;
	}
	public void setMainHeaderTitle(String mainHeaderTitle) {
		this.mainHeaderTitle = mainHeaderTitle;
	}
	public boolean isAutomaticTitle() {
		return automaticTitle;
	}
	public void setAutomaticTitle(boolean automaticTitle) {
		this.automaticTitle = automaticTitle;
	}
	public int getBottomSpace() {
		return bottomSpace;
	}
	public void setBottomSpace(int bottomSpace) {
		this.bottomSpace = bottomSpace;
	}
	public int getTopSpace() {
		return topSpace;
	}
	public void setTopSpace(int topSpace) {
		this.topSpace = topSpace;
	}
	public CrossTabColorShema getCtColorScheme() {
		return ctColorScheme;
	}
	public void setCtColorScheme(CrossTabColorShema ctColorScheme) {
		this.ctColorScheme = ctColorScheme;
	}
	public Style getRowTotalheaderStyle() {
		return rowTotalheaderStyle;
	}
	
	/**
	 * Default style. Can be overwritten by the row 
	 * @param rowTotalheaderStyle
	 */
	public void setRowTotalheaderStyle(Style rowTotalheaderStyle) {
		this.rowTotalheaderStyle = rowTotalheaderStyle;
	}
	public Style getColumnTotalheaderStyle() {
		return columnTotalheaderStyle;
	}
	
	/**
	 * Default style. Can be overwritten by the column
	 * @param columnTotalheaderStyle
	 */
	public void setColumnTotalheaderStyle(Style columnTotalheaderStyle) {
		this.columnTotalheaderStyle = columnTotalheaderStyle;
	}
	public Style getRowHeaderStyle() {
		return rowHeaderStyle;
	}
	
	/**
	 * Default style. Can be overwritten by the row
	 * @param rowHeaderStyle
	 */
	public void setRowHeaderStyle(Style rowHeaderStyle) {
		this.rowHeaderStyle = rowHeaderStyle;
	}
	public Style getColumnHeaderStyle() {
		return columnHeaderStyle;
	}
	
	/**
	 * Default style. Can be overwritten by the column
	 * @param columnHeaderStyle
	 */
	public void setColumnHeaderStyle(Style columnHeaderStyle) {
		this.columnHeaderStyle = columnHeaderStyle;
	}
	public Style getMeasureStyle() {
		return measureStyle;
	}
	public void setMeasureStyle(Style measureStyle) {
		this.measureStyle = measureStyle;
	}
	public Style getColumnTotalStyle() {
		return columnTotalStyle;
	}
	public void setColumnTotalStyle(Style columnTotalStyle) {
		this.columnTotalStyle = columnTotalStyle;
	}
	public Style getRowTotalStyle() {
		return rowTotalStyle;
	}
	public void setRowTotalStyle(Style rowTotalStyle) {
		this.rowTotalStyle = rowTotalStyle;
	}
	public DJLabel getCaption() {
		return caption;
	}
	public void setCaption(DJLabel caption) {
		this.caption = caption;
	}
	
	public boolean isIgnoreWidth() {
		return ignoreWidth;
	}

	public void setIgnoreWidth(boolean ignoreWidth) {
		this.ignoreWidth = ignoreWidth;
	}

    public List getVisibleMeasures() {
        List visibleMeasures = new ArrayList();

        for (Object measureObject : this.getMeasures()) {
            DJCrosstabMeasure measure = DJCrosstabMeasure.class.cast(measureObject);
            if (measure.getVisible() != null && measure.getVisible().equals(Boolean.TRUE)) {
                visibleMeasures.add(measure);
            }
        }

        return Collections.unmodifiableList(visibleMeasures);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy