部分内容转至http://blog.csdn.net/welcome_xu/article/details/6694985
1:图像的形态学处理:
膨胀、腐蚀、开、闭运算是数学形态学最基本的变换,用得最多的主要是针对二值图像的形态学
膨胀:把二值图像各1像素连接成分的边界扩大一层(填充边缘或0像素内部的孔);
腐蚀:把二值图像各1像素连接成分的边界点去掉从而缩小一层(可提取骨干信息,去掉毛刺,去掉孤立的0像素);
开:先腐蚀再膨胀,可以去掉目标外的孤立点
闭:先膨胀再腐蚀,可以去掉目标内的孔。
首先看一下opencv中自带的函数:
腐蚀:
CV_EXPORTS_W void erode( InputArray src, OutputArray dst, InputArray kernel,
Point anchor=Point(-1,-1), int iterations=1,
int borderType=BORDER_CONSTANT,
const Scalar& borderValue=https://www.it610.com/article/morphologyDefaultBorderValue() );
其中,src为输入的图像,一般为二值图像也可以是灰度图像,dst为输出图像,和src可以是同一个变量,kennels为结构元素,默认的话为一个3×3的矩阵, anchor:结构元素的中心,如果是默认参数(-1,-1),程序会自动将其设置为结构元素的中心。 iterations:迭代次数,我们可以选择对图像进行多次形态学运算。后面两个参数是边界类型,由于要处理领域问题,所以图像需要扩充边界。一般情况下使用默认即可。
膨胀:
CV_EXPORTS_W void dilate( InputArray src, OutputArray dst, InputArray kernel,
Point anchor=Point(-1,-1), int iterations=1,
int borderType=BORDER_CONSTANT,
const Scalar& borderValue=https://www.it610.com/article/morphologyDefaultBorderValue() );
参数和上边一样;
int _tmain(int argc, _TCHAR* argv[])
{
Mat image = imread("003.jpg",1);
cvtColor(image,image,CV_RGB2GRAY);
threshold(image,image,65,255,THRESH_BINARY);
namedWindow("原图");
imshow("原图",image);
Mat eroded;
erode(image,eroded,Mat());
namedWindow("腐蚀");
imshow("腐蚀",eroded);
Mat dilated;
dilate(image,dilated,Mat());
namedWindow("膨胀");
imshow("膨胀",dilated);
waitKey(0);
return 0;
}
原二值图像和腐蚀膨胀后的结果如下图: 【opencv图像形态学处理】
文章图片
文章图片
文章图片
2:开运算与闭运算:
CV_EXPORTS_W void morphologyEx( InputArray src, OutputArray dst,
int op, InputArray kernel,
Point anchor=Point(-1,-1), int iterations=1,
int borderType=BORDER_CONSTANT,
const Scalar& borderValue=https://www.it610.com/article/morphologyDefaultBorderValue() );
可以看到参数与腐蚀膨胀运算差不多,就是第三个参数op不一样。op为MORPH_CLOSE,表示闭运算。MORPH_OPEN表示开运算;
int _tmain(int argc, _TCHAR* argv[])
{
Mat image = imread("003.jpg",1);
cvtColor(image,image,CV_RGB2GRAY);
threshold(image,image,65,255,THRESH_BINARY);
namedWindow("原图");
imshow("原图",image);
Mat element(5,5,CV_8U,Scalar(1));
Mat closed;
morphologyEx(image,closed,MORPH_CLOSE,element);
namedWindow("closed");
imshow("closed",closed);
Mat opened;
morphologyEx(image,opened,MORPH_OPEN,element);
namedWindow("opened");
imshow("opened",opened);
waitKey(0);
return 0;
}
得到的结果:
文章图片
文章图片
图像的形态学操作主要用于:边缘检测、图像分割、形态骨架提取、噪声滤除。
选取结构元素的方法:多结构元素、遗传算法。
推荐阅读
- 人脸识别|【人脸识别系列】| 实现自动化妆
- OpenCV|OpenCV-Python实战(18)——深度学习简介与入门示例
- opencv|图像处理之椒盐噪声的添加与去除
- 人脸识别|【人脸识别系列】| 实现人脸截图保存并编写128维特征向量
- opencv|网络爬虫入门练习
- OpenCV|【OpenCV 完整例程】89. 带阻滤波器的传递函数
- OpenCV|【OpenCV 完整例程】90. 频率域陷波滤波器
- OpenCV|【OpenCV 完整例程】22. 图像添加非中文文字
- OpenCV|【OpenCV 完整例程】91. 高斯噪声、瑞利噪声、爱尔兰噪声
- opencv|python+opencv车道线,实线虚线的检测