#include "stdafx.h" #include <iostream> #include <highgui.h> #include <cv.h> #include <cxcore.h> int main() { IplImage* dst = NULL; cvNamedWindow("in"); cvNamedWindow("out"); IplImage * in= cvLoadImage("C:\\Users\\Administrator\\Desktop\\1001.png",0);//导入图片并灰度化 cvShowImage("in",in); dst = cvCreateImage( cvGetSize( in ), IPL_DEPTH_8U, 1 ); cvCanny( in, dst, 50, 150, 3 );//边缘检测 // IplImage * out = doPryDown(in); cvShowImage("out",dst); cvWaitKey(0);//key point cvReleaseImage(&in); cvReleaseImage(&dst); cvDestroyWindow("in"); cvDestroyWindow("out"); }
/* Runs canny edge detector */ CVAPI(void) cvCanny( const CvArr* image, CvArr* edges, double threshold1, double threshold2, int aperture_size CV_DEFAULT(3) );
- image
- 单通道输入图像.
- edges
- 单通道存储边缘的输出图像
- threshold1
- 第一个阈值
- threshold2
- 第二个阈值
- aperture_size
- Sobel 算子内核大小 (见 cvSobel).
函数 cvCanny 采用 CANNY 算法发现输入图像的边缘而且在输出图像中标识这些边缘。threshold1和threshold2 当中的小阈值用来控制边缘连接,大的阈值用来控制强边缘的初始分割。