【问题标题】:graphviz dot HTML attributes not working?graphviz dot HTML 属性不起作用?
【发布时间】:2021-01-05 06:15:45
【问题描述】:

我正在用 graphviz dot 在 macbook 上绘制图表,这是我的图表 simple.dot

digraph {
    node [shape=record, fontname="Courier New, Courier", fontsize=12]
    graph [fontname="Courier New, Courier", fontsize=12]
    edge [fontname="Courier New, Courier", fontsize=12]

    node626 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell625">global.1</TD></TR>
        <TR><TD PORT="cell627">symbol: name: integer_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell633">symbol: name: string_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell639">symbol: name: floating_point_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell645">symbol: name: character_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell651">typeSymbol: name: byte, kind: Plain</TD></TR>
        <TR><TD PORT="cell652">typeSymbol: name: ubyte, kind: Plain</TD></TR>
        <TR><TD PORT="cell653">typeSymbol: name: short, kind: Plain</TD></TR>
        <TR><TD PORT="cell654">typeSymbol: name: ushort, kind: Plain</TD></TR>
        <TR><TD PORT="cell655">typeSymbol: name: int, kind: Plain</TD></TR>
        <TR><TD PORT="cell656">typeSymbol: name: uint, kind: Plain</TD></TR>
        <TR><TD PORT="cell657">typeSymbol: name: long, kind: Plain</TD></TR>
        <TR><TD PORT="cell658">typeSymbol: name: ulong, kind: Plain</TD></TR>
        <TR><TD PORT="cell659">typeSymbol: name: float, kind: Plain</TD></TR>
        <TR><TD PORT="cell660">typeSymbol: name: double, kind: Plain</TD></TR>
        <TR><TD PORT="cell661">typeSymbol: name: char, kind: Plain</TD></TR>
        <TR><TD PORT="cell662">typeSymbol: name: boolean, kind: Plain</TD></TR>
        <TR><TD PORT="cell663">typeSymbol: name: void, kind: Plain</TD></TR></TABLE>>]
    node629 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell628">integer_literal</TD></TR>
        <TR><TD PORT="cell630">symbol: name: local.2, type: void, kind: Local</TD></TR></TABLE>>]
    node632 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell631">local.2</TD></TR></TABLE>>]
    node635 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell634">string_literal</TD></TR>
        <TR><TD PORT="cell636">symbol: name: local.3, type: void, kind: Local</TD></TR></TABLE>>]
    node638 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell637">local.3</TD></TR></TABLE>>]
    node641 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell640">floating_point_literal</TD></TR>
        <TR><TD PORT="cell642">symbol: name: local.4, type: void, kind: Local</TD></TR></TABLE>>]
    node644 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell643">local.4</TD></TR></TABLE>>]
    node647 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell646">character_literal</TD></TR>
        <TR><TD PORT="cell648">symbol: name: local.5, type: void, kind: Local</TD></TR></TABLE>>]
    node650 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell649">local.5</TD></TR></TABLE>>]

    node629:cell630 -> node632:cell631
    node626:cell627 -> node629:cell628
    node635:cell636 -> node638:cell637
    node626:cell633 -> node635:cell634
    node641:cell642 -> node644:cell643
    node626:cell639 -> node641:cell640
    node647:cell648 -> node650:cell649
    node626:cell645 -> node647:cell646
}

dot -Tpng simple.dot -o simple.png编译,它给了我:

但是PORT 似乎不起作用,因为边缘应该从&lt;TD&gt; 指向另一个&lt;TD&gt;。而&lt;TABLE BORDER&gt; 也无法正常工作,因为我的表格边框是粗体。

请帮忙。

【问题讨论】:

    标签: visualization graphviz dot


    【解决方案1】:

    您文件中的核心问题是这一行:

    node [shape=record, fontname="Courier New, Courier", fontsize=12]
    

    你想要的是 node [shape=none ...]

    node [shape=none, fontname="Courier New, Courier", fontsize=12]
    

    这修复了表格边框和端口问题。如果您在某些边缘添加指南针点,情况会变得更好。

     node626:cell627 -> node629:cell628:n
    

    【讨论】:

      猜你喜欢
      • 2020-05-23
      • 2011-03-04
      • 2020-10-16
      • 1970-01-01
      • 1970-01-01
      • 2010-09-29
      • 2019-08-29
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多