DragCanvas 拖拽画布
阅读时间约 5 分钟
DragCanvas 是 G6 中用于实现画布拖拽功能的内置交互,支持通过鼠标或触摸屏幕拖动来平移整个画布。这是图可视化中最基础且常用的导航交互,让用户能够自由探索超出当前视口的图内容。
这一交互主要用于:
createGraph({data: { nodes: [{ id: 'node-1' }] },layout: { type: 'force' },behaviors: [{type: 'drag-canvas',key: 'drag-canvas',},],node: { style: { fill: '#7e3feb' } },edge: { style: { stroke: '#8b9baf' } },plugins: [{ type: 'grid-line', size: 30 }],},{ width: 600, height: 300 },(gui, graph) => {const options = {key: 'drag-canvas',type: 'drag-canvas',enable: true,sensitivity: 1,trigger: 'Use cursor by default',};const optionFolder = gui.addFolder('ZoomCanvas Options');optionFolder.add(options, 'type').disable(true);optionFolder.add(options, 'enable');optionFolder.add(options, 'sensitivity', 0, 10, 1);optionFolder.add(options, 'trigger', {'Use cursor by default': [],'Shift+Arrow Key': {up: ['Shift', 'ArrowUp'],down: ['Shift', 'ArrowDown'],left: ['Shift', 'ArrowLeft'],right: ['Shift', 'ArrowRight'],},});optionFolder.onChange(({ property, value }) => {graph.updateBehavior({key: 'drag-canvas',[property]: value,});graph.render();});},);
在图配置中添加这一交互:
// 使用默认配置const graph = new Graph({// 其他配置...behaviors: ['drag-canvas'], // 直接添加,使用默认配置});// 或使用自定义配置const graph = new Graph({// 其他配置...behaviors: [{type: 'drag-canvas',direction: 'x', // 只允许水平方向拖拽key: 'drag-behavior', // 为交互指定标识符,方便动态更新},],});
配置项 | 说明 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
type | 交互类型名称 | string | drag-canvas | ✓ |
enable | 是否启用该交互 | boolean | ((event: Event | KeyboardEvent) => boolean) | true | |
animation | 拖拽动画配置,仅在使用按键移动时有效 | ViewportAnimationEffectTiming | - | |
direction | 允许的拖拽方向,配置项 | 'x' | 'y' | 'both' | 'both' (不限制方向) | |
range | 可拖拽的视口范围(以视口大小为单位),配置项 | number | number[] | Infinity | |
sensitivity | 触发一次按键移动的距离 | number | 10 | |
trigger | 触发拖拽的键盘按键,配置项 | object | - | |
onFinish | 拖拽完成时的回调函数 | () => void | - |
direction
用于限制拖拽的方向:
'both'
(默认):允许在任意方向拖拽'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: ['drag-canvas'],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'drag-canvas',direction: 'x', // 只允许水平拖拽},],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'drag-canvas',range: 1.5, // 限制拖拽范围为1.5个视口大小},],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'drag-canvas',trigger: {up: ['ArrowUp'],down: ['ArrowDown'],left: ['ArrowLeft'],right: ['ArrowRight'],},animation: {duration: 100, // 添加平滑动画效果},},],});
DragCanvas
用于拖拽整个画布视图DragElement
用于拖拽单个图元素(节点/边/组合)ScrollCanvas
用于滚轮滚动画布,不改变缩放比例