Axes
Axes visualize spatial scale mappings using ticks, grid lines and labels. Vega currently supports axes for Cartesian (rectangular) coordinates. Similar to scales, axes can be defined either at the top-level of the specification, or as part of a group mark.
Axis Properties
Properties for specifying a coordinate axis.
Property | Type | Description |
---|---|---|
scale | String | Required. The name of the scale backing the axis component. |
orient | String | Required. The orientation of the axis. See the axis orientation reference. |
bandPosition | Number | An interpolation fraction indicating where, for band scales, axis ticks should be positioned. A value of 0 places ticks at the left edge of their bands. A value of 0.5 places ticks in the middle of their bands. |
domain | Boolean | A boolean flag indicating if the domain (the axis baseline) should be included as part of the axis (default true ). |
domainCap | String | The stroke cap for the axis domain line. One of "butt" (default), "round" or "square" . ≥ 5.11 |
domainColor | Color | Color of axis domain line. |
domainDash | Number[ ] | Stroke dash of axis domain lines (or [] for solid lines). ≥ 5.0 |
domainDashOffset | Number | The pixel offset at which to start the domain dash array. ≥ 5.0 |
domainOpacity | Number | Opacity of axis domain line. ≥ 4.1 |
domainWidth | Number | Stroke width of axis domain line. |
encode | Object | Optional mark encodings for custom axis styling. Supports encoding blocks for axis , ticks , grid , labels , title , and domain . See custom axis encodings. |
format | String | TimeMultiFormat | The format specifier pattern for axis labels. For numerical values, must be a legal d3-format specifier. For date-time values, must be a legal d3-time-format specifier or a TimeMultiFormat object. |
formatType | String | Specifies the type of format to use ("number" , "time" , "utc" ) for scales that do not have a strict domain data type. This property is useful for formatting date-time values for band or point scales. If specified, the format property must have a valid specifier pattern for the given type. Supported ≥ 5.1, UTC support ≥ 5.8. |
grid | Boolean | A boolean flag indicating if grid lines should be included as part of the axis (default false ). |
gridCap | String | The stroke cap for axis grid lines. One of "butt" (default), "round" or "square" . ≥ 5.11 |
gridColor | Color | Color of axis grid lines. |
gridDash | Number[ ] | Stroke dash of axis grid lines (or [] for solid lines). |
gridDashOffset | Number | The pixel offset at which to start the grid dash array. ≥ 5.0 |
gridOpacity | Number | Opacity of axis grid lines. |
gridScale | String | The name of the scale to use for including grid lines. By default grid lines are driven by the same scale as the ticks and labels. |
gridWidth | Number | Stroke width of axis grid lines. |
labels | Boolean | A boolean flag indicating if labels should be included as part of the axis (default true ). |
labelAlign | String | Horizontal text alignment of axis tick labels, overriding the default setting for the current axis orientation. |
labelAngle | Number | Angle in degrees of axis tick labels. |
labelBaseline | String | Vertical text baseline of axis tick labels, overriding the default setting for the current axis orientation. One of alphabetic (default), top , middle , bottom , line-top , or line-bottom . The line-top and line-bottom values ≥ 5.10 operate similarly to top and bottom , but are calculated relative to the lineHeight rather than fontSize alone. |
labelBound | Boolean | Number | Indicates if labels should be hidden if they exceed the axis range. If false (the default) no bounds overlap analysis is performed. If true , labels will be hidden if they exceed the axis range by more than 1 pixel. If this property is a number, it specifies the pixel tolerance: the maximum amount by which a label bounding box may exceed the axis range. |
labelColor | Color | Text color of axis tick labels. |
labelFlush | Boolean | Number | Indicates if labels at the beginning or end of the axis should be aligned flush with the scale range. If a number, indicates a pixel distance threshold: labels with anchor coordinates within the threshold distance for an axis end-point will be flush-adjusted. If true , a default threshold of 1 pixel is used. Flush alignment for a horizontal axis will left-align labels near the beginning of the axis and right-align labels near the end. For vertical axes, bottom and top text baselines will be applied instead. |
labelFlushOffset | Number | Indicates the number of pixels by which to offset flush-adjusted labels (default 0 ). For example, a value of 2 will push flush-adjusted labels 2 pixels outward from the center of the axis. Offsets can help the labels better visually group with corresponding axis ticks. |
labelFont | String | Font name for axis tick labels. |
labelFontSize | Number | Font size of axis tick labels. |
labelFontStyle | String | Font style of axis tick labels (e.g., normal or italic ). ≥ 5.0 |
labelFontWeight | String | Number | Font weight of axis tick labels. |
labelLimit | Number | The maximum allowed length in pixels of axis tick labels. |
labelLineHeight | Number | Line height in pixels for multi-line label text or label text with "line-top" or "line-bottom" baseline. ≥ 5.10 |
labelOffset | Number | Position offset in pixels to apply to labels, in addition to tickOffset. ≥ 5.10 |
labelOpacity | Number | Opacity of axis tick labels. ≥ 4.1 |
labelOverlap | Boolean | String | The strategy to use for resolving overlap of axis labels. If false (the default), no overlap reduction is attempted. If set to true or "parity" , a strategy of removing every other label is used (this works well for standard linear axes). If set to "greedy" , a linear scan of the labels is performed, removing any label that overlaps with the last visible label (this often works better for log-scaled axes). |
labelPadding | Number | The padding in pixels between labels and ticks. |
labelSeparation | Number | The minimum separation that must be between label bounding boxes for them to be considered non-overlapping (default 0 ). This property is ignored if labelOverlap resolution is not enabled. ≥ 5.0 |
minExtent | Number | Value | The minimum extent in pixels that axis ticks and labels should use. This determines a minimum offset value for axis titles. |
maxExtent | Number | Value | The maximum extent in pixels that axis ticks and labels should use. This determines a maximum offset value for axis titles. |
offset | Number | Value | The orthogonal offset in pixels by which to displace the axis from its position along the edge of the chart. |
position | Number | Value | The anchor position of the axis in pixels (default 0 ). For x-axes with top or bottom orientation, this sets the axis group x coordinate. For y-axes with left or right orientation, this sets the axis group y coordinate. |
ticks | Boolean | A boolean flag indicating if ticks should be included as part of the axis (default true ). |
tickBand | String | Indicates the type of tick style to use in conjunction with band scales. One of "center" (default) to center ticks in the middle of the band interval, or "extent" to place ticks at band extents (interval boundaries). If specified, this property may override the settings of bandPosition , tickExtra , and tickOffset . ≥ 5.8 |
tickCap | String | The stroke cap for axis tick marks. One of "butt" (default), "round" or "square" . ≥ 5.11 |
tickColor | Color | Color of axis ticks. |
tickCount | Number | String | Object | A desired number of ticks, for axes visualizing quantitative scales. The resulting number may be different so that values are “nice” (multiples of 2, 5, 10) and lie within the underlying scale’s range. For scales of type time or utc , the tick count can instead be a time interval specifier. Legal string values are "millisecond" , "second" , "minute" , "hour" , "day" , "week" , "month" , and "year" . Alternatively, an object-valued interval specifier of the form {"interval": "month", "step": 3} includes a desired number of interval steps. Here, ticks are generated for each quarter (Jan, Apr, Jul, Oct) boundary. |
tickDash | Number[ ] | Stroke dash of axis tick marks (or [] for solid lines). ≥ 5.0 |
tickDashOffset | Number | The pixel offset at which to start the tick mark dash array. ≥ 5.0 |
tickMinStep | Number | The minimum desired step between axis ticks, in terms of scale domain values. For example, a value of 1 indicates that ticks should not be less than 1 unit apart. If tickMinStep is specified, the tickCount value will be adjusted, if necessary, to enforce the minimum step value. ≥ 5.0 |
tickExtra | Boolean | Boolean flag indicating if an extra axis tick should be added for the initial position of the axis. This flag is useful for styling axes for band scales such that ticks are placed on band boundaries rather in the middle of a band. Use in conjunction with "bandPosition": 1 and an axis "padding" value of 0 . |
tickOffset | Number | Position offset in pixels to apply to ticks, labels, and gridlines. |
tickOpacity | Number | Opacity of axis ticks. ≥ 4.1 |
tickRound | Boolean | Boolean flag indicating if pixel position values should be rounded to the nearest integer. |
tickSize | Number | The length in pixels of axis ticks. |
tickWidth | Number | Width in pixels of axis ticks. |
title | String | String[ ] | A title for the axis (none by default). For versions ≥ 5.7, a string array specifies a title with multiple lines of text. |
titleAnchor | String | The anchor position for placing the axis title. One of "start" , "middle" , "end" , or null (default, for automatic determination). For example, with an orient of "bottom" these anchor positions map to a left-, center-, or right-aligned title. The anchor point is determined relative to the axis scale range. ≥ 5.0 |
titleAlign | String | Horizontal text alignment of the axis title. One of "left" , "center" , or "right" . If specified, this value overrides automatic alignment based on the titleAnchor value. |
titleAngle | Number | Angle in degrees of the axis title. |
titleBaseline | String | Vertical text baseline of the axis title. One of alphabetic (default), top , middle , bottom , line-top , or line-bottom . The line-top and line-bottom values ≥ 5.10 operate similarly to top and bottom , but are calculated relative to the lineHeight rather than fontSize alone. |
titleColor | Color | Text color of the axis title. |
titleFont | String | Font name of the axis title. |
titleFontSize | Number | Font size of the axis title. |
titleFontStyle | String | Font style of the axis title (e.g., normal or italic ). ≥ 5.0 |
titleFontWeight | String | Number | Font weight of axis title. |
titleLimit | Number | The maximum allowed length in pixels of the axis title. |
titleLineHeight | Number | Line height in pixels for multi-line title text or title text with "line-top" or "line-bottom" baseline. ≥ 5.7 |
titleOpacity | Number | Opacity of axis title. ≥ 4.1 |
titlePadding | Number | Value | The padding in pixels between the axis labels and axis title. |
titleX | Number | Custom X position of the axis title relative to the axis group, overriding the standard layout. |
titleY | Number | Custom Y position of the axis title relative to the axis group, overriding the standard layout. |
translate | Number | Coordinate space translation offset for axis layout. By default, axes are translated by a 0.5 pixel offset for both the x and y coordinates in order to align stroked lines with the pixel grid. However, for vector graphics output these pixel-specific adjustments may be undesirable, in which case translate can be changed (for example, to zero). ≥ 5.8 |
values | Array | Explicitly set the visible axis tick and label values. The array entries should be legal values in the backing scale domain. |
zindex | Number | The integer z-index indicating the layering of the axis group relative to other axis, mark, and legend groups. The default value is 0 and axes and grid lines are drawn behind any marks defined in the same specification level. Higher values (1 ) will cause axes and grid lines to be drawn on top of marks. |
Accessibility Properties ≥ 5.11
Accessibility properties are used to determine ARIA (Accessible Rich Internet Applications) attributes when using Vega to render SVG output.
Property | Type | Description |
---|---|---|
aria | Boolean | A boolean flag (default true ) indicating if ARIA attributes should be included (SVG output only). If false , the “aria-hidden” attribute will be set on the output SVG group, removing the axis from the ARIA accessibility tree. |
description | String | A text description of this axis for ARIA accessibility (SVG output only). If the aria property is true , for SVG output the “aria-label” attribute will be set to this description. If the description is unspecified it will be automatically generated. |
Themes and Configuration
To create themes, new default values for many axis properties can be set using a config object.
Axis Orientation Reference
Valid settings for the axis orient parameter.
Value | Description |
---|---|
left |
Place a y-axis along the left edge of the chart. |
right |
Place a y-axis along the right edge of the chart. |
top |
Place an x-axis along the top edge of the chart. |
bottom |
Place an x-axis along the bottom edge of the chart. |
Custom Axis Encodings
Custom mark properties can be set for all axis elements using the encode parameter. The addressable elements are:
axis
for the axis group mark,ticks
for tick rule marks,grid
for gridline rule marks,labels
for label text marks,title
for the title text mark, anddomain
for the axis domain rule mark.
Each element accepts a set of visual encoding directives grouped into enter
, update
, exit
, etc. objects as described in the Marks documentation. Mark properties can be styled using standard value references.
In addition, each encode block may include a string-valued name
property to assign a unique name to the mark set, a boolean-valued interactive
property to enable input event handling, and a string-valued (or array-valued) style
property to apply default property values. Unless otherwise specified, title elements use a default style of "guide-title"
and labels elements use a default style of "guide-label"
.
Each axis tick, grid line, and label instance is backed by a data object with the following fields, which may be accessed as part of a custom visual encoding rule.
label
- the string labelvalue
- the data valueindex
- fractional tick index (0
for the first tick and1
for the last tick)
The following example shows how to set custom colors, thickness, text angle, and fonts. The labels
encoding block also make legend labels responsive to input events, and changes the text color on mouse hover.
"axes": [
{
"orient": "bottom",
"scale": "x",
"title": "X-Axis",
"encode": {
"ticks": {
"update": {
"stroke": {"value": "steelblue"}
}
},
"labels": {
"interactive": true,
"update": {
"text": {"signal": "format(datum.value, '+,')"},
"fill": {"value": "steelblue"},
"angle": {"value": 50},
"fontSize": {"value": 14},
"align": {"value": "left"},
"baseline": {"value": "middle"},
"dx": {"value": 3}
},
"hover": {
"fill": {"value": "firebrick"}
}
},
"title": {
"update": {
"fontSize": {"value": 16}
}
},
"domain": {
"update": {
"stroke": {"value": "#333"},
"strokeWidth": {"value": 1.5}
}
}
}
}
]
Custom text can be defined using the "text"
property for labels
. For example, one could define an ordinal scale that serves as a lookup table from axis values to axis label text.