OpenCV形态学操作(腐蚀,膨胀,形态学变换)C++

先补两个滤波方法

双边滤波:

使用bilateralFilter函数,需要填五个参数,大家可以尝试对后三个参数使用trackbar调参,观察图像的变化。

 图片效果朦胧梦幻,毕竟双边滤波是非线性滤波方法

代码:

#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
    Mat img=imread("../xiao.jpg"),tmp;
    //cvtColor(img,img,COLOR_BGR2GRAY);
    printf("%d %d\n",img.type(),CV_8UC3);
    bilateralFilter(img,tmp,30,123,123);
    imshow("img",img);
    imshow("tmp",tmp);
    waitKey(0);
    return 0;
}

通用线性滤波:

使用filter2D,第三个参数尽量填img.depth(),第四个参数为自定义的卷积核

 用(0,-1,0 ; -1,5,-1 ; 0,1,0)卷积和可以让图像锐化,边界更加显眼了

#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
    Mat img=imread("../xiao.jpg"),tmp;
    //cvtColor(img,img,COLOR_BGR2GRAY);
    Mat kernel=(Mat_<char>(3,3) << 0,-1,0,
                                  -1,5,-1,
                                   0,-1,0);
    filter2D(img,tmp,img.depth(),kernel);
    imshow("img",img);
    imshow("tmp",tmp);
    waitKey(0);
    return 0;
}

图像腐蚀

直接使用erode函数,第一个参数输入Mat,第二个参数输出Mat,第三个参数kernel

kernel需要使用getStructuringElement函数来获得

而getStructuringElement函数需要两个参数

第一个参数有三种选择:MORPH_RECT(矩形),MORPH_CROSS(交叉形),MORPH_ELLIPSE(椭圆形)

第二个参数就是Size(a,b),即形状的长宽尺寸

代码:

#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
    Mat img=imread("../xiao.jpg"),tmp;
    Mat kern=getStructuringElement(MORPH_RECT,Size(3,3));
    erode(img,tmp,kern);
    imshow("img",img);
    imshow("erode_rect",tmp);
    waitKey(0);
    return 0;
}

效果:(感觉线条变粗了,这真的是腐蚀吗?)(555555魈被腐蚀了)

图像膨胀

直接使用dilate函数,与erode的格式一样,不再赘述

代码:

#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
    Mat img=imread("../xiao.jpg"),tmp;
    Mat kern=getStructuringElement(MORPH_RECT,Size(3,3));
    dilate(img,tmp,kern);
    imshow("img",img);
    imshow("dilate_rect",tmp);
    waitKey(0);
    return 0;
}

效果:(感觉这个效果更接近腐蚀的意思吧。。。)

图像腐蚀膨胀的一些用途

详见博客:http://mangoroom.cn/opencv/opencv-learning-erode.html

一般都是先腐蚀后膨胀

可用于消除噪声,分离独立元素,连接相同元素,求出极值区域,求图像梯度等等

代码:

#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
    Mat img=imread("../xiao.jpg"),tmp;
    Mat kern=getStructuringElement(MORPH_RECT,Size(3,3));
    erode(img,tmp,kern);
    dilate(tmp,tmp,kern);
    imshow("img",img);
    imshow("rect",tmp);
    waitKey(0);
    return 0;
}

 效果:(感觉更有水墨画的意境了)

形态学操作

使用函数morphologyEx,需要填4个参数

前两个输入输出Mat,第四个是kernel,使用getStructuringElement

第三个参数有下面的几种填法(抄的课件。。)

MORPH_OPEN:开操作(先腐蚀后膨胀),可去除小对象
MORPH_CLOSE:闭操作(先膨胀后腐蚀),可填补小洞
MORPH_TOPHAT:顶帽(原图与开操作的差值),保留小对象
MORPH_BLACKHAT:黑帽(闭操作与原图的差值),保留小洞
MORPH_GRADIENT:形态学梯度(膨胀减腐蚀)

代码:(以morph_ellipse与morph_close为例)

#include<opencv2/opencv.hpp>
using namespace cv;
int main()
{
    Mat img=imread("../xiao.jpg"),tmp;
    Mat kern=getStructuringElement(MORPH_ELLIPSE,Size(3,3));
    morphologyEx(img,tmp,MORPH_CLOSE,kern);
    imshow("img",img);
    imshow("morph",tmp);
    waitKey(0);
    return 0;
}

效果:

完结撒花O(∩_∩)O~~O(∩_∩)O~~

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++ OpenCV中,形态学操作是一种图像处理技术,用于改变图像的形状和结构。形态学操作通常用于图像分割、去噪、边缘检测等应用中。 在进行形态学操作之前,我们需要获取图像的结构元素。结构元素类似于卷积核,它定义了形态学操作的形状和大小。在OpenCV中,我们可以使用getStructuringElement()函数来获取特定形状和大小的结构元素\[2\]。 getStructuringElement()函数的使用方式如下: ``` Mat element = getStructuringElement(shape, size); ``` 其中,shape参数指定结构元素的形状,可以是矩形、椭圆或十字形。size参数指定结构元素的大小。 获取到结构元素后,我们可以将其用于后续的形态学操作,例如腐蚀膨胀、开运算、闭运算等。这些操作可以通过调用morphologyEx()函数来实现\[3\]。 morphologyEx()函数的使用方式如下: ``` morphologyEx(src, dst, op, kernel, anchor, iterations, borderType, borderValue); ``` 其中,src参数是输入图像,dst参数是输出图像,op参数指定形态学操作的类型,kernel参数是结构元素,anchor参数是结构元素的锚点,iterations参数是操作的迭代次数,borderType参数是边界处理方式,borderValue参数是边界像素的值。 通过使用getStructuringElement()函数获取结构元素,并结合morphologyEx()函数进行形态学操作,我们可以实现各种图像处理任务。 #### 引用[.reference_title] - *1* *2* [C++ opencv 图像形态学膨胀腐蚀、闭、开、顶帽、黑帽](https://blog.csdn.net/HWWH520/article/details/125015959)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [opencv c++ 图像形态学操作](https://blog.csdn.net/lucust/article/details/128207799)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值