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

org.jCharts.properties.PieChart2DProperties Maven / Gradle / Ivy

The newest version!
/***********************************************************************************************
 * File Info: $Id: PieChart2DProperties.java,v 1.5 2003/03/11 02:53:19 nathaniel_auvil Exp $
 * Copyright (C) 2002
 * Author: Nathaniel G. Auvil
 * Contributor(s):
 *
 * Copyright 2002 (C) Nathaniel G. Auvil. All Rights Reserved.
 *
 * Redistribution and use of this software and associated documentation ("Software"), with or
 * without modification, are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain copyright statements and notices.
 * 	Redistributions must also contain a copy of this document.
 *
 * 2. Redistributions in binary form must reproduce the above copyright notice, this list of
 * 	conditions and the following disclaimer in the documentation and/or other materials
 * 	provided with the distribution.
 *
 * 3. The name "jCharts" or "Nathaniel G. Auvil" must not be used to endorse or promote
 * 	products derived from this Software without prior written permission of Nathaniel G.
 * 	Auvil.  For written permission, please contact [email protected]
 *
 * 4. Products derived from this Software may not be called "jCharts" nor may "jCharts" appear
 * 	in their names without prior written permission of Nathaniel G. Auvil. jCharts is a
 * 	registered trademark of Nathaniel G. Auvil.
 *
 * 5. Due credit should be given to the jCharts Project (http://jcharts.sourceforge.net/).
 *
 * THIS SOFTWARE IS PROVIDED BY Nathaniel G. Auvil AND CONTRIBUTORS ``AS IS'' AND ANY
 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL
 * jCharts OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
 * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE
 ************************************************************************************************/

package org.jCharts.properties;


import org.jCharts.test.HTMLGenerator;
import org.jCharts.test.HTMLTestable;
import org.jCharts.Chart;
import org.jCharts.types.PieLabelType;
import org.jCharts.properties.util.ChartFont;

import com.google.code.appengine.awt.*;


final public class PieChart2DProperties extends ChartTypeProperties implements HTMLTestable
{
	public static final Paint DEFAULT_BORDER_PAINT = Color.black;
	public static final Stroke DEFAULT_BORDER_STROKE = new BasicStroke( 1.5f, BasicStroke.CAP_SQUARE, BasicStroke.JOIN_ROUND );

	private Paint borderPaint = DEFAULT_BORDER_PAINT;
	private Stroke borderStroke = DEFAULT_BORDER_STROKE;

	//---draw a twenty degrees by default.
	private float zeroDegreeOffset = 20.0f;

	private PieLabelType pieLabelType = PieLabelType.NO_LABELS;
	private boolean isCurrency = false;
	private boolean showGrouping = false;
	private int roundingPowerOfTen = 0;
	private ChartFont valueLabelFont = ChartFont.DEFAULT_PIE_VALUE;
	private float tickLength = 5;


	/*********************************************************************************************
	 *
	 **********************************************************************************************/
	public PieChart2DProperties()
	{
		super();
	}


	/*********************************************************************************************
	 * The offset from zero degrees which the first slice of pie is drawn.  Charts look better to
	 *  my eye when they do not start at zero degrees, but beauty is in the eye of the beholder.
	 *
	 * @param zeroDegreeOffset
	 **********************************************************************************************/
	public void setZeroDegreeOffset( float zeroDegreeOffset )
	{
		this.zeroDegreeOffset = zeroDegreeOffset;
	}


	/*********************************************************************************************
	 *
	 * @return double
	 **********************************************************************************************/
	public float getZeroDegreeOffset()
	{
		return this.zeroDegreeOffset;
	}


	/*********************************************************************************************
	 *
	 * @return stroke
	 **********************************************************************************************/
	public Stroke getBorderStroke()
	{
		return this.borderStroke;
	}


	/*********************************************************************************************
	 *
	 * @param stroke
	 **********************************************************************************************/
	public void setBorderStroke( Stroke stroke )
	{
		this.borderStroke = stroke;
	}


	/*********************************************************************************************
	 *
	 * @return Paint
	 **********************************************************************************************/
	public Paint getBorderPaint()
	{
		return this.borderPaint;
	}


	/*********************************************************************************************
	 *
	 * @param paint
	 **********************************************************************************************/
	public void setBorderPaint( Paint paint )
	{
		this.borderPaint = paint;
	}


	/*****************************************************************************
	 *
	 * @return
	 *****************************************************************************/
	public PieLabelType getPieLabelType()
	{
		return pieLabelType;
	}


	/****************************************************************************
	 * Sets the type of label to draw on the PieChart. The default value is:
	 * 	PieLabelType.NO_LABELS so no labels will be drawn on chart.
	 *
	 * @param pieLabelType
	 ***************************************************************************/
	public void setPieLabelType( PieLabelType pieLabelType )
	{
		this.pieLabelType = pieLabelType;
	}


	public ChartFont getValueLabelFont()
	{
		return valueLabelFont;
	}


	/*****************************************************************************
	 * Sets the ChartFont used to draw the chart value labels.
	 *
	 * @param valueLabelFont
	 *****************************************************************************/
	public void setValueLabelFont( ChartFont valueLabelFont )
	{
		this.valueLabelFont = valueLabelFont;
	}


	public void setCurrency( boolean currency )
	{
		isCurrency = currency;
	}


	public void setShowGrouping( boolean showGrouping )
	{
		this.showGrouping = showGrouping;
	}


	public void setRoundingPowerOfTen( int roundingPowerOfTen )
	{
		this.roundingPowerOfTen = roundingPowerOfTen;
	}


	public void setTickLength( float tickLength )
	{
		this.tickLength = tickLength;
	}


	public float getTickLength()
	{
		return tickLength;
	}


	public boolean showValueLabelCurrency()
	{
		return isCurrency;
	}


	public boolean showValueLabelGrouping()
	{
		return showGrouping;
	}


	public int getValueLabelRoundingPowerOfTen()
	{
		return roundingPowerOfTen;
	}


	/*********************************************************************************************
	 * Enables the testing routines to display the contents of this Object.
	 *
	 * @param htmlGenerator
	 **********************************************************************************************/
	public void toHTML( HTMLGenerator htmlGenerator )
	{
		htmlGenerator.propertiesTableStart( "PieChart2DProperties" );
		htmlGenerator.addTableRow( "Zero Degree Offset", Double.toString( this.getZeroDegreeOffset() ) );
		htmlGenerator.addTableRow( "Border Paint", this.getBorderPaint() );
		htmlGenerator.addTableRow( "Border Stroke", this.getBorderStroke() );
		htmlGenerator.addTableRow( "Label Type", this.pieLabelType );
		htmlGenerator.propertiesTableEnd();
	}


	/******************************************************************************************
	 * Validates the properties.
	 *
	 * @param chart
	 * @throws PropertyException
	 *****************************************************************************************/
	public void validate( Chart chart ) throws PropertyException
	{

	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy