14---OpenCV:图像检测之边缘检测

article/2025/9/15 12:02:07

一、图像边缘

边缘(edge)是指图像局部强度变化最显著的部分。主要存在于目标与目标、目标与背景、区域与区域(包括不同色彩)之间,是图像分割、纹理特征和形状特征等图像分析的重要基础。图像强度的显著变化可分为:

  • 阶跃变化函数,即图像强度在不连续处的两边的像素灰度值有着显著的差异

  • 线条(屋顶)变化函数,即图像强度突然从一个值变化到另一个值,保持一较小行程后又回到原来的值

图像的边缘有方向和幅度两个属性,沿边缘方向像素变化平缓,垂直于边缘方向像素变化剧烈.边缘上的这种变化可以用微分算子检测出来,通常用一阶或二阶导数来检测边缘。

 ab分别是阶跃函数和屋顶函数的三维图像

cd是阶跃和屋顶函数的函数二维图像

ef对应一阶导数

gh是二阶导数

1.Sobel算子(索伯)

        Sobel算子是一种常用的边缘检测算子,是一阶的梯度算法。对噪声具有平滑作用,提供较为精确的边缘方向信息,边缘定位精度不够高。当对精度要求不是很高时,是一种较为常用的边缘检测方法。

计算过程

API介绍

void Sobel( InputArray src, OutputArray dst, int ddepth,int dx, int dy, int ksize = 3,double scale = 1, double delta = 0,int borderType = BORDER_DEFAULT );
/*******************************************************************
*			src: 			输入图				
*			dst:	        输出图
*			ddepth:			输出图深度 CV_16S/CV_32F/CV_64F等
*			dx:				x方向上的差分阶数
*			dy:		    	y方向上的差分阶数
*			ksize:  		卷积核大小,一般5*5或3*3
*			scale:			计算导数值时可选的缩放因子
*			delta:			默认为0
*			borderType:		边缘处理模式	
*********************************************************************/

2.LapLace 算子(拉普拉斯)

拉普拉斯对噪声敏感,会产生双边效果。不能检测出边的方向。通常不直接用于边的检测,只起辅助的角色,检测一个像素是在边的亮的一边还是暗的一边利用零跨越,确定边的位置.

计算过程

API介绍

void Laplacian( InputArray src, OutputArray dst, int ddepth,int ksize = 1, double scale = 1, double delta = 0,int borderType = BORDER_DEFAULT );
/*******************************************************************
*           src:            输入图             
*           dst:            输出图
*           ddepth:         输出图深度 CV_16S/CV_32F/CV_64F等
*           ksize:          核大小,必须是正奇数,默认值是1
*           scale:          计算导数值时可选的缩放因子
*           delta:          可选值,默认为0
*           borderType:     边缘处理模式  
*********************************************************************/

3.Canny算子(坎尼)

计算过程

  • 用高斯滤波器平滑图像

  • 用一阶偏导的有限差分计算梯度的幅值核方向

  • 对梯度幅值进行非极大值抑制

    • 超过255 用255表示

    • 低于0 用绝对值表示

  • 用双阈值算法检测和连接边缘

API介绍

void Canny( InputArray image, OutputArray edges,double threshold1, double threshold2,int apertureSize = 3, bool L2gradient = false );
/*******************************************************************
*           src:            输入图             
*           edges:          输出图
*           threshold1:     第一个阈值
*           threshold2:     第二个阈值
*           apertureSize:   内核大小
*           L2gradient:     计算图像梯度幅值方法的标志
*********************************************************************/

4.综合代码

注意:

        ①相关函数说明

convertScaleAbs(result["y"], result["y"]);  //图像增强函数
addWeighted(result["x"], 0.5, result["y"], 0.5, 0, result["xy"]);
//将两个图像按一定权值融合在一起

        ②sobel算子和拉普拉斯算子处理完后效果并不会太好,需要调用图像增强函数。

#include <iostream>
#include <string>
#include <map>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
class Edge 
{
public:Edge() :img(imread("test.jpg")) {result["img"] = img;}void TestSobel() {Sobel(img, result["x"], CV_16S, 1, 0);//图像增强//α*src+βconvertScaleAbs(result["x"], result["x"]);Sobel(img, result["y"], CV_16S, 0, 1);convertScaleAbs(result["y"], result["y"]);addWeighted(result["x"], 0.5, result["y"], 0.5, 0, result["xy"]);Sobel(img, result["sobel"], CV_16S, 1, 1);convertScaleAbs(result["sobel"], result["sobel"]);}void TestLapLacian() {Laplacian(img, result["LapLacian"], CV_16S);convertScaleAbs(result["LapLacian"], result["LapLacian"]);}void TestCanny() {//高阈值Canny(img, result["Canny"], 100, 200);//灰度后的高阈值和低阈值cvtColor(img, result["Gray"], COLOR_BGR2GRAY);Canny(result["Gray"], result["Max"], 100, 200);Canny(result["Gray"], result["Min"], 20, 40);//高斯模糊后做双阈值GaussianBlur(result["Gray"], result["Gauss"], Size(3, 3), 5);Canny(result["Gauss"], result["OK"], 100, 200);}
​void Show() {for (auto& v : result) {imshow(v.first, v.second);}waitKey(0);}
protected:Mat img;map<string, Mat> result;
};
​
int main() 
{unique_ptr<Edge> p(new Edge);p->TestSobel();p->TestLapLacian();p->TestCanny();p->Show();
​return 0;
}

显然最佳的方法是用二值化的灰度图像,然后高斯滤波处理,再去用canny检测算法(两个阈值的选定很重要---->要多试试)(得到的OK图像如下,边缘的线条很细,且取出了原本canny算法算出来的很多的噪声)


http://chatgpt.dhexx.cn/article/Upbk9LHp.shtml

相关文章

OpenCV学习11_边缘检测

本部分,我们将一起学习OpenCV中边缘检测的各种算子和滤波器-Canny算子、Sobel算子、Laplacian算子以及Scharr滤波器。 一、边缘检测步骤 在具体介绍之前,先来一起看看边缘检测的一般步骤。 1.【第一步】滤波 边缘检测的算法主要是基于图像强度的一阶和二阶导数,但导数通常对噪…

opencv--边缘检测

opencv--边缘检测 1 边缘检测原理2 Sobel检测算子2.1 Sobel检测方法2.2 应用 3 Laplacian算子4. Canny边缘检测4.1 原理4.2应用 5 算子比较 1 边缘检测原理 边缘检测是图像处理和计算机视觉中的基本问题&#xff0c;边缘检测的目的是标识数字图像中亮度变化明显的点。图像属性…

【OpenCV--边缘检测】

目录 一、边缘检测概念 二、Sobel算子 1.描述&#xff1a; 2.方法&#xff1a; 3.Sobel算子的应用&#xff1a; 三、Laplacian算子 1.描述&#xff1a; 2.应用&#xff1a; 四、Canny边缘检测 1.原理&#xff1a; 2.应用&#xff1a; 一、边缘检测概念 1.边缘检测是图像处理和…

利用OpenCV进行边缘检测

简 介&#xff1a; 本文讨论了图像处理中重要的技术&#xff1a;边缘检测&#xff0c;重点介绍了两种方法&#xff08;Sobel边缘检测和Canny边缘检测&#xff09;。在展示OpenCV中的用法 同时也强调了为什么图像平滑是重要的预处理步骤。在Canny边缘检测中 也是使用的Sobel算子…

微信小程序实现轮播图根据图片大小自适应高度

上效果图 话不多说——————上代码 首先wxml <swiper class"con_img" style"height:{{swiperheight}}px" indicator-dots"true" autoplay"true" indicator-active-color"#f8e112" bindchange"changeheight&quo…

微信小程序-图片自适应

image组件 使用使用mode&#xff1a;widthFix&#xff0c;宽度固定&#xff0c;高度自适应 <image class"nav_img" mode"widthFix" src"{{img}}"></image> 注意&#xff0c;在初次进入页面时会有高度拉伸情况&#xff0c;使用样式…

小程序中图片宽度实现100%,高度自适应

在做轮播图时放了几个图片&#xff0c;但是显示一直怪怪的&#xff0c;宽度没有占满&#xff0c;右边总是留一大块空白&#xff0c;怪难看的&#xff0c;开始试了所有的mode属性都不行&#xff0c;至于mode属性起什么作用可以查一下小程序组件的API说明&#xff0c;主要用于控制…

微信小程序之swiper组件高度自适应

要求&#xff1a; &#xff08;顶部广告栏 &#xff09; 改变swiper组件的固定高度&#xff0c;使之随内部每张图片的高度做自适应 原理&#xff1a; 图片加载完之后&#xff0c;获取图片的原始宽高&#xff0c;根据宽高比&#xff0c;计算出适应后的宽高&#xff0c;如果是适…

微信小程序图片固定宽度,高度自适应处理方法及相关API介绍

微信小程序图片固定宽度&#xff0c;高度自适应处理方法及相关API介绍 1、背景 在我们写js代码时&#xff0c;控制图片固定宽度固定&#xff0c;使得高度自适应缩小&#xff0c;是非常简单的&#xff0c;但在微信小程序中不了解微信小程中组件image相关的属性是有些麻烦的&am…

html微信图片自适应,微信小程序实现图片高度自适应

1. swiper轮播海报通过wx.getSystemInfo接口获取屏幕高度&#xff0c;高度依据图片宽高等比缩放 运行于app.js&#xff0c;全局保存 // 设备信息 wx.getSystemInfo({ success: function(res) { that.screenWidth res.windowWidth; } }); page前端调用 bannerHeight: Math.ceil…

微信小程序的swiper轮播图中的图片设置自适应高度的一种方法

微信小程序的swiper轮播图中的图片设置自适应高度的一种方法 小程序中的轮播图很简单&#xff0c;但是唯一的缺陷就是 swiper 是固定的150px 高度&#xff08;320px 宽度&#xff09;&#xff0c;这样如果传入的图片大于这个高度就会被隐藏。那么如何让图片自适应不同分辨率是一…

【小程序中image自适应以及默认高度问题】

原因&#xff1a;小程序不知道background-image&#xff0c;本人开发小程序有个头图&#xff0c;根据天气展示不同的头图&#xff0c;要适配各种宽窄不同的屏幕以及Ipad&#xff0c;不能拉伸图片&#xff0c;UI不同意使用渐变&#xff0c;其实使用宽100%完全可以解决&#xff0…

小程序图片高度自适应等问题

小程序图片高度自适应 这里踩了很多遍的坑&#xff0c;花了很多时间&#xff0c;以为像以前以前给他上级的盒子不给高度就行了&#xff0c;oh,no&#xff0c;这是一个坑&#xff0c;关键在于image标签的一个属性&#xff1a;mode"widthFix"&#xff0c;简单搞定 &l…

微信小程序图片高度按照图片真实宽高比自适应

原理&#xff1a;image组件bindload属性 前端在按照设计图定的宽度做好图片的宽高之后&#xff0c;如果图片的原始宽高比对应不上&#xff0c;那么图片就会出现拉伸变形的情况&#xff0c;虽然微信小程序有mode属性可以对图片进行适应&#xff0c;但是会有部分显示不完全或者会…

微信小程序——整个页面的自动适应布局、图片自适应、高度自动占满剩余部分

1、按比例适应布局 大家有没有过一个烦恼&#xff0c;就是让某个view的高度或者宽度扩大点&#xff0c;而且是要按比例适应不同的手机&#xff0c;遇到这类问题应该怎么办&#xff1f; 下面就为大家讲解怎么做一个能够自动适应不同手机的布局 1、像素单位 rpx 首先&#xff…

用arcgis裁剪面时出错,ERROR 999999: 执行函数时出错

转载地址&#xff1a;http://blog.sina.com.cn/s/blog_712f5b3b0101frfj.html 方法&#xff1a;ArcToolBox tool Data Management Tools -> Features -> Repair Geometry . 注&#xff1a;要裁剪的图层是要编辑&#xff08;editor&#xff09;状态。

ArcGIS裁剪时警告 warning001003:Datum conflict between input and output

问题描述 ArcGIS进行clip操作的时候警告&#xff1a;warning001003:Datum conflict between input and output。 原因 问题在于&#xff0c;输入和裁剪范围的坐标系不同。即Input raster和output extent两个图层的坐标系不同。 解决方案 统一坐标系统&#xff0c;具体方法很…

ArcGIS裁剪影像如何保持裁剪完全一致

ArcGIS裁剪影像如何保持裁剪范围完全一致 在长时间序列的数据分析中&#xff0c;经常会遇到要求所有的栅格数据范围一致&#xff0c;栅格数一致&#xff0c;所以在使用ArcGIS时&#xff0c;需要设置一些参数&#xff0c;才能得到正确的结果。 使用mask工具&#xff08;掩膜提取…

gis 数据框裁剪_ArcGIS中裁剪工具的使用

应约讲下裁剪。数据裁剪是经常使用的一个工具&#xff0c;工具说明也直接明了&#xff0c;隐藏功能他是不是说的&#xff0c;今天具体讲讲怎么用。 1.分析工具-提取分析-裁剪&#xff0c;启动裁剪工具。 2.将数据选中后&#xff0c;进行裁剪。输入要素此时不做任何选中。 看结果…

ArcGIS:矢量、栅格文件裁剪(批量处理)

一、栅格文件批量裁剪 1.加载矢量边界&#xff08;xzq&#xff09;&#xff0c;在Catalog对应文件夹中可查看原始数据为6个tif文件 2.在工具栏中打开ModelBuilder: &#xff08;1&#xff09;将矢量边界拖入Model&#xff1b;通过Insert->Iterators->Rasters添加栅格数据…