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

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

The newest version!
/***********************************************************************************************
 * File Info: $Id: LegendProperties.java,v 1.6 2003/03/08 23:19:33 nathaniel_auvil Exp $
 * Copyright (C) 2002
 * Author: Nathaniel G. Auvil
 * Contributor(s): Sandor Dornbush
 *
 * 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.properties.util.ChartStroke;

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


final public class LegendProperties extends LegendAreaProperties implements HTMLTestable
{
	public static final Font DEFAULT_FONT = new Font( "Serif", Font.PLAIN, 12 );
	public static final Paint DEFAULT_FONT_PAINT = Color.black;
	public static final Stroke DEFAULT_ICON_BORDER_STROKE = new BasicStroke( 1.0f );
	public static final Paint DEFAULT_ICON_BORDER_PAINT = Color.black;

	private Font font = DEFAULT_FONT;
	private Paint fontPaint = DEFAULT_FONT_PAINT;

	private Paint iconBorderPaint = DEFAULT_ICON_BORDER_PAINT;
	private Stroke iconBorderStroke = DEFAULT_ICON_BORDER_STROKE;
	private Dimension size = null;


	/*********************************************************************************************
	 *
	 **********************************************************************************************/
	public LegendProperties()
	{
		super();

		//---Legend background should be transparent by default.
		super.setBackgroundPaint( null );

		super.setBorderStroke( ChartStroke.DEFAULT_LEGEND_OUTLINE );
	}


	/*********************************************************************************************
	 * Sets the Font used by the Legend.
	 *
	 * @param legendFont
	 **********************************************************************************************/
	public void setFont( Font legendFont )
	{
		this.font = legendFont;
	}


	/*********************************************************************************************
	 * Returns the Font used by the Legend.
	 *
	 * @return Font
	 **********************************************************************************************/
	public Font getFont()
	{
		return this.font;
	}


	/*********************************************************************************************
	 * Sets the Icon border color used by the Legend. If NULL is passed, there will be no border.
	 *
	 * @param iconBorderPaint
	 **********************************************************************************************/
	public void setIconBorderPaint( Paint iconBorderPaint )
	{
		this.iconBorderPaint = iconBorderPaint;
	}


	/*********************************************************************************************
	 * Returns the Icon border Color used by the Legend.
	 *
	 * @return Paint
	 **********************************************************************************************/
	public Paint getIconBorderPaint()
	{
		return this.iconBorderPaint;
	}


	/*********************************************************************************************
	 * Sets the icon border Stroke. If NULL is passed, there will be no border.
	 *
	 * @param stroke
	 **********************************************************************************************/
	public void setIconBorderStroke( Stroke stroke )
	{
		this.iconBorderStroke = stroke;
	}


	/*********************************************************************************************
	 * Returns the icon border Stroke
	 *
	 * @return Stroke
	 **********************************************************************************************/
	public Stroke getIconBorderStroke()
	{
		return this.iconBorderStroke;
	}


	/*********************************************************************************************
	 * Sets the Font color used by the Legend.
	 *
	 * @param fontPaint
	 **********************************************************************************************/
	public void setFontPaint( Paint fontPaint )
	{
		this.fontPaint = fontPaint;
	}


	/*********************************************************************************************
	 * Returns the Font Paint used by the Legend.
	 *
	 * @return Paint
	 **********************************************************************************************/
	public Paint getFontPaint()
	{
		return this.fontPaint;
	}


	/*********************************************************************************************
	 * Enables the testing routines to display the contents of this Object.
	 *
	 * @param htmlGenerator
	 **********************************************************************************************/
	public void toHTML( HTMLGenerator htmlGenerator )
	{
		htmlGenerator.propertiesTableStart( "LegendProperties" );
		super.toHTML( htmlGenerator );
		htmlGenerator.addTableRow( "Icon Border Paint", this.getIconBorderPaint() );
		htmlGenerator.addTableRow( "Icon Border Stroke", this.getIconBorderStroke() );
		htmlGenerator.addTableRow( "Font", this.getFont() );
		htmlGenerator.addTableRow( "Font Paint", this.getFontPaint() );
		htmlGenerator.propertiesTableEnd();
	}


	/** Getter for property size.
	 * @return Value of property size.
	 *
	 */
	public Dimension getSize()
	{
		return this.size;
	}


	/** Setter for property size.
	 * @param size New value of property size.
	 *
	 */
	public void setSize( Dimension size )
	{
		this.size = size;
	}

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy