用于图中绘制的函数。 详细信息...
用于图中绘制的函数。
- 注意
- 这是正在进行开发的功能,API 可能会在未来版本中发生更改。
G-API 能够使用通用操作和一组 渲染基元 渲染图形。与传统的 OpenCV 不同,在 G-API 中,用户需要形成一个要绘制的基元的“渲染列表”。此列表可以手动构建或在图形中生成。此列表传递给 特殊操作或函数,所有基元在此处被解释并应用于图像。
例如,在复杂管道中,可以通过图形将检测到的对象列表转换为 cv::gapi::wip::draw::Rect 基元列表,以使用边界框突出显示,还可以将检测到的面部列表转换为 cv::gapi::wip::draw::Mosaic 基元列表,以隐藏敏感内容或保护隐私。
与其他操作一样,可以在 G-API 中通过不同的后端重新实现渲染。目前仅提供基于 OpenCV 的后端。
除了图形级操作外,还提供了常规(即时)OpenCV 类函数,请参见 cv::gapi::wip::draw::render()。这些函数只是常规 G-API 的包装器,可以即时生成渲染图形,因此将编译参数作为参数。
目前,此 API 更面向机器而非人。其主要目的是将一组特定于领域的转换为要绘制的基元列表。例如,要生成这样的图片
需要按如下方式生成渲染列表
int main(
int argc,
char *argv[])
{
if (argc < 2) {
std::cerr << "Filename required" << std::endl;
return 1;
}
std::vector<draw::Prim> prims;
prims.emplace_back(draw::Circle{
{400,72},
32,
coral,
0
});
prims.emplace_back(draw::Text{
"Hello from G-API!",
{64,96},
font,
1.0,
blue,
2,
false
});
prims.emplace_back(draw::Rect{
{16,48,400,72},
green,
2,
0
});
prims.emplace_back(draw::Mosaic{
{320,96,128,32},
16,
0
});
draw::render(test, prims);
return 0;
}
用于指定图片或矩形的尺寸的模板类。
定义 types.hpp:335
#define CV_8UC3
定义 interface.h:90
CV_EXPORTS_W bool imwrite(const String &filename, InputArray img, const std::vector< int > ¶ms=std::vector< int >())
将图片保存到指定文件中。
@ FONT_HERSHEY_DUPLEX
普通大小的无衬线字体(比 FONT_HERSHEY_SIMPLEX 复杂)
定义 imgproc.hpp:903
@ LINE_8
8 连接线
定义 imgproc.hpp:893
@ FILLED
定义 imgproc.hpp:891
int main(int argc, char *argv[])
定义 highgui_qt.cpp:3