首页
/ LiveCharts2 v2.0.0-rc5 发布:图表库的重大升级与改进

LiveCharts2 v2.0.0-rc5 发布:图表库的重大升级与改进

2025-06-12 06:24:56作者:滕妙奇

LiveCharts2 是一个功能强大的跨平台数据可视化库,支持多种 UI 框架,包括 MAUI、Avalonia、Uno Platform 等。最新发布的 v2.0.0-rc5 版本带来了超过 400 项提交的改进,标志着该库在性能、功能和用户体验方面都取得了显著进步。

核心架构重构:绘图引擎全面升级

本次版本最重大的改进是对绘图引擎的全面重构。在之前的版本中,当元素位于布局中时,Canvas 变换不会应用到子元素上。新版本解决了这个问题,现在变换会正确传递到子元素。这一特性在工具提示中得到了充分体现,现在工具提示的几何图形的不透明度和缩放也会应用到其内部内容。

绘图引擎的代码结构变得更加清晰。过去,库使用接口来定义所有图形,现在改为使用基类的方式。例如,BaseRoundedRectangleGeometry 类继承自 DrawnGeometry,这个基类处理动画和变换,而在 SkiaSharp 程序集中,我们只需继承这个基类并使用 SkiaSharp 绘制矩形。这种设计不仅使代码更加整洁,还为未来移除对 SkiaSharp 的依赖提供了可能。

MAUI 兼容性与安装改进

针对 MAUI 用户,新版本改进了处理程序的注册方式,使其更符合 MAUI 的逻辑。这一变化解决了之前版本中存在的一些问题,如处理程序未正确注册等。现在,用户需要在 MauiProgram.cs 文件中显式调用 .UseLiveCharts() 方法来初始化图表库。

可视化元素增强

可视化元素(VisualElements)在之前的版本中感觉有些"hacky",定制起来比较困难。新版本大大简化了这一过程,现在在画布上绘制任何我们需要的元素都变得更加容易。虽然旧的视觉元素仍然受支持,但其中一些已被标记为过时。

GPU 渲染支持

性能方面的一个重要改进是新增了 GPU 渲染支持。应用启动时,可以通过设置 LiveCharts.UseGPU = true 来启用 SkiaSharp 提供的硬件加速视图。需要注意的是,由于技术限制,这一特性在 .NET Framework 和某些平台上(如 Avalonia 或 Eto)尚不可用。

性能监控:FPS 日志

开发者现在可以更直观地监控图表性能。通过设置 LiveCharts.ShowFPS = true 可以显示图表每秒帧数(FPS),甚至可以通过 LiveCharts.MaxFps = 90 尝试提高帧率(默认为 65)。这一功能在性能优化和调试时非常有用。

指针交互改进

新版本收集了大量用户关于图表交互方式的反馈,并提供了全面的解决方案。FindingStrategy 属性现在更加灵活,允许用户配置库如何在图表上选择点。库提供了 8 种不同的策略,当这些预设策略不够用时,用户还可以创建自己的选择逻辑。

轴比例尺灵活性增强

轴比例尺现在完全可定制。新版本增加了一个专门的文档来解释如何匹配和自定义比例尺,为用户提供了更大的控制权。

移除对 Xamarin 的支持

随着 .NET MAUI 的成熟,新版本不再支持 Xamarin。建议仍在使用 Xamarin 的用户迁移到 MAUI。

迁移指南与重大变更

对于大多数用户来说,如果没有进行自定义绘制(如自定义图例、工具提示或视觉元素),升级应该是无缝的。但绘图引擎的重构意味着任何自定义绘制代码都可能受到影响。主要变更包括:

  • IChartLegend<T>IChartTooltip<T> 不再需要泛型参数
  • Chart.VisualElements 属性的类型从 ChartElement<T> 改为 ChartElement
  • VisualElement<T> 改为 VisualElement

对于自定义绘制代码,大多数变更只是移除了 TDrawingContext 泛型参数或重命名了对象。所有过时的代码都会有提示,指导开发者如何更新到新 API。

LiveCharts2 v2.0.0-rc5 版本代表了该库发展的重要里程碑,为开发者提供了更强大、更灵活的工具来创建丰富的数据可视化应用。无论是性能优化、交互改进还是架构重构,这个版本都为未来的发展奠定了坚实的基础。

登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
165
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
954
563
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
16
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
17
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
408
387
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Python
77
71
rainbondrainbond
无需学习 Kubernetes 的容器平台,在 Kubernetes 上构建、部署、组装和管理应用,无需 K8s 专业知识,全流程图形化管理
Go
14
1