水平三次贝塞尔曲线边 CubicHorizontal
上一篇
三次贝塞尔曲线边 Cubic
下一篇
垂直三次贝塞尔曲线边 CubicVertical
Loading...
水平三次贝塞尔曲线是一种平滑的曲线,其控制点主要沿水平方向分布,适合在水平方向上连接节点。
使用场景:
适用于水平布局的图,如流程图、层次结构图。
当需要强调水平方向的连接关系时使用。
特别注意,计算控制点时主要考虑 x 轴上的距离,忽略 y 轴的变化
createGraph({autoFit: 'center',data: {nodes: [{ id: 'node1' }, { id: 'node2' }, { id: 'node3' }, { id: 'node4' }, { id: 'node5' }, { id: 'node6' }],edges: [{ source: 'node1', target: 'node2' },{ source: 'node1', target: 'node3' },{ source: 'node1', target: 'node4', text: 'cubic-horizontal' },{ source: 'node1', target: 'node5' },{ source: 'node1', target: 'node6' },],},node: {style: {fill: '#f8f8f8',stroke: '#8b9baf',lineWidth: 1,port: true,ports: [{ placement: 'left' }, { placement: 'right' }],},},edge: {type: 'cubic-horizontal',style: {stroke: '#7e3feb',lineWidth: 2,labelText: (d) => d.text,labelBackground: true,labelBackgroundFill: '#f9f0ff',labelBackgroundOpacity: 1,labelBackgroundLineWidth: 2,labelBackgroundStroke: '#7e3feb',labelPadding: [1, 10],labelBackgroundRadius: 4,},},behaviors: ['drag-canvas', 'drag-element'],layout: {type: 'antv-dagre',rankdir: 'LR',nodesep: 15,ranksep: 100,},plugins: [{ type: 'grid-line', size: 30 }],},{ width: 600, height: 400 },(gui, graph) => {gui.add({ type: 'cubic-horizontal' }, 'type').disable();const options = {curveOffset: 20,curvePosition: 0.5,};const optionFolder = gui.addFolder('cubic-horizontal.style');optionFolder.add(options, 'curveOffset', 0, 100);optionFolder.add(options, 'curvePosition', 0, 1);optionFolder.onChange(({ property, value }) => {graph.updateEdgeData((prev) => prev.map((edge) => ({ ...edge, style: { [property]: value } })));graph.render();});},);
设置 edge.type
为 cubic-horizontal
以使用水平方向的三次贝塞尔曲线。
如果元素有其特定的属性,我们将在下面列出。对于所有的通用样式属性,见 BaseEdge
属性 | 描述 | 类型 | 默认值 | 必选 |
---|---|---|---|---|
curvePosition | 控制点在两端点连线上的相对位置,范围为0-1 | number | number[] | [0.5,0.5] | |
curveOffset | 控制点距离两端点连线的距离,可理解为控制边的弯曲程度 | number | number[] | [0,0] |
import { Graph } from '@antv/g6';const data = {nodes: [{id: 'node1',},{id: 'node2',},{id: 'node3',},{id: 'node4',},{id: 'node5',},{id: 'node6',},],edges: [{id: 'line-default',source: 'node1',target: 'node2',},{id: 'line-active',source: 'node1',target: 'node3',states: ['active'],},{id: 'line-selected',source: 'node1',target: 'node4',states: ['selected'],},{id: 'line-highlight',source: 'node1',target: 'node5',states: ['highlight'],},{id: 'line-inactive',source: 'node1',target: 'node6',states: ['inactive'],},],};const graph = new Graph({container: 'container',data,node: {style: {port: true,ports: [{ placement: 'right' }, { placement: 'left' }],},},edge: {type: 'cubic-horizontal',style: {labelText: (d) => d.id,labelBackground: true,endArrow: true,},},layout: {type: 'antv-dagre',rankdir: 'LR',nodesep: 20,ranksep: 120,},});graph.render();