LiveCharts2:.NET开源的跨平台图表库重磅来袭

发表时间: 2024-07-20 09:30
LiveCharts2是一个功能全面的开源.NET库,它提供了一系列易于使用的图表、地图和仪表组件。这个库以其简单性、灵活性和交互性著称,支持跨多个平台运行,包括Maui、Uno Platform、Blazor-wasm、WPF、WinForms、Xamarin、Avalonia、WinUI和UWP。


访问地址:[LiveCharts2 API文档](
https://livecharts.dev/docs/blazor/2.0.0-rc2/gallery)


以下是在Blazor WebAssembly项目中使用LiveCharts2的步骤:

首先,创建一个新的Blazor WebAssembly项目。
安装NuGet包
通过NuGet安装LiveCharts2的Blazor支持包:

```shellInstall-Package LiveChartsCore.SkiaSharpView.Blazor```

创建视图模型(ViewModel)
定义一个视图模型来管理图表的数据和配置:

```csharppublic partial class ViewModel : ObservableObject{ public ISeries[] Series { get; set; } = { new ColumnSeries<double> { Name = "Mary", Values = new double[] { 2, 5, 4 } }, new ColumnSeries<double> { Name = "Ana", Values = new double[] { 3, 1, 6 } } };
public Axis[] XAxes { get; set; } = { new Axis { // 配置X轴的属性 } };}```


创建HTML页面
在Blazor页面中使用`CartesianChart`组件来显示图表:

```html@page "/Bars/Basic"@using LiveChartsCore.SkiaSharpView.Blazor@using ViewModelsSamples.Bars.Basic
<CartesianChart Series="ViewModel.Series" XAxes="ViewModel.XAxes" LegendPosition="LiveChartsCore.Measure.LegendPosition.Right"></CartesianChart>
@code { public ViewModel ViewModel { get; set; } = new();}```


延迟动画示例
LiveCharts2还支持创建具有延迟效果的动画图表。以下是实现延迟动画的ViewModel和HTML页面示例:

```csharppublic partial class ViewModel : ObservableObject{ public ViewModel() { // 初始化图表数据和动画逻辑 }
private void OnPointMeasured(ChartPoint<float, RoundedRectangleGeometry, LabelGeometry> point) { // 设置每个数据点的动画延迟 }
public List<ISeries> Series { get; set; }}```


HTML页面

```html@page "/Bars/DelayedAnimation"@using LiveChartsCore.SkiaSharpView.Blazor@using ViewModelsSamples.Bars.DelayedAnimation
<CartesianChart Series="ViewModel.Series"></CartesianChart>
@code { public ViewModel ViewModel { get; set; } = new();}```


项目的源代码可以在GitHub上找到:[LiveCharts2 GitHub仓库](
https://github.com/beto-rodriguez/LiveCharts2)


LiveCharts2是一个功能丰富且易于使用的.NET图表库,适合需要在应用程序中集成图表功能的开发者。希望这篇文章能帮助您快速上手LiveCharts2。