首页 > 解决方案 > 当有指向相同节点的反向链接时,如何使用 Graphviz 使主箭头笔直?

问题描述

给定下图:

digraph g {
  rankdir=LR;
  node [shape=box];

  A;
  { rank = same;
    B; C; D; E;
  };
  A -> B [label="144"];
  B -> A [label="261"; constraint=false];
  B -> C [label="144"];
  C -> B [label="261"; constraint=false];
  C -> D [label="144"];
  D -> C [label="261"; constraint=false];
  D -> E [label="144"];
  E -> D [label="261"; constraint=false];

  B -> n1 [label="144"];
  n1 -> B [label="261"; constraint=false];
  n1 -> n2 [label="144"];
  n2 -> n1 [label="261"; constraint=false];

  C -> n3 [label="144"];
  n3 -> C [label="261"; constraint=false];
  n3 -> n4 [label="144"];
  n4 -> n3 [label="261"; constraint=false];

  D -> n5 [label="144"];
  n5 -> D [label="261"; constraint=false];
  n5 -> n6 [label="144"];
  n6 -> n5 [label="261"; constraint=false];

  E -> n7 [label="144"];
  n7 -> E [label="261"; constraint=false];
  n7 -> n8 [label="144"];
  n8 -> n7 [label="261"; constraint=false];
};

结果输出是:

图形输出

这几乎是我想要的(特别是要弄清楚如何在第二等级中制作直线的字母节点需要很多麻烦),但我的问题是在垂直节点中绘制边缘箭头的方式.

我想要的是“向前”箭头(图中向右/向下的箭头,以及没有constraint=false的箭头)是直的,而“反向”箭头(在图中向左/向上,带有constraint=false)是弯曲的. 在这两种情况下,我都希望标签不会妨碍彼此。(对于垂直箭头,这可能意味着将标签推到另一侧。)

我尝试过设置组和权重,但到目前为止似乎没有任何东西可以帮助交换垂直箭头。而且我还没有找到任何可以将标签移到另一边的东西。

我也尝试使用该splines设置,但它没有做任何事情。

标签: graphvizdot

解决方案


管理边缘放置非常困难。
这是否满足您的要求 - 它使用端口来调整边缘位置。

digraph g {
  rankdir=LR;
  node [shape=box];
  
  A;
  { rank = same;
    B; C; D; E;
  };
  A -> B [label="144"];
  B -> A [label="261"; constraint=false];
  B -> C [label="144"];
  C -> B:se [label="261"; constraint=false];
  C -> D [label="144"];
  D -> C:se [label="261"; constraint=false];
  D -> E [label="144"];
  E -> D:se [label="261"; constraint=false];

  B -> n1 [label="144"];
  n1 -> B [label="261"; constraint=false];
  n1 -> n2 [label="144"];
  n2 -> n1 [label="261"; constraint=false];

  C -> n3 [label="144"];
  n3 -> C [label="261"; constraint=false];
  n3 -> n4 [label="144"];
  n4 -> n3 [label="261"; constraint=false];

  D -> n5 [label="144"];
  n5 -> D [label="261"; constraint=false];
  n5 -> n6 [label="144"];
  n6 -> n5 [label="261"; constraint=false];

  E -> n7 [label="144"];
  n7 -> E [label="261"; constraint=false];
  n7 -> n8 [label="144"];
  n8 -> n7 [label="261"; constraint=false];
}

在此处输入图像描述


推荐阅读