您的位置:首页 > 运维架构

opencv中用Sobel算子进行边缘检测

2012-11-08 15:55 387 查看
workImg:当前工作图像(全局);

img3:Sobel_edge结果;

m_imagetype:图像类型(全局);

[cpp] view
plaincopy

OnEdgedetSobel()

{

IplImage *img = cvCreateImage( cvGetSize(workImg), IPL_DEPTH_16S, 1);

if(workImg->nChannels==3)

OnColorToGray();

//img=workImg;

imageClone(workImg,&img);

cvFlip(img);

IplImage *img2 = cvCreateImage( cvGetSize(img), IPL_DEPTH_16S, 1);//当输入图像是 8 位的,要求输出图像是 16 位的

IplImage *img3 = cvCreateImage( cvGetSize(img), IPL_DEPTH_8U, 1);

cvSobel( img, img2, 1, 0);

cvConvertScaleAbs(img2,img3,1,0);

cvReleaseImage(&img);

cvReleaseImage(&img2);

cvFlip(img3);

m_dibFlag=imageReplace(img3,&workImg);

m_ImageType=1;

Invalidate();
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐