使用OpenCV2.4.9+VS2013
include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
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("F:\\test.jpg");
if (!src.data) {
cout << "could not load image..." << endl;
cin.get();
cin.get();
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));
//定义一个结构元素,形状为矩形,大小为s,锚点为中心像素点(-1,-1)
dilate(src, dst, structureElement, Point(-1, -1), 1); //进行膨胀操作,用最大值替换中心像素
//erode(src, dst, structureElement); //进行腐蚀操作,用最小值替换中心像素
imshow("output image", dst);
return;
}
运行结果:
1. 膨胀操作
2. 腐蚀操作