Skip to content
+

Charts - Scatter

Scatter charts express the relation between two variables, using points in a surface.

Overview

Scatter charts are ideal for visualizing relationships or correlations as they show how one variable changes relative to another, identifying clusters, trends, and outliers in datasets. Each point represents an individual data observation, positioned by its values on the two axes, often revealing patterns. Scatter charts are commonly used for statistical analysis, scientific data, and performance metrics.

Processor density (in transistor/mm²)

  • Other
  • Intel
  • Apple
  • AMD

Basics

Scatter chart series should contain a data property containing an array of objects. Those objects require the x and y properties. With an optional id property if more optimization is needed.

  • Series A
  • Series B
Press Enter to start editing

Using a dataset

If your data is stored in an array of objects, you can use the dataset helper prop. It accepts an array of objects such as dataset={[{a: 1, b: 32, c: 873}, {a: 2, b: 41, c: 182}, ...]}.

You can reuse this data when defining the series. The scatter series work a bit differently than in other charts. You need to specify the datasetKeys properties which is an object that requires the x and y keys. With an optional id and z keys if needed.

  • Series A
  • Series B
Press Enter to start editing

Interaction

Since scatter elements can be small, interactions do not require hovering exactly over an element. When the pointer is in the drawing area, the closest scatter element will be used for interactions (tooltip or highlights). To do so, the chart computes Voronoi cells which map the pointer position to the closest element.

You can define a maximal radius with the voronoiMaxRadius prop. If the distance with the pointer is larger than this radius, no item will be selected. Alternatively, set the voronoiMaxRadius prop to item to trigger interactions only when hovering exactly over an element instead of Voronoi cells.

  • Series A
  • Series B

Maximum radius

Numeric radius

Click event

Scatter Chart provides an onItemClick handler for handling clicks on specific scatter items. It has the following signature.

const onItemClick = (
  event, // The mouse event.
  params, // An object that identifies the clicked elements.
) => {};
  • A
  • B

Click on the chart

// The data will appear here

If voronoiMaxRadius is item, users need to click precisely on the scatter element, and the mouse event will come from this element.

Otherwise, the click behavior will be the same as defined in the interaction section and the mouse event will come from the svg component.

Styling

Color scale

As with other charts, you can modify the series color either directly, or with the color palette.

You can also modify the color by using axes colorMap which maps values to colors. The scatter charts use by priority:

  1. The z-axis color
  2. The y-axis color
  3. The x-axis color
  4. The series color

Learn more about the colorMap properties in the Styling docs.

x-axis colorMap
y-axis colorMap
z-axis colorMap
<ScatterChart
  /* ... */
  series={[{ data: data.map(point => ({...point, z: point.x + point.y})) }]}
  xAxis={[{
    colorMap: {
      type: 'piecewise',
      thresholds: [-1.5, 0, 1.5],
      colors: ['#d01c8b', '#f1b6da', '#b8e186', '#4dac26'],
    }
  }]}
  yAxis={[{}]}
  zAxis={[{}]}
/>

Grid

You can add a grid in the background of the chart with the grid prop.

See Axis—Grid documentation for more information.

  • Series A
  • Series B
Press Enter to start editing

CSS

You can target scatter markers with the following CSS selectors:

  • [data-series='<series id>'] Selects the group containing markers of the series with the given id.
  • [data-highlighted=true] Selects markers with highlighted state.
  • [data-faded=true] Selects markers with faded state.

To select all marker groups, use the scatterClasses.root class name.

Here is an example that customizes the look of highlighted items depending on the series they belong to.

  • Series A
  • Series B
Press Enter to start editing

Shape

The shape of points in a scatter chart can be customized by passing a component to the marker slot.

If you want the legend and tooltip to match, then you also need to customize the labelMarkType of each series, as shown in the example below.

  • Series A
  • Series B

Size

You can customize the size of points in a scatter chart using the markerSize prop of every series. For circles, the markerSize is the radius of the point in pixels.

  • Series A
  • Series B
Press Enter to start editing

Plot customization

You can customize the plotting of the data in a scatter chart by providing custom components as children of the ScatterChart component.

A scatter chart's series can be accessed through the useScatterSeries hook. This hook returns the order of the series and information about the series themselves, including their data points, color, etc.

See Custom components to learn how to further customize your charts.

  • Open
  • Closed
Press Enter to start editing

Performance

Scatter charts can have a lot of data points, which can impact performance. The default rendering of scatter points uses SVG circle elements, which can be slow for a large number of points.

To improve performance, you can use the renderer prop set to "svg-batch", which renders the circles more efficiently. However, this comes with the following limitations:

  • CSS styling of single circle elements is no longer possible;
  • Overriding the marker slot is not supported;
  • Transparent highlight style: for performance reasons, the highlighted state creates a highlighted circle on top of the original marker. Applying transparency to the highlighted circle can cause the original circle to be partially visible;
  • disableHover for scatter series does not work.

On top of that, there's also some differences in behavior:

  • The rendering order might be different, which might cause overlapping circles to render at different depths when compared to the default rendering;
  • When disableVoronoi is true, onItemClick does not work as it requires that plugin to work.

The example below uses the renderer prop to improve performance when rendering a dataset with 16,000 data points.

Life-cycle Carbon Intensity of Electricity Generation - 2024
  • Belgium
  • Switzerland
  • Germany
  • Denmark
  • Spain
  • France
  • Italy
  • Norway
  • Poland
  • Portugal
  • Sweden
Source: ENTSO-E, ElectricityMaps.com
Press Enter to start editing

Composition

Use the <ChartDataProvider /> to provide series, xAxis, and yAxis props for composition.

In addition to the common chart components available for composition, you can use the <ScatterPlot /> component that renders the scatter marks.

Here's how the Scatter Chart is composed:

<ChartDataProvider>
  <ChartsWrapper>
    <ChartsLegend />
    <ChartsSurface>
      <ChartsAxis />
      <ChartsGrid />
      <g data-drawing-container>
        {/* Elements able to overflow the drawing area. */}
        <ScatterPlot />
      </g>
      <ChartsOverlay />
      <ChartsAxisHighlight />
    </ChartsSurface>
    <ChartsTooltip trigger="item" />
  </ChartsWrapper>
</ChartDataProvider>

Regression line

You add a regression line to a scatter plot by leveraging composition.

Relation between Weight and Price of Diamonds
Source: OpenML

API

See the documentation below for a complete reference to all of the props and classes available to the components mentioned here.