brushYFilter
上一篇
brushXFilter
下一篇
chartIndex
Loading...
brushYFilter
交互是 brushFilter 的纵向限定版本,专用于基于 Y 轴维度的数据筛选。该交互限制用户只能通过垂直方向的框选操作(沿 Y 轴方向),对图表元素进行范围过滤,特别适用于数值区间分析、纵向对比等场景。
核心特征:
垂直操作:仅允许垂直方向框选,X 轴范围自动全选
数值聚焦:精准控制 Y 轴数值范围(如价格区间、温度范围)
动态响应:筛选结果实时映射到关联视图
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/antvdemo/assets/data/scatter.json',},encode: {x: 'height',y: 'weight', // Y 轴绑定数值型数据},interaction: {brushYFilter: { maskStroke: '#52c41a' }, // 启用绿色边框的纵向筛选},});chart.render();
配置 brushYFilter
交互有两种方式
通过布尔值开启交互,使用默认配置:
({type: 'interval',interaction: { brushYFilter: true }, // 启用默认配置的Y轴刷选过滤});
通过配置项 精细化控制交互行为:
({type: 'interval',interaction: {brushYFilter: {reverse: false, // 关闭反向选择maskFill: '#rgba(0,0,0,0.3)', // 自定义蒙版颜色},},});
交互可以配置在 Mark 层级:
({type: 'interval',interaction: { brushYFilter: true },});
也可以配置在 View 层级,视图上声明的交互会传递给 children
声明的标记,如果该标记有声明对应的交互,就合并;否则不影响。
({type: 'view',interaction: { brushYFilter: true },});
配置框选区域的蒙版的样式。
属性 | 描述 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
maskFill | 蒙版的填充色 | string | #777 | |
maskFillOpacity | 蒙版的填充透明度 | number | 0.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 的鼠标样式 | string | default |
在配置框选区域的蒙版样式的时候,不是以对象的形式来配置,而是以 mask
前缀加属性的方式来配置。
样式配置示例:
({interaction: {brushYFilter: {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;const [yMin, yMax] = data.selection[1]; // 注意数据结构差异console.log(`数值区间:${yMin.toFixed(2)} - ${yMax.toFixed(2)}`);});
通过编程方式触发筛选:
/// 设置 Y 轴筛选范围(数值型示例)chart.emit('brush:filter', {data: {selection: [null, // X 轴保持全选[20, 60], // Y 轴范围 20-60],},});
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: {brushYFilter: {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();