Graphviz的。如何自动将节点放在正确的位置

时间:2013-10-23 07:12:42

标签: graphviz dot

此代码将节点放在正确的位置。

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的情况下放置这样的节点?

1 个答案:

答案 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属性用于强制节点在图形中处于同一级别,并将覆盖由边缘驱动的自然层次结构。您还可以使用约束属性在确定高度时为某些边缘打折。

选择取决于您的源数据结构,以及您是否希望能够在不进行任何编辑的情况下生成图形。