第三章 利用OpenCV3进行canny边缘检测
第三章 利用OpenCV3进行canny边缘检测
目标:
- 1、canny算子的使用
- 2、实现简单的边缘检测处理
1、载入原始图片
Mat srcImage = imread("book.jpg"); // 载入图片,注意设置图片路径
imshow("【原始图像】Canny边缘检测", srcImage); // 显示载入的图片
2、转换成灰度图
edge代表进行边缘检测的容器,grayImage代表灰度图容器。
cvtColor()函数第一个参数是输入图像、第二个参数是输出图像,第三个参数是转换成灰度图。
Mat edge, grayImage; // 定义Mat类型
cvtColor(srcImage, grayImage, CV_BGR2GRAY); // 转化成灰度图
3、 图像模糊降噪
blur(grayImage, edge, Size(3, 3)); // 使用blur模糊函数降低噪声
4、canny函数边缘检测
Canny()函数:第一个参数,输入图像、第二个参数,输出图像、第三个参数是低阈值、第四个参数是高阈值,第五个参数表示Sobel算子的孔径大小,默认值为3,高低阈值的比值最好在2:1到3:1之间。
Canny(edge, edge, 3, 9, 3); // 使用canny函数进行图像边缘检测
5、小结
边缘检测的一般步骤:滤波、增强、检测,完整的代码如下。
#include<opencv2/opencv.hpp>
#include<opencv2/imgproc/imgproc.hpp>
using namespace cv;
int main()
{
Mat srcImage = imread("book.jpg");
imshow("【原始图像】Canny边缘检测", srcImage); // 显示载入的图片
Mat edge, grayImage; // 定义Mat类型
cvtColor(srcImage, grayImage, CV_BGR2GRAY); // 转化成灰度图
blur(grayImage, edge, Size(3, 3)); // 使用blur模糊函数降低噪声
Canny(edge, edge, 3, 9, 3); // 使用canny函数进行图像边缘检测
imshow("【效果图】Canny边缘检测", edge);
waitKey(0);
return 0;
}