儿童在graphviz树中排序

时间:2013-05-19 17:17:01

标签: graphviz dot

我有以下树:

digraph G {
    subgraph cluster0{
        37[label="+"];
        42[label="a"];
        44[label="b"];
        47[label="*"];
        46[label="c"];
        49[label="d"];
        51[label="e"];
        53[label="f"];
        55[label="g"];
        57[label="h"];
        61[label="*"];
        60[label="i"];
        63[label="j"];
        37 -> 42[label="c"];
        37 -> 44[label="c"];
        37 -> 47[label="c"];
        37 -> 61[label="c"];
        42 -> 37[label="p"];
        44 -> 37[label="p"];
        47 -> 37[label="p"];
        47 -> 46[label="c"];
        47 -> 49[label="c"];
        47 -> 51[label="c"];
        47 -> 53[label="c"];
        47 -> 55[label="c"];
        47 -> 57[label="c"];
        46 -> 47[label="p"];
        49 -> 47[label="p"];
        51 -> 47[label="p"];
        53 -> 47[label="p"];
        55 -> 47[label="p"];
        57 -> 47[label="p"];
        61 -> 37[label="p"];
        61 -> 60[label="c"];
        61 -> 63[label="c"];
        60 -> 61[label="p"];
        63 -> 61[label="p"];
    }
}

输出在这里:http://i.imgur.com/q1qXkCT.png

第一个*子树中的子项顺序为:G H C D E F,但应为C D E F G H。 我注意到如果我删除subgraph cluster0{订单是正确的,但我不能这样做。 你能建议任何其他解决方案吗?

1 个答案:

答案 0 :(得分:0)

Graphviz尝试在没有其他约束时保留节点的词法排序。但是,边缘标签可能会影响放置,因为它们占用空间并可以推动节点。

如果您有特定的订单,那么请尝试类似

的订单
{ rank = same; 
46 -> 49 -> 51 -> 53 -> 55 -> 57 [style = invis];
}

将额外的排序约束引入图中。

你需要小心这一点,因为它可能以非常难以预测的方式扭曲更复杂的图形。