我正在尝试为两个不同群集中的两个节点提供相同的等级,以使点以相同的级别显示它们。特别是在此示例中,我希望节点a4和b3处于同一级别。 这是代码:
digraph G {
subgraph cluster_0 {
style=filled;
color=lightgrey;
node [style=filled,color=white];
a0 -> a1 -> a2 -> a3 -> a4;
label = "process #1";
}
subgraph cluster_1 {
node [style=filled];
b0 -> b1 -> b2 -> b3;
label = "process #2";
color=blue
}
start -> a0;
start -> b0;
a1 -> b3;
b2 -> a3;
a4 -> end;
b3 -> end;
// {rank=same; a4; b3;}
start [shape=Mdiamond];
end [shape=Msquare];
}
我尝试添加行{rank=same; a4; b3;}
,但这只是弄乱了群集,因为从它们各自的群集中删除了节点a4和b3。我也尝试添加不可见的节点,但是它们也以错误的方式修改了集群。
知道如何解决这个问题吗?
答案 0 :(得分:0)
基本上,您想跳过b
集群中的级别;您只能通过以正确的方式引入不可见节点来做到这一点。希望这段代码对您有所帮助:
digraph G {
start[ shape=Mdiamond ];
end[ shape=Msquare ];
bx[ shape = point, width = 0.01 ]; // invisible node
subgraph cluster_0 {
style=filled;
color=lightgrey;
node [style=filled,color=white];
a0 -> a1 -> a2 -> a3 -> a4;
label = "process #1";
}
subgraph cluster_1 {
node [style=filled];
b0 -> b1;
b1 -> b2;
b2 -> bx[ dir = none ]; // connecting inv node without arrow
bx -> b3; // continue normally
label = "process #2";
color=blue
}
start -> a0;
start -> b0;
a1 -> b3;
b2 -> a3;
a4 -> end;
b3 -> end;
}
给你