Dot 画图常用语法¶
有向图¶
digraph {
a -> b
}
data:image/s3,"s3://crabby-images/3e31c/3e31cb20e2f5cebbbaf9c16ee404c9c0e3c35a89" alt="_images/dot-digraph.png"
无向图¶
graph {
a -- b
}
data:image/s3,"s3://crabby-images/c9d30/c9d302277587048a34d86a18fe32f2e2ce4f956c" alt="_images/dot-graph.png"
图属性¶
label="My Graph"
给图添加标题。rankdir=LR
默认图为上下布局,修改为左右布局。{rank=same; a, b, c }
将 a, b, c 画到同一个层级上
digraph {
label="xyz"
rankdir=LR
{rank=same; a, b}
a -> b
b -> c
}
data:image/s3,"s3://crabby-images/aa2f0/aa2f02df9347b6e5a2c966e800698b529d433b8f" alt="_images/dot-graph-attrs.png"
节点属性¶
边属性¶
label="XXX"
给边添加说明信息color=red
修改边 颜色penwidth=2.0
修改边宽度style=dotted
修改边的样式
graph {
rankdir=LR
a [label="Foo"]
b [shape=box, style=filled, fillcolor=yellow]
a -- b -- c [color=blue]
b -- d [style=dotted]
}
data:image/s3,"s3://crabby-images/e7142/e7142f0d79d06b7ec13bffe07e552f9758328246" alt="_images/dot-node-attrs.png"
常见的节点和边样式属性:
data:image/s3,"s3://crabby-images/e1ba0/e1ba08c93870d78d97bfbba114370db064f9fbf0" alt="_images/dot-style.png"
Record 节点¶
digraph structs {
node [shape=record];
struct1 [shape=record,label="<f0> left|<f1> middle|<f2> right"];
struct2 [shape=record,label="<f0> one|<f1> two"];
struct3 [shape=record,label="hello\nworld |{ b |{c|<here> d|e}| f}| g | h"];
struct1:f1 -> struct2:f0;
struct1:f2 -> struct3:here;
struct2 -> struct3
}
data:image/s3,"s3://crabby-images/753bd/753bdf46fe34f6318b8f978c063c9a24f70f3252" alt="_images/dot-record.png"
命令行参数¶
将图源码保存为 input.dot
文件,执行以下命令生成 png 图:
$ dot -Tpng -o output.png input.dot