OpenCV学习笔记_图片边缘检测

#include <cv.h>
#include <highgui.h>

using namespace std;


IplImage* doCanny(IplImage* in, double lowThresh, double highThresh, double aperture)
{
	if (in->nChannels != 1)
		return(0); // Canny only handles gray scale images
	IplImage* out = cvCreateImage(cvGetSize(in), in->depth, 1);
	//图像的边缘检测.lowThresh 第一个阈值,highThresh 第二个阈值,aperture 算子内核大小
	cvCanny(in, out, lowThresh, highThresh, aperture);
	return(out);
};

int main(int argc, char** argv)
{
	IplImage* img_rgb = cvLoadImage("D:\\15.jpg");
	IplImage* img_gry = cvCreateImage(cvSize(img_rgb->width, img_rgb->height), img_rgb->depth, 1);
	//将BGR图转成灰度图
	cvCvtColor(img_rgb, img_gry, CV_BGR2GRAY);
	cvShowImage("Example Gray", img_gry);
	IplImage* smooth = cvCreateImage(cvGetSize(img_rgb), img_rgb->depth, 1);
	//在进行图片边缘检测前,应先对图片进行模糊处理
	cvSmooth(img_gry, smooth, CV_GAUSSIAN, 3, 3);
	//进行图片边缘检测
	IplImage* img_cny = doCanny(smooth, 10, 100, 3);
	cvShowImage("Example Canny", img_cny);
	cvWaitKey(0);
	cvReleaseImage(&img_rgb);
	cvReleaseImage(&img_gry);
	cvReleaseImage(&smooth);
	cvReleaseImage(&img_cny);
	cvDestroyWindow("Example Gray");
	cvDestroyWindow("Example Canny");
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值