OPENCV中的常見算法之一 CANNY

以下是最簡單的圖像處理函數(shù),主要是提取邊緣。

void CCannyDoc::OnCanny()
{
 
   IplImage * pImg = NULL;
   IplImage * pCannyImg = NULL;
   IplImage * pImg1=NULL;
   //讀入原始圖像,Cstring i;圖片路徑
   pImg = cvLoadImage( i, 0); 

//創(chuàng)建一個八位,一通道的圖像
 pImg1=cvCreateImage(cvGetSize(pImg),IPL_DEPTH_8U,1);          
//高斯平滑 第二個0為標(biāo)準(zhǔn)差,pImg為輸出圖像 
cvSmooth(pImg,pImg1,CV_GAUSSIAN,3,0,0,0);                     

//分配新圖的內(nèi)存空間
 pCannyImg = cvCreateImage(cvGetSize(pImg),IPL_DEPTH_8U,1);   

//canny邊緣檢測,pCannyImg輸出圖像 
 cvCanny(pImg1, pCannyImg, 20, 150, 3);                        
    cvNamedWindow("smooth", 1);
    cvNamedWindow("canny",1);     //創(chuàng)建窗口
    cvShowImage( "smooth", pImg1 );
    cvShowImage( "canny", pCannyImg ); //顯示圖像
 cvWaitKey(0);   //等待按鍵,按下0鍵之后窗口關(guān)閉
AfxMessageBox("運行通過標(biāo)志");
 cvDestroyWindow( "smooth" );//銷毀窗口
     cvDestroyWindow( "canny" );
     
     cvReleaseImage( &pImg1 );
     cvReleaseImage( &pCannyImg ); //釋放圖像
     cvReleaseImage(&pImg1);
}
BOOL CCannyDoc::OnOpenDocument(LPCTSTR lpszPathName)
{
 if (!CDocument::OnOpenDocument(lpszPathName))
  return FALSE;
 
  i=lpszPathName;
 IplImage*p=cvLoadImage( lpszPathName, 0);
    cvNamedWindow("s", 1);   //這里s為窗口的名字
 cvShowImage( "s", p );
 //cvDestroyWindow( "s" );
 //cvReleaseImage( &p );
 return TRUE;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容