GraphViz强制执行列

GraphViz强制执行列,graphviz,subgraph,Graphviz,Subgraph,我有以下要点: 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

我有以下要点:

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)

有办法吗

谢谢你的帮助, 提前谢谢

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并添加不可见的边以获得正确的排名

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
和具有适当
权重的隐藏边

结果图片: