【OpenCV】形态学处理的应用

最近在做一个项目,是从无规则网格背景中,提取无规则目标物体,在此极简为如下图的情形。
在这里插入图片描述
这里主要针对简化后的模型做下形态学处理的对比,包括腐蚀、膨胀、开运算、闭运算、心态学梯度、顶帽、黑帽和击中击不中变换,网上对于这些处理方法、概念讲述的都比较清楚,此处不再叙述,仅将处理后的图像进行对比展示。
笔者的编译环境为 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;
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值