膨胀与腐蚀
膨胀:假设有图像A和结构元素B,结构元素B在图像A上移动,假设结构元素B的中心点为锚点,在结构元素B下的图像A中最大的像素值替换锚点,其中B作为结构体,可以是任意形状,矩形,圆形,椭圆等等。
腐蚀:假设有图像A和结构元素B,结构元素B在图像A上移动,假设结构元素B的中心点为锚点,在结构元素B下的图像A中最小的像素值替换锚点,其中B作为结构体,可以是任意形状,矩形,圆形,椭圆等等。
getStructuringElement(int shape, Size ksize,Point anchor)第一个参数为结构体形状,例如MORPH_RECT,第二个参数为大小,第三个参数锚点默认为中心点Point(-1,-1)。
膨胀API为 dilate(src,dst,kernel)
腐蚀API为dilate(src,dst,kernel)
使用createTrackbar对膨胀和腐蚀后的输出图像上对结构元素大小进行实时调整。例如
createTrackbar(“Element Size :”, OUTPUT_WIN, &element_size, max_size, CallBack_Demo);
膨胀效果图
腐蚀效果图
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
Mat src, dst;
char OUTPUT_WIN[] = "output image";
int element_size = 3;
int max_size = 21;
void CallBack_Demo(int, void*);
int main(int argc, char** argv) {
src = imread("C:/Users/ASUS/Desktop/001.jpg");
if (!src.data) {
printf("could not load image...\n");
return -1;
}
namedWindow("input image", CV_WINDOW_AUTOSIZE);
imshow("input image", src);
namedWindow(OUTPUT_WIN, CV_WINDOW_AUTOSIZE);
createTrackbar("Element Size :", OUTPUT_WIN, &element_size, max_size, CallBack_Demo);
CallBack_Demo(0, 0);
waitKey(0);
return 0;
}
void CallBack_Demo(int, void*) {
int s = element_size * 2 + 1;
Mat structureElement = getStructuringElement(MORPH_RECT, Size(s, s), Point(-1, -1));
dilate(src, dst, structureElement, Point(-1, -1), 1);
erode(src, dst, structureElement);
imshow(OUTPUT_WIN, dst);
return;
}