OpenCV 图形API(61)图像特征检测------检测图像边缘的函数Canny()

  • 操作系统:ubuntu22.04
  • OpenCV版本:OpenCV4.9
  • IDE:Visual Studio Code
  • 编程语言:C++11

算法描述

使用Canny算法在图像中查找边缘。

该函数在输入图像中查找边缘,并使用Canny算法在输出映射(edges)中标记它们。在边缘连接过程中,会使用threshold1和threshold2之间的较小值。而较大值则用于找到强烈边缘的初始段。详情请参见:Canny边缘检测器

cv::gapi::Canny 是 OpenCV 的 G-API 模块中用于检测图像边缘的函数。G-API 是 OpenCV 中的一个模块,它提供了一种新的方式来处理图像和视频流,通过定义图形操作然后在不同的后端上执行它们。

注意:

函数文本ID为"org.opencv.imgproc.feature.canny"

函数原型

cpp 复制代码
GMat cv::gapi::Canny
(
 	const GMat &  	image,
	double  	threshold1,
	double  	threshold2,
	int  	apertureSize = 3,
	bool  	L2gradient = false 
) 		

参数

  • 参数 image: 8位输入图像。
  • 参数 threshold1: 滞后阈值法的第一个阈值。
  • 参数 threshold2: 滞后阈值法的第二个阈值。
  • 参数 apertureSize: 用于Sobel算子的孔径大小。
  • 参数 L2gradient: 一个标志,指示是否应该使用更精确的L2范数 n o r m = ( d I / d x ) 2 + ( d I / d y ) 2 norm=\sqrt{(dI/dx)^2 + (dI/dy)^2} norm=(dI/dx)2+(dI/dy)2

​来计算图像梯度幅度(当L2gradient=true时),或者默认的L1范数=|dI/dx|+|dI/dy|是否足够(当L2gradient=false时)。

代码示例

cpp 复制代码
#include <opencv2/opencv.hpp>
#include <opencv2/gapi.hpp>
#include <opencv2/gapi/core.hpp> // 包含核心功能
#include <opencv2/gapi/imgproc.hpp> // 包含图像处理功能

int main() {
    // 读取输入图像
    cv::Mat bgr_img = cv::imread("/media/dingxin/data/study/OpenCV/sources/images/Lenna.png");
    if (bgr_img.empty()) {
        std::cerr << "Error: Image not found!" << std::endl;
        return -1;
    }

    // 将BGR图像转换为灰度图像
    cv::Mat gray_img;
    cv::cvtColor(bgr_img, gray_img, cv::COLOR_BGR2GRAY);

    // 定义G-API图
    cv::GMat in;
    auto edges = cv::gapi::Canny(in, 50, 150, 3, false); 

    cv::GComputation comp(cv::GIn(in), cv::GOut(edges));

    // 创建输出矩阵
    cv::Mat out_edges;

    // 应用计算图并执行边缘检测
    comp.apply(cv::gin(gray_img), cv::gout(out_edges),
               cv::compile_args(cv::gapi::kernels()));

    // 显示原始图像和边缘检测结果
    cv::imshow("Original Image", bgr_img);
    cv::imshow("Edges Detected", out_edges);

    cv::waitKey(0); // 等待按键

    return 0;
}

运行结果

相关推荐
pen-ai2 分钟前
【NLP】 38. Agent
人工智能·自然语言处理
Morpheon7 分钟前
循环神经网络(RNN):从理论到翻译
人工智能·rnn·深度学习·循环神经网络
量子位11 分钟前
6 分钟狂掉 750 亿市值!苹果发布会发啥了…
人工智能·ai编程
Gyoku Mint16 分钟前
机器学习×第五卷:线性回归入门——她不再模仿,而开始试着理解你
人工智能·python·算法·机器学习·pycharm·回归·线性回归
机器之心17 分钟前
刚刚,苹果WWDC掀AI重构风暴!端侧模型全开放、AI版Siri却成最大「鸽」王
人工智能
Blossom.11821 分钟前
基于机器学习的智能故障预测系统:构建与优化
人工智能·python·深度学习·神经网络·机器学习·分类·tensorflow
DisonTangor36 分钟前
【字节拥抱开源】字节团队开源视频模型 ContentV: 有限算力下的视频生成模型高效训练
人工智能·开源·aigc
吴声子夜歌1 小时前
OpenCV——图像基本操作(一)
python·opencv·计算机视觉
春末的南方城市1 小时前
腾讯开源视频生成工具 HunyuanVideo-Avatar,上传一张图+一段音频,就能让图中的人物、动物甚至虚拟角色“活”过来,开口说话、唱歌、演相声!
人工智能·计算机视觉·自然语言处理·aigc·音视频·视频生成
UQI-LIUWJ1 小时前
论文笔记:Urban Computing in the Era of Large Language Models
人工智能·语言模型·自然语言处理