#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 当中的小阈值用来控制边缘连接,大的阈值用来控制强边缘的初始分割。