ChartAxis
Render axis frames, ticks and labels on a ChartContainer.
data:image/s3,"s3://crabby-images/27315/273150e2ede89a70c6e974f96c77fe7f3a2ab9b0" alt="Screenshot of component ChartAxis topofdoc"
Usage
Import the component and include it inside a ChartContainer
to enable the axis frame and gridlines with automatic tick settings.
data:image/s3,"s3://crabby-images/89653/89653cbf858e287cca46c256eb131808ec28a099" alt="Screenshot of component ChartAxis basic"
HorizontalAxis
represents the x-axis of the chart, or for streaming line charts using RealTimeDomain
we use TimeAxis
. VerticalAxis
is the y-axis.
The two axis components can operate standalone or together, and both share the same configuration properties.
import { ChartContainer , LineChart , RealTimeDomain , TimeAxis , VerticalAxis ,} from '@electricui/components-desktop-charts'import { useMessageDataSource } from '@electricui/core-timeseries' const OverviewPage = () => { const signalDataSource = useMessageDataSource ('speed') return ( <React .Fragment > <ChartContainer > <LineChart dataSource ={signalDataSource } /> <RealTimeDomain window ={10000} /> <TimeAxis /> <VerticalAxis /> </ChartContainer > </React .Fragment > )}
Labels
Configure axis labels by passing the label
property a string.
data:image/s3,"s3://crabby-images/d979a/d979a76a4ea4d850d46cee7df0ac39da0a69990e" alt="Screenshot of component ChartAxis label"
<TimeAxis label ="Time (s)" /><VerticalAxis label ="Speed (RPM)" />
The labelPadding
property is available on both axis, specifying the spacing between the labels and the chart.
data:image/s3,"s3://crabby-images/533cd/533cdc4ce6bdbbcc3edd79728d933c680180ceb7" alt="Screenshot of component ChartAxis labelpadding"
<TimeAxis label ="Time (s)" labelPadding ={30} />
Tick Quantity
Pass tickCount
a positive number to override the number of ticks drawn on the axis frame.
This value is approximate - it prioritises evenly spaced and 'round' numbered ticks over strict adherence to the count.
data:image/s3,"s3://crabby-images/c8eb7/c8eb761823853086e83f0985df532573209ff620" alt="Screenshot of component ChartAxis tickcount"
<TimeAxis tickCount ={2} /><VerticalAxis tickCount ={8} />
Tick Values
Pass tickValues
an array of numbers to manually specify the tick render behaviour.
This can be useful where varying densities of grid-lines and axis ticks improve readability.
data:image/s3,"s3://crabby-images/7d896/7d896354270297b1dce8f557826f3c2538f8f625" alt="Screenshot of component ChartAxis tickvalues"
<VerticalAxis tickValues ={[0, 300, 500, 700, 1000]} />
tickValues
is not available on theTimeAxis
component.
Custom Tick Formatting
Format ticks by passing a the tickFormat
prop a styling function.
Commonly used for adding symbols like degrees °
, or changing the text from the raw value 10000
to a more readable string such as 10k
.
data:image/s3,"s3://crabby-images/25a5b/25a5bbef7732ed6b8a1ba927b4108eabc97bc833" alt="Screenshot of component ChartAxis tickformat"
It passes the current tick, the index of the tick, and the entire array of ticks as arguments and expects a string or number as a return value.
<VerticalAxis tickFormat ={(tick : number, index : number, ticks : number[]) => `${tick / 1000}k` } label ="ADC Counts"/>
A common distinction for formatting occurs when allowing user-selectable Zoom levels.
When this occurs, absolute time is used and alternative formatting controls are available with
tickFormatAbsolute
Specifying data ranges
By default, the chart will autoscale the y-axis based on the range of visible data. To constrain the bounds, use the yMin
and yMax
properties of the domain component of the chart. While the axis component provides the visual tick marks, the domain component controls the actual bounds of data.
TimeAxis alignment
The TimeAxis
has the 0
aligned to the right by default. That alignment can be changed via the align
prop to the left
, right
or center
. By default values don't display a negative sign, but if this behaviour is undesirable, it can be disabled by setting the allowNegative
prop.
This chart has its time axis aligned to the right, no allowNegative
, this is the default:
<TimeAxis align ="right" />
data:image/s3,"s3://crabby-images/fa071/fa071f33ab33101d5960954297b72e4212e83496" alt="Screenshot of component ChartAxis time-axis-right-aligned-no-negative"
Aligned to the right, with allowNegative
:
<TimeAxis align ="right" allowNegative />
data:image/s3,"s3://crabby-images/dffea/dffea2bcec560cffe2ab2970c962ca369eb1667f" alt="Screenshot of component ChartAxis time-axis-right-aligned-allow-negative"
Aligned to the left: (allowNegative
has no effect here since the origin is on the left)
<TimeAxis align ="left" />
data:image/s3,"s3://crabby-images/2ed91/2ed9181b981eaf0d8b935970166cc7151ef39217" alt="Screenshot of component ChartAxis time-axis-left-aligned-no-negative"
Center aligned, no allowNegative
:
<TimeAxis align ="center" />
data:image/s3,"s3://crabby-images/aaf4b/aaf4bfeeda31fe1111827a340bc62737349e1523" alt="Screenshot of component ChartAxis time-axis-center-aligned-no-negative"
Center aligned, with allowNegative
:
<TimeAxis align ="center" allowNegative />
data:image/s3,"s3://crabby-images/1a4d6/1a4d6b0ef2d073a8cdb36228d7d3db1afda7bbcf" alt="Screenshot of component ChartAxis time-axis-center-aligned-allow-negative"