GraphViz 强制列数

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)。

有没有办法做到这一点?

感谢您的帮助。

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的隐藏边缘。

结果的图片:

enter image description here


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,并添加不可见的边以进行正确的排名。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接