Package org.jfree.chart.plot
Class Plot
java.lang.Object
org.jfree.chart.plot.Plot
- All Implemented Interfaces:
- Serializable,- Cloneable,- EventListener,- AnnotationChangeListener,- AxisChangeListener,- MarkerChangeListener,- LegendItemSource,- PublicCloneable,- DatasetChangeListener
- Direct Known Subclasses:
- CategoryPlot,- CompassPlot,- DialPlot,- FastScatterPlot,- FlowPlot,- MeterPlot,- MultiplePiePlot,- PiePlot,- PolarPlot,- SpiderWebPlot,- ThermometerPlot,- WaferMapPlot,- XYPlot
public abstract class Plot
extends Object
implements AxisChangeListener, DatasetChangeListener, AnnotationChangeListener, MarkerChangeListener, LegendItemSource, PublicCloneable, Cloneable, Serializable
The base class for all plots in JFreeChart.  The 
JFreeChart class
 delegates the drawing of axes and data to the plot.  This base class
 provides facilities common to most plot types.- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final floatThe default background alpha transparency.static final PaintThe default background color.static final floatThe default foreground alpha transparency.static final RectangleInsetsThe default insets.static final ShapeA default box shape for legend items.static final ShapeA default circle shape for legend items.static final PaintThe default outline color.static final StrokeThe default outline stroke.static final intThe minimum height at which the plot should be drawn.static final intThe minimum width at which the plot should be drawn.static final NumberUseful constant representing zero.
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddChangeListener(PlotChangeListener listener) Registers an object for notification of changes to the plot.voidReceives notification of a change to anAnnotationadded to this plot.voidaxisChanged(AxisChangeEvent event) Receives notification of a change to one of the plot's axes.booleanEnsures symmetry between super/subclass implementations of equals.clone()Creates a clone of the plot.protected voidcreateAndAddEntity(Rectangle2D dataArea, PlotRenderingInfo plotState, String toolTip, String urlText) Creates a plot entity that contains a reference to the plot and the data area as shape.voiddatasetChanged(DatasetChangeEvent event) Receives notification of a change to the plot's dataset.abstract voiddraw(Graphics2D g2, Rectangle2D area, Point2D anchor, PlotState parentState, PlotRenderingInfo info) Draws the plot within the specified area.voiddrawBackground(Graphics2D g2, Rectangle2D area) Draws the plot background (the background color and/or image).voiddrawBackgroundImage(Graphics2D g2, Rectangle2D area) Draws the background image (if there is one) aligned within the specified area.protected voiddrawNoDataMessage(Graphics2D g2, Rectangle2D area) Draws a message to state that there is no data to plot.voiddrawOutline(Graphics2D g2, Rectangle2D area) Draws the plot outline.booleanTests this plot for equality with another object.booleanFetches the element hinting flag from the chart that this plot is assigned to.protected voidfillBackground(Graphics2D g2, Rectangle2D area) Fills the specified area with the background paint.protected voidfillBackground(Graphics2D g2, Rectangle2D area, PlotOrientation orientation) Fills the specified area with the background paint.protected voidSends aPlotChangeEventto all registered listeners.floatReturns the alpha transparency of the plot area background.Returns the background image that is used to fill the plot's background area.intReturns the background image alignment.floatReturns the alpha transparency used to draw the background image.Returns the background color of the plot area.getChart()Returns the chart that this plot is assigned to.Returns the dataset group for the plot (not currently used).Returns the drawing supplier for the plot.floatReturns the alpha-transparency for the plot foreground.Returns the insets for the plot area.Returns the legend items for the plot.Returns the string that is displayed when the dataset is empty ornull.Returns the font used to display the 'no data' message.Returns the paint used to display the 'no data' message.Returns the color used to draw the outline of the plot area.Returns the stroke used to outline the plot area.Returns the parent plot (ornullif this plot is not part of a combined plot).abstract StringReturns a short string describing the plot type.protected doublegetRectX(double x, double w1, double w2, RectangleEdge edge) Adjusts the supplied x-value.protected doublegetRectY(double y, double h1, double h2, RectangleEdge edge) Adjusts the supplied y-value.Returns the root plot.voidhandleClick(int x, int y, PlotRenderingInfo info) Handles a 'click' on the plot.inthashCode()booleanisNotify()Returns a flag that controls whether or not change events are sent to registered listeners.booleanReturns the flag that controls whether or not the plot outline is drawn.booleanReturnstrueif this plot is part of a combined plot structure (that is,getParent()returns a non-nullvalue), andfalseotherwise.voidmarkerChanged(MarkerChangeEvent event) Receives notification of a change to a marker that is assigned to the plot.voidnotifyListeners(PlotChangeEvent event) Notifies all registered listeners that the plot has been modified.voidremoveChangeListener(PlotChangeListener listener) Unregisters an object for notification of changes to the plot.static RectangleEdgeresolveDomainAxisLocation(AxisLocation location, PlotOrientation orientation) Resolves a domain axis location for a given plot orientation.static RectangleEdgeresolveRangeAxisLocation(AxisLocation location, PlotOrientation orientation) Resolves a range axis location for a given plot orientation.voidsetBackgroundAlpha(float alpha) Sets the alpha transparency of the plot area background, and notifies registered listeners that the plot has been modified.voidsetBackgroundImage(Image image) Sets the background image for the plot and sends aPlotChangeEventto all registered listeners.voidsetBackgroundImageAlignment(int alignment) Sets the alignment for the background image and sends aPlotChangeEventto all registered listeners.voidsetBackgroundImageAlpha(float alpha) Sets the alpha transparency used when drawing the background image.voidsetBackgroundPaint(Paint paint) Sets the background color of the plot area and sends aPlotChangeEventto all registered listeners.voidsetChart(JFreeChart chart) Sets the chart that the plot is assigned to.protected voidsetDatasetGroup(DatasetGroup group) Sets the dataset group (not currently used).voidsetDrawingSupplier(DrawingSupplier supplier) Sets the drawing supplier for the plot and sends aPlotChangeEventto all registered listeners.voidsetDrawingSupplier(DrawingSupplier supplier, boolean notify) Sets the drawing supplier for the plot and, if requested, sends aPlotChangeEventto all registered listeners.voidsetForegroundAlpha(float alpha) Sets the alpha-transparency for the plot and sends aPlotChangeEventto all registered listeners.voidsetInsets(RectangleInsets insets) Sets the insets for the plot and sends aPlotChangeEventto all registered listeners.voidsetInsets(RectangleInsets insets, boolean notify) Sets the insets for the plot and, if requested, and sends aPlotChangeEventto all registered listeners.voidsetNoDataMessage(String message) Sets the message that is displayed when the dataset is empty ornull, and sends aPlotChangeEventto all registered listeners.voidsetNoDataMessageFont(Font font) Sets the font used to display the 'no data' message and sends aPlotChangeEventto all registered listeners.voidsetNoDataMessagePaint(Paint paint) Sets the paint used to display the 'no data' message and sends aPlotChangeEventto all registered listeners.voidsetNotify(boolean notify) Sets a flag that controls whether or not listeners receivePlotChangeEventnotifications.voidsetOutlinePaint(Paint paint) Sets the paint used to draw the outline of the plot area and sends aPlotChangeEventto all registered listeners.voidsetOutlineStroke(Stroke stroke) Sets the stroke used to outline the plot area and sends aPlotChangeEventto all registered listeners.voidsetOutlineVisible(boolean visible) Sets the flag that controls whether or not the plot's outline is drawn, and sends aPlotChangeEventto all registered listeners.voidSets the parent plot.voidzoom(double percent) Performs a zoom on the plot.
- 
Field Details- 
ZEROUseful constant representing zero.
- 
DEFAULT_INSETSThe default insets.
- 
DEFAULT_OUTLINE_STROKEThe default outline stroke.
- 
DEFAULT_OUTLINE_PAINTThe default outline color.
- 
DEFAULT_FOREGROUND_ALPHAThe default foreground alpha transparency.- See Also:
 
- 
DEFAULT_BACKGROUND_ALPHAThe default background alpha transparency.- See Also:
 
- 
DEFAULT_BACKGROUND_PAINTThe default background color.
- 
MINIMUM_WIDTH_TO_DRAWThe minimum width at which the plot should be drawn.- See Also:
 
- 
MINIMUM_HEIGHT_TO_DRAWThe minimum height at which the plot should be drawn.- See Also:
 
- 
DEFAULT_LEGEND_ITEM_BOXA default box shape for legend items.
- 
DEFAULT_LEGEND_ITEM_CIRCLEA default circle shape for legend items.
 
- 
- 
Constructor Details- 
Plotprotected Plot()Creates a new plot.
 
- 
- 
Method Details- 
getChartReturns the chart that this plot is assigned to. This method can returnnullif the plot is not yet assigned to a plot, or if the plot is a subplot of another plot.- Returns:
- The chart (possibly null).
 
- 
setChartSets the chart that the plot is assigned to. This method is not intended for external use.- Parameters:
- chart- the chart (- nullpermitted).
 
- 
fetchElementHintingFlagFetches the element hinting flag from the chart that this plot is assigned to. If the plot is not assigned (directly or indirectly) to a chart instance, this method will returnfalse.- Returns:
- A boolean.
 
- 
getDatasetGroupReturns the dataset group for the plot (not currently used).- Returns:
- The dataset group.
- See Also:
 
- 
setDatasetGroupSets the dataset group (not currently used).- Parameters:
- group- the dataset group (- nullpermitted).
- See Also:
 
- 
getNoDataMessageReturns the string that is displayed when the dataset is empty ornull.- Returns:
- The 'no data' message (nullpossible).
- See Also:
 
- 
setNoDataMessageSets the message that is displayed when the dataset is empty ornull, and sends aPlotChangeEventto all registered listeners.- Parameters:
- message- the message (- nullpermitted).
- See Also:
 
- 
getNoDataMessageFontReturns the font used to display the 'no data' message.- Returns:
- The font (never null).
- See Also:
 
- 
setNoDataMessageFontSets the font used to display the 'no data' message and sends aPlotChangeEventto all registered listeners.- Parameters:
- font- the font (- nullnot permitted).
- See Also:
 
- 
getNoDataMessagePaintReturns the paint used to display the 'no data' message.- Returns:
- The paint (never null).
- See Also:
 
- 
setNoDataMessagePaintSets the paint used to display the 'no data' message and sends aPlotChangeEventto all registered listeners.- Parameters:
- paint- the paint (- nullnot permitted).
- See Also:
 
- 
getPlotTypeReturns a short string describing the plot type.Note: this gets used in the chart property editing user interface, but there needs to be a better mechanism for identifying the plot type. - Returns:
- A short string describing the plot type (never
     null).
 
- 
getParentReturns the parent plot (ornullif this plot is not part of a combined plot).- Returns:
- The parent plot.
- See Also:
 
- 
setParentSets the parent plot. This method is intended for internal use, you shouldn't need to call it directly.- Parameters:
- parent- the parent plot (- nullpermitted).
- See Also:
 
- 
getRootPlotReturns the root plot.- Returns:
- The root plot.
- See Also:
 
- 
isSubplotReturnstrueif this plot is part of a combined plot structure (that is,getParent()returns a non-nullvalue), andfalseotherwise.- Returns:
- trueif this plot is part of a combined plot structure.
- See Also:
 
- 
getInsetsReturns the insets for the plot area.- Returns:
- The insets (never null).
- See Also:
 
- 
setInsetsSets the insets for the plot and sends aPlotChangeEventto all registered listeners.- Parameters:
- insets- the new insets (- nullnot permitted).
- See Also:
 
- 
setInsetsSets the insets for the plot and, if requested, and sends aPlotChangeEventto all registered listeners.- Parameters:
- insets- the new insets (- nullnot permitted).
- notify- a flag that controls whether the registered listeners are notified.
- See Also:
 
- 
getBackgroundPaintReturns the background color of the plot area.- Returns:
- The paint (possibly null).
- See Also:
 
- 
setBackgroundPaintSets the background color of the plot area and sends aPlotChangeEventto all registered listeners.- Parameters:
- paint- the paint (- nullpermitted).
- See Also:
 
- 
getBackgroundAlphaReturns the alpha transparency of the plot area background.- Returns:
- The alpha transparency.
- See Also:
 
- 
setBackgroundAlphaSets the alpha transparency of the plot area background, and notifies registered listeners that the plot has been modified.- Parameters:
- alpha- the new alpha value (in the range 0.0f to 1.0f).
- See Also:
 
- 
getDrawingSupplierReturns the drawing supplier for the plot.- Returns:
- The drawing supplier (possibly null).
- See Also:
 
- 
setDrawingSupplierSets the drawing supplier for the plot and sends aPlotChangeEventto all registered listeners. The drawing supplier is responsible for supplying a limitless (possibly repeating) sequence ofPaint,StrokeandShapeobjects that the plot's renderer(s) can use to populate its (their) tables.- Parameters:
- supplier- the new supplier.
- See Also:
 
- 
setDrawingSupplierSets the drawing supplier for the plot and, if requested, sends aPlotChangeEventto all registered listeners. The drawing supplier is responsible for supplying a limitless (possibly repeating) sequence ofPaint,StrokeandShapeobjects that the plot's renderer(s) can use to populate its (their) tables.- Parameters:
- supplier- the new supplier.
- notify- notify listeners?
- See Also:
 
- 
getBackgroundImageReturns the background image that is used to fill the plot's background area.- Returns:
- The image (possibly null).
- See Also:
 
- 
setBackgroundImageSets the background image for the plot and sends aPlotChangeEventto all registered listeners.- Parameters:
- image- the image (- nullpermitted).
- See Also:
 
- 
getBackgroundImageAlignmentReturns the background image alignment. Alignment constants are defined in theAlignclass.- Returns:
- The alignment.
- See Also:
 
- 
setBackgroundImageAlignmentSets the alignment for the background image and sends aPlotChangeEventto all registered listeners. Alignment options are defined by theAlignclass.- Parameters:
- alignment- the alignment.
- See Also:
 
- 
getBackgroundImageAlphaReturns the alpha transparency used to draw the background image. This is a value in the range 0.0f to 1.0f, where 0.0f is fully transparent and 1.0f is fully opaque.- Returns:
- The alpha transparency.
- See Also:
 
- 
setBackgroundImageAlphaSets the alpha transparency used when drawing the background image.- Parameters:
- alpha- the alpha transparency (in the range 0.0f to 1.0f, where 0.0f is fully transparent, and 1.0f is fully opaque).
- Throws:
- IllegalArgumentException- if- alphais not within the specified range.
- See Also:
 
- 
isOutlineVisibleReturns the flag that controls whether or not the plot outline is drawn. The default value istrue. Note that for historical reasons, the plot's outline paint and stroke can take onnullvalues, in which case the outline will not be drawn even if this flag is set totrue.- Returns:
- The outline visibility flag.
- See Also:
 
- 
setOutlineVisibleSets the flag that controls whether or not the plot's outline is drawn, and sends aPlotChangeEventto all registered listeners.- Parameters:
- visible- the new flag value.
- See Also:
 
- 
getOutlineStrokeReturns the stroke used to outline the plot area.- Returns:
- The stroke (possibly null).
- See Also:
 
- 
setOutlineStrokeSets the stroke used to outline the plot area and sends aPlotChangeEventto all registered listeners. If you set this attribute tonull, no outline will be drawn.- Parameters:
- stroke- the stroke (- nullpermitted).
- See Also:
 
- 
getOutlinePaintReturns the color used to draw the outline of the plot area.- Returns:
- The color (possibly null).
- See Also:
 
- 
setOutlinePaintSets the paint used to draw the outline of the plot area and sends aPlotChangeEventto all registered listeners. If you set this attribute tonull, no outline will be drawn.- Parameters:
- paint- the paint (- nullpermitted).
- See Also:
 
- 
getForegroundAlphaReturns the alpha-transparency for the plot foreground.- Returns:
- The alpha-transparency.
- See Also:
 
- 
setForegroundAlphaSets the alpha-transparency for the plot and sends aPlotChangeEventto all registered listeners.- Parameters:
- alpha- the new alpha transparency.
- See Also:
 
- 
getLegendItemsReturns the legend items for the plot. By default, this method returnsnull. Subclasses should override to return aLegendItemCollection.- Specified by:
- getLegendItemsin interface- LegendItemSource
- Returns:
- The legend items for the plot (possibly null).
 
- 
isNotifyReturns a flag that controls whether or not change events are sent to registered listeners.- Returns:
- A boolean.
- See Also:
 
- 
setNotifySets a flag that controls whether or not listeners receivePlotChangeEventnotifications.- Parameters:
- notify- a boolean.
- See Also:
 
- 
addChangeListenerRegisters an object for notification of changes to the plot.- Parameters:
- listener- the object to be registered.
- See Also:
 
- 
removeChangeListenerUnregisters an object for notification of changes to the plot.- Parameters:
- listener- the object to be unregistered.
- See Also:
 
- 
notifyListenersNotifies all registered listeners that the plot has been modified.- Parameters:
- event- information about the change event.
 
- 
fireChangeEventSends aPlotChangeEventto all registered listeners.
- 
drawpublic abstract void draw(Graphics2D g2, Rectangle2D area, Point2D anchor, PlotState parentState, PlotRenderingInfo info) Draws the plot within the specified area. The anchor is a point on the chart that is specified externally (for instance, it may be the last point of the last mouse click performed by the user) - plots can use or ignore this value as they see fit.
 Subclasses need to provide an implementation of this method, obviously.- Parameters:
- g2- the graphics device.
- area- the plot area.
- anchor- the anchor point (- nullpermitted).
- parentState- the parent state (if any,- nullpermitted).
- info- carries back plot rendering info.
 
- 
drawBackgroundDraws the plot background (the background color and/or image).This method will be called during the chart drawing process and is declared public so that it can be accessed by the renderers used by certain subclasses. You shouldn't need to call this method directly. - Parameters:
- g2- the graphics device.
- area- the area within which the plot should be drawn.
 
- 
fillBackgroundFills the specified area with the background paint.- Parameters:
- g2- the graphics device.
- area- the area.
- See Also:
 
- 
fillBackgroundFills the specified area with the background paint. If the background paint is an instance ofGradientPaint, the gradient will run in the direction suggested by the plot's orientation.- Parameters:
- g2- the graphics target.
- area- the plot area.
- orientation- the plot orientation (- nullnot permitted).
 
- 
drawBackgroundImageDraws the background image (if there is one) aligned within the specified area.- Parameters:
- g2- the graphics device.
- area- the area.
- See Also:
 
- 
drawOutlineDraws the plot outline. This method will be called during the chart drawing process and is declared public so that it can be accessed by the renderers used by certain subclasses. You shouldn't need to call this method directly.- Parameters:
- g2- the graphics device.
- area- the area within which the plot should be drawn.
 
- 
drawNoDataMessageDraws a message to state that there is no data to plot.- Parameters:
- g2- the graphics device.
- area- the area within which the plot should be drawn.
 
- 
createAndAddEntityprotected void createAndAddEntity(Rectangle2D dataArea, PlotRenderingInfo plotState, String toolTip, String urlText) Creates a plot entity that contains a reference to the plot and the data area as shape.- Parameters:
- dataArea- the data area used as hot spot for the entity.
- plotState- the plot rendering info containing a reference to the EntityCollection.
- toolTip- the tool tip (defined in the respective Plot subclass) (- nullpermitted).
- urlText- the url (defined in the respective Plot subclass) (- nullpermitted).
 
- 
handleClickHandles a 'click' on the plot. Since the plot does not maintain any information about where it has been drawn, the plot rendering info is supplied as an argument so that the plot dimensions can be determined.- Parameters:
- x- the x coordinate (in Java2D space).
- y- the y coordinate (in Java2D space).
- info- an object containing information about the dimensions of the plot.
 
- 
zoomPerforms a zoom on the plot. Subclasses should override if zooming is appropriate for the type of plot.- Parameters:
- percent- the zoom percentage.
 
- 
annotationChangedReceives notification of a change to anAnnotationadded to this plot.- Specified by:
- annotationChangedin interface- AnnotationChangeListener
- Parameters:
- event- information about the event (not used here).
 
- 
axisChangedReceives notification of a change to one of the plot's axes.- Specified by:
- axisChangedin interface- AxisChangeListener
- Parameters:
- event- information about the event (not used here).
 
- 
datasetChangedReceives notification of a change to the plot's dataset.The plot reacts by passing on a plot change event to all registered listeners. - Specified by:
- datasetChangedin interface- DatasetChangeListener
- Parameters:
- event- information about the event (not used here).
 
- 
markerChangedReceives notification of a change to a marker that is assigned to the plot.- Specified by:
- markerChangedin interface- MarkerChangeListener
- Parameters:
- event- the event.
 
- 
getRectXAdjusts the supplied x-value.- Parameters:
- x- the x-value.
- w1- width 1.
- w2- width 2.
- edge- the edge (left or right).
- Returns:
- The adjusted x-value.
 
- 
getRectYAdjusts the supplied y-value.- Parameters:
- y- the x-value.
- h1- height 1.
- h2- height 2.
- edge- the edge (top or bottom).
- Returns:
- The adjusted y-value.
 
- 
equalsTests this plot for equality with another object.
- 
canEqualEnsures symmetry between super/subclass implementations of equals. For more detail, see http://jqno.nl/equalsverifier/manual/inheritance.- Parameters:
- other- Object
- Returns:
- true ONLY if the parameter is THIS class type
 
- 
hashCode
- 
cloneCreates a clone of the plot.- Specified by:
- clonein interface- PublicCloneable
- Overrides:
- clonein class- Object
- Returns:
- A clone.
- Throws:
- CloneNotSupportedException- if some component of the plot does not support cloning.
 
- 
resolveDomainAxisLocationpublic static RectangleEdge resolveDomainAxisLocation(AxisLocation location, PlotOrientation orientation) Resolves a domain axis location for a given plot orientation.- Parameters:
- location- the location (- nullnot permitted).
- orientation- the orientation (- nullnot permitted).
- Returns:
- The edge (never null).
 
- 
resolveRangeAxisLocationpublic static RectangleEdge resolveRangeAxisLocation(AxisLocation location, PlotOrientation orientation) Resolves a range axis location for a given plot orientation.- Parameters:
- location- the location (- nullnot permitted).
- orientation- the orientation (- nullnot permitted).
- Returns:
- The edge (never null).
 
 
-