用于图中绘制的函数。 更多...
用于图中绘制的函数。
- 注意
- 这是一个正在进行中的功能,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 << "需要文件名" << 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;
}
用于指定图像或矩形大小的模板类。
Definition types.hpp:335
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:905
@ LINE_8
8 连接线
Definition imgproc.hpp:895
@ FILLED
定义 imgproc.hpp:893
int main(int argc, char *argv[])
定义 highgui_qt.cpp:3