ZoomCanvas 缩放画布
阅读时间约 4 分钟
ZoomCanvas 是 G6 中用于实现画布缩放功能的内置交互,支持通过鼠标滚轮或键盘快捷键调整画布缩放比例。这是图可视化中最常用的交互之一,能帮助用户查看图的整体结构和局部细节。
这一交互主要用于:
createGraph({data: { nodes: [{ id: 'node-1' }] },layout: { type: 'force' },behaviors: [{type: 'zoom-canvas',key: 'zoom-canvas',},],node: { style: { fill: '#873bf4' } },edge: { style: { stroke: '#8b9baf' } },plugins: [{ type: 'grid-line', size: 30 }],},{ width: 600, height: 300 },(gui, graph) => {const options = {key: 'zoom-canvas',type: 'zoom-canvas',animation: true,enable: true,sensitivity: 1,trigger: 'Use wheel by default',};const optionFolder = gui.addFolder('ZoomCanvas Options');optionFolder.add(options, 'type').disable(true);optionFolder.add(options, 'animation');optionFolder.add(options, 'enable');optionFolder.add(options, 'sensitivity', 0, 10, 1);optionFolder.add(options, 'trigger', {'Use wheel by default': [],'Control+Wheel': ['Control'],'zoomIn:Ctrl+1 zoomOut:Ctrl+2 reset:Ctrl+0': {zoomIn: ['Control', '1'],zoomOut: ['Control', '2'],reset: ['Control', '0'],},});optionFolder.onChange(({ property, value }) => {graph.updateBehavior({key: 'zoom-canvas',[property]: value,});graph.render();});},);
在图配置中添加这一交互:
// 使用默认配置const graph = new Graph({// 其他配置...behaviors: ['zoom-canvas'], // 直接添加,使用默认配置});// 或使用自定义配置const graph = new Graph({// 其他配置...behaviors: [{type: 'zoom-canvas',sensitivity: 1.5, // 设置灵敏度key: 'zoom-behavior', // 为交互指定标识符,方便动态更新},],});
配置项 | 说明 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
type | 交互类型名称 | string | zoom-canvas | ✓ |
animation | 缩放动画效果设置 | ViewportAnimationEffectTiming | { duration: 200 } | |
enable | 是否启用该交互 | boolean | ((event: Event) => boolean) | true | |
onFinish | 缩放完成时的回调函数 | () => void | - | |
preventDefault | 是否阻止浏览器默认事件 | boolean | true | |
sensitivity | 缩放灵敏度,值越大缩放速度越快 | number | 1 | |
trigger | 触发缩放的方式,支持滚轮和键盘快捷键,配置项 | object | - |
trigger
有两种使用方式,分别适用于不同场景:
当你希望只有在按下某些键的同时滚动滚轮才触发缩放时,可以这样配置:
{trigger: ['Control']; // 按住 Control 键同时滚动鼠标滚轮才能缩放}
常见的修饰键有:
Control
Shift
Alt
不知道键盘按键对应什么值?请参考 MDN Key Values。
当你希望完全使用键盘控制缩放操作时,可以设置组合键:
{trigger: {zoomIn: ['Control', '+'], // 放大快捷键zoomOut: ['Control', '-'], // 缩小快捷键reset: ['Control', '0'] // 重置缩放比例快捷键}}
const graph = new Graph({container: 'container',width: 800,height: 600,behaviors: ['zoom-canvas'],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'zoom-canvas',sensitivity: 0.8, // 降低灵敏度,缩放变化更平缓},],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'zoom-canvas',trigger: ['Shift'], // 按住 Shift 键同时滚动才能缩放},],});
const graph = new Graph({// 其他配置...behaviors: [{type: 'zoom-canvas',trigger: {zoomIn: ['Control', '='], // Ctrl + = 放大zoomOut: ['Control', '-'], // Ctrl + - 缩小reset: ['Control', '0'], // Ctrl + 0 重置},},],});
为避免缩放过大或过小,可以设置缩放限制:
const graph = new Graph({// 其他配置...zoomRange: [0.5, 3], // 允许缩小到50%和放大到300%behaviors: ['zoom-canvas'],});
缩放与拖拽是常见的组合,实现完整的导航体验:
const graph = new Graph({// 其他配置...behaviors: ['drag-canvas', 'zoom-canvas'],});