最近在做一个项目,是从无规则网格背景中,提取无规则目标物体,在此极简为如下图的情形。
这里主要针对简化后的模型做下形态学处理的对比,包括腐蚀、膨胀、开运算、闭运算、心态学梯度、顶帽、黑帽和击中击不中变换,网上对于这些处理方法、概念讲述的都比较清楚,此处不再叙述,仅将处理后的图像进行对比展示。
笔者的编译环境为 WIN10+VS2019+OpenCV4.1
以下为笔者实现的编译代码,比较简单,如果有什么疑问可以留言,一起讨论学习。
#include <opencv2\opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
int main()
{
//用图像验证形态学操作效果
Mat img = imread("huangyi.jpg", IMREAD_GRAYSCALE);
Mat erode1, dilate1, open, close, gradient, tophat, blackhat, hitmiss;
Mat kernel = getStructuringElement(0, Size(11, 11));
namedWindow("原图像", WINDOW_NORMAL);
imshow("原图像", img);
//对图像进行腐蚀运算
erode(img, erode1, kernel);
namedWindow("腐蚀", WINDOW_NORMAL);
imshow("腐蚀", erode1);
//对图像进行膨胀运算
dilate(img, dilate1, kernel);
namedWindow("膨胀", WINDOW_NORMAL);
imshow("膨胀", dilate1);
//对图像进行开运算
morphologyEx(img, open, MORPH_OPEN, kernel);
namedWindow("开运算",WINDOW_NORMAL);
imshow("开运算", open);
//对图像进行闭运算
morphologyEx(img, close, MORPH_CLOSE, kernel);
namedWindow("闭运算", WINDOW_NORMAL);
imshow("闭运算", close);
//对图像进行梯度运算
morphologyEx(img, gradient, MORPH_GRADIENT, kernel);
namedWindow("梯度运算", WINDOW_NORMAL);
imshow("梯度运算", gradient);
//对图像进行顶帽运算
morphologyEx(img, tophat, MORPH_TOPHAT, kernel);
namedWindow("顶帽", WINDOW_NORMAL);
imshow("顶帽", tophat);
//对图像进行黑帽运算
morphologyEx(img, blackhat, MORPH_BLACKHAT, kernel);
namedWindow("黑帽", WINDOW_NORMAL);
imshow("黑帽", blackhat);
//对图像进行击中击不中变换
morphologyEx(img, hitmiss, MORPH_HITMISS, kernel);
namedWindow("击中击不中", WINDOW_NORMAL);
imshow("击中击不中", hitmiss);
waitKey(0);
destroyAllWindows();
return 0;
}