部分内容转至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=morphologyDefaultBorderValue() );
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=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;
}
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=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 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;
}
图像的形态学操作主要用于:边缘检测、图像分割、形态骨架提取、噪声滤除。
选取结构元素的方法:多结构元素、遗传算法。