WPF优秀组件推荐之LiveCharts
概述
LiveCharts是一个比较漂亮的WPF图表控件,在数据变化时还会有动画切换的效果,并且样式也可以控制。
官方网站:Live Charts (lvcharts.net)
开源代码:GitHub - Live-Charts/Live-Charts: Simple, flexible, interactive & powerful charts, maps and gauges for .Net
本文代码基于Stylet开发,如果您还不了解Stylet,请参阅:
WPF优秀组件推荐之Stylet(一) - seabluescn - 博客园 (cnblogs.com)
WPF优秀组件推荐之Stylet(二) - seabluescn - 博客园 (cnblogs.com)
环境安装
通过Nuget引用下面两个组件;
基本使用
本文介绍一个常用的折线图的控件,其它控件请查看官方代码。
Xaml:
<lvc:CartesianChart > <lvc:CartesianChart.Series> <lvc:LineSeries Title="Voltage" Values="{Binding VoltageLineSeries}" /> <lvc:LineSeries Title="Current" Values="{Binding CurrentLineSeries}" /> </lvc:CartesianChart.Series> <!--定义Y轴--> <lvc:CartesianChart.AxisY> <lvc:Axis Title="Voltage/Current"></lvc:Axis> </lvc:CartesianChart.AxisY> <!--定义X轴--> <lvc:CartesianChart.AxisX> <lvc:Axis Title="Samples" Labels="{Binding XTimeLabels}"/> </lvc:CartesianChart.AxisX> </lvc:CartesianChart>
Code:

#region LiveCharts public string[] XTimeLabels { get; set; } = new string[] { "0" }; public ChartValues<double> VoltageLineSeries { get; set; } public ChartValues<double> CurrentLineSeries { get; set; } public void ReflashDatas() { Random random = new Random(); VoltageLineSeries = new ChartValues<double>(); CurrentLineSeries = new ChartValues<double>(); Task.Run(() => { while (true) { VoltageLineSeries.Add(random.Next(200, 300)); CurrentLineSeries.Add(random.Next(1, 20)); int Count = VoltageLineSeries.Count; if (Count > 0) { XTimeLabels = new string[Count]; for (int i = 0; i < Count; i++) { XTimeLabels[i] = (i + 1).ToString(); } } Thread.Sleep(2000); } }); } #endregion
以上代码下载地址:NiceComponents · Bruce/Learn WPF - 码云 - 开源中国 (gitee.com)
参考文档:
WPF绘制图表-LiveCharts - 橘子香气 - 博客园 (cnblogs.com)
WPF LiveChart 图表详解 - 痕迹g - 博客园 (cnblogs.com)
更多资源请参考官方源码。
签名区:
如果您觉得这篇博客对您有帮助或启发,请点击右侧【推荐】支持,谢谢!
分类:
WPF
标签:
wpf
, LiveCharts
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY