Graphviz边缘使用正交线不与端口对齐。

huangapple go评论61阅读模式
英文:

Graphviz edges with ortho lines not aligning with ports

问题

我正在尝试创建一个具有双向箭头的Graphviz块图。我使用了从Python Graphviz包创建的Graphviz代码。在探索边缘选项后,我喜欢正交边缘,但当我编写正交边缘时,边缘未正确连接到端口,并且标签根本不与边缘对齐。我该如何修复这个问题。非常感谢您提前的帮助:D

以下是您提供的Graphviz代码,Python后端生成的:

digraph {
	graph [nodesep=.3 rankdir=LR ranksep=2 splines=ortho]
	node [shape=record]
	Node1 [label="{{Node1}|{<f0>A|<f1>A|<f2>A}}" fontsize=25 width=3]
	Node2 [label="{<p0>B|{Node2}|{<f0>A|<f1>A|<f2>A}}" fontsize=25 width=3]
	Node3 [label="{<p0>B|{Node3}|{<f0>A|<f1>A|<f2>A}}" fontsize=25 width=3]
	Node4 [label="{<p0>B|{Node4}}" fontsize=25 width=3]
	Node5 [label="{<p0>B|{Node5}}" fontsize=25 width=3]
	Node6 [label="{<p0>B|{Node6}}" fontsize=25 width=3]
	Node7 [label="{<p0>B|{Node7}}" fontsize=25 width=3]
	Node8 [label="{<p0>B|{Node8}}" fontsize=25 width=3]
	Node9 [label="{<p0>B|{Node9}}" fontsize=25 width=3]
	Node10 [label="{<p0>B|{Node10}}" fontsize=25 width=3]
	Node1:<f0> -> Node2:<p0>
	Node1:<f1> -> Node3:<p0>
	Node1:<f2> -> Node4:<p0>
	Node2:<f0> -> Node5:<p0>
	Node2:<f1> -> Node6:<p0>
	Node2:<f2> -> Node7:<p0>
	Node2:<p0> -> Node1:<f0>
	Node3:<f0> -> Node8:<p0>
	Node3:<f1> -> Node9:<p0>
	Node3:<f2> -> Node10:<p0>
	Node3:<p0> -> Node1:<f1>
	Node4:<p0> -> Node1:<f2>
	Node5:<p0> -> Node2:<f0>
	Node6:<p0> -> Node2:<f1>
	Node7:<p0> -> Node2:<f2>
	Node8:<p0> -> Node3:<f0>
	Node9:<p0> -> Node3:<f1>
	Node10:<p0> -> Node3:<f2>
}

这是Python后端生成的Graphviz代码。在使用直线时生成的图如下,它表示正确,但我想使用正交边缘而不是直线:

Graphviz边缘使用正交线不与端口对齐。

这是使用直线生成的图。

英文:

I am trying to create a graphviz block diagram with bidirectional arrows. I have used this graphviz code created from python graphviz package. After exploring the edge options, I liked ortho edges but when I code that, the edges are not getting connected to ports properly and the labels are not at all aligned to the edges. What can I do to fix this. Thanks a lot in advance Graphviz边缘使用正交线不与端口对齐。

digraph {
	graph [nodesep=.3 rankdir=LR ranksep=2 splines=ortho]
	node [shape=record]
	Node1 [label=&quot;{{Node1}|{&lt;f0&gt;A|&lt;f1&gt;A|&lt;f2&gt;A}}&quot; fontsize=25 width=3]
	Node2 [label=&quot;{&lt;p0&gt;B|{Node2}|{&lt;f0&gt;A|&lt;f1&gt;A|&lt;f2&gt;A}}&quot; fontsize=25 width=3]
	Node3 [label=&quot;{&lt;p0&gt;B|{Node3}|{&lt;f0&gt;A|&lt;f1&gt;A|&lt;f2&gt;A}}&quot; fontsize=25 width=3]
	Node4 [label=&quot;{&lt;p0&gt;B|{Node4}}&quot; fontsize=25 width=3]
	Node5 [label=&quot;{&lt;p0&gt;B|{Node5}}&quot; fontsize=25 width=3]
	Node6 [label=&quot;{&lt;p0&gt;B|{Node6}}&quot; fontsize=25 width=3]
	Node7 [label=&quot;{&lt;p0&gt;B|{Node7}}&quot; fontsize=25 width=3]
	Node8 [label=&quot;{&lt;p0&gt;B|{Node8}}&quot; fontsize=25 width=3]
	Node9 [label=&quot;{&lt;p0&gt;B|{Node9}}&quot; fontsize=25 width=3]
	Node10 [label=&quot;{&lt;p0&gt;B|{Node10}}&quot; fontsize=25 width=3]
	Node1:&lt;f0&gt; -&gt; Node2:&lt;p0&gt;
	Node1:&lt;f1&gt; -&gt; Node3:&lt;p0&gt;
	Node1:&lt;f2&gt; -&gt; Node4:&lt;p0&gt;
	Node2:&lt;f0&gt; -&gt; Node5:&lt;p0&gt;
	Node2:&lt;f1&gt; -&gt; Node6:&lt;p0&gt;
	Node2:&lt;f2&gt; -&gt; Node7:&lt;p0&gt;
	Node2:&lt;p0&gt; -&gt; Node1:&lt;f0&gt;
	Node3:&lt;f0&gt; -&gt; Node8:&lt;p0&gt;
	Node3:&lt;f1&gt; -&gt; Node9:&lt;p0&gt;
	Node3:&lt;f2&gt; -&gt; Node10:&lt;p0&gt;
	Node3:&lt;p0&gt; -&gt; Node1:&lt;f1&gt;
	Node4:&lt;p0&gt; -&gt; Node1:&lt;f2&gt;
	Node5:&lt;p0&gt; -&gt; Node2:&lt;f0&gt;
	Node6:&lt;p0&gt; -&gt; Node2:&lt;f1&gt;
	Node7:&lt;p0&gt; -&gt; Node2:&lt;f2&gt;
	Node8:&lt;p0&gt; -&gt; Node3:&lt;f0&gt;
	Node9:&lt;p0&gt; -&gt; Node3:&lt;f1&gt;
	Node10:&lt;p0&gt; -&gt; Node3:&lt;f2&gt;
}

This is the graphviz code that python backend generated.

Graphviz边缘使用正交线不与端口对齐。

This is what generated when using lines. It represents correctly but I would like to have ortho edges rather than line

Graphviz边缘使用正交线不与端口对齐。

答案1

得分: 2

对于 splines=ortho,你不应该使用边缘的标签规范,所以你可以用 Node1 -> Node2 替代 Node1:&lt;f0&gt; -> Node2:&lt;p0&gt;

英文:

For splines=ortho you should not use the label specifiers for the edges, so instead of Node1:&lt;f0&gt; -&gt; Node2:&lt;p0&gt; you can just use Node1 -&gt; Node2.

digraph {
    graph [nodesep=.3 rankdir=LR ranksep=2 splines=ortho]
    node [shape=record]
    Node1 [label=&quot;{{Node1}|{&lt;f0&gt;A|&lt;f1&gt;A|&lt;f2&gt;A}}&quot; fontsize=25 width=3]
    Node2 [label=&quot;{&lt;p0&gt;B|{Node2}|{&lt;f0&gt;A|&lt;f1&gt;A|&lt;f2&gt;A}}&quot; fontsize=25 width=3]
    Node3 [label=&quot;{&lt;p0&gt;B|{Node3}|{&lt;f0&gt;A|&lt;f1&gt;A|&lt;f2&gt;A}}&quot; fontsize=25 width=3]
    Node4 [label=&quot;{&lt;p0&gt;B|{Node4}}&quot; fontsize=25 width=3]
    Node5 [label=&quot;{&lt;p0&gt;B|{Node5}}&quot; fontsize=25 width=3]
    Node6 [label=&quot;{&lt;p0&gt;B|{Node6}}&quot; fontsize=25 width=3]
    Node7 [label=&quot;{&lt;p0&gt;B|{Node7}}&quot; fontsize=25 width=3]
    Node8 [label=&quot;{&lt;p0&gt;B|{Node8}}&quot; fontsize=25 width=3]
    Node9 [label=&quot;{&lt;p0&gt;B|{Node9}}&quot; fontsize=25 width=3]
    Node10 [label=&quot;{&lt;p0&gt;B|{Node10}}&quot; fontsize=25 width=3]
    Node1 -&gt; Node2
    Node1 -&gt; Node3
    Node1 -&gt; Node4
    Node2 -&gt; Node5
    Node2 -&gt; Node6
    Node2 -&gt; Node7
    Node2 -&gt; Node1
    Node3 -&gt; Node8
    Node3 -&gt; Node9
    Node3 -&gt; Node10
    Node3 -&gt; Node1
    Node4 -&gt; Node1
    Node5 -&gt; Node2
    Node6 -&gt; Node2
    Node7 -&gt; Node2
    Node8 -&gt; Node3
    Node9 -&gt; Node3
    Node10 -&gt; Node3
}

Result:

Graphviz边缘使用正交线不与端口对齐。

huangapple
  • 本文由 发表于 2023年4月7日 03:23:45
  • 转载请务必保留本文链接:https://go.coder-hub.com/75953069.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定