G2 5.0 来啦,伴着春天的脚步,从语言到思维

简介: G2 5.0 来啦,伴着春天的脚步,从语言到思维

G2(发音为 /ʤiː tuː/) 是蚂蚁集团 AntV 旗下的开源可视化图表库。今天,我们很激动地宣布 G2 5.0 正式版本 “Spring” 的发布。

本次主版本更新包含更简洁和专业的可视化语法更丰富的图表类型和图表特性易于拓展的全新 API 和架构。在提高 G2 灵活性和易用性的同时,也为 G2 未来的长期稳定迭代和生态的建设奠定了夯实的基础。

5.0 的发布意味着团队和社区两年多的努力,从最初底层模块 @antv/scale 和 @antv/coord 的梳理开始,而后掘金小册《可视化入门:从 0 到 1 开发一个图表库》的推广,到如今正式版本的发布,这算是一次“蓄谋已久”的升级。5.0 在一年前的3月21日绘制出了第一个条形图,经过团队和社区成员反复讨论、设计、实现以及不懈的努力,渐渐有了如今的模样。

G2 为公司业务而生,却也希望服务好社区用户,如今一年之期已到,在这带来福运的“闰二月”之际,希望能给大家展现一份满意的答卷。

 渐进式可视化语法

G2 从最开始就有一个简单的愿景:“一句话绘制出一个图表”。为此我们实践了图形语法《The Grammar of Graphics》的核心理论:拒绝图表分类学,用一系列可视化组件来描述一个图表。相对于“一图一做”,大大丰富了可绘制图表的种类。但随着可视化场景越来越复杂,以及根据内外用户的反馈,我们发现 G2 在易用性和灵活性上还有不小的提升空间。

为此,我们参考前端框架 React 和 Vue 复用逻辑的编程范式,给出了“Mark 是一等公民”的设计原则,提出了一套“渐进式的可视化语法”:一个可以逐步学习和采用的可视化语法,在保证复杂度几乎不变的情况下,可以为越来越丰富和苛刻的可视化场景提供持续的支持

同时在可视化描述层面,我们参考了学术界的 Vega-Lite 可视化语法的设计,提高了 G2 语法的通用性和专业性,希望能给用户专递正确的、专业的可视化思维,提高开发效率和更多得从可视化中获益。

 更丰富图表类型

为了满足不同场景的诉求,5.0 新增了更多图表类型:平行坐标系、马赛克图和差分面积图等,同时也将直接支持仪表盘、水波图和韦恩图等的绘制。除此之外,因为图形语法本身的“包罗万象”,以及复合型数据类型场景的增多,G2 将不仅仅针对统计数据,也会为关系型数据和地理数据可视化提供简单的支持(更加专业和复杂的诉求移步 G6 和 L7)

 全新数据分析能力

大规模和复杂的数据分析往往由后端的完成,针对小规模和特定的场景,我们参考 D3 作者  Mike Bostock 最新开源的 Observable Plot,设计了 transform API 来规范化数据分析的能力。使得用户可以通过简洁的 API 完成分组、分箱、求异常值等分析任务。另一方面,我们也参考 Vega-Lite 的视图复合设计、微软团队的 Atom 单元可视化语法,以及前端开发的 DOM 树规范,设计了一颗视图树去描述可视化。这样不仅可以更容易地去分析高维数据,还可以从“一句话绘制出一个图表”升级为“一句话绘制一张报表”,将不同数据集放在同一页面去分析。

 全新动画能力

可视化中动画可以提高用户的愉悦度,以及更好的展现和分析时序数据。4.0 和大多数主流的可视化框架都没有提供声明形式的动画语法,为了弥补这个缺陷,我们参考山东大学 Canis 动画语法给 5.0 增加了编码动画属性和执行分组动画的能力。同时我们参考 CSS Animation 规范,设计了时序容器,简化了声明可视化叙事的成本。

 数据标注能力提升

数据标注常常用于为用户提供值得关注的辅助信息。在 4.0 的设计中,标注 Annotation 和几何元素 Geometry 是两个不同的实现,这使得标注的能力没有几何元素灵活和强大。在 5.0 中,标注和几何元素都是标记 Mark,拥有相同的渲染流程,从而使得标注也获得了声明式的批量绘制、支持数据转换、支持动画以及展现提示信息的能力。同时对于每一个图形元素,也可以添加多个数据标签 Label。

 数据展示能力提升

坐标轴和图例等组件可以帮助用户加速理解可视化,在 5.0 中我们优化了组件的展示。包括支持多个坐标轴的自适应布局,更多种的图例布局模式,以及各个部分使用 HTML 定制。Ticks 的文本的混乱展示一直是组件的痛点,我们内置了 d3-format 使得格式化工作更加的简单。

 颜色表达力提升

颜色通道是可视化中一个重要的通道,它能高效地展示编码的信息。5.0 增强了对连续颜色通道的展示能力,包括提供 Threshold、Quantile 和 Quantize 比例尺去离散化颜色,让颜色的差异感分布更加明显和均匀。也内置了 d3-scale-chromatic 中的离散色板和连续插值器,提供了更多色彩空间的选择。对于折线图也支持连续的渐变色编码。

 丰富的个性化风格

为了个性化场景和趣味性需求,借助底层强大的渲染引擎 @antv/g, 所有图表都支持手绘风格和纹理。同时也优化了条形图和饼图等的圆角展示。

 实验性 Spec API

G2 提供了函数风格的链式 API Chart 去声明图表,这样使得图表的声明可以更加自由。但我们发现这种非结构化 API 对部分用户并不友好,同时不利于上层工具的封装。所以在增强传统 Chart API 的同时,G2 5.0 引入了 Spec API 一套全新的 API,旨在降低 G2 的使用和学习成本以及方便生态的扩展。Spec API 是 Chart API 的基础,提供了类似 ECharts 和 G2Plot 那样的通过 JavaScript 对象声明图表的能力。目前 Spec API 目前在 G2 中已经实现,并可以通过调用 chart.options(options) 使用。但是暴露这个特性的目的只是为了收集反馈,并且给依赖相关能力的库一个预览。我们将和 @antv/ava 团队一起测试和迭代这个功能,并且可能在 5.1.0 版本中正式发布它。

 按需加载

G2 5.0 的核心能力仍然通过 Chart暴露,但是内部实现已经被完全重写,通过 runtime + stdlib 的形式已经解耦成一个个模块的集合。新的架构下为源码提供了更好的可维护性,并且为未来按需打包,减少运行时体积打下了坚实的基础。同时这些模块拥有相似的函数签名,可以在自定义是保持心智的相对统一。

 服务端渲染

G2 5.0 拥有了服务端渲染的能力。这也拓展了更多使用场景,例如在一个服务端自动生成内容的邮件或报表系统中嵌入图表。不同于 AnyChart 或者 Highcharts 基于 PhantomJS 这样的无头浏览器方案,我们使用了可以在 Node.js 环境下运行的 node-canvas、JSDOM 和 headless-gl 为不同渲染器提供支持。

 分阶段发布

G2 5.0 正式的发布意味着框架已经整体就绪。虽然框架的一些子模块还需要进一步调整和完善才能达到稳定状态(尤其是 Mark 和 Shape 模块的内部接口设计),并且后续还会拆包减少包体积,但是我们相信已经可以使用 G2 5.0 开启全新的项目。同时也鼓励社区使用了 G2 4.0 的库计划升级项目以支持 G2 5.0。

 下一阶段工作

对于发布后的一段时间内,我们将重点关注:

  • 调整内部接口,暴露各个模块的自定义能力。
  • 优化视觉效果,提供更多主题风格以及主题构建工具。
  • 落地新的交互规范并且设计新的交互语法。
  • 完善 Spec API,提供相应文档、案例以及相关工具。
  • 优化性能和保证能力稳定。
  • 进一步补全教程和文章。

G2 栈团队还会继续维护 v4 版本,针对 Bug 发布 Patch 版本修复,但是此后不再接收新的 Feature Request,截止日期为 2023 年年底。原 v4 官网迁移至 https://g2-v4.antv.vision/

 如何升级

首先得和社区的广大开发者说一声抱歉,因为这是一个全新的版本,所以对已有项目来说,有不低的升级成本。为了尽可能降低用户的升级成本,我们保证了大部分可视化概念的统一,同时也会提供一个升级文档来指出新老版本的一些差异。在 G2 5.0 版本发布之后,我们也会保持一周一次的版本更新速度,欢迎大家通过 issue、disscusion 和钉钉讨论群抛出在升级过程中遇见的困难,我们将尽全力帮助大家更加平稳的升级。

做出全面升级这个决定是艰难的,但确实有很多存量问题老的架构很难或者不能解决,其中的历史包袱也一直阻碍着 G2 的进步一步发展。所以,我们希望的是“不破不立”,也希望升级带来的收益可以让大家觉得其中的困难是值得的。

 结语

以上就是 G2 5.0 发布相关的主要内容了,但是这次的发布只是一个开始。因为我们希望 G2 不仅仅是一个做可视化的工具,还希望它能给用户传递正确的可视化思维:“让人们在数据世界里获得视觉化思考能力”。我们会继续对其不断进行打磨,也希望社区有更多志同道合的小伙伴通过各种形式参与共建。

最后,Today's tools help shape tomorrow’s art,让我们一起让 G2 5.0 变得更好,让可视化触手可及。

更多


AntV 数据可视化官网




https://antv.antgroup.com/

AntV 数据可视化 GitHub

https://github.com/antvis

关注我们,了解更多~

相关文章
|
4月前
|
开发者
从代码中汲取智慧——我的编程之旅与技术感悟
【9月更文挑战第24天】在数字世界的迷宫中,代码是指引我们前行的罗盘。它不仅仅是冷冰冰的指令集合,更是一扇窗,透过它,我们可以看到逻辑的严谨、问题的解决以及创新的火花。本文将分享我在编程旅途中的一些深刻体会,从最初的困惑与挫败,到逐渐掌握编程语言的乐趣,再到通过代码解决问题的成就感。我将探讨如何通过编程提升思维能力,以及编程对个人成长和职业发展的重要性。无论你是编程新手还是资深开发者,这段旅程都将启发你去思考和探索技术的深层次意义。
39 1
|
5月前
|
并行计算 算法 数据处理
编程之道:从代码中领悟技术与生活的哲理
【8月更文挑战第28天】在数字世界的迷宫中,每一行代码都像是宇宙中的一个星系,既独立又相互联系。本文将通过一段简单的Python代码示例,探讨如何从编程实践中汲取生活智慧。我们将看到,代码不仅仅是冷冰冰的指令序列,它也能反映出人类思维的深度和广度。正如甘地所言:“你必须成为你希望在世界上看到的改变。”在编程的世界里,我们同样可以创造并见证这种改变。
56 3
|
2月前
|
算法 开发者
编程之旅:从迷茫到精通的蜕变之路
【10月更文挑战第37天】编程,一个看似高深莫测的世界,却充满了无限可能。它不仅仅是一种技能,更是一种思维方式和解决问题的艺术。本文将带你走进编程的世界,探索它的奥秘,分享作者在编程旅途中的感悟和经验。无论你是编程新手还是资深开发者,这篇文章都将为你提供新的视角和思考方式,让你重新审视编程,并找到属于自己的道路。让我们一起踏上这段充满挑战与乐趣的编程之旅吧!
58 34
|
2月前
|
人工智能 搜索推荐 算法
编程之舞:从代码到艺术的蜕变
【10月更文挑战第30天】在数字世界的无限舞台上,编程不仅仅是冰冷的逻辑和枯燥的算法。它是创造者手中的画笔,是构建梦想的乐章。本文将带你领略编程背后蕴含的艺术之美,探索如何通过代码示例将技术与创造力结合,从而让程序设计成为一种独特的艺术表达。
41 2
|
3月前
|
程序员
代码与生活:技术感悟中的哲理
【10月更文挑战第20天】 在编程的世界里,我们不仅仅是在编写代码,更是在塑造一种生活方式。本文将探讨如何将编程思维应用到日常生活中,以及这种思维方式如何帮助我们更好地理解世界和自己。通过具体的例子和深入的分析,我们将看到,编程不仅仅是一种技能,更是一种生活哲学。
43 0
|
8月前
|
算法 程序员
探寻技术之美:代码世界的奇妙旅程
在数字化时代,技术已经渗透到生活的方方面面,而作为程序员,我深深感受到了代码世界的奇妙之处。本文将带领读者一起探寻技术之美,感悟代码背后的精妙之处。
|
5月前
|
算法 程序员
代码之舞:编程艺术与技术感悟
在数字世界的广阔舞台上,编程不仅是逻辑的堆砌与算法的运行,它更像是一场精心编排的舞蹈。本文将通过个人的技术旅程,探讨编程之美,揭示如何将枯燥的代码转变为优雅的解决方案,并分享在技术探索中收获的深刻感悟。
43 2
|
5月前
|
Python
编程之禅的奇幻之旅:探寻代码世界与生活万象的惊世共鸣,颠覆你的认知!
【8月更文挑战第7天】编程不仅是技术活,更融汇艺术与哲学。它启示我们在生活里追求简洁高效,如Python列表推导式的优雅;教会我们面对挑战时冷静分析,正如调试代码;体现分工合作的重要性,像模块化设计;并鼓励持续优化,提升效能。编程所蕴含的生活智慧,能引导我们创造更美好、有序的人生。
56 1
代码之舞:我的编程之旅与技术感悟
在数字世界的无限舞台上,每一行代码都像是精心编排的舞步,共同谱写着技术的交响曲。本文将带领读者穿梭于编程的世界,探索那些隐藏在逻辑严谨与创新自由之间的奥秘。从最初的迷茫到渐渐的熟练,每一次的挑战都是自我提升的机会。文章旨在分享个人的技术成长历程,展现编程之美,并鼓励更多的技术爱好者踏上属于自己的代码之旅。我们将一同见证,如何在细节中追求完美,在复杂中寻找简单,最终在技术的海洋里找到自己的航道。
|
5月前
|
JavaScript 前端开发 开发者
震撼揭秘!JS模块化进化史:从混沌到秩序,一场代码世界的华丽蜕变,你怎能错过这场编程盛宴?
【8月更文挑战第23天】在 Web 前端开发领域,JavaScript 模块化已成为处理日益复杂的 Web 应用程序的关键技术。通过将代码分解成独立且可重用的模块,开发者能够更有效地组织和管理代码,避免命名冲突和依赖混乱。从最早的全局函数模式到 IIFE,再到 CommonJS 和 AMD,最终进化到了 ES6 的原生模块支持以及 UMD 的跨环境兼容性。本文通过具体示例介绍了这些模块化规范的发展历程及其在实际开发中的应用。
61 0

热门文章

最新文章