【OpenCV 基础知识 3】边缘检测

cvCanny

这行代码使用OpenCV库中的 cvCanny 函数对灰度图像进行边缘检测。让我解释一下:

cvCanny(gray, dst, 10, 100, 3);
  1. gray: 这是输入的灰度图像,即要进行边缘检测的图像。
  2. dst: 这是输出的边缘图像,即将结果存储到的图像。
  3. 10: 这是Canny边缘检测算法的低阈值。像素梯度值低于该阈值的边缘点将被抑制。
  4. 100: 这是Canny边缘检测算法的高阈值。像素梯度值高于该阈值的像素将被认为是强边缘,而低于该阈值但高于低阈值的像素将根据连接性保留或抑制。
  5. 3: 这是Sobel运算符的内核大小,用于计算图像的梯度。在这里,内核大小为3,表示使用3x3的Sobel内核。

所以,整个行的作用是使用Canny边缘检测算法对输入的灰度图像进行边缘检测,并将结果存储在 dst 中。这是一种常见的图像处理操作,用于检测图像中的边缘结构。

完整示例代码

program cv_Canny;

{$APPTYPE CONSOLE}
{$R *.res}

uses
  System.SysUtils,
  ocv.highgui_c,
  ocv.core_c,
  ocv.core.types_c,
  ocv.imgproc_c,
  ocv.imgproc.types_c,
  uResourcePaths;

const
  filename = cResourceMedia + 'cat2.jpg';

var
  image: pIplImage = nil;
  gray: pIplImage = nil;
  dst: pIplImage = nil;

begin
  try

    image := cvLoadImage(filename);
    WriteLn(Format('[i] image: %s', [filename]));

    //创建两张纯灰图像
    gray := cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
    dst := cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);


    cvNamedWindow('original', CV_WINDOW_AUTOSIZE);
    cvNamedWindow('gray', CV_WINDOW_AUTOSIZE);
    cvNamedWindow('cvCanny', CV_WINDOW_AUTOSIZE);

    // 灰度化图片
    cvCvtColor(image, gray, CV_RGB2GRAY);

    // 边缘检测
    cvCanny(gray, dst, 10, 100, 3);


    cvShowImage('original', image);
    cvShowImage('gray', gray);
    cvShowImage('cvCanny', dst);

    cvWaitKey(0);

    cvReleaseImage(image);
    cvReleaseImage(gray);
    cvReleaseImage(dst);

    cvDestroyAllWindows();
  except
    on E: Exception do
      WriteLn(E.ClassName, ': ', E.Message);
  end;

end.
  • 13
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

D-Nolan

请我喝杯咖啡吧,鼓励一下创作!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值