Cubic
Reading needs 2 minutes
Before reading this section, please first read the API - Edge Configuration chapter.
createGraph({data: {nodes: [{ id: 'node1' }, { id: 'node2' }],edges: [{ id: 'edge1', source: 'node1', target: 'node2', text: 'cubic' }],},node: {style: {fill: '#f8f8f8',stroke: '#8b9baf',lineWidth: 1,},},edge: {type: 'cubic',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: 'grid', cols: 2 },plugins: [{ type: 'grid-line', size: 30 }],},{ width: 600, height: 300 },(gui, graph) => {gui.add({ type: 'cubic' }, 'type').disable();const options = {curveOffset: 20,curvePosition: 0.5,};const optionFolder = gui.addFolder('cubic.style');optionFolder.add(options, 'curveOffset', 0, 100, 1);optionFolder.add(options, 'curvePosition', 0, 1, 0.1);optionFolder.onChange(({ property, value }) => {graph.updateEdgeData([{ id: 'edge1', style: { [property]: value } }]);graph.render();});},);
设置 edge.type
为 cubic
以使用三次贝塞尔曲线。
If the element has its specific properties, we will list them below. For all generic style attributes, seeBaseEdge
[[number, number] | [number, number, number] | Float32Array, [number, number] | [number, number, number] | Float32Array__]
Control points. Used to define the shape of the curve. If not specified, it will be calculated using curveOffset
and curvePosition
.
number | [number, number] Default:
20
The distance of the control point from the line
number | [number, number] Default:
0.5
The relative position of the control point on the line, ranging from 0-1