PHP版本的Graphviz样例之集群流程图

2024-04-08 23:32

本文主要是介绍PHP版本的Graphviz样例之集群流程图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Graphviz是一个强大的开源的图形软件包,不仅支持桌面应用,也支持Web应用,其关键技术在于它的自动布局和布线功能。

安装libgv-php5后,Graphviz支持PHP编程,可以实现浏览器上显示图形。然而,整个开发环境的安装与设置相对比较复杂一些,需要相当的专业技术。


Graphviz是一个开源软件,有源码,支持不同平台。linux系统下使用XDot程序显示dot格式的文件。

Graphviz显示图形时,可以选择不同的策略进行布局和布线显示图形。

Graphviz的官方网站(点击进入)Graphviz | Graphviz - Graph Visualization Software。

Web版的Graphviz网站(点击进入)Webgraphviz


PHP代码如下(其中保护若干调试代码,已经注释了):

<!DOCTYPE html>
<html lang="zh-CN"><head><meta charset="utf-8"><title>GVPHP</title>
</head><?php
//  ini_set('display_errors', true);//  if( !(bool)ini_get( "enable_dl" ) || (bool)ini_get( "safe_mode" ) ) {
//     ECHO "dh_local(): Loading extensions is not permitted.\n";
//  } else {
//     ECHO "OK";
//  }// http://www.graphviz.org/pdf/dotguide.pdf page 23include('libgv-php5/gv2.php');$g = gv::digraph('G'); //line 1$N = gv::protonode($g); // line 3$cluster0 = gv::graph($g, 'cluster0'); // line 2gv::setv($N, "style", "filled"); // line 3gv::setv($N, "color", "white"); // line 3gv::setv($cluster0, "style", "filled"); // line 4gv::setv($cluster0, "color", "lightgrey"); // line 5gv::edge($cluster0, 'a0', 'a1'); //line 6gv::edge($cluster0, 'a1', 'a2'); //line 6gv::edge($cluster0, 'a2', 'a3'); //line 6gv::setv($cluster0, "label", "process #1"); // line 7$cluster1 = gv::graph($g, 'cluster1'); // line 10gv::setv($N, "style", "solid");gv::setv($N, "color", "black");gv::edge($cluster1, 'b0', 'b1'); //line 12gv::edge($cluster1, 'b1', 'b2'); //line 12gv::edge($cluster1, 'b2', 'b3'); //line 12gv::setv($cluster1, "label", "process #2"); // line 13gv::setv($cluster1, "color", "blue"); // line 14  $node_start = gv::node($g, 'start');gv::setv($node_start, "shape", "Mdiamond");$node_end = gv::node($g, 'end');gv::setv($node_end, "shape", "Msquare");gv::edge($g, 'start', 'a0'); //line 16gv::edge($g, 'start', 'b0'); //line 17gv::edge($g, 'a1', 'b3'); //line 18gv::edge($g, 'b2', 'a3'); //line 19gv::edge($g, 'a0', 'a3'); //line 20gv::edge($g, 'a3', 'end'); //line 21gv::edge($g, 'b3', 'end'); //line 22gv::layout($g, 'dot');gv::render($g, 'png', 'graph1.png');gv::rm($g);echo '<img src="graph1.png">';
?></html>

界面效果如下:



DOT语言代码如下:

digraph G {  subgraph cluster0 {  node [style=filled,color=white];  style=filled;  color=lightgrey;  a0 -> a1 -> a2 -> a3;  label = "process #1";  }  subgraph cluster1 {  node [style=filled];  b0 -> b1 -> b2 -> b3;  label = "process #2";  color=blue  }  start -> a0;  start -> b0;  a1 -> b3;  b2 -> a3;  a3 -> a0;  a3 -> end;  b3 -> end;  start [shape=Mdiamond];  end [shape=Msquare];  
}


这篇关于PHP版本的Graphviz样例之集群流程图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/886665

相关文章

如何在一台服务器上使用docker运行kafka集群

《如何在一台服务器上使用docker运行kafka集群》文章详细介绍了如何在一台服务器上使用Docker运行Kafka集群,包括拉取镜像、创建网络、启动Kafka容器、检查运行状态、编写启动和关闭脚本... 目录1.拉取镜像2.创建集群之间通信的网络3.将zookeeper加入到网络中4.启动kafka集群

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O

什么是 Ubuntu LTS?Ubuntu LTS和普通版本区别对比

《什么是UbuntuLTS?UbuntuLTS和普通版本区别对比》UbuntuLTS是Ubuntu操作系统的一个特殊版本,旨在提供更长时间的支持和稳定性,与常规的Ubuntu版本相比,LTS版... 如果你正打算安装 Ubuntu 系统,可能会被「LTS 版本」和「普通版本」给搞得一头雾水吧?尤其是对于刚入

windows端python版本管理工具pyenv-win安装使用

《windows端python版本管理工具pyenv-win安装使用》:本文主要介绍如何通过git方式下载和配置pyenv-win,包括下载、克隆仓库、配置环境变量等步骤,同时还详细介绍了如何使用... 目录pyenv-win 下载配置环境变量使用 pyenv-win 管理 python 版本一、安装 和

PHP执行php.exe -v命令报错的解决方案

《PHP执行php.exe-v命令报错的解决方案》:本文主要介绍PHP执行php.exe-v命令报错的解决方案,文中通过图文讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下... 目录执行phpandroid.exe -v命令报错解决方案执行php.exe -v命令报错-PHP War

Nacos集群数据同步方式

《Nacos集群数据同步方式》文章主要介绍了Nacos集群中服务注册信息的同步机制,涉及到负责节点和非负责节点之间的数据同步过程,以及DistroProtocol协议在同步中的应用... 目录引言负责节点(发起同步)DistroProtocolDistroSyncChangeTask获取同步数据getDis

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

HDFS—集群扩容及缩容

白名单:表示在白名单的主机IP地址可以,用来存储数据。 配置白名单步骤如下: 1)在NameNode节点的/opt/module/hadoop-3.1.4/etc/hadoop目录下分别创建whitelist 和blacklist文件 (1)创建白名单 [lytfly@hadoop102 hadoop]$ vim whitelist 在whitelist中添加如下主机名称,假如集群正常工作的节

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo