density
上一篇
chord
下一篇
gauge
Loading...
density是一种用于可视化连续变量分布概率密度的图表类型,通过核密度估计(Kernel Density Estimation, KDE) 将离散数据点转化为平滑的连续概率密度曲线,直观反映数据的集中趋势、分布形态及异常值。
density 的核心目标是从散点或点云数据中提取出其整体分布模式,并将其密度信息映射为一个连续的区域图或渐变效果。这种图表通常用于分析大量数据点的聚集区域、数据集中热点或数据分布的概率密度,例如在地理可视化中用于表示人口分布的密集程度,或者在分析中展示交易频率的区域性。
import { Chart } from '@antv/g2';const chart = new Chart({container: 'container',});chart.options({type: 'density', // 设置图表类型为密度图data: {type: 'fetch', // 指定数据类型为通过网络获取value: 'https://assets.antv.antgroup.com/g2/species.json', // 设置数据的 URL 地址transform: [{type: 'kde', // 使用核密度估计(KDE)进行数据转换field: 'y', // 指定 KDE 计算的字段为 'y'groupBy: ['x', 'species'], // 按 'x' 和 'species' 字段对数据进行分组},],},encode: {x: 'x', // 将 'x' 字段映射到 x 轴y: 'y', // 将 'y' 字段映射到 y 轴color: 'species', // 将 'species' 字段映射到颜色size: 'size', // 将 'size' 字段映射到图形大小series: 'species', // 将 'species' 字段映射到系列},tooltip: false, // 关闭图表的 tooltip 功能});chart.render();
更多的案例,可以查看图表示例 - 小提琴图页面。
| 属性 | 描述 | 类型 | 默认值 | 必选 |
|---|---|---|---|---|
| coordinate | 配置 density 图形坐标系统,支持的属性:cartesian | polar | coordinate | 'cartesian' | |
| encode | 配置 density 标记的视觉通道,包括x、y、color、size等,用于指定视觉元素属性和数据之间的关系 | encode | - | ✓ |
| scale | 配置 density 标记的图形缩放,包括x、y、series、size等 | scale | - | |
| style | 配置 density 图形样式 | style | - |
coordinate是数据可视化中定义数据映射到图形空间的核心系统,它决定了数据如何从“数值域”转换为“视觉位置”。坐标系通过不同的空间变换规则,重塑密度分布的视觉表达形式。
| 坐标系 | 类型 | 图表 |
|---|---|---|
| 直角坐标系 | 'cartesian' | 和密度图等 |
| 极坐标系 | 'polar' | 极坐标小提琴图等 |
const { Chart } = G2;const chart = new Chart({container: 'container',});const container = chart.getContainer();const coordinateMap = [{coordinate: 'cartesian',label: '直角坐标系',},{coordinate: 'polar',label: '极坐标系',},];chart.options({type: 'density',data: {type: 'fetch',value: 'https://assets.antv.antgroup.com/g2/species.json',transform: [{type: 'kde',field: 'y',groupBy: ['x', 'species'],},],},encode: {x: 'x',y: 'y',color: 'species',size: 'size',series: 'species',},coordinate: { type: coordinateMap[0].coordinate },tooltip: false,});const handleSetCoordinate = (coordinate) => {// 设置选中的坐标系chart.coordinate({type: coordinate,});chart.render(); // 重新渲染图表};// 插入Encode-Color 选择器const selectorContainer = document.createElement('div');selectorContainer.textContent = '选择坐标系 ';const selector = document.createElement('select');selector.innerHTML = coordinateMap.map((coordinate, index) =>`<option value="${coordinate.coordinate}" ${index === 0 ? 'selected' : ''}>${coordinate.label}</option>`,);selector.onchange = (e) => {handleSetCoordinate(e.target.value);};selectorContainer.appendChild(selector);container.insertBefore(selectorContainer, container.childNodes[0]);chart.render();
更多的coordinate配置,可以查查看 coordinate 介绍页面。
配置 density 标记的视觉通道,定义数据字段与视觉属性之间映射关系的重要配置,它决定了数据如何转化为视觉表现。
| 属性 | 描述 | 类型 | 默认值 | 必选 |
|---|---|---|---|---|
| x | 绑定 density 标记的 x 属性通道,一般是 data 中的时间或有序名词字段 | encode | - | ✓ |
| y | 绑定 density 标记的 y 属性通道,一般是 data 中的数值或数组字段 | encode | - | ✓ |
| color | 绑定 density 标记的 color 属性通道,如果将数据字段映射到颜色通道,会对数据进行分组,将数据拆分成多个不同颜色的区域 | encode | - | |
| size | 绑定 density 标记的 size 属性通道,用于将数据字段映射为图形元素的尺寸属性,通过调整密度曲线的线条粗细或填充区域的视觉比例,增强数据分布的对比维度与信息密度。 | encode | - | ✓ |
| series | 绑定 density 标记的 series 属性通道, 用于将数据分组字段映射到图表的系列或类别的配置项,根据某个字段对数据进行分类,并为每个类别生成独立的图形表现。 | encode | - | ✓ |
更多的encode配置,可以查查看 encode 介绍页面。
scale用于定义数据如何映射到视觉属性(如颜色、大小、形状等)。在cell的使用场景,scale 的常见作用就是为每个视觉通道(如颜色、大小、位置等)提供映射规则,使数据点能够准确地呈现。
更多的scale配置,可以查查看 scale 介绍页面。
style 用于设置图表元素的外观样式,包括填充颜色、边框样式、阴影效果等。
| 属性 | 描述 | 类型 | 默认值 | 必选 |
|---|---|---|---|---|
| fill | 图形的填充色 | string | Function<string> | - | |
| fillOpacity | 图形的填充透明度 | number | Function<number> | - | |
| stroke | 图形的描边 | string | Function<string> | - | |
| strokeOpacity | 描边透明度 | number | Function<number> | - | |
| lineWidth | 图形描边的宽度 | number | Function<number> | - | |
| lineDash | 描边的虚线配置,第一个值为虚线每个分段的长度,第二个值为分段间隔的距离。lineDash 设为[0, 0]的效果为没有描边。 | [number,number] | Function<[number, number]> | - | |
| opacity | 图形的整体透明度 | number | Function<number> | - | |
| shadowColor | 图形阴影颜色 | string | Function<string> | - | |
| shadowBlur | 图形阴影的高斯模糊系数 | number | Function<number> | - | |
| shadowOffsetX | 设置阴影距图形的水平距离 | number | Function<number> | - | |
| shadowOffsetY | 设置阴影距图形的垂直距离 | number | Function<number> | - | |
| cursor | 鼠标样式。同 css 的鼠标样式,默认 'default'。 | string | Function<string> | 'default' |
更多的style配置,可以查看 style 介绍页面。
尝试一下:
import { Chart } from '@antv/g2';const chart = new Chart({container: 'container',autoFit: true,});chart.data({type: 'fetch',value: 'https://assets.antv.antgroup.com/g2/species.json',transform: [{type: 'kde',field: 'y',groupBy: ['x'],size: 20,},],});chart.density().encode('x', 'x').encode('y', 'y').encode('color', 'x').encode('size', 'size').tooltip(false);chart.render();