📄 imageprocessingview.cpp
字号:
*/
//DEL void CImageProcessingView::OnEnhanceSharpFreq()
//DEL {
//DEL // TODO: Add your command handler code here
//DEL //更改光标形状
//DEL BeginWaitCursor();
//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 int y;
//DEL int x;
//DEL
//DEL CSize sizeImage = pDib->GetDimensions();
//DEL int nWidth = sizeImage.cx ;
//DEL int nHeight= sizeImage.cy ;
//DEL
//DEL int nSaveWidth = pDib->GetDibSaveDim().cx;
//DEL
//DEL // 开辟内存,存储图象数据,该数据的存储不是DWORD对齐的
//DEL unsigned char * pUnchImage = new unsigned char[nWidth*nHeight];
//DEL
//DEL for(y=0; y<nHeight; y++)
//DEL {
//DEL for(x=0; x<nWidth; x++)
//DEL {
//DEL pUnchImage[y*nWidth+x] = pDib->m_lpImage[y*nSaveWidth+x];
//DEL }
//DEL }
//DEL
//DEL // 调用高通滤波函数进行图象增强
//DEL HighPassFilterEnhance(pUnchImage, nWidth, nHeight, 50) ;
//DEL
//DEL // 增强以后的图象拷贝到pDib中,进行显示
//DEL for(y=0; y<nHeight; y++)
//DEL {
//DEL for(x=0; x<nWidth; x++)
//DEL {
//DEL pDib->m_lpImage[y*nSaveWidth+x] = pUnchImage[y*nWidth+x];
//DEL }
//DEL }
//DEL
//DEL // 释放内存
//DEL delete []pUnchImage;
//DEL pUnchImage = NULL ;
//DEL
//DEL // 恢复光标形状
//DEL EndWaitCursor();
//DEL
//DEL // 设置脏标记
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新视图
//DEL pDoc->UpdateAllViews(NULL);
//DEL }
/*************************************************************************
*
* \函数名称:
* OnEnhanceButtHight()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 该函数利用Butterworth高通滤波实现图象平滑
*
************************************************************************
*/
//DEL void CImageProcessingView::OnEnhanceButtHight()
//DEL {
//DEL //更改光标形状
//DEL BeginWaitCursor();
//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 int y;
//DEL int x;
//DEL
//DEL CSize sizeImage = pDib->GetDimensions();
//DEL int nWidth = sizeImage.cx ;
//DEL int nHeight= sizeImage.cy ;
//DEL
//DEL int nSaveWidth = pDib->GetDibSaveDim().cx;
//DEL
//DEL // 开辟内存,存储图象数据,该数据的存储不是DWORD对齐的
//DEL unsigned char * pUnchImage = new unsigned char[nWidth*nHeight];
//DEL
//DEL for(y=0; y<nHeight; y++)
//DEL {
//DEL for(x=0; x<nWidth; x++)
//DEL {
//DEL pUnchImage[y*nWidth+x] = pDib->m_lpImage[y*nSaveWidth+x];
//DEL }
//DEL }
//DEL
//DEL // 调用ButterWorth高通滤波函数进行图象增强
//DEL ButterWorthHighPass(pUnchImage, nWidth, nHeight, nWidth/2) ;
//DEL
//DEL // 增强以后的图象拷贝到pDib中,进行显示
//DEL for(y=0; y<nHeight; y++)
//DEL {
//DEL for(x=0; x<nWidth; x++)
//DEL {
//DEL pDib->m_lpImage[y*nSaveWidth+x] = pUnchImage[y*nWidth+x];
//DEL }
//DEL }
//DEL
//DEL // 释放内存
//DEL delete []pUnchImage;
//DEL pUnchImage = NULL ;
//DEL
//DEL // 恢复光标形状
//DEL EndWaitCursor();
//DEL
//DEL // 设置脏标记
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新视图
//DEL pDoc->UpdateAllViews(NULL);
//DEL
//DEL }
/*************************************************************************
*
* \函数名称:
* OnRegionsegFix()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 实现并行区域分割
*
************************************************************************
*/
//DEL void CImageProcessingView::OnRegionsegFix()
//DEL {
//DEL // TODO: Add your command handler code here
//DEL
//DEL //更改光标形状
//DEL BeginWaitCursor();
//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 RegionSegFixThreshold(pDib,200);
//DEL
//DEL // 恢复光标形状
//DEL EndWaitCursor();
//DEL
//DEL // 设置脏标记
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新视图
//DEL pDoc->UpdateAllViews(NULL);
//DEL }
/*************************************************************************
*
* \函数名称:
* OnAdaRegionSeg()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 实现自适应区域分割算法
*
************************************************************************
*/
//DEL void CImageProcessingView::OnAdaRegionSeg()
//DEL {
//DEL // TODO: Add your command handler code here
//DEL
//DEL //更改光标形状
//DEL BeginWaitCursor();
//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 RegionSegAdaptive(pDib);
//DEL
//DEL // 恢复光标形状
//DEL EndWaitCursor();
//DEL
//DEL // 设置脏标记
//DEL pDoc->SetModifiedFlag(TRUE);
//DEL
//DEL // 更新视图
//DEL pDoc->UpdateAllViews(NULL);
//DEL
//DEL }
/*************************************************************************
*
* \函数名称:
* OnEdgeRoberts()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 实现并行边界分割-Roberts算子
*
************************************************************************
*/
//DEL void CImageProcessingView::OnEdgeRoberts()
//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 pImageData = pDib->m_lpImage;
//DEL
//DEL // 图像在计算机在存储中的实际大小
//DEL CSize sizeImageSave = pDib->GetDibSaveDim();
//DEL
//DEL // 图像在内存中每一行象素占用的实际空间
//DEL int nSaveWidth = sizeImageSave.cx;
//DEL
//DEL // 应用Roberts算子求梯度
//DEL RobertsOperator(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 *( pImageData+y*nSaveWidth+x )=0;
//DEL else
//DEL *( pImageData+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 }
/*************************************************************************
*
* \函数名称:
* OnEdgeSobel()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 实现并行边界分割-Sobel算子
*
************************************************************************
*/
//DEL void CImageProcessingView::OnEdgeSobel()
//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 // 应用Sobel算子求梯度
//DEL SobelOperator(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 }
/*************************************************************************
*
* \函数名称:
* OnEdgePrewitt()
*
* \输入参数:
* 无
*
* \返回值:
* 无
*
* \说明:
* 实现并行边界分割-Prewitt算子
*
************************************************************************
*/
//DEL void CImageProcessingView::OnEdgePrewitt()
//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;
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -