workImg:当前工作图像(全局);
img3:Sobel_edge结果;
m_imagetype:图像类型(全局);
- 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();