Class NumberAxis
- All Implemented Interfaces:
Serializable,Cloneable,PublicCloneable
- Direct Known Subclasses:
CyclicNumberAxis,LogarithmicAxis,ModuloAxis,SymbolAxis
If the axis is set up to automatically determine its range to fit the data,
you can ensure that the range includes zero (statisticians usually prefer
this) by setting the autoRangeIncludesZero flag to
true.
The NumberAxis class has a mechanism for automatically
selecting a tick unit that is appropriate for the current axis range.
- See Also:
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final booleanThe default value for the autoRangeIncludesZero flag.static final booleanThe default value for the autoRangeStickyZero flag.static final NumberTickUnitThe default tick unit.static final booleanThe default setting for the vertical tick labels flag.Fields inherited from class org.jfree.chart.axis.ValueAxis
DEFAULT_AUTO_RANGE, DEFAULT_AUTO_RANGE_MINIMUM_SIZE, DEFAULT_AUTO_TICK_UNIT_SELECTION, DEFAULT_INVERTED, DEFAULT_LOWER_MARGIN, DEFAULT_RANGE, DEFAULT_UPPER_MARGIN, MAXIMUM_TICK_COUNTFields inherited from class org.jfree.chart.axis.Axis
DEFAULT_AXIS_LABEL_FONT, DEFAULT_AXIS_LABEL_INSETS, DEFAULT_AXIS_LABEL_PAINT, DEFAULT_AXIS_LINE_PAINT, DEFAULT_AXIS_LINE_STROKE, DEFAULT_AXIS_VISIBLE, DEFAULT_TICK_LABEL_FONT, DEFAULT_TICK_LABEL_INSETS, DEFAULT_TICK_LABEL_PAINT, DEFAULT_TICK_LABELS_VISIBLE, DEFAULT_TICK_MARK_INSIDE_LENGTH, DEFAULT_TICK_MARK_OUTSIDE_LENGTH, DEFAULT_TICK_MARK_PAINT, DEFAULT_TICK_MARK_STROKE, DEFAULT_TICK_MARKS_VISIBLE -
Constructor Summary
ConstructorsConstructorDescriptionDefault constructor.NumberAxis(String label) Constructs a number axis, using default values where necessary. -
Method Summary
Modifier and TypeMethodDescriptionprotected voidRescales the axis to ensure that all data is visible.protected doubleCalculates the value of the highest visible tick on the axis.protected doubleCalculates the value of the lowest visible tick on the axis.protected intCalculates the number of visible ticks.clone()Returns a clone of the axis.voidConfigures the axis to work with the specified plot.static TickUnitSourceReturns a collection of tick units for integer values.static TickUnitSourcecreateIntegerTickUnits(Locale locale) Returns a collection of tick units for integer values.static TickUnitSourceCreates the standard tick units.static TickUnitSourcecreateStandardTickUnits(Locale locale) Creates a collection of standard tick units.draw(Graphics2D g2, double cursor, Rectangle2D plotArea, Rectangle2D dataArea, RectangleEdge edge, PlotRenderingInfo plotState) Draws the axis on a Java 2D graphics device (such as the screen or a printer).booleanTests the axis for equality with an arbitrary object.protected doubleEstimates the maximum tick label height.protected doubleestimateMaximumTickLabelWidth(Graphics2D g2, TickUnit unit) Estimates the maximum width of the tick labels, assuming the specified tick unit is used.booleanReturns the flag that indicates whether or not the automatic axis range (if indeed it is determined automatically) is forced to include zero.booleanReturns a flag that affects the auto-range when zero falls outside the data range but inside the margins defined for the axis.Returns the (optional) marker band for the axis.Returns the number format override.Returns the axis range type.Returns the tick unit for the axis.inthashCode()Returns a hash code for this object.doublejava2DToValue(double java2DValue, Rectangle2D area, RectangleEdge edge) Converts a coordinate in Java2D space to the corresponding data value, assuming that the axis runs along one edge of the specified dataArea.refreshTicks(Graphics2D g2, AxisState state, Rectangle2D dataArea, RectangleEdge edge) Calculates the positions of the tick labels for the axis, storing the results in the tick label list (ready for drawing).protected ListrefreshTicksHorizontal(Graphics2D g2, Rectangle2D dataArea, RectangleEdge edge) Calculates the positions of the tick labels for the axis, storing the results in the tick label list (ready for drawing).protected ListrefreshTicksVertical(Graphics2D g2, Rectangle2D dataArea, RectangleEdge edge) Calculates the positions of the tick labels for the axis, storing the results in the tick label list (ready for drawing).protected voidselectAutoTickUnit(Graphics2D g2, Rectangle2D dataArea, RectangleEdge edge) Selects an appropriate tick value for the axis.protected voidselectHorizontalAutoTickUnit(Graphics2D g2, Rectangle2D dataArea, RectangleEdge edge) Selects an appropriate tick value for the axis.protected voidselectVerticalAutoTickUnit(Graphics2D g2, Rectangle2D dataArea, RectangleEdge edge) Selects an appropriate tick value for the axis.voidsetAutoRangeIncludesZero(boolean flag) Sets the flag that indicates whether or not the axis range, if automatically calculated, is forced to include zero.voidsetAutoRangeStickyZero(boolean flag) Sets a flag that affects the auto-range when zero falls outside the data range but inside the margins defined for the axis.voidsetMarkerBand(MarkerAxisBand band) Sets the marker band for the axis.voidsetNumberFormatOverride(NumberFormat formatter) Sets the number format override.voidsetRangeType(RangeType rangeType) Sets the axis range type.voidsetTickUnit(NumberTickUnit unit) Sets the tick unit for the axis and sends anAxisChangeEventto all registered listeners.voidsetTickUnit(NumberTickUnit unit, boolean notify, boolean turnOffAutoSelect) Sets the tick unit for the axis and, if requested, sends anAxisChangeEventto all registered listeners.doublevalueToJava2D(double value, Rectangle2D area, RectangleEdge edge) Converts a data value to a coordinate in Java2D space, assuming that the axis runs along one edge of the specified dataArea.Methods inherited from class org.jfree.chart.axis.ValueAxis
calculateAnchorPoint, centerRange, drawAxisLine, drawTickMarksAndLabels, findMaximumTickLabelHeight, findMaximumTickLabelWidth, getAutoRangeMinimumSize, getAutoTickIndex, getDefaultAutoRange, getDownArrow, getFixedAutoRange, getLeftArrow, getLowerBound, getLowerMargin, getMinorTickCount, getRange, getRightArrow, getStandardTickUnits, getUpArrow, getUpperBound, getUpperMargin, isAutoRange, isAutoTickUnitSelection, isInverted, isNegativeArrowVisible, isPositiveArrowVisible, isVerticalTickLabels, lengthToJava2D, pan, reserveSpace, resizeRange, resizeRange, resizeRange2, setAutoRange, setAutoRange, setAutoRangeMinimumSize, setAutoRangeMinimumSize, setAutoTickIndex, setAutoTickUnitSelection, setAutoTickUnitSelection, setDefaultAutoRange, setDownArrow, setFixedAutoRange, setInverted, setLeftArrow, setLowerBound, setLowerMargin, setMinorTickCount, setNegativeArrowVisible, setPositiveArrowVisible, setRange, setRange, setRange, setRangeAboutValue, setRangeWithMargins, setRangeWithMargins, setRangeWithMargins, setRightArrow, setStandardTickUnits, setUpArrow, setUpperBound, setUpperMargin, setVerticalTickLabels, zoomRangeMethods inherited from class org.jfree.chart.axis.Axis
addChangeListener, createAndAddEntity, createAttributedLabel, drawAttributedLabel, drawLabel, fireChangeEvent, getAttributedLabel, getAxisLinePaint, getAxisLineStroke, getFixedDimension, getLabel, getLabelAngle, getLabelEnclosure, getLabelFont, getLabelInsets, getLabelLocation, getLabelPaint, getMinorTickMarkInsideLength, getMinorTickMarkOutsideLength, getPlot, getTickLabelFont, getTickLabelInsets, getTickLabelPaint, getTickMarkInsideLength, getTickMarkOutsideLength, getTickMarkPaint, getTickMarkStroke, hasListener, isAxisLineVisible, isMinorTickMarksVisible, isTickLabelsVisible, isTickMarksVisible, isVisible, labelAnchorH, labelAnchorV, labelLocationX, labelLocationY, notifyListeners, removeChangeListener, setAttributedLabel, setAttributedLabel, setAxisLinePaint, setAxisLineStroke, setAxisLineVisible, setFixedDimension, setLabel, setLabelAngle, setLabelFont, setLabelInsets, setLabelInsets, setLabelLocation, setLabelPaint, setMinorTickMarkInsideLength, setMinorTickMarkOutsideLength, setMinorTickMarksVisible, setPlot, setTickLabelFont, setTickLabelInsets, setTickLabelPaint, setTickLabelsVisible, setTickMarkInsideLength, setTickMarkOutsideLength, setTickMarkPaint, setTickMarkStroke, setTickMarksVisible, setVisible
-
Field Details
-
DEFAULT_AUTO_RANGE_INCLUDES_ZERO
The default value for the autoRangeIncludesZero flag.- See Also:
-
DEFAULT_AUTO_RANGE_STICKY_ZERO
The default value for the autoRangeStickyZero flag.- See Also:
-
DEFAULT_TICK_UNIT
The default tick unit. -
DEFAULT_VERTICAL_TICK_LABELS
The default setting for the vertical tick labels flag.- See Also:
-
-
Constructor Details
-
NumberAxis
public NumberAxis()Default constructor. -
NumberAxis
Constructs a number axis, using default values where necessary.- Parameters:
label- the axis label (nullpermitted).
-
-
Method Details
-
getRangeType
Returns the axis range type.- Returns:
- The axis range type (never
null). - See Also:
-
setRangeType
Sets the axis range type.- Parameters:
rangeType- the range type (nullnot permitted).- See Also:
-
getAutoRangeIncludesZero
Returns the flag that indicates whether or not the automatic axis range (if indeed it is determined automatically) is forced to include zero.- Returns:
- The flag.
-
setAutoRangeIncludesZero
Sets the flag that indicates whether or not the axis range, if automatically calculated, is forced to include zero.If the flag is changed to
true, the axis range is recalculated.Any change to the flag will trigger an
AxisChangeEvent.- Parameters:
flag- the new value of the flag.- See Also:
-
getAutoRangeStickyZero
Returns a flag that affects the auto-range when zero falls outside the data range but inside the margins defined for the axis.- Returns:
- The flag.
- See Also:
-
setAutoRangeStickyZero
Sets a flag that affects the auto-range when zero falls outside the data range but inside the margins defined for the axis.- Parameters:
flag- the new flag.- See Also:
-
getTickUnit
Returns the tick unit for the axis.Note: if the
autoTickUnitSelectionflag istruethe tick unit may be changed while the axis is being drawn, so in that case the return value from this method may be irrelevant if the method is called before the axis has been drawn.- Returns:
- The tick unit for the axis.
- See Also:
-
setTickUnit
Sets the tick unit for the axis and sends anAxisChangeEventto all registered listeners. A side effect of calling this method is that the "auto-select" feature for tick units is switched off (you can restore it using theValueAxis.setAutoTickUnitSelection(boolean)method).- Parameters:
unit- the new tick unit (nullnot permitted).- See Also:
-
setTickUnit
Sets the tick unit for the axis and, if requested, sends anAxisChangeEventto all registered listeners. In addition, an option is provided to turn off the "auto-select" feature for tick units (you can restore it using theValueAxis.setAutoTickUnitSelection(boolean)method).- Parameters:
unit- the new tick unit (nullnot permitted).notify- notify listeners?turnOffAutoSelect- turn off the auto-tick selection?
-
getNumberFormatOverride
Returns the number format override. If this is non-null, then it will be used to format the numbers on the axis.- Returns:
- The number formatter (possibly
null). - See Also:
-
setNumberFormatOverride
Sets the number format override. If this is non-null, then it will be used to format the numbers on the axis.- Parameters:
formatter- the number formatter (nullpermitted).- See Also:
-
getMarkerBand
Returns the (optional) marker band for the axis.- Returns:
- The marker band (possibly
null). - See Also:
-
setMarkerBand
Sets the marker band for the axis.The marker band is optional, leave it set to
nullif you don't require it.- Parameters:
band- the new band (nullpermitted).- See Also:
-
configure
Configures the axis to work with the specified plot. If the axis has auto-scaling, then sets the maximum and minimum values. -
autoAdjustRange
Rescales the axis to ensure that all data is visible.- Specified by:
autoAdjustRangein classValueAxis
-
valueToJava2D
Converts a data value to a coordinate in Java2D space, assuming that the axis runs along one edge of the specified dataArea.Note that it is possible for the coordinate to fall outside the plotArea.
- Specified by:
valueToJava2Din classValueAxis- Parameters:
value- the data value.area- the area for plotting the data.edge- the axis location.- Returns:
- The Java2D coordinate.
- See Also:
-
java2DToValue
Converts a coordinate in Java2D space to the corresponding data value, assuming that the axis runs along one edge of the specified dataArea.- Specified by:
java2DToValuein classValueAxis- Parameters:
java2DValue- the coordinate in Java2D space.area- the area in which the data is plotted.edge- the location.- Returns:
- The data value.
- See Also:
-
calculateLowestVisibleTickValue
Calculates the value of the lowest visible tick on the axis.- Returns:
- The value of the lowest visible tick on the axis.
- See Also:
-
calculateHighestVisibleTickValue
Calculates the value of the highest visible tick on the axis.- Returns:
- The value of the highest visible tick on the axis.
- See Also:
-
calculateVisibleTickCount
Calculates the number of visible ticks.- Returns:
- The number of visible ticks on the axis.
-
draw
public AxisState draw(Graphics2D g2, double cursor, Rectangle2D plotArea, Rectangle2D dataArea, RectangleEdge edge, PlotRenderingInfo plotState) Draws the axis on a Java 2D graphics device (such as the screen or a printer).- Specified by:
drawin classAxis- Parameters:
g2- the graphics device (nullnot permitted).cursor- the cursor location.plotArea- the area within which the axes and data should be drawn (nullnot permitted).dataArea- the area within which the data should be drawn (nullnot permitted).edge- the location of the axis (nullnot permitted).plotState- collects information about the plot (nullpermitted).- Returns:
- The axis state (never
null).
-
createStandardTickUnits
Creates the standard tick units.If you don't like these defaults, create your own instance of TickUnits and then pass it to the setStandardTickUnits() method in the NumberAxis class.
- Returns:
- The standard tick units.
- See Also:
-
createIntegerTickUnits
Returns a collection of tick units for integer values.- Returns:
- A collection of tick units for integer values.
- See Also:
-
createStandardTickUnits
Creates a collection of standard tick units. The supplied locale is used to create the number formatter (a localised instance ofNumberFormat).If you don't like these defaults, create your own instance of
TickUnitsand then pass it to thesetStandardTickUnits()method.- Parameters:
locale- the locale.- Returns:
- A tick unit collection.
- See Also:
-
createIntegerTickUnits
Returns a collection of tick units for integer values. Uses a given Locale to create the DecimalFormats.- Parameters:
locale- the locale to use to represent Numbers.- Returns:
- A collection of tick units for integer values.
- See Also:
-
estimateMaximumTickLabelHeight
Estimates the maximum tick label height.- Parameters:
g2- the graphics device.- Returns:
- The maximum height.
-
estimateMaximumTickLabelWidth
Estimates the maximum width of the tick labels, assuming the specified tick unit is used.Rather than computing the string bounds of every tick on the axis, we just look at two values: the lower bound and the upper bound for the axis. These two values will usually be representative.
- Parameters:
g2- the graphics device.unit- the tick unit to use for calculation.- Returns:
- The estimated maximum width of the tick labels.
-
selectAutoTickUnit
Selects an appropriate tick value for the axis. The strategy is to display as many ticks as possible (selected from an array of 'standard' tick units) without the labels overlapping.- Parameters:
g2- the graphics device.dataArea- the area defined by the axes.edge- the axis location.
-
selectHorizontalAutoTickUnit
protected void selectHorizontalAutoTickUnit(Graphics2D g2, Rectangle2D dataArea, RectangleEdge edge) Selects an appropriate tick value for the axis. The strategy is to display as many ticks as possible (selected from an array of 'standard' tick units) without the labels overlapping.- Parameters:
g2- the graphics device.dataArea- the area defined by the axes.edge- the axis location.
-
selectVerticalAutoTickUnit
Selects an appropriate tick value for the axis. The strategy is to display as many ticks as possible (selected from an array of 'standard' tick units) without the labels overlapping.- Parameters:
g2- the graphics device.dataArea- the area in which the plot should be drawn.edge- the axis location.
-
refreshTicks
Calculates the positions of the tick labels for the axis, storing the results in the tick label list (ready for drawing).- Specified by:
refreshTicksin classAxis- Parameters:
g2- the graphics device.state- the axis state.dataArea- the area in which the plot should be drawn.edge- the location of the axis.- Returns:
- A list of ticks.
-
refreshTicksHorizontal
Calculates the positions of the tick labels for the axis, storing the results in the tick label list (ready for drawing).- Parameters:
g2- the graphics device.dataArea- the area in which the data should be drawn.edge- the location of the axis.- Returns:
- A list of ticks.
-
refreshTicksVertical
Calculates the positions of the tick labels for the axis, storing the results in the tick label list (ready for drawing).- Parameters:
g2- the graphics device.dataArea- the area in which the plot should be drawn.edge- the location of the axis.- Returns:
- A list of ticks.
-
clone
Returns a clone of the axis.- Specified by:
clonein interfacePublicCloneable- Overrides:
clonein classValueAxis- Returns:
- A clone
- Throws:
CloneNotSupportedException- if some component of the axis does not support cloning.
-
equals
Tests the axis for equality with an arbitrary object. -
hashCode
Returns a hash code for this object.
-