logo

G6

  • Docs
  • API
  • Playground
  • Community
  • Productsantv logo arrow
  • 5.0.47
  • 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 and KeyShape
      • Atomic Shapes and Their Properties
      • Design and Implementation of Composite Shape
  • Layout
    • Layout Overview
    • Build-in Layout
      • 3D Force-Directed Layout
      • AntvDagre Layout
      • Circular Layout
      • ComboCombined Layout
      • Common Layout Configuration Options
      • CompactBox
      • Concentric Layout
      • D3 Force-Directed Layout
      • Dagre Layout
      • Dendrogram Layout
      • Fishbone Layout
      • Force Force-directed Layout
      • ForceAtlas2 Force-directed Layout
      • Fruchterman Force-directed Layout
      • Grid Layout
      • Indented Tree
      • MDS High-dimensional Data Dimensionality Reduction Layout
      • Mindmap Tree
      • Radial Layout
      • Random Layout
      • Snake Layout
    • 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

Dagre Layout

Previous
D3 Force-Directed Layout
Next
Dendrogram Layout

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...

Dagre Layout

Overview

Dagre is a hierarchical layout suitable for directed acyclic graphs (DAGs). It can automatically handle the direction and spacing between nodes and supports both horizontal and vertical layouts. See more Dagre layout examples, source code, and official documentation.

Dagre Layout

Configuration

const graph = new Graph({
layout: {
type: 'dagre',
rankdir: 'TB',
align: 'UL',
nodesep: 50,
ranksep: 50,
controlPoints: false,
},
});

Options

For more options, refer to the official documentation

Dagre Layout Options Illustration
PropertyDescriptionTypeDefaultRequired
typeLayout typedagre-✓
rankdirLayout direction, optionsTB | BT | LR | RLTB
alignNode alignment, optionsUL | UR | DL | DRUL
nodesepNode spacing (px). For TB or BT, it's the horizontal spacing; for LR or RL, it's the vertical spacingnumber50
ranksepRank spacing (px). For TB or BT, it's the vertical spacing between ranks; for LR or RL, it's the horizontal spacing between ranksnumber100
rankerAlgorithm for assigning ranks to nodes: longest-path, tight-tree, or network-simplexnetwork-simplex | tight-tree | longest-pathnetwork-simplex
nodeSizeG6 custom property, specify node size for all or each node. If a single number, width and height are the same; if array: [width, height]number | number[] | () => (number | number[])
controlPointsWhether to retain edge control pointsbooleanfalse

rankdir

TB | BT | LR | RL, Default: TB

Layout direction

  • TB: Top to Bottom;
Top to Bottom Layout
  • BT: Bottom to Top;
Bottom to Top Layout
  • LR: Left to Right;
Left to Right Layout
  • RL: Right to Left.
Right to Left Layout

align

UL | UR | DL | DR, Default: UL

Node alignment

  • UL: Upper Left
  • UR: Upper Right
  • DL: Down Left
  • DR: Down Right

nodesep

number, Default: 50

Node spacing (px). For TB or BT, it's the horizontal spacing; for LR or RL, it's the vertical spacing

ranksep

number, Default: 50

Rank spacing (px). For TB or BT, it's the vertical spacing between ranks; for LR or RL, it's the horizontal spacing between ranks

ranker

network-simplex | tight-tree | longest-path, Default: network-simplex

Algorithm for assigning ranks to nodes, supports three algorithms:

  • longest-path: Uses DFS to recursively find the longest path for each node. Simple and fast, but may result in many long edges.
  • tight-tree: An optimization algorithm to reduce the number of long edges. It first uses longest-path to compute initial ranks, then adjusts slack edges to build a feasible tree.
  • network-simplex: Based on A Technique for Drawing Directed Graphs, iteratively modifies node ranks to minimize slack edges.

nodeSize

number | number[] | () => (number | number[])

G6 custom property, specify node size for all or each node. If a single number, width and height are the same; if array: [width, height]

(d) => {
// d is a node
if (d.id === 'testId') return 20;
return [10, 20];
};

controlPoints

boolean, Default: false

Whether to retain edge control points.

Applicable Scenarios

  • Flowcharts: Suitable for displaying flowcharts, automatically handling direction and spacing between nodes.
  • Dependency Graphs: Display dependencies between packages or modules.
  • Task Scheduling Graphs: Show dependencies and execution order between tasks.

Related Documentation

The following documents can help you better understand Dagre layout

  • Graph Layout Algorithms|Detailed Dagre Layout
  • In-depth Interpretation of Dagre Layout Algorithm