本文需要了解的库函数有:
//创建结构元素
IplConvKernel* cvCreateStructuringElementEx( int cols, int rows, int anchor_x, int anchor_y, int shape, int* values=NULL );
下面是形态学闭操作的例程
#pragma comment(lib,"cv.lib")
#pragma comment(lib,"cvaux.lib")
#pragma comment(lib,"highgui.lib")
#pragma comment(lib,"cxcore.lib")
#include <cv.h>
#include <highgui.h>
#include<stdio.h>
IplImage *image =NULL; //图像指针
IplImage *dst =NULL; //目标图像指针
IplConvKernel * kernel = NULL;//核指针
const char* winnane = "形态学闭操作";
int size = 0;//尺寸大小
void OnTrack(int pos) //闭操作回调
{
kernel = cvCreateStructuringElementEx(size*2+1,size*2+1,size,size,CV_SHAPE_RECT,NULL); //创建核
cvDilate(image,dst,kernel,1);
cvErode(dst,dst,kernel,1);
cvShowImage(winnane,dst);
}
int main()
{
image = cvLoadImage("lena.jpg",1);//加载图像
dst = cvCreateImage(cvGetSize(image),8,3);//创建目标图像
cvNamedWindow(winnane,1);
cvCreateTrackbar("结构尺寸",winnane,&size,10,OnTrack);
OnTrack(size);//调用一次更新视图
cvWaitKey(0);
cvReleaseImage(&image);
cvReleaseImage(&dst);
cvDestroyWindow(winnane);
return 0;
}
结果: