G2 5.1.0 发布:新主题,3D 可视化,按需打包

G2 是蚂蚁集团 AntV 团队开源的企业级可视化框架,在今年的3月份发布了全新的 5.0 版本。半年以来,在公司和社区同学共同的努力下,我们迎来了 5.1.0 的发布。希望新的版本能像更好地实现我们的愿景用 G2,你可以更专业地、快速得获得更多可视化效果,同时获得可视化思维

那么接下来就来看看 5.1.0 版本带来的一些变化和新特性:

默认安装版本

从 G2 5.1.0 开始,G2 5.x 的版本将作为 NPM 安装的默认版本。这意味着如下命令将直接安装 G2 5.x 的版本:

bash 复制代码
$ npm install @antv/g2

新主题

G2 5.1.0 引入了新主题:light,该主题包含了全新的色板,希望能让用户获得更清晰的看数体验。(案例

light该主题会作为 G2 5.x 的默认主题,不需要显式指定:

javascript 复制代码
import { Chart } from '@antv/g2';

const chart = new Chart(); // 没有指定 theme,会使用新主题

对于使用 5.0.x 的用户,如果希望使用新的默认主题,只需要去掉 theme: 'classic',否则将会继续使用老的默认主题:

javascript 复制代码
import { Chart } from '@antv/g2';

const chart = new Chart({
  theme: 'classic', // 去掉这一行,将会使用新主题
}); 

3D 可视化

G2 5.1.0 版本推出了 3D 可视化能力,对于 G2 来说这一个重大的突破,让 G2 未来在科学可视化、VR 可视化等领域发展成为可能。(文档 · 案例

javascript 复制代码
chart
  .point3D()
  .data({
    type: 'fetch',
    value:
      'https://gw.alipayobjects.com/os/bmw-prod/2c813e2d-2276-40b9-a9af-cf0a0fb7e942.csv',
  })
  .encode('x', 'Horsepower')
  .encode('y', 'Miles_per_Gallon')
  .encode('z', 'Weight_in_lbs')
  .encode('color', 'Origin')
  .encode('size', 'Acceleration')
  .encode('shape', 'sphere')
  .coordinate({ type: 'cartesian3D' })

按需打包

G2 5.1.0 推出了按需打包的能力,可以根据应用场景来选择需要的图表集合,从而控制包大小。(文档

下面的例子展示了只绘制桑基图:

javascript 复制代码
import { Runtime, corelib, graphlib, extend } from '@antv/g2';

// 通过扩展 Runtime 获得新的 Chart 对象
const Chart = extend(Runtime, {
  ...corelib(), // 核心能力库
  ...graphlib(), // 包含桑基图的库
});

chart.snakey(); // 使用桑基图

Spec API

G2 5.1.0 正式推出 Spec API,这使得我们可以通过一个 JavaScript 声明一个图表。(文档

javascript 复制代码
import { Chart } from "@antv/g2";

const chart = new Chart({ container: "container" });

chart.options({
  type: "interval",
  data: {
    type: "fetch",
    value:
      "https://gw.alipayobjects.com/os/bmw-prod/fb9db6b7-23a5-4c23-bbef-c54a55fee580.csv",
  },
  encode: { x: "letter", y: "frequency" },
  axis: { y: { labelFormatter: ".0%" } },
});

chart.render();

所有的官网案例也可以一键切换至 Spec API。

交互式代码块

G2 5.1.0 开始的文档支持可以交互的代码块,能看见代码实际运行的效果,提高阅读体验。(文档

更多能力

除了上述特性以外,从 5.0.0 到 5.1.0 之间 G2 还新增了如下一些重要的特性:

  • 支持设置交互初始状态,并且获得交互数据,增强了图表联动能力。(#4946
  • 可以改变大小和自定义 Handle 样式的 Brush。(#5012
  • Tooltip 可以指定挂的 DOM。(#4980
  • 支持 Auto Padding。(#5046
  • 新增热力图 Heatmap。(#5047
  • 新增韦恩图 Venn。(#5129
  • 新增坐标轴 Mark:AxisX 和 AxisY。(#5188
  • 新增图例 Mark:Legends。(#5290
  • 优化图例的布局和展示。(#5202
  • Chart API 和 Spec API 可以同时使用。(#5074
  • 支持离散的 size 通道。(#5230
  • 支持 HexBin。(#5413
  • 支持 HTML 数据。(#5354
  • 新增变宽折线图。(#5137
  • 条形图支持设置最大和最小宽度。(#5123

更多迭代内容可以看 G2 的 Releases Notes

未来工作

目前 G2 5.0 还在高速发展的阶段,后半年重点在视觉文档能力稳定社区繁荣上面。如果对下面感兴趣的小伙伴欢迎联系我们,让我们一起打造一个更好的可视化工具。

  • 新增主题 Token,并且提供主题生成器。
  • 文档的完善和翻译。
  • 新增更多 3D 图表。
  • 集成 @antv/ava 的能力,提供智能可视化的能力。
  • ...
相关推荐
GDAL11 分钟前
vue3入门教程:ref能否完全替代reactive?
前端·javascript·vue.js
vvw&2 小时前
Docker Build 命令详解:在 Ubuntu 上构建 Docker 镜像教程
linux·运维·服务器·ubuntu·docker·容器·开源
小马哥编程2 小时前
Function.prototype和Object.prototype 的区别
javascript
王小王和他的小伙伴3 小时前
解决 vue3 中 echarts图表在el-dialog中显示问题
javascript·vue.js·echarts
学前端的小朱3 小时前
处理字体图标、js、html及其他资源
开发语言·javascript·webpack·html·打包工具
outstanding木槿3 小时前
react+antd的Table组件编辑单元格
前端·javascript·react.js·前端框架
好名字08213 小时前
前端取Content-Disposition中的filename字段与解码(vue)
前端·javascript·vue.js·前端框架
摇光933 小时前
js高阶-async与事件循环
开发语言·javascript·事件循环·宏任务·微任务
胡西风_foxww4 小时前
【ES6复习笔记】Class类(15)
javascript·笔记·es6·继承··class·静态成员
布兰妮甜4 小时前
使用 WebRTC 进行实时通信
javascript·webrtc·实时通信