⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 imageprocessingview.cpp

📁 基本的数字图象处理的VC++实现,包括反色、拉伸、中值滤波等
💻 CPP
📖 第 1 页 / 共 5 页
字号:
//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 + -