大宇私人领地伊甸园丨宁愿做了后悔,也不要错过后悔[www.mrdayu.com]
注册

24小时联系邮箱:[email protected]

所有文章
大宇私人伊甸园: 首页 > 所有文章 > 编程人生 > 开源库 > opencv > [001.11]膨胀与腐蚀

[001.11]膨胀与腐蚀

发布时间:2018/07/13 opencv 标签opencv形态学腐蚀膨胀阅读:29

膨胀与腐蚀:

  • 腐蚀
  • 膨胀
  • 代码演示

形态学操作(morphology operators)-膨胀:

  • 图像形态学操作 – 基于形状的一系列图像处理操作的合集,主要是基于集合论基础上的形态学数学
  • 形态学有四个基本操作:腐蚀、膨胀、开、闭
  • 膨胀与腐蚀是图像处理中最常用的形态学操作手段

形态学操作膨胀:

跟卷积操作类似,假设有图像A和结构元素B,结构元素B在A上面移动

其中B定义其中心为锚点,计算B覆盖下A的最大像素值用来替换锚点的像素,其中B作为结构体可以是任意形状

形态学操作腐蚀:

腐蚀跟膨胀操作的过程类似,唯一不同的是以最小值替换锚点重叠下图像的像素值

相关API:

getStructuringElement(int shape, Size ksize, Point anchor)

第一个参数shape:形状 (MORPH_RECT \MORPH_CROSS \MORPH_ELLIPSE)

第二个参数ksize:大小

第三个参数anchor:锚点 默认是Point(-1, -1)意思就是中心像素
dilate(src, dst, kernel)//膨胀

erode(src, dst, kernel)//腐蚀

动态调整结构元素大小:

TrackBar:

createTrackbar(const String & trackbarname, const String winName,  int* value, int count, Trackbarcallback func, void* userdata=0)

其中最中要的是 callback 函数功能。如果设置为NULL就是说只有值update,但是不会调用callback的函数。

代码演示:

腐蚀效果:

#include <opencv2/opencv.hpp>
#include <iostream>

using namespace std;
using namespace cv;
char OUTPUT_WIN[] = "dst image";
int element_size = 3;
int max_size = 21;
void CallBack_Demo(int, void*);
Mat src, dst;
int main() {
	src = imread("c:/dangtao.jpg");
	if (!src.data) {
		printf("error from open image");
		return -1;
	}
	namedWindow("src image",CV_WINDOW_AUTOSIZE);
	imshow("src image",src);
	namedWindow(OUTPUT_WIN,CV_WINDOW_AUTOSIZE);
	createTrackbar("Size",OUTPUT_WIN, &element_size,max_size, CallBack_Demo);
	CallBack_Demo(0,0);
	waitKey(0);
	return true;
}
void CallBack_Demo(int, void*) {
	int s = element_size * 2 + 1;
	Mat structureElement = getStructuringElement(MORPH_RECT, Size(s, s), Point(-1, -1));
	erode(src, dst, structureElement);
	imshow(OUTPUT_WIN, dst);
	return;
}

膨胀效果:

#include <opencv2/opencv.hpp>
#include <iostream>

using namespace std;
using namespace cv;
char OUTPUT_WIN[] = "dst image";
int element_size = 3;
int max_size = 21;
void CallBack_Demo(int, void*);
Mat src, dst;
int main() {
	src = imread("c:/dangtao.jpg");
	if (!src.data) {
		printf("error from open image");
		return -1;
	}
	namedWindow("src image",CV_WINDOW_AUTOSIZE);
	imshow("src image",src);
	namedWindow(OUTPUT_WIN,CV_WINDOW_AUTOSIZE);
	createTrackbar("Size",OUTPUT_WIN, &element_size,max_size, CallBack_Demo);
	CallBack_Demo(0,0);
	waitKey(0);
	return true;
}
void CallBack_Demo(int, void*) {
	int s = element_size * 2 + 1;
	Mat structureElement = getStructuringElement(MORPH_RECT, Size(s, s), Point(-1, -1));
	//erode(src, dst, structureElement);
	dilate(src, dst, structureElement, Point(-1, -1), 1);
	imshow(OUTPUT_WIN, dst);
	return;
}

The bottom line, for me, is simple.

Let’s hope it doesn’t take 500 years for a discipline of testing to becomes the standard for software developers.

From:dayu

您好!请登录

合作网站快捷登录:
点击取消回复

已有1评论

  • 闺房独自乐
    闺房独自乐 回复

    炎热的夏天,看到这样的博客瞬间清凉了许多!


    2018年07月14日00:29

大宇博客

点击这里给我发消息点击这里给我发消息