1

我正在处理一个点文件来呈现节点的分层。

我手上的图就是这个。(对不起,我没有足够的声誉来发布图片..) http://www.flickr.com/photos/40328682@N03/8473003861/in/photostream/lightbox/

但是,我希望树(蓝色节点)不被压缩并且每棵树只占用一层。我通过添加不可见节点和更多边缘来绘制示例,如下所示: http ://www.flickr.com/photos/40328682@N03/8474093000/in/photostream/lightbox/

我尝试 $ rank = same $ 使黄色节点和蓝色节点(顶部)处于同一级别,但如果不插入不可见节点,我无法添加更多层。

有什么方法可以在不添加不可见节点的情况下在不同等级之间添加更多层?非常感谢!

4

1 回答 1

3

如果子图之间没有连接,则无法控制它们的定位。rank=same在左侧的图例中使用是一种常见的方法,以及不可见的节点来强制结构进入布局。

如果您只需要在两个节点之间添加最小量的空间,那么您可以使用minlen =隐藏边上的属性来强制进行所需的分离。这也在dot 中的子图集群排名中得到了解释。

这体现在:

digraph {
    node [label = ""];

    A; B; C; D;
    E [style = invis];

    {   node [shape = box, label = ""];

        1 -> 2;
        3 -> { 4; 5; 6; 7; 8; 9; 10; 11; 12; }; 5 -> 13; 7 -> 14; 10 -> 15; 12 -> { 16; 17; }; 16 -> 18;
        19 -> { 34; 35; 36; 37; 38; 39; 40; 41; }; 35 -> 42; 36 -> 43; 40 -> { 45; 46; }; 41 -> 44;
        20 -> { 21; 22; 23};
    }

    {   edge [weight = 10];
        A -> B [minlen = 2];
        B -> C [minlen = 3];
        C -> D [minlen = 3];
        D -> E [style = invis];
    }

    {   rank = same; A -> 1; }
    {   rank = same; B -> 3; }
    {   rank = same; C -> 19; }
    {   rank = same; D -> 20; }
}

最后一棵树(引用 fromD将落在左侧的椭圆下而没有 hidden E。如果这是不可接受的,则需要将来自上面树中的一个节点的隐藏边连接到 node 20

椭圆之间的间距可以通过minlen =属性进行调整。

于 2013-09-23T13:21:50.447 回答