ScrollCanvas 滚动画布
阅读时间约 6 分钟
ScrollCanvas 是 G6 中用于实现画布滚动功能的内置交互,支持通过鼠标滚轮或键盘方向键平移画布。这种交互方式对于浏览较大的图表特别有用,能让用户在不改变缩放比例的情况下探索图表的不同区域。
这一交互主要用于:
createGraph({data: { nodes: [{ id: 'node-1' }] },layout: { type: 'force' },behaviors: [{type: 'scroll-canvas',key: 'scroll-canvas',},],node: { style: { fill: '#873bf4' } },edge: { style: { stroke: '#8b9baf' } },plugins: [{ type: 'grid-line', size: 30 }],},{ width: 600, height: 300 },(gui, graph) => {const options = {key: 'scroll-canvas',type: 'scroll-canvas',direction: 'No limit',enable: true,sensitivity: 1,trigger: 'Use wheel by default',};const optionFolder = gui.addFolder('ZoomCanvas Options');optionFolder.add(options, 'type').disable(true);optionFolder.add(options, 'direction', {'No limit': '','Only allow horizontal scrolling': 'x','Only allow vertical scrolling': 'y',});optionFolder.add(options, 'enable');optionFolder.add(options, 'sensitivity', 0, 10, 1);optionFolder.add(options, 'trigger', {'Use wheel by default': [],'Shift+Arrow Key': {up: ['Shift', 'ArrowUp'],down: ['Shift', 'ArrowDown'],left: ['Shift', 'ArrowLeft'],right: ['Shift', 'ArrowRight'],},});optionFolder.onChange(({ property, value }) => {graph.updateBehavior({key: 'scroll-canvas',[property]: value,});graph.render();});},);
在图配置中添加这一交互:
// 使用默认配置const graph = new Graph({// 其他配置...behaviors: ['scroll-canvas'], // 直接添加,使用默认配置});// 或使用自定义配置const graph = new Graph({// 其他配置...behaviors: [{type: 'scroll-canvas',sensitivity: 1.5, // 设置灵敏度direction: 'y', // 只允许垂直方向滚动key: 'scroll-behavior', // 为交互指定标识符,方便动态更新},],});
配置项 | 说明 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
type | 交互类型名称 | string | scroll-canvas | ✓ |
enable | 是否启用该交互 | boolean | ((event: WheelEvent | KeyboardEvent) => boolean) | true | |
direction | 允许的滚动方向,配置项 | 'x' | 'y' | undefined | undefined (不限制方向) | |
range | 可滚动的视口范围(以视口大小为单位),配置项 | number | number[] | 1 | |
sensitivity | 滚动灵敏度,值越大滚动速度越快 | number | 1 | |
trigger | 触发滚动的键盘快捷键,配置项 | object | - | |
onFinish | 滚动完成时的回调函数 | () => void | - | |
preventDefault | 是否阻止浏览器默认事件 | boolean | true |
direction
用于限制滚动的方向:
undefined
:允许在任意方向滚动'x'
:只允许水平方向滚动'y'
:只允许垂直方向滚动这在特定的可视化场景下很有用,例如在时间轴图表中可能只需要水平滚动。
range
用于控制画布可滚动的范围:
例如:
range: 2; // 在任何方向上都可以滚动2个视口的距离range: [1, 2, 1, 2]; // 上下方向可滚动1个视口,左右方向可滚动2个视口
每个方向的取值范围是 [0, Infinity],0表示不能滚动,Infinity表示无限滚动。
trigger
允许你配置键盘方向键来控制画布滚动:
{trigger: {up: ['ArrowUp'], // 向上滚动的快捷键down: ['ArrowDown'], // 向下滚动的快捷键left: ['ArrowLeft'], // 向左滚动的快捷键right: ['ArrowRight'] // 向右滚动的快捷键}}
你也可以配置组合键:
{trigger: {up: ['Control', 'ArrowUp'], // Ctrl + 上箭头down: ['Control', 'ArrowDown'], // Ctrl + 下箭头left: ['Control', 'ArrowLeft'], // Ctrl + 左箭头right: ['Control', 'ArrowRight'] // Ctrl + 右箭头}}
const graph = new Graph({container: 'container',width: 800,height: 600,behaviors: ['scroll-canvas'],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'scroll-canvas',direction: 'x', // 只允许水平滚动},],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'scroll-canvas',sensitivity: 1.8, // 提高滚动灵敏度range: [0.5, 2, 0.5, 2], // 上下方向限制较小,左右方向限制较大},],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'scroll-canvas',trigger: {up: ['ArrowUp'],down: ['ArrowDown'],left: ['ArrowLeft'],right: ['ArrowRight'],},},],});
ScrollCanvas
用于平移画布,不改变缩放比例ZoomCanvas
用于缩放画布,改变视图的缩放比例两者常结合使用,提供完整的画布导航功能:
const graph = new Graph({// 其他配置...behaviors: ['drag-canvas', 'zoom-canvas', 'scroll-canvas'],});