?? imageprocessingview.cpp
字號:
//DEL
//DEL // 圖像在計算機在存儲中的實際大小
//DEL CSize sizeImageSave = pDib->GetDibSaveDim();
//DEL
//DEL // 圖像在內存中每一行象素占用的實際空間
//DEL int nSaveWidth = sizeImageSave.cx;
//DEL
//DEL // 應用Prewitt算子求梯度
//DEL PrewittOperator(pDib, pdGrad);
//DEL
//DEL
//DEL for(y=0; y<nHeight ; y++ )
//DEL for(x=0 ; x<nWidth ; x++ )
//DEL {
//DEL if(*(pdGrad+y*nWidth+x)>50)
//DEL *( lpImage+y*nSaveWidth+x )=0;
//DEL else
//DEL *( lpImage+y*nSaveWidth+x )=255;
//DEL }
//DEL
//DEL //釋放內存空間
//DEL delete []pdGrad;
//DEL pdGrad=NULL;
//DEL
//DEL // 恢復光標形狀
//DEL EndWaitCursor();
//DEL
//DEL // 設置臟標記
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新視圖
//DEL pDoc->UpdateAllViews(NULL);
//DEL
//DEL }
/*************************************************************************
*
* \函數名稱:
* OnEdgeLaplace()
*
* \輸入參數:
* 無
*
* \返回值:
* 無
*
* \說明:
* 實現并行邊界分割-拉普拉斯算子
*
************************************************************************
*/
//DEL void CImageProcessingView::OnEdgeLaplace()
//DEL {
//DEL // TODO: Add your command handler code here
//DEL
//DEL //更改光標形狀
//DEL BeginWaitCursor();
//DEL
//DEL // 循環控制變量
//DEL int y;
//DEL int x;
//DEL
//DEL CImageProcessingDoc * pDoc = (CImageProcessingDoc *)this->GetDocument();
//DEL CDib * pDib = pDoc->m_pDibInit;
//DEL
//DEL LPBITMAPINFOHEADER lpBMIH=pDib->m_lpBMIH;
//DEL
//DEL // 判斷是否是8-bpp位圖
//DEL if (lpBMIH->biBitCount != 8)
//DEL {
//DEL // 提示用戶
//DEL MessageBox("目前只支持256色位圖的圖象分割!", "系統提示" ,
//DEL MB_ICONINFORMATION | MB_OK);
//DEL
//DEL // 返回
//DEL return;
//DEL }
//DEL
//DEL // 圖象的長寬大小
//DEL CSize sizeImage = pDib->GetDimensions();
//DEL int nWidth = sizeImage.cx ;
//DEL int nHeight = sizeImage.cy ;
//DEL
//DEL // 指向梯度數據的指針
//DEL double * pdGrad;
//DEL
//DEL // 按照圖像的大小開辟內存空間,存儲梯度計算的結果
//DEL pdGrad=new double[nHeight*nWidth];
//DEL
//DEL //圖像數據的指針
//DEL LPBYTE lpImage = pDib->m_lpImage;
//DEL
//DEL // 圖像在計算機在存儲中的實際大小
//DEL CSize sizeImageSave = pDib->GetDibSaveDim();
//DEL
//DEL // 圖像在內存中每一行象素占用的實際空間
//DEL int nSaveWidth = sizeImageSave.cx;
//DEL
//DEL // 應用Laplace算子求梯度
//DEL LaplacianOperator(pDib, pdGrad);
//DEL
//DEL
//DEL for(y=0; y<nHeight ; y++ )
//DEL for(x=0 ; x<nWidth ; x++ )
//DEL {
//DEL if(*(pdGrad+y*nWidth+x)>50)
//DEL *( lpImage+y*nSaveWidth+x )=0;
//DEL else
//DEL *( lpImage+y*nSaveWidth+x )=255;
//DEL }
//DEL
//DEL //釋放內存空間
//DEL delete []pdGrad;
//DEL pdGrad=NULL;
//DEL
//DEL // 恢復光標形狀
//DEL EndWaitCursor();
//DEL
//DEL // 設置臟標記
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新視圖
//DEL pDoc->UpdateAllViews(NULL);
//DEL
//DEL }
/*************************************************************************
*
* \函數名稱:
* OnEdgeCanny()
*
* \輸入參數:
* 無
*
* \返回值:
* 無
*
* \說明:
* 實現并行邊界分割-Canny算子
*
************************************************************************
*/
void CImageProcessingView::OnEdgeCanny()
{
// TODO: Add your command handler code here
//更改光標形狀
BeginWaitCursor();
CImageProcessingDoc * pDoc = (CImageProcessingDoc *)this->GetDocument();
CDib * pDib = pDoc->m_pDibInit;
LPBITMAPINFOHEADER lpBMIH=pDib->m_lpBMIH;
// 判斷是否是8-bpp位圖
if (lpBMIH->biBitCount != 8)
{
// 提示用戶
MessageBox("目前只支持256色位圖的圖象分割!", "系統提示" ,
MB_ICONINFORMATION | MB_OK);
// 返回
return;
}
// 循環控制變量
int y;
int x;
CSize sizeImage = pDib->GetDimensions();
int nWidth = sizeImage.cx ;
int nHeight= sizeImage.cy ;
int nSaveWidth = pDib->GetDibSaveDim().cx;
// 開辟內存,存儲圖象數據
unsigned char * pUnchImage = new unsigned char[nWidth*nHeight];
for(y=0; y<nHeight; y++)
{
for(x=0; x<nWidth; x++)
{
pUnchImage[y*nWidth+x] = pDib->m_lpImage[y*nSaveWidth+x];
}
}
// canny算子計算后的結果
unsigned char * pUnchEdge = new unsigned char[nWidth*nHeight];
// 調用canny函數進行邊界提取
Canny(pUnchImage, nWidth, nHeight, 0.4, 0.4, 0.79, pUnchEdge) ;
for(y=0; y<nHeight; y++)
{
for(x=0; x<nWidth; x++)
{
pDib->m_lpImage[y*nWidth+x]=(unsigned char)(255-pUnchEdge[y*nWidth+x]);
}
}
delete []pUnchImage;
pUnchImage = NULL ;
delete []pUnchEdge ;
pUnchEdge = NULL ;
// 恢復光標形狀
EndWaitCursor();
// 設置臟標記
pDoc->SetModifiedFlag(TRUE);
// 更新視圖
pDoc->UpdateAllViews(NULL);
}
/*************************************************************************
*
* \函數名稱:
* OnEdgeTrack()
*
* \輸入參數:
* 無
*
* \返回值:
* 無
*
* \說明:
* 實現邊界跟蹤算法
*
************************************************************************
*/
//DEL void CImageProcessingView::OnEdgeTrack()
//DEL {
//DEL // TODO: Add your command handler code here
//DEL
//DEL //更改光標形狀
//DEL BeginWaitCursor();
//DEL
//DEL // 獲得Doc類的指
//DEL CImageProcessingDoc * pDoc = (CImageProcessingDoc *)this->GetDocument();
//DEL
//DEL CDib * pDib = pDoc->m_pDibInit;
//DEL
//DEL LPBITMAPINFOHEADER lpBMIH=pDib->m_lpBMIH;
//DEL
//DEL // 判斷是否是8-bpp位圖
//DEL if (lpBMIH->biBitCount != 8)
//DEL {
//DEL // 提示用戶
//DEL MessageBox("目前只支持256色位圖的圖象分割!", "系統提示" ,
//DEL MB_ICONINFORMATION | MB_OK);
//DEL
//DEL // 返回
//DEL return;
//DEL }
//DEL
//DEL
//DEL // 圖像在計算機在存儲中的實際大小
//DEL CSize sizeImageSave = pDib->GetDibSaveDim();
//DEL
//DEL // 圖像在內存中每一行象素占用的實際空間
//DEL int nSaveWidth = sizeImageSave.cx;
//DEL
//DEL // 遍歷圖象的縱坐標
//DEL int y;
//DEL
//DEL // 遍歷圖象的橫坐標
//DEL int x;
//DEL
//DEL // 圖象的長寬大小
//DEL CSize sizeImage = pDib->GetDimensions();
//DEL int nWidth = sizeImage.cx ;
//DEL int nHeight = sizeImage.cy ;
//DEL
//DEL
//DEL // 指向圖像數據的指針
//DEL LPBYTE lpImage ;
//DEL lpImage = pDib->m_lpImage ;
//DEL
//DEL // 邊界跟蹤后的結果區域
//DEL unsigned char * pUnEdgeTrack ;
//DEL
//DEL pUnEdgeTrack = new unsigned char[nWidth * nHeight] ;
//DEL
//DEL EdgeTrack(pDib, pUnEdgeTrack);
//DEL
//DEL for(y=0; y<nHeight; y++)
//DEL {
//DEL for(x=0; x<nWidth; x++)
//DEL {
//DEL lpImage[y*nSaveWidth + x] = (unsigned char) (255-pUnEdgeTrack[y*nWidth + x]);
//DEL }
//DEL }
//DEL
//DEL //釋放內存
//DEL delete pUnEdgeTrack;
//DEL pUnEdgeTrack = NULL;
//DEL
//DEL // 恢復光標形狀
//DEL EndWaitCursor();
//DEL
//DEL // 設置臟標記
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新視圖
//DEL pDoc->UpdateAllViews(NULL);
//DEL
//DEL }
/*************************************************************************
*
* \函數名稱:
* OnRegionGrow()
*
* \輸入參數:
* 無
*
* \返回值:
* 無
*
* \說明:
* 實現區域生長算法
*
************************************************************************
*/
//DEL void CImageProcessingView::OnRegionGrow()
//DEL {
//DEL // TODO: Add your command handler code here
//DEL
//DEL //更改光標形狀
//DEL BeginWaitCursor();
//DEL
//DEL // 獲得Doc類的指
//DEL CImageProcessingDoc * pDoc = (CImageProcessingDoc *)this->GetDocument();
//DEL
//DEL CDib * pDib = pDoc->m_pDibInit;
//DEL
//DEL LPBITMAPINFOHEADER lpBMIH=pDib->m_lpBMIH;
//DEL
//DEL // 判斷是否是8-bpp位圖
//DEL if (lpBMIH->biBitCount != 8)
//DEL {
//DEL // 提示用戶
//DEL MessageBox("目前只支持256色位圖的圖象分割!", "系統提示" ,
//DEL MB_ICONINFORMATION | MB_OK);
//DEL
//DEL // 返回
//DEL return;
//DEL }
//DEL
//DEL // 遍歷圖象的縱坐標
//DEL int y;
//DEL
//DEL // 遍歷圖象的橫坐標
//DEL int x;
//DEL
//DEL // 圖像在計算機在存儲中的實際大小
//DEL CSize sizeImageSave = pDib->GetDibSaveDim();
//DEL
//DEL // 圖像在內存中每一行象素占用的實際空間
//DEL int nSaveWidth = sizeImageSave.cx;
//DEL
//DEL // 圖象的長寬大小
//DEL CSize sizeImage = pDib->GetDimensions();
//DEL int nWidth = sizeImage.cx ;
//DEL int nHeight = sizeImage.cy ;
//DEL
//DEL // 指向圖像數據的指針
//DEL LPBYTE lpImage ;
//DEL lpImage = pDib->m_lpImage ;
//DEL
//DEL unsigned char * pUnchRgRst = new unsigned char[nWidth * nHeight];
//DEL // 初始化
//DEL memset(pUnchRgRst, 0 , sizeof(unsigned char)*nWidth*nHeight );
//DEL
//DEL RegionGrow(pDib, pUnchRgRst);
//DEL
//DEL for(y=0; y<nHeight; y++)
//DEL for(x=0; x<nWidth; x++)
//DEL {
//DEL lpImage[y*nSaveWidth + x] =(unsigned char) (255-pUnchRgRst[y*nWidth+x] );
//DEL }
//DEL
//DEL // 釋放內存
//DEL delete []pUnchRgRst;
//DEL pUnchRgRst = NULL ;
//DEL
//DEL // 恢復光標形狀
//DEL EndWaitCursor();
//DEL
//DEL // 設置臟標記
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新視圖
//DEL pDoc->UpdateAllViews(NULL);
//DEL }
/*************************************************************************
*
* \函數名稱:
* OnMotionBackground()
*
* \輸入參數:
* 無
*
* \返回值:
* 無
*
* \說明:
* 該函數根據運動圖象提取其中的靜止背景。其中運動圖象要求為bmp文件,并按
*順序排列。
*
*************************************************************************
*/
//DEL void CImageProcessingView::OnMotionBackground()
//DEL {
//DEL // 提取背景成功標志
//DEL BOOL bFlag;
//DEL
//DEL // 獲取文檔指針
//DEL CImageProcessingDoc* pDoc;
//DEL pDoc = GetDocument();
//DEL
//DEL // 獲得當前打開文件的文件路徑名
//DEL CString strPathName;
//DEL strPathName = pDoc->GetPathName();
//DEL
//DEL // 序列的總幀數
//DEL int nTotalFrameNum = 20;
//DEL
//DEL // 圖象的寬度
//DEL int nImageWidth;
//DEL nImageWidth = pDoc->m_pDibInit->m_lpBMIH->biWidth;
//DEL
//DEL // 圖象的高度
//DEL int nImageHeight;
//DEL nImageHeight = pDoc->m_pDibInit->m_lpBMIH->biHeight;
//DEL
//DEL // 圖象的靜止背景
//DEL unsigned char* pUnchBackGround;
//DEL pUnchBackGround = new unsigned char[nImageWidth*nImageHeight];
//DEL
//DEL // 更改光標形狀
//DEL BeginWaitCursor();
//DEL
//DEL // 調用GetBackground函數提取靜止背景
//DEL bFlag = GetBackground(strPathName, nTotalFrameNum, nImageWidth,nImageHeight, pUnchBackGround);
//DEL if(bFlag == FALSE){
//DEL return;
//DEL }
//DEL
//DEL // 將背景設置為當前顯示圖象
//DEL LPBYTE lpTemp;
//DEL lpTemp = pDoc->m_pDibInit->m_lpImage;
//DEL
//DEL // 將數據拷貝到圖象中
//DEL memcpy(lpTemp, (LPBYTE)pUnchBackGround, nImageWidth*nImageHeight);
//DEL
//DEL // 恢復光標形狀
//DEL EndWaitCursor();
//DEL
//DEL // 釋放已分配內存
//DEL delete[]pUnchBackGround;
//DEL pUnchBackGround = NULL;
//DEL
//DEL // 設置臟標記
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新視圖
//DEL pDoc->UpdateAllViews(NULL);
//DEL }
/*************************************************************************
*
* \函數名稱:
* OnRecogMatch()
*
* \輸入參數:
* 無
*
* \返回值:
* 無
*
* \說明:
* 根據圖象模板,在待匹配的圖象中找到匹配的位置
*
*************************************************************************
*/
//DEL void CImageProcessingView::OnRecogMatch()
//DEL {
//DEL CImageProcessingD
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -