CartesianValueFormatter
x and y values are numerical. You can use CartesianValueFormatter
to format them for display. They can remain numbers, or they can be transformed to dates, category names, and so on.
There are two CartesianValueFormatter
factory functions: CartesianValueFormatter.decimal
and CartesianValueFormatter.yPercent
. For more complex use cases, create custom implementations can be created. CartesianValueFormatter
s are most commonly used with HorizontalAxis
and VerticalAxis
—see the valueFormatter
parameters and properties. However, these aren’t the only APIs that accept CartesianValueFormatter
instances.
When the values remain numerical, formatting is straightforward. DecimalFormat
, which is used by CartesianValueFormatter.decimal
, is typically involved. Thus, on this page, we focus on formatting with nonnumerical results. The aim in such cases is to find a predictable mapping that doesn’t involve overly large values (as these can lead to precision loss). The optimal approach depends on the use case. Some common situations are discussed below.
A chart’s domain can be a list of categories. An easy way to implement this pattern is to use x values that serve as indices. As previously discussed, the series-creating functions have overloads that add such x values automatically.
Another common use case is mapping dates to y values.
The dates will be spaced out proportionally. If you need nonproportional spacing, use the approach from 2.8.2. This is also worth considering if there are no gaps in your data, in which case there’s no distinction between proportional and nonproportional spacing—the category approach will be simpler.