生成给定点文本 c++ 的 GraphViz 图形图像

Generate image of GraphViz graph given dot text c++

本文关键字:c++ GraphViz 图形图像 文本      更新时间:2023-10-16

我在C++ Qt应用程序(在Ubuntu上(中有一个字符串,其中包含有效的GraphViz/dot图语法。我想从此文本生成一个图像文件/对象,类似于各种在线工具(例如:http://www.webgraphviz.com/(吐出的图像。也许我使用了错误的搜索词,但我似乎找不到相关的帮助。

我基本上想要的是这样的东西:

generate_dot_graph_image(std::string dot_text, std::string image_file_path)

其他细节:我有一个 Dijkstra 求解器,我想在我的应用程序中可视化其解决方案(基本上是去除未使用边后的原始图形(。求解器已经包含一个选项,用于将解决方案转换为字符串,该字符串可以使用实用程序(例如我上面链接的实用程序(解析为点图。但我想要的是能够从C++内部做到这一点。

因此,我能够使用 GraphViz 库做我想做的事情。您可以使用sudo apt-get install graphviz-libsudo apt-get install libgraphviz-dev将它们安装在 Ubuntu 上。完成后:

#include <graphviz/gvc.h>
bool DotGraphGenerator::saveImage()
{
std::string o_arg = std::string("-o") + "/path/to/image_file.png";
char* args[] = {const_cast<char*>("dot"), const_cast<char*>("Tpng"), const_cast<char*>("-Gsize=8,4!"), const_cast<char*>("-Gdpi=100"),
const_cast<char*>(DOT_TEXT_FILE.c_str()),  //DOT_TEXT_FILE is the file path in which the graph is saved as valid DOT syntax
const_cast<char*>(o_arg.c_str()) };
const int argc = sizeof(args)/sizeof(args[0]);
Agraph_t *g, *prev = NULL;
GVC_t *gvc;
gvc = gvContext();
gvParseArgs(gvc, argc, args);
while ((g = gvNextInputGraph(gvc)))
{
if (prev)
{
gvFreeLayout(gvc, prev);
agclose(prev);
}
gvLayoutJobs(gvc, g);
gvRenderJobs(gvc, g);
prev = g;
}
return !gvFreeContext(gvc);
}

gvc 是一个 C 库,函数将非常量的 C 字符串作为参数,因此一开始const_casts。您还可以通过更改-Gsize=8,4-Gdpi=100参数来编辑图像大小。使用当前配置,您将获得一个 8*100 x 4*100 = 800x400 的图像文件。无论如何,这些参数与您从 bash 运行dot命令时应用的参数相同。

除此之外,这段代码基本上是从 graphViz 中的一个示例复制而来的,作为库手册: http://www.graphviz.org/pdf/libguide.pdf

我找到了一种方法,我使用了以下函数并且它有效:

bool saveImageGV(std::string file_path){
GVC_t *gvc;
Agraph_t *g;
FILE *fp;
gvc = gvContext();
fp = fopen((file_path+".dot").c_str(), "r");
g = agread(fp, 0);
gvLayout(gvc, g, "dot");
gvRender(gvc, g, "png", fopen((file_path+".png").c_str(), "w"));
gvFreeLayout(gvc, g);
agclose(g);
return (gvFreeContext(gvc));
}