此代码将节点放在正确的位置。
digraph g {
edge [dir=none];
node [shape=box,fillcolor="palegreen",style="filled"];
a -> b;
a -> c
b -> c
b -> d
b -> e
d -> e
c -> f
e -> f
a [label="A",pos="150,155!"];
b [label="B",fillcolor="red",pos="75,75!"];
c [label="C",pos="230,75!"];
d [label="D",pos="0,0!"];
e [label="E",pos="150,0!"];
f [label="F",pos="300,0!"];
}
如何在不指定节点中的pos的情况下放置这样的节点?
答案 0 :(得分:1)
尝试
digraph g {
edge [dir=none];
node [shape=box,fillcolor="palegreen",style="filled"];
a -> b;
a -> c
b -> c
b -> d
b -> e
d -> e
c -> f [constraint = false]; // Use to relax weight of edge
e -> f
{ rank = same; b; c; } // Force specific nodes onto same height
{ rank = same; d; e; f; }
a [label="A"];
b [label="B",fillcolor="red"];
c [label="C"];
d [label="D"];
e [label="E"];
f [label="F"];
}
边缘属性constraint = false
用于防止边缘影响边缘的位置。如果确切的水平定位并不重要,请将其取出以避免以后出现问题。
rank = same
属性用于强制节点在图形中处于同一级别,并将覆盖由边缘驱动的自然层次结构。您还可以使用约束属性在确定高度时为某些边缘打折。
选择取决于您的源数据结构,以及您是否希望能够在不进行任何编辑的情况下生成图形。