#include <iostream>
int main(
int argc,
char** argv )
{
"{@input |lena.jpg|输入图像}"
"{ksize k|1|ksize (运行时按 'K' 键增加其值)}"
"{scale s|1|scale (运行时按 'S' 键增加其值)}"
"{delta d|0|delta (运行时按 'D' 键增加其值)}"
"{help h|false|显示帮助信息}");
cout << "该示例使用 Sobel 或 Scharr OpenCV 函数进行边缘检测\n\n";
cout << "\n按 'ESC' 退出程序。\n按 'R' 重置值 ( ksize 将为 -1 等于 Scharr 函数 )";
const String window_name =
"Sobel Demo - 简单边缘检测器";
int ksize = parser.
get<
int>(
"ksize");
int scale = parser.
get<
int>(
"scale");
int delta = parser.
get<
int>(
"delta");
image = imread( samples::findFile( imageName ), IMREAD_COLOR );
{
printf("错误:打开图像失败: %s\n", imageName.c_str());
return EXIT_FAILURE;
}
for (;;)
{
GaussianBlur(image, src,
Size(3, 3), 0, 0, BORDER_DEFAULT);
cvtColor(src, src_gray, COLOR_BGR2GRAY);
Mat abs_grad_x, abs_grad_y;
Sobel(src_gray, grad_x, ddepth, 1, 0, ksize, scale, delta, BORDER_DEFAULT);
Sobel(src_gray, grad_y, ddepth, 0, 1, ksize, scale, delta, BORDER_DEFAULT);
convertScaleAbs(grad_x, abs_grad_x);
convertScaleAbs(grad_y, abs_grad_y);
addWeighted(abs_grad_x, 0.5, abs_grad_y, 0.5, 0, grad);
imshow(window_name, grad);
char key = (char)waitKey(0);
if(key == 27)
{
return EXIT_SUCCESS;
}
if (key == 'k' || key == 'K')
{
ksize = ksize < 30 ? ksize+2 : -1;
}
if (key == 's' || key == 'S')
{
scale++;
}
if (key == 'd' || key == 'D')
{
delta++;
}
if (key == 'r' || key == 'R')
{
scale = 1;
ksize = -1;
delta = 0;
}
}
return EXIT_SUCCESS;
}
用于命令行解析。
定义 utility.hpp:820
T get(const String &name, bool space_delete=true) const
按名称访问参数。
定义 utility.hpp:886
void printMessage() const
打印帮助信息。
bool empty() const
如果数组没有元素,则返回 true。
用于指定图像或矩形大小的模板类。
定义 types.hpp:335
std::string String
定义 cvstd.hpp:151
#define CV_16S
定义 interface.h:76
int main(int argc, char *argv[])
定义 highgui_qt.cpp:3
与磁盘上文件关联的文件存储的“黑盒”表示。
定义 core.hpp:102