当有指向相同节点的反向链接时,如何使用 Graphviz 使主箭头变直?

How to make primary arrows straight with Graphviz when there are reverse links to the same nodes?

给定下图:

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];
};

结果输出为:

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

我想要的是“正向”箭头(图中的 right/down 和没有 constraint=false 的箭头)是直的,而“反向”箭头(向图中left/up,constraint=false)为曲线。在这两种情况下,我都希望标签彼此分开。 (对于垂直箭头,这可能意味着将标签推到另一边。)

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

我也尝试使用 splines 设置,但它没有任何作用。

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

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];
}