brushFilter

概述

brushFilter 交互主要用于实现图表元素的动态范围筛选功能。通过鼠标刷选操作,用户可以在图表上划定特定区域(基于 x/y 轴坐标系),G2 会重新渲染该区域内符合筛选条件的图表元素。

example

典型应用场景:

数据探索:快速聚焦特定数据区间进行深入分析

异常检测:定位分布异常的离散数据点

对比分析:横向/纵向对比不同区间的数据特征

import { Chart } from '@antv/g2';
const chart = new Chart({ container: 'container' });
chart.options({
type: 'point',
autoFit: true,
data: {
type: 'fetch',
value:
'https://gw.alipayobjects.com/os/basement_prod/6b4aa721-b039-49b9-99d8-540b3f87d339.json',
},
encode: { x: 'height', y: 'weight', color: 'gender' },
state: { inactive: { stroke: 'gray' } },
interaction: { brushFilter: true },
});
chart.render();

使用方式

配置 brushFilter 交互有两种方式

快速启用模式

通过布尔值开启交互,使用默认配置:

({
type: 'interval',
interaction: { brushFilter: true }, // 启用默认配置的刷选过滤
});

自定义配置模式

通过配置项 精细化控制交互行为:

({
type: 'interval',
interaction: {
brushFilter: {
reverse: false, // 关闭反向选择
maskFill: '#rgba(0,0,0,0.3)', // 自定义蒙版颜色
},
},
});

配置层级

交互可以配置在 Mark 层级:

({
type: 'interval',
interaction: { brushFilter: true },
});

也可以配置在 View 层级,视图上声明的交互会传递给 children 声明的标记,如果该标记有声明对应的交互,就合并;否则不影响。

({
type: 'view',
interaction: { brushFilter: true },
});

配置项

属性描述类型默认值必选
reversebrush 是否反转booleanfalse
mask框选区域的蒙版样式mask详见 mask

mask

配置框选区域的蒙版的样式。

属性描述类型默认值必选
maskFill蒙版的填充色string#777
maskFillOpacity蒙版的填充透明度number0.3
maskStroke蒙版的描边string#fff
maskStrokeOpacity描边透明度number
maskLineWidth蒙版描边的宽度number
maskLineDash描边的虚线配置,第一个值为虚线每个分段的长度,第二个值为分段间隔的距离。lineDash 设为[0,0]的效果为没有描边。[number,number]
maskOpacity蒙版的整体透明度number
maskShadowColor蒙版阴影颜色string
maskShadowBlur蒙版阴影的高斯模糊系数number
maskShadowOffsetX设置阴影距蒙版的水平距离number
maskShadowOffsetY设置阴影距蒙版的垂直距离number
maskCursor鼠标样式。同 css 的鼠标样式stringdefault

在配置框选区域的蒙版样式的时候,不是以对象的形式来配置,而是以 mask前缀加属性的方式来配置。

样式配置示例:

({
interaction: {
brushFilter: {
maskFill: '#000',
maskFillOpacity: 0.2,
maskStroke: 'red',
maskStrokeOpacity: 0.9,
maskLineWidth: 2,
maskLineDash: [4, 8],
maskOpacity: 0.2,
maskShadowColor: '#d3d3d3',
maskShadowBlur: 10,
maskShadowOffsetX: 10,
maskShadowOffsetY: 10,
maskCursor: 'pointer',
},
},
});

事件

监听事件

监听刷选过滤动作:

chart.on('brush:filter', (event) => {
const {
data, // 筛选后的数据集合
nativeEvent, // 原始 DOM 事件
} = event;
console.log('当前选中范围:', data.selection);
});

触发交互

通过编程方式触发筛选:

// 设置 x 轴范围 [50,100],y 轴范围 [20,80]
chart.emit('brush:filter', {
data: {
selection: [
[50, 100],
[20, 80],
],
},
});

案例

import { Chart } from '@antv/g2';
const data = [
{ letter: 'A', frequency: 0.08167 },
{ letter: 'B', frequency: 0.01492 },
{ letter: 'C', frequency: 0.02782 },
{ letter: 'D', frequency: 0.04253 },
{ letter: 'E', frequency: 0.12702 },
{ letter: 'F', frequency: 0.02288 },
{ letter: 'G', frequency: 0.02015 },
{ letter: 'H', frequency: 0.06094 },
{ letter: 'I', frequency: 0.06966 },
{ letter: 'J', frequency: 0.00153 },
{ letter: 'K', frequency: 0.00772 },
{ letter: 'L', frequency: 0.04025 },
{ letter: 'M', frequency: 0.02406 },
{ letter: 'N', frequency: 0.06749 },
{ letter: 'O', frequency: 0.07507 },
{ letter: 'P', frequency: 0.01929 },
{ letter: 'Q', frequency: 0.00095 },
{ letter: 'R', frequency: 0.05987 },
{ letter: 'S', frequency: 0.06327 },
{ letter: 'T', frequency: 0.09056 },
{ letter: 'U', frequency: 0.02758 },
{ letter: 'V', frequency: 0.00978 },
{ letter: 'W', frequency: 0.0236 },
{ letter: 'X', frequency: 0.0015 },
{ letter: 'Y', frequency: 0.01974 },
{ letter: 'Z', frequency: 0.00074 },
];
const chart = new Chart({
container: 'container',
});
chart.options({
autoFit: true,
interaction: {
brushFilter: {
maskFill: '#000',
maskFillOpacity: 0.2,
maskStroke: 'red',
maskStrokeOpacity: 0.9,
maskLineWidth: 2,
maskLineDash: [4, 8],
maskOpacity: 0.2,
maskShadowColor: '#d3d3d3',
maskShadowBlur: 10,
maskShadowOffsetX: 10,
maskShadowOffsetY: 10,
maskCursor: 'pointer',
},
},
});
chart.interval().data(data).encode('x', 'letter').encode('y', 'frequency');
chart.render();
Previous
brushYHighlight
Next
brushXFilter