第三章 利用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、小结

边缘检测的一般步骤:滤波、增强、检测,完整的代码如下。

Created with Raphaël 2.2.0开始 滤波 增强 检测结束
#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;
}
第三章 利用OpenCV3进行canny边缘检测
第三章 利用OpenCV3进行canny边缘检测