形态学
形态学操作就是基于形状的一系列图像处理操作,最基本的形态学操作有二种:膨胀和腐蚀
膨胀和腐蚀可以实现如下功能:
1.消除噪声
2.分割出独立的图像元素,在图像中连接相邻的元素
3.寻找图像中明显的极大值区域和极小值区域
4.求出图像额梯度
膨胀就是图像中的高亮部分进行膨胀,“领域扩张”,效果图拥有比原图更大的高亮区域;腐蚀就是原图中的高亮部分被腐蚀,“领域被蚕食”,效果图拥有比原图更小的高亮区域。
膨胀
腐蚀
源码分析
//膨胀
void cv::erode(InputArray src, OutputArraydst, InputArray kernel,
Point anchor,int iterations,
int borderType, constScalar& borderValue)
{
morphOp( MORPH_ERODE, src, dst, kernel, anchor, iterations, borderType, borderType, borderValue);
//调用morphOp函数,并设定标识符为**MORPH_ERODE**
}
void cv::dilate( InputArray src,OutputArray dst, InputArray kernel, Point anchor, int iterations,int borderType, constScalar& borderValue )
{
//调用morphOp函数,并设定标识符为**MORPH_DILATE**
morphOp( MORPH_DILATE, src, dst, kernel, anchor, iterations, borderType,borderValue );
}
使用
我们一般使用getStructuringElement函数来配合erode函数和dilate函数使用。
//载入原图
Mat image = imread("1.jpg");
//获取自定义核
Mat element = getStructuringElement(MORPH_RECT,Size(15,15));
//第一个参数:内核形状 第二个:内核尺寸 第三个:锚点的位置
Mat out;
//进行膨胀操作
dilate(image, out, element);
完整代码:
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <iostream>
using namespace std;
using namespace cv;
int main(){
//载入原图
Mat image = imread("1.jpg");
//创建窗口
nameWindow("原图");
nameWindow("效果图");
//显示原图
imshow("原图",image);
//获取自定义核
Mat element = getStructuringElemnet(MORPH_RECT, Size(15,15));
Mat out;
//进行膨胀操作
dilate(image,out,element);
//显示效果图
imshow("效果图",out);
waitKey(0);
return 0;
}