opencv之形态学操作

 本文需要了解的库函数有:

//创建结构元素
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;
}

结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值