logo

G6

  • Docs
  • API
  • Playground
  • Community
  • Productsantv logo arrow
  • 5.0.45
  • Introduction
  • Data
  • Getting Started
    • Quick Start
    • Installation
    • Integration
      • react
      • vue
      • angular
    • Step-by-step guide
  • Graph
    • Extensions En
    • Graph
    • Options
    • extension
  • Element
    • Element Overview
    • Element State
    • Node
      • Node Overview
      • Build-in Node
        • Common Node Configurations
        • Diamond
        • Donut
        • Ellipse
        • Hexagon
        • Html
        • Image
        • Rect
        • Star
        • Triangle
        • Circle
      • Custom Node
      • Define Nodes with React
    • Edge
      • Edge Overview
      • Build-in Edge
        • Common Edge Configurations
        • Cubic Bezier Curve
        • CubicHorizontal Bezier Curve
        • CubicVertical Bezier Curve
        • Line
        • Polyline
        • Quadratic Bezier Curve
      • Custom Edge
    • Combo
      • Combo Overview
      • Build-in Combo
        • Circle
        • Combo Configuration Options
        • Rect
      • Custom Combo
    • Shape
      • Shape Overview
      • Shape Properties
  • Layout
    • Layout Overview
    • Build-in Layout
      • AntvDagre
      • Circular
      • ComboCombined
      • CompactBox
      • Concentric
      • D3Force
      • D3Force3D
      • Dagre
      • Dendrogram
      • Fishbone
      • Force
      • ForceAtlas2
      • Fruchterman
      • Grid Layout
      • Indented
      • Layout Common Options
      • Mds
      • Mindmap
      • Radial
      • Random
      • Snake
    • Custom Layout
  • Behavior
    • Behavior Overview
    • Build-in Behavior
      • AutoAdaptLabel
      • BrushSelect
      • ClickSelect
      • CollapseExpand
      • CreateEdge
      • DragCanvas
      • DragElement
      • DragElementForce
      • FixElementSize
      • FocusElement
      • HoverActivate
      • LassoSelect
      • OptimizeViewportTransform
      • ScrollCanvas
      • ZoomCanvas
    • Custom Behavior
  • Plugin
    • Plugin Overview
    • Build-in Plugin
      • Background
      • BubbleSets
      • Contextmenu
      • EdgeBundling
      • EdgeFilterLens
      • Fisheye
      • Fullscreen
      • GridLine
      • History
      • Hull
      • Legend
      • Minimap
      • Snapline
      • Timebar
      • Toolbar
      • Tooltip
      • Watermark
    • Custom Plugin
  • Transform
    • Data Transformation Overview
    • Build-in Transform
      • MapNodeSize
      • PlaceRadialLabels
      • ProcessParallelEdges
    • Custom Transform
  • Theme
    • Theme Overview
    • Custom Theme
    • Palette
    • Custom Palette
  • Animation
    • Animation Overview
    • Custom Animation
  • Further Reading
    • Event
    • renderer
    • coordinate
    • download-image
    • Using Iconfont
    • Use 3D
    • Bundle Project
  • What's new
    • Feature
    • Upgrade To 5.0
  • FAQ
  • contribute

CubicVertical Bezier Curve

Previous
CubicHorizontal Bezier Curve
Next
Line

Resources

Ant Design
Galacea Effects
Umi-React Application Framework
Dumi-Component doc generator
ahooks-React Hooks Library

Community

Ant Financial Experience Tech
seeconfSEE Conf-Experience Tech Conference

Help

GitHub
StackOverflow

more productsMore Productions

Ant DesignAnt Design-Enterprise UI design language
yuqueYuque-Knowledge creation and Sharing tool
EggEgg-Enterprise-class Node development framework
kitchenKitchen-Sketch Tool set
GalaceanGalacean-互动图形解决方案
xtechLiven Experience technology
© Copyright 2025 Ant Group Co., Ltd..备案号:京ICP备15032932号-38

Loading...

Overview

The vertical cubic Bezier curve is a smooth curve with control points primarily distributed along the vertical direction, suitable for connecting nodes vertically.

Use cases:

  • Suitable for vertically laid-out graphs, such as organizational charts and tree diagrams.

  • Use when emphasizing vertical connections is needed.

Note: When calculating control points, the distance on the y-axis is primarily considered, ignoring changes on the x-axis.

Online Experience

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-vertical' },
{ source: 'node1', target: 'node5' },
{ source: 'node1', target: 'node6' },
],
},
node: {
style: {
fill: '#f8f8f8',
stroke: '#8b9baf',
lineWidth: 1,
port: true,
ports: [{ placement: 'top' }, { placement: 'bottom' }],
},
},
edge: {
type: 'cubic-vertical',
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: 'TB',
nodesep: 25,
ranksep: 80,
},
plugins: [{ type: 'grid-line', size: 30 }],
},
{ width: 600, height: 300 },
(gui, graph) => {
gui.add({ type: 'cubic-vertical' }, 'type').disable();
const options = {
curveOffset: 20,
curvePosition: 0.5,
};
const optionFolder = gui.addFolder('cubic-vertical.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-vertical 以使用垂直方向的三次贝塞尔曲线。

Style Configuration

If the element has specific attributes, we will list them below. For all general style attributes, see BaseEdge

AttributeDescriptionTypeDefaultRequired
curvePositionRelative position of the control point on the line connecting the two endpoints, ranging from 0-1.number | number[][0.5,0.5]
curveOffsetDistance of the control point from the line connecting the two endpoints, understood as the degree of curve bending.number | number[][0,0]

Example

Built-in Vertical Cubic Bezier Curve Edge Effect