TL;DR: Let’s see how to use the .NET MAUI Stacked Area Chart to visualize 100+ years of exports by economic superpowers. The blog covers gathering data, configuring the chart, and adding annotations for enhanced clarity. You’ll learn to bind data and use text, shape, and view annotations to highlight key points.
Welcome to our Chart of the Week blog series!
Today, we’ll visualize the economic history of global superpowers over 100+ years using the Syncfusion .NET MAUI Stacked Area Chart and its annotation feature.
Throughout the centuries, nations have risen and fallen, and their economic influence has profoundly shaped the global stage. In this exploration, we’ll leverage data visualization to unravel the stories behind the numbers, revealing the economic forces that have shaped our modern world.
Join us on a captivating journey through economic history as we visualize a century of exports from the world’s leading economic powers.
Annotations are essential for enhancing the visual appeal and informational depth of charts. They allow us to add additional elements, such as shapes, text, or even custom views, to highlight specific areas of interest and provide context to the data. Before we delve into annotations, we’ll first design the Stacked Area Chart to analyze the economic history of global superpowers over the past 100+ years.
Let’s get started!
Before creating the chart, we need to gather data on 100+ years of exports for top economic superpowers from this Export Data source, page no 21.
Now, create the ExportModel class to hold export data for various countries with the Year and Export values.
public class ExportModel { public DateTime Year {get; set;} public double UK {get; set;} public double Germany {get; set;} public double US {get; set;} public double Japan {get; set;} public double China {get; set;} }
Next, generate the data collection with the help of the ExportViewModel class and ExportData collection.
public class ExportViewModel { public ObservableCollection ExportData {get; set; } public ExportViewModel () { ExportData = new ObservableCollection (). ExportData.Add(new ExportModel () {Year = new DateTime (1913, 01, 01), China = 2.0, US = 9.0, Germany = 18.0, Japan = 0.8, UK = 18.5}); ExportData.Add(new ExportModel () {Year = new DateTime (1929, 01, 01), China = 2.4, US = 11.5, Germany = 13.3, Japan = 1.7, UK = 12.2}); ExportData.Add(new ExportModel () {Year = new DateTime (1950, 01, 01), China = 2.1, US = 14.6, Germany = 4.5, Japan = 1.2, UK = 13.3}); ExportData.Add(new ExportModel () {Year = new DateTime (1973, 01, 01), China = 0.7, US = 10.3, Germany = 11.5, Japan = 5.6, UK = 5.6}); ExportData.Add(new ExportModel () {Year = new DateTime (1990, 01, 01), China = 1.8, US = 11.3, Germany = 12.0, Japan = 8.2, UK = 5.3}); ExportData.Add(new ExportModel () {Year = new DateTime (1998, 01, 01), China = 3.3, US = 12.4, Germany = 9.9, Japan = 7.0, UK = 5.0}); ExportData.Add(new ExportModel () {Year = new DateTime (2000, 01, 01), China = 3.9, US = 12.1, Germany = 8.5, Japan = 7.4, UK = 4.4}); ExportData.Add(new ExportModel () {Year = new DateTime (2010, 01, 01), China = 10.3, US = 8.4, Germany = 8.2, Japan = 5.0, UK = 2.7}); ExportData.Add(new ExportModel () {Year = new DateTime (2012, 01, 01), China = 11.1, US = 8.4, Germany = 7.6, Japan = 4.3, UK = 2.6}); ExportData.Add(new ExportModel () {Year = new DateTime (2019, 01, 01), China = 13.2, US = 8.6, Germany = 7.8, Japan = 3.7, UK = 2.4}); ExportData.Add(new ExportModel () {Year = new DateTime (2022, 01, 01), China = 14.4, US = 8.3, Germany = 6.6, Japan = 3.0, UK = 2.1 }); } }
Let’s configure the Syncfusion .NET MAUI Cartesian Charts control according to the documentation.
Refer to the following code example.
<chart:SfCartesianChart> <chart:SfCartesianChart.XAxes> <chart:DateTimeAxis/> </chart:SfCartesianChart.XAxes> <chart:SfCartesianChart.YAxes> <chart:NumericalAxis/> </chart:SfCartesianChart.YAxes> </chart:SfCartesianChart>
To analyze exports for multiple countries, we’ll use multiple Syncfusion StackedArea series. Then, bind the ItemsSource property to the ExportData collection, XBindingPath to Year, and YBindingPath for each country.
Refer to the following code example.
<chart: StackedAreaSeries ItemsSource="{Binding ExportData}" XBindingPath="Year" YBindingPath="China"/> <chart: StackedAreaSeries ItemsSource="{Binding ExportData}" XBindingPath="Year" YBindingPath="US"/> <chart: StackedAreaSeries ItemsSource="{Binding ExportData}" XBindingPath="Year" YBindingPath="Germany"/> <chart: StackedAreaSeries ItemsSource="{Binding ExportData}" XBindingPath="Year" YBindingPath="Japan"/> <chart: StackedAreaSeries ItemsSource="{Binding ExportData}" XBindingPath="Year" YBindingPath="UK"/>
We can add different types of annotations, such as TextAnnotation, ViewAnnotation, and ShapeAnnotation, to enhance the clarity and visual appeal of charts.
The TextAnnotation allows you to add text labels or notes directly onto the chart. This feature is particularly useful for providing context, labeling data points, or explaining trends.
To differentiate exports, we’ll add additional information, such as country names, to the .NET MAUI Stacked Area Chart.
Refer to the following code example.
XAML
<chart:SfCartesianChart.Annotations> <chart: TextAnnotation X1="2010-12-31" Y1="6" Text="CHINA"> <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle TextColor="White" FontSize="20"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> <chart:TextAnnotation X1="1945-12-31" Y1="11" Text="U.S."> <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle TextColor="White" FontSize="20"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> <chart:TextAnnotation X1="1920-12-31" Y1="{OnPlatform Android=21,iOS=21,Default=20}" Text="GERMANY"> <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle TextColor="White" FontSize="20" HorizontalTextAlignment="End"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> <chart:TextAnnotation X1="1990-12-31" Y1=" 30" Text="JAPAN"> <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle TextColor="White" FontSize="20"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> <chart:TextAnnotation X1="1917-12-31" Y1="{OnPlatform Android=40,iOS=40,Default=43}" Text="UK"> <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle TextColor="White" FontSize="20"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> <chart:TextAnnotation X1="1913-12-31" Y1="40" x:Name="textAnnotation"> <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle TextColor="White" HorizontalTextAlignment="End" VerticalTextAlignment="End"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> <chart:TextAnnotation X1="1980-01-01" Y1="45" x:Name="japanText" > <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle HorizontalTextAlignment="End" VerticalTextAlignment="Start" Background="White" Stroke="#FFC943" StrokeWidth="2"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> <chart:TextAnnotation X1="1950-01-01" Y1="{OnPlatform Android='75',iOS='75',Default='78'}" Text="Merchandise Export Share 1900-2022"> <chart:TextAnnotation.LabelStyle> <chart:ChartAnnotationLabelStyle HorizontalTextAlignment="End" VerticalTextAlignment="End" FontSize="{OnPlatform Android='12',iOS='12',Default='16'}" FontAttributes="Bold" Background="#FFC943"/> </chart:TextAnnotation.LabelStyle> </chart:TextAnnotation> </chart:SfCartesianChart.Annotations>
C#
#if WINDOWS || MACCATALYST textAnnotation.Text = "In the late 1800s, the UK was the world's \nlargest exporter by value. By 2022, it had \nshrunk to the 15th largest."; japanText.Text = "Japan's growth in electronic goods production \nbriefly made it one of the world's largest\nexporters."; titleText.Text = "100+ Years of Global Trade: Economic Superpowers"; #else titleText.Text = "100+ Years of Global Trade"; #endif
Refer to the following output image.
The ShapeAnnotation allows us to add shapes such as rectangles, circles, and lines to your charts. These shapes can highlight specific data points, emphasize trends, or delineate areas of interest. This will enhance the overall aesthetics of your visualizations while making them more informative and engaging for viewers.
Refer to the following code example.
<chart:EllipseAnnotation X1="1990-01-01" Y1="33" Fill="#FFC943" Stroke="#FFC943" IsVisible="{OnPlatform Android='False',iOS='False'}" /> <chart:LineAnnotation X1="1990-01-01" Y1="33" X2="1990-01-01" Y2="45" Stroke="#FFC943" IsVisible="{OnPlatform Android='False',iOS='False'}" />
Refer to the following output image.
The ViewAnnotation enables the embedding of custom views directly onto the chart canvas. These views can include images, buttons, or other interactive elements, enhancing the chart’s interactivity and functionality. This will improve user engagement by offering customized visual enhancements tailored to specific data visualization needs.
Refer to the following code example.
<chart:ViewAnnotation X1="{OnPlatform Android='100',iOS='100',Default='150'}" Y1="{OnPlatform Android='40',iOS='40',Default='120'}" CoordinateUnit="Pixel"> <chart:ViewAnnotation.View> <Image Source="ship.png" HeightRequest="{OnPlatform Android='150',iOS='150',Default='300'}" WidthRequest="{OnPlatform Android='300',iOS='300',Default='400'}"/> </chart:ViewAnnotation.View> </chart:ViewAnnotation>
Refer to the following output image.
After executing the complete code examples, the output will look like the following image.
For more details, refer to the visualization of 100+ years of export of economic superpowers with the .NET MAUI Stacked Area Chart GitHub demo.
Thanks for reading! In this blog, we’ve seen how to visualize the 100+ years of export of economic superpowers using the Syncfusion .NET MAUI Stacked Area Chart. We encourage you to follow the steps outlined in this blog and share your feedback in the comments section below.
The existing customers can download the latest version of Essential Studio from the License and Downloads page. If you are new, try our 30-day free trial to explore our incredible features.
If you require any assistance, please don’t hesitate to contact us via our support forum, support portal, or feedback portal. We are always eager to help you!