4

我有以下点:

digraph G
{
    rank="same";
    subgraph sys
    {
        1 [shape=record, label="| | Système"];
    }

    subgraph obj
    {
        2 [shape=box, label="Sites"];
        3 [shape=box, label="Sociétés de\nmaintenance"];
        1 -> 2 [arrowhead=none] [label="a"];
        1 -> 3 [arrowhead=none] [label="b"];
    }

    subgraph constraints
    {
        4 [style=dotted, label="Surveiller"];
        5 [style=dotted, label="Effectuer des\ninterventions"];
        4 -> 2 [style=dotted];
        4 -> 3 [style=dotted];
        5 -> 2 [style=dotted];
        5 -> 3 [style=dotted];
    }

}

这给了我这张图片:

在此处输入图像描述

但我想按列有一个子图(第一列是 1,第二列是 2-3,最后一列是 4-5)。

有没有办法做到这一点?

为了您的帮助,在此先感谢。

4

2 回答 2

6
digraph G
{
    rank=same
    rankdir=LR

    subgraph sys
    {
        1 [shape=record, label="| | Système"]
    }
    subgraph obj
    {
        node [shape=box]
        2 [label="Sites"]
        3 [label="Sociétés de\nmaintenance"]
    }
    subgraph constraints
    {
        node [style=dotted]
        4 [label="Surveiller"]
        5 [label="Effectuer des\ninterventions"]
    }

    edge [style=invis, weight=2]
    2->4
    3->5

    edge [style=dotted]
    4 -> 2
    4 -> 3
    5 -> 2
    5 -> 3

    edge [style="" arrowhead=none]
    1 -> 2 [label="a"]
    1 -> 3 [label="b"]
} 

这个解决方案与@alexandr_anturis (+1) 建议的相同,但我已经删除了一些不相关的“语法噪音”,因为我觉得像dot语言这样复杂而强大的规范可以从任何可用的简化中受益。

使用rankdir和隐藏适当的边缘weight

结果图片:

在此处输入图像描述

于 2013-01-17T14:27:22.303 回答
2
digraph G
{
rank="same";
layout="dot";
rankdir=LR;
subgraph sys
{
    style=filled;
    1 [rank=1, shape=record, label="| | Système"];
}



subgraph obj
{
    2 [rank=2,shape=box, label="Sites"];
    3 [rank=3,shape=box, label="Sociétés de\nmaintenance"];
}
subgraph constraints
{
    4 [rank=4,style=dotted, label="Surveiller"];
    5 [rank=5,style=dotted, label="Effectuer des\ninterventions"];
}
    2->3->4->5 [color=white, weight=100];
    rankdir=LR;
    4 ->2 [style=dotted, w=0];
    4 -> 3 [style=dotted, w=0];
    5 -> 2 [style=dotted, w=0];
    5 -> 3 [style=dotted, w=0];


    1 -> 2 [arrowhead=none] [label="a"];
    1 -> 3 [arrowhead=none] [label="b"];
} 

你可以使用这样的东西。制作你想要的东西的方法是使用 rankdir 并添加不可见的边缘以进行正确的排名。

于 2013-01-17T13:29:43.293 回答