org.jfree.chart.title
Class ImageTitle

java.lang.Object
  extended by org.jfree.chart.block.AbstractBlock
      extended by org.jfree.chart.title.Title
          extended by org.jfree.chart.title.ImageTitle
All Implemented Interfaces:
java.io.Serializable, java.lang.Cloneable, Block, org.jfree.ui.Drawable

public class ImageTitle
extends Title

A chart title that displays an image. This is useful, for example, if you have an image of your corporate logo and want to use as a footnote or part of a title in a chart you create.

ImageTitle needs an image passed to it in the constructor. For ImageTitle to work, you must have already loaded this image from its source (disk or URL). It is recomended you use something like Toolkit.getDefaultToolkit().getImage() to get the image. Then, use MediaTracker or some other message to make sure the image is fully loaded from disk.

Author:
David Berry
See Also:
Serialized Form

Field Summary
 
Fields inherited from class org.jfree.chart.title.Title
DEFAULT_HORIZONTAL_ALIGNMENT, DEFAULT_PADDING, DEFAULT_POSITION, DEFAULT_VERTICAL_ALIGNMENT
 
Constructor Summary
ImageTitle(java.awt.Image image)
          Creates a new image title.
ImageTitle(java.awt.Image image, int height, int width, org.jfree.ui.RectangleEdge position, org.jfree.ui.HorizontalAlignment horizontalAlignment, org.jfree.ui.VerticalAlignment verticalAlignment, org.jfree.ui.RectangleInsets padding)
          Creates a new image title with the given image scaled to the given width and height in the given location.
ImageTitle(java.awt.Image image, org.jfree.ui.RectangleEdge position, org.jfree.ui.HorizontalAlignment horizontalAlignment, org.jfree.ui.VerticalAlignment verticalAlignment)
          Creates a new image title.
 
Method Summary
 void draw(java.awt.Graphics2D g2, java.awt.geom.Rectangle2D titleArea)
          Draws the title on a Java 2D graphics device (such as the screen or a printer).
 java.lang.Object draw(java.awt.Graphics2D g2, java.awt.geom.Rectangle2D area, java.lang.Object params)
          Draws the block within the specified area.
protected  org.jfree.ui.Size2D drawHorizontal(java.awt.Graphics2D g2, java.awt.geom.Rectangle2D chartArea)
          Draws the title on a Java 2D graphics device (such as the screen or a printer).
protected  org.jfree.ui.Size2D drawVertical(java.awt.Graphics2D g2, java.awt.geom.Rectangle2D chartArea)
          Draws the title on a Java 2D graphics device (such as the screen or a printer).
 java.awt.Image getImage()
          Returns the image for the title.
 void setImage(java.awt.Image image)
          Sets the image for the title and notifies registered listeners that the title has been modified.
 
Methods inherited from class org.jfree.chart.title.Title
addChangeListener, clone, equals, getHorizontalAlignment, getNotify, getPosition, getVerticalAlignment, hashCode, notifyListeners, removeChangeListener, setHorizontalAlignment, setNotify, setPosition, setVerticalAlignment
 
Methods inherited from class org.jfree.chart.block.AbstractBlock
arrange, arrange, calculateTotalHeight, calculateTotalWidth, drawBorder, getBorder, getBounds, getContentXOffset, getContentYOffset, getHeight, getID, getMargin, getPadding, getWidth, setBorder, setBorder, setBounds, setHeight, setID, setMargin, setMargin, setPadding, setPadding, setWidth, toContentConstraint, trimBorder, trimMargin, trimPadding, trimToContentHeight, trimToContentWidth
 
Methods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface org.jfree.chart.block.Block
arrange, arrange, getBounds, getID, setBounds, setID
 

Constructor Detail

ImageTitle

public ImageTitle(java.awt.Image image)
Creates a new image title.

Parameters:
image - the image (null not permitted).

ImageTitle

public ImageTitle(java.awt.Image image,
                  org.jfree.ui.RectangleEdge position,
                  org.jfree.ui.HorizontalAlignment horizontalAlignment,
                  org.jfree.ui.VerticalAlignment verticalAlignment)
Creates a new image title.

Parameters:
image - the image (null not permitted).
position - the title position.
horizontalAlignment - the horizontal alignment.
verticalAlignment - the vertical alignment.

ImageTitle

public ImageTitle(java.awt.Image image,
                  int height,
                  int width,
                  org.jfree.ui.RectangleEdge position,
                  org.jfree.ui.HorizontalAlignment horizontalAlignment,
                  org.jfree.ui.VerticalAlignment verticalAlignment,
                  org.jfree.ui.RectangleInsets padding)
Creates a new image title with the given image scaled to the given width and height in the given location.

Parameters:
image - the image (null not permitted).
height - the height used to draw the image.
width - the width used to draw the image.
position - the title position.
horizontalAlignment - the horizontal alignment.
verticalAlignment - the vertical alignment.
padding - the amount of space to leave around the outside of the title.
Method Detail

getImage

public java.awt.Image getImage()
Returns the image for the title.

Returns:
The image for the title (never null).

setImage

public void setImage(java.awt.Image image)
Sets the image for the title and notifies registered listeners that the title has been modified.

Parameters:
image - the new image (null not permitted).

draw

public void draw(java.awt.Graphics2D g2,
                 java.awt.geom.Rectangle2D titleArea)
Draws the title on a Java 2D graphics device (such as the screen or a printer).

Specified by:
draw in interface org.jfree.ui.Drawable
Specified by:
draw in class Title
Parameters:
g2 - the graphics device.
titleArea - the area within which the title (and plot) should be drawn.

drawHorizontal

protected org.jfree.ui.Size2D drawHorizontal(java.awt.Graphics2D g2,
                                             java.awt.geom.Rectangle2D chartArea)
Draws the title on a Java 2D graphics device (such as the screen or a printer).

Parameters:
g2 - the graphics device.
chartArea - the area within which the title (and plot) should be drawn.
Returns:
The size of the area used by the title.

drawVertical

protected org.jfree.ui.Size2D drawVertical(java.awt.Graphics2D g2,
                                           java.awt.geom.Rectangle2D chartArea)
Draws the title on a Java 2D graphics device (such as the screen or a printer).

Parameters:
g2 - the graphics device.
chartArea - the area within which the title (and plot) should be drawn.
Returns:
The size of the area used by the title.

draw

public java.lang.Object draw(java.awt.Graphics2D g2,
                             java.awt.geom.Rectangle2D area,
                             java.lang.Object params)
Draws the block within the specified area.

Parameters:
g2 - the graphics device.
area - the area.
params - ignored (null permitted).
Returns:
Always null.