如果子图之间没有连接,则无法控制它们的定位。rank=same
在左侧的图例中使用是一种常见的方法,以及不可见的节点来强制结构进入布局。
如果您只需要在两个节点之间添加最小量的空间,那么您可以使用minlen =
隐藏边上的属性来强制进行所需的分离。这也在dot 中的子图集群排名中得到了解释。
这体现在:
digraph {
node [label = ""];
A; B; C; D;
E [style = invis];
{ node [shape = box, label = ""];
1 -> 2;
3 -> { 4; 5; 6; 7; 8; 9; 10; 11; 12; }; 5 -> 13; 7 -> 14; 10 -> 15; 12 -> { 16; 17; }; 16 -> 18;
19 -> { 34; 35; 36; 37; 38; 39; 40; 41; }; 35 -> 42; 36 -> 43; 40 -> { 45; 46; }; 41 -> 44;
20 -> { 21; 22; 23};
}
{ edge [weight = 10];
A -> B [minlen = 2];
B -> C [minlen = 3];
C -> D [minlen = 3];
D -> E [style = invis];
}
{ rank = same; A -> 1; }
{ rank = same; B -> 3; }
{ rank = same; C -> 19; }
{ rank = same; D -> 20; }
}
最后一棵树(引用 fromD
将落在左侧的椭圆下而没有 hidden E
。如果这是不可接受的,则需要将来自上面树中的一个节点的隐藏边连接到 node 20
。
椭圆之间的间距可以通过minlen =
属性进行调整。