Bubble Chart
The Blazor Bubble chart shows the data as points with coordinates and size defined by their items' values. You might think of a Bubble chart as a variation of the Scatter chart, in which the data points are replaced with bubbles. This allows a Bubble chart to display three dimensional data — two values for the items' coordinates and one for their size.
A Bubble chart is useful for visualizing different scientific relationships (e.g, economical, social, etc.). This chart type's x-axis is also numerical and does not require items.
This article assumes you are familiar with the chart basics and data binding.
To create a bubble chart:
- add a
ChartSeries
to theChartSeriesItems
collection - set its
Type
property toChartSeriesType.Bubble
- provide a data collection to its
Data
property, which contains numerical data for the X and Y axes, and for the bubble size
@* Bubble Series *@
<TelerikChart>
<ChartSeriesItems>
<ChartSeries Type="ChartSeriesType.Bubble"
Data="@Series1Data"
Name="North America"
XField="@nameof(ModelData.LifeExpectancy)"
YField="@nameof(ModelData.FertilityRate)"
SizeField="@nameof(ModelData.PopulationChange)">
<ChartSeriesLabels Visible="true" Template="@labelTemplate"></ChartSeriesLabels>
</ChartSeries>
<ChartSeries Type="ChartSeriesType.Bubble"
Data="@Series2Data"
Name="Europe"
XField="@nameof(ModelData.LifeExpectancy)"
YField="@nameof(ModelData.FertilityRate)"
SizeField="@nameof(ModelData.PopulationChange)">
<ChartSeriesLabels Visible="true" Template="@labelTemplate"></ChartSeriesLabels>
</ChartSeries>
</ChartSeriesItems>
<ChartXAxes>
<ChartXAxis>
<ChartXAxisTitle Text="Life Expectancy (years)"></ChartXAxisTitle>
</ChartXAxis>
</ChartXAxes>
<ChartYAxes>
<ChartYAxis>
<ChartYAxisTitle Text="Fertility Rate (children per family)"></ChartYAxisTitle>
</ChartYAxis>
</ChartYAxes>
<ChartTitle Text="Life expectancy, fertility rate and projected population change" />
</TelerikChart>
@code {
string labelTemplate = "#=dataItem.Country#";
public class ModelData
{
public double LifeExpectancy { get; set; }
public double FertilityRate { get; set; }
public int PopulationChange { get; set; }
public string Country { get; set; }
}
public List<ModelData> Series1Data = new List<ModelData>()
{
new ModelData() { LifeExpectancy = 80.66, FertilityRate = 1.27, PopulationChange = 500000, Country = "Canada" },
new ModelData() { LifeExpectancy = 78.09, FertilityRate = 2.3, PopulationChange = 7600000, Country = "USA" }
};
public List<ModelData> Series2Data = new List<ModelData>()
{
new ModelData() { LifeExpectancy = 67.3, FertilityRate = 1.54, PopulationChange = 25000, Country = "Denmark" },
new ModelData() { LifeExpectancy = 74.3, FertilityRate = 1.85, PopulationChange = 3000000, Country = "Great Britain" }
};
}
Bubble Chart Specific Appearance Settings
Color
The color of a series is controlled through the Color
property that can take any valid CSS color (for example, #abcdef
, #f00
, or blue
). The color control the fill color of the bubble.
The ColorField
can change the color of individual items. To use it, pass a valid CSS color to the corresponding field in the model and the chart will use its values instead of the Color
parameter.
Opacity
You can control how transparent the series fill is through the Opacity
property. 0
means a completely transparent series, and 1
means a completely opaque (non-transparent) fill. You can use decimal values to set the desired transparency (for example, Opacity="0.3"
).
Negative Values
Negative values are allowed for the X and Y fields, because they are plotted on standard numerical axes.
The size field should, generally, have positive values as it correlates to the physical size of the bubble. To render negative values, set the Visible
parameter of the ChartSeriesNegativeValues
tag of the series to true
. Bubbles with negative size values will be calculated as if their sizes are positive. To distinguish one from the other, you can have negative items show up in a different color through the Color
parameter of the ChartSeriesNegativeValues
tag.
@* Negative bubble sizes can showcase decreases in values and can render in different color than the rest of the series *@
<TelerikChart>
<ChartSeriesItems>
<ChartSeries Type="ChartSeriesType.Bubble"
Data="@SeriesData"
XField="@nameof(ModelData.X)"
YField="@nameof(ModelData.Y)"
SizeField="@nameof(ModelData.Size)">
<ChartSeriesNegativeValues Visible="true" Color="cyan"></ChartSeriesNegativeValues>
<ChartSeriesLabels Visible="true" Template="#=dataItem.MetaData#"></ChartSeriesLabels>
</ChartSeries>
</ChartSeriesItems>
</TelerikChart>
@code {
public class ModelData
{
public int X { get; set; }
public int Y { get; set; }
public int Size { get; set; }
public string MetaData { get; set; }
}
public List<ModelData> SeriesData = new List<ModelData>()
{
new ModelData() { X = 250, Y = 5000, Size = 50000 , MetaData = "positive size"},
new ModelData() { X = 500, Y = 1100, Size = -760000, MetaData = "negative size" }
};
}
Customize Chart Elements - Nested Tags Settings
When configuring nested properties and child elements in your chart, the inner tags will contain their parent tag name and add specifics to its end. In general the structure of such nested tags will be <Chart*Category**Specifics*>
where the Category can be one of the following:
- CategoryAxis
- ChartArea
- Legend
- PlotArea
- SeriesItems
- Title
- Tooltip
- ValueAxis
- XAxes
- YAxes
- and others
To customize the chart, look for nested tags and their properties - the inner tags will contain their parent tag name and add specifics to its end. For example, the
ChartSeries
tag has aChartSeriesLabels
tag that exposes configuration options and more child tags.
For example, for numerical charts you can rotate the Labels for ChartXAxes
or ChartYAxes
depending on your application design needs and layout. This can be done through the
ChartXAxes
> ChartXAxis
> ChartXAxisLabelsRotation
tag
where you can set the Angle
property to the desired value in degrees (they might be negative or positive numbers). By using similar approach you can take control over ChartXAxisLabelsBorder
(add borders), ChartXAxisLabelsMargin
(add margin for top, bottom, left and right) and others.
This approach is not limited only to the Labels - it can be used with to all tags that are applicable for the chart type, for example the Chart Title ChartTitle
> ChartTitleMargin
.