dot简介(一)

(50) 2024-02-27 12:54:44

DOT语言又是啥子?

这个叫做地球的星球上,好像各种各样好的坏的莫名其妙的语言已经够多的了,还有无聊的家伙搞出来过一个莫名其妙的什么“干你脑”语言(BrainFuck),那叫一吐血,怎么现在又冒出来一个啥子语言?其实这个东西还真的挺有用的,它是一种绘制流程图的语言。废话少说,装上试试就知道了(下面命令只适用于Debian/Ubuntu系的Linux发行版操作系统,如使用其他操作系统,请到官网下载安装)。

sudo apt-get install graphviz 

不是说是DOT语言吗?怎么装了一个叫graphviz的东西?其实DOT语言就是GraphViz使用的流程描述语言。当然,graphviz也支持其他的几种图形描述语言,以生成更多种类的图形,当然,最常用的还是这个DOT语言。装好了后,就可以继续了。

用途说明

Graphviz (Graph Visualization Software的缩写)是一个由AT&T实验室启动的开源工具包,用于绘制DOT语言脚本描述的图形。它也提供了供其它软件使用的库。Graphviz是一个自由软件,其授权为Common Public License。其Mac版本曾经获得2004年的苹果设计奖。Graphviz包括很多命令行工具,dot命令是一个用来将生成的图形转换成多种输出格式的命令行工具,其输出格式包括PostScript,PDF,SVG,PNG,含注解的文本等等。neato命令用于spring model的生成(在Mac OS版本中称为energy minimized)。twopi命令用于放射状图形的生成。circo命令用于圆形图形的生成。fdp命令另一个用于生成无向图的工具。dotty命令一个用于可视化与修改图形的图形用户界面程序。lefty命令是一个可编程的(使用一种被EZ影响的语言[4])控件,它可以显示DOT图形,并允许用户用鼠标在图上执行操作。Lefty可以作为MVC模型的使用图形的GUI程序中的视图部分。 DOT语言是一种文本图形描述语言。它提供了一种简单的描述图形的方法,并且可以为人类和计算机程序所理解。DOT语言文件通常是具有.gv或是.dot的文件扩展名。本文将主要介绍从源代码安装Graphviz工具以及dot命令的使用方式。

常用参数

格式:dot -T<type> -o<outfile> <infile.dot>

输入文件是<infile.dot>,生成的格式由<type>指定,生成的文件是<outfile>。

 

其中-T<type>包括:

-Tps (PostScript),

-Tsvg -Tsvgz (Structured Vector Graphics), 

-Tfig (XFIG  graphics), 

-Tmif  (FrameMaker graphics),

-Thpgl (HP pen plotters),

-Tpcl (Laserjet printers),

-Tpng -Tgif (bitmap graphics),

-Tdia (GTK+ based diagrams),

-Timap (imagemap files for httpd servers for each node or edge  that  has a non-null "href" attribute.),

-Tcmapx (client-side imagemap for use in html and xhtml).

下面简单介绍下DOT语言的语法:

无向图 :在最简单的应用中,DOT语言可以用来描述一张无向图。无向图显示了对象间最简单的关系,例如人之间的友谊。使用关键字graph开始一张无向图的定义,并用大括号包含要描述的节点,双连字号(--)被用来描述节点间的关系。另外,一行的末尾需要加上分号(;)。
 graph graphname {

     a -- b -- c;
     b -- d;
 }

有向图 :类似于无向图,DOT语言也可以用来描述一张有向图,类似于流程图和树状图。其语法与无向图相似,但要在图的最开始使用关键字'digraph',并用箭头(->)表示节点直接的关系。
 digraph graphname {

     a -> b -> c;
     b -> d;
 }

属性 :

DOT语言中,可以对节点和边添加不同的属性。这些属性可以控制节点和边的显示样式,例如颜色,形状和线形。可以在语句和句尾的分号间放置一对方括号,并在其中中放置一个或多个属性-值对。多个属性可以被逗号和空格(, )分开。节点的属性被放置在只包含节点名称的表达式后。
 graph graphname {

     // label属性可以改变节点的显示名称
     a [label="Foo"];
     // 节点形状被改变了
     b [shape=box];
     // a-b边和b-c边有相同的属性
     a -- b -- c [color=blue];
     b -- d [style=dotted];
 }
注释 :

DOT语言支持C语言与C++风格的单行与多行注释。另外,也支持Shell脚本风格的以#开头的注释。
 // 单行注释
 /* 多行
    注
    释 */
 # 如此的行也会被忽略。

一段最基本的Dot

来个最基本的流程图,我们来看看这个语言到底有什么神奇之处?把下面的代码随便用任何一款文本编辑器,保存为test.dot文件。

digraph G {     a -> b -> c -> a; } 

然后,在这个文件的目录中:

$ dot -Tpng test.dot -o test.png 

现在,用看图软件,看一下生成的test.png文件,是不是很神奇?

DOT语言能可视化编辑吗?

目前尚未找到好的DOT可视化编辑器,似乎也没这个必要。当然,可预览编辑还是有的。可以用vimdot命令。如我们编辑上面的test.dot文件,就可以用下面的命令:

$ vimdot test.dot 

它会同时打开两个窗口,一个是vim,另一个就是graphviz的预览窗口,当你在vim中编辑dot代码完毕,存盘后,预览窗口就会更新显示出该dot文件的生成结果。

dot简介(一) (https://mushiming.com/)  第1张

就这么简单?

当然不是,如果要复杂,DOT语言可以十分复杂,当然,我们大部分情况下是根本不需要那么多复杂的功能的。在后面的笔记中,会逐步介绍我经常用到的各种常用的DOT语言属性。比方说生成如下图这样的:

dot简介(一) (https://mushiming.com/)  第2张


源码安装:
http://codingstandards.iteye.com/blog/840055


问题思考

相关资料

【1】维基百科   Graphviz    

【2】维基百科   DOT语言

【3】啄木鸟社区  Graphviz

【4】age的个人空间  用Dot绘图

【5】海贼’blog   linux dot 绘图

【6】daxuxu   graphviz dot简介

【7】openstudy  英文版linux安装中文字体

 

返回 我使用过的Linux命令系列总目录

THE END

发表回复