ar.com.fdvs.dj.domain.chart.builder.DJLineChartBuilder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of DynamicJasper Show documentation
Show all versions of DynamicJasper Show documentation
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
/*
* 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.chart.builder;
import java.awt.Color;
import java.util.List;
import org.jfree.chart.plot.PlotOrientation;
import ar.com.fdvs.dj.domain.DJHyperLink;
import ar.com.fdvs.dj.domain.StringExpression;
import ar.com.fdvs.dj.domain.chart.DJChart;
import ar.com.fdvs.dj.domain.chart.dataset.CategoryDataset;
import ar.com.fdvs.dj.domain.chart.plot.DJAxisFormat;
import ar.com.fdvs.dj.domain.chart.plot.LinePlot;
import ar.com.fdvs.dj.domain.constants.Font;
import ar.com.fdvs.dj.domain.entities.columns.AbstractColumn;
import ar.com.fdvs.dj.domain.entities.columns.PropertyColumn;
import ar.com.fdvs.dj.domain.hyperlink.LiteralExpression;
public class DJLineChartBuilder extends AbstractChartBuilder {
//chart
/**
* Sets the chart data operation (DJChart.CALCULATION_COUNT or DJChart.CALCULATION_SUM).
*
* @param operation the chart data operation
**/
public DJLineChartBuilder setOperation(byte operation) {
this.chart.setOperation(operation);
return this;
}
/**
* Sets the hyperlink.
*
* @param link the hyperlink
**/
public DJLineChartBuilder setLink(DJHyperLink link) {
this.chart.setLink(link);
return this;
}
//chart options
/**
* Sets the background color.
*
* @param backColor the background color
**/
public DJLineChartBuilder setBackColor(Color backColor) {
this.chart.getOptions().setBackColor(backColor);
return this;
}
/**
* Sets the chart height.
*
* @param height the chart height
**/
public DJLineChartBuilder setHeight(int height) {
this.chart.getOptions().setHeight(height);
return this;
}
/**
* Sets the chart width.
*
* @param width the chart width
**/
public DJLineChartBuilder setWidth(int width) {
this.chart.getOptions().setWidth(width);
return this;
}
/**
* Sets the centered.
*
* @param centered the centered
**/
public DJLineChartBuilder setCentered(boolean centered) {
this.chart.getOptions().setCentered(centered);
return this;
}
/**
* Sets the position (DJChartOptions.POSITION_FOOTER or DJChartOptions.POSITION_HEADER).
*
* @param position the position
**/
public DJLineChartBuilder setPosition(byte position) {
this.chart.getOptions().setPosition(position);
return this;
}
/**
* Sets the y position.
*
* @param y the y position
**/
public DJLineChartBuilder setY(int y) {
this.chart.getOptions().setY(y);
return this;
}
/**
* Sets the x position.
*
* @param y the x position
**/
public DJLineChartBuilder setX(int x) {
this.chart.getOptions().setX(x);
return this;
}
/**
* Sets the legend visibility.
*
* @param showLegend the legend visibility
**/
public DJLineChartBuilder setShowLegend(boolean showLegend) {
this.chart.getOptions().setShowLegend(new Boolean(showLegend));
return this;
}
/**
* Sets the title color.
*
* @param titleColor the title color
**/
public DJLineChartBuilder setTitleColor(Color titleColor) {
this.chart.getOptions().setTitleColor(titleColor);
return this;
}
/**
* Sets the subtitle color.
*
* @param subtitleColor the subtitle color
**/
public DJLineChartBuilder setSubtitleColor(Color subtitleColor) {
this.chart.getOptions().setSubtitleColor(subtitleColor);
return this;
}
/**
* Sets the legend color.
*
* @param legendColor the legend color
**/
public DJLineChartBuilder setLegendColor(Color legendColor) {
this.chart.getOptions().setLegendColor(legendColor);
return this;
}
/**
* Sets the legend background color.
*
* @param legendBackgroundColor the legend background color
**/
public DJLineChartBuilder setLegendBackgroundColor(Color legendBackgroundColor) {
this.chart.getOptions().setLegendBackgroundColor(legendBackgroundColor);
return this;
}
/**
* Sets the theme.
* Chart themes support to allow changing the overall appearance of charts generated with the build-in chart element
*
* @param theme the theme
**/
public DJLineChartBuilder setTheme(String theme) {
this.chart.getOptions().setTheme(theme);
return this;
}
/**
* Sets the title font.
*
* @param titleFont the title font
**/
public DJLineChartBuilder setTitleFont(Font titleFont) {
this.chart.getOptions().setTitleFont(titleFont);
return this;
}
/**
* Sets the subtitle font.
*
* @param subtitleFont the subtitle font
**/
public DJLineChartBuilder setSubtitleFont(Font subtitleFont) {
this.chart.getOptions().setSubtitleFont(subtitleFont);
return this;
}
/**
* Sets the legend font.
*
* @param legendFont the legend font
**/
public DJLineChartBuilder setLegendFont(Font legendFont) {
this.chart.getOptions().setLegendFont(legendFont);
return this;
}
/**
* Sets the legend position (DJChartOptions.EDGE_TOP, DJChartOptions.EDGE_BOTTOM, DJChartOptions.EDGE_LEFT, DJChartOptions.EDGE_RIGHT).
*
* @param legendPosition the legend position
**/
public DJLineChartBuilder setLegendPosition(byte legendPosition) {
this.chart.getOptions().setLegendPosition(legendPosition);
return this;
}
/**
* Sets the title position (DJChartOptions.EDGE_TOP, DJChartOptions.EDGE_BOTTOM, DJChartOptions.EDGE_LEFT, DJChartOptions.EDGE_RIGHT).
*
* @param titlePosition the title position
**/
public DJLineChartBuilder setTitlePosition(byte titlePosition) {
this.chart.getOptions().setTitlePosition(titlePosition);
return this;
}
/**
* Sets the title.
*
* @param title the title
**/
public DJLineChartBuilder setTitle(String title) {
this.chart.getOptions().setTitleExpression(new LiteralExpression(title));
return this;
}
/**
* Sets the title expression.
*
* @param titleExpression the title expression
**/
public DJLineChartBuilder setTitle(StringExpression titleExpression) {
this.chart.getOptions().setTitleExpression(titleExpression);
return this;
}
/**
* Sets the subtitle.
*
* @param subtitle the subtitle
**/
public DJLineChartBuilder setSubtitle(String subtitle) {
this.chart.getOptions().setSubtitleExpression(new LiteralExpression(subtitle));
return this;
}
/**
* Sets the subtitle expression.
*
* @param subtitleExpression the subtitle expression
**/
public DJLineChartBuilder setSubtitle(StringExpression subtitleExpression) {
this.chart.getOptions().setSubtitleExpression(subtitleExpression);
return this;
}
/**
* Sets the line style (DJChartOptions.LINE_STYLE_SOLID, DJChartOptions.LINE_STYLE_DASHED, DJChartOptions.LINE_STYLE_DOTTED, DJChartOptions.LINE_STYLE_DOUBLE).
*
* @param lineStyle one of the line style constants in DJChartOptions class
*/
public DJLineChartBuilder setLineStyle(byte lineStyle) {
this.chart.getOptions().setLineStyle(lineStyle);
return this;
}
/**
* Sets the line width.
*
* @param lineWidth the line width
**/
public DJLineChartBuilder setLineWidth(float lineWidth) {
this.chart.getOptions().setLineWidth(new Float(lineWidth));
return this;
}
/**
* Sets the line color.
*
* @param lineColor the line color
**/
public DJLineChartBuilder setLineColor(Color lineColor) {
this.chart.getOptions().setLineColor(lineColor);
return this;
}
/**
* Sets the padding.
*
* @param padding the padding
**/
public DJLineChartBuilder setPadding(int padding) {
this.chart.getOptions().setPadding(new Integer(padding));
return this;
}
/**
* Sets a user specified chart customizer class name.
* @see net.sf.jasperreports.engine.JRChartCustomizer
*/
public DJLineChartBuilder setCustomizerClass(String customizerClass) {
this.chart.getOptions().setCustomizerClass(customizerClass);
return this;
}
//dataset
/**
* Sets the category column.
*
* @param category the category column
**/
public DJLineChartBuilder setCategory(PropertyColumn category) {
getDataset().setCategory(category);
return this;
}
/**
* Adds the specified serie column to the dataset.
*
* @param column the serie column
**/
public DJLineChartBuilder addSerie(AbstractColumn column) {
getDataset().addSerie(column);
return this;
}
/**
* Adds the specified serie column to the dataset with custom label.
*
* @param column the serie column
* @param label column the custom label
**/
public DJLineChartBuilder addSerie(AbstractColumn column, String label) {
getDataset().addSerie(column, label);
return this;
}
/**
* Adds the specified serie column to the dataset with custom label.
*
* @param column the serie column
* @param label column the custom label
**/
public DJLineChartBuilder addSerie(AbstractColumn column, StringExpression labelExpression) {
getDataset().addSerie(column, labelExpression);
return this;
}
public DJLineChartBuilder setUseSeriesAsCategory(boolean useSeriesAsCategory) {
getDataset().setUseSeriesAsCategory(useSeriesAsCategory);
return this;
}
//plot
/**
* Sets the angle in degrees to rotate the data axis labels. The range is -360 to 360. A positive value angles
* the label so it reads downwards wile a negative value angles the label so it reads upwards. Only charts that
* use a category based axis (such as line or bar charts) support label rotation.
*
* @param labelRotation the label rotation
**/
public DJLineChartBuilder setLabelRotation(double labelRotation) {
this.getPlot().setLabelRotation(new Double(labelRotation));
return this;
}
/**
* Sets the plot orientation (PlotOrientation.HORIZONTAL or PlotOrientation.VERTICAL).
*
* @param orientation the plot orientation
**/
public DJLineChartBuilder setOrientation(PlotOrientation orientation) {
getPlot().setOrientation(orientation);
return this;
}
/**
* Adds the specified series color to the plot.
*
* @param color the series color
**/
public DJLineChartBuilder addSeriesColor(Color color) {
getPlot().addSeriesColor(color);
return this;
}
/**
* Set the specified series colors to the plot.
*
* @param seriesColors the series colors
**/
public DJLineChartBuilder setSeriesColors(List seriesColors) {
getPlot().setSeriesColors(seriesColors);
return this;
}
//category plot
/**
* Sets the category axis format.
*
* @param categoryAxisFormat the category axis format
**/
public DJLineChartBuilder setCategoryAxisFormat(DJAxisFormat categoryAxisFormat) {
getPlot().setCategoryAxisFormat(categoryAxisFormat);
return this;
}
/**
* Sets the value axis format.
*
* @param valueAxisFormat the value axis format
**/
public DJLineChartBuilder setValueAxisFormat(DJAxisFormat valueAxisFormat) {
getPlot().setValueAxisFormat(valueAxisFormat);
return this;
}
//line plot
/**
* Sets the shapes visibility.
*
* @param showShapes the shapes visibility
**/
public DJLineChartBuilder setShowShapes(boolean showShapes) {
getPlot().setShowShapes(new Boolean(showShapes));
return this;
}
/**
* Sets the lines visibility.
*
* @param showLines the lines visibility
**/
public DJLineChartBuilder setShowLines(boolean showLines) {
getPlot().setShowLines(new Boolean(showLines));
return this;
}
protected CategoryDataset getDataset() {
return (CategoryDataset) chart.getDataset();
}
protected LinePlot getPlot() {
return (LinePlot) chart.getPlot();
}
protected byte getChartType() {
return DJChart.LINE_CHART;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy