亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? imageprocessingview.cpp

?? 這是一個關于圖像邊緣檢測的小程序
?? 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 + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美视频一区二| 欧美激情在线看| 成人免费精品视频| 成人免费视频在线观看| 成人免费一区二区三区视频| 亚洲国产精品自拍| 国产精品亚洲专一区二区三区| 成人性生交大片免费看中文| 99这里只有久久精品视频| 欧美性生活影院| 欧美mv日韩mv国产网站| 中文文精品字幕一区二区| 亚洲日本青草视频在线怡红院| 亚洲大片精品永久免费| 国产乱码一区二区三区| 在线观看区一区二| 久久久www成人免费无遮挡大片 | 成人动漫精品一区二区| 在线看国产一区二区| 久久久精品tv| 爽好多水快深点欧美视频| 亚洲欧美激情在线| 精品一区二区在线视频| 91视频免费看| 中文成人av在线| 亚洲福中文字幕伊人影院| 成人午夜激情影院| 欧美成人a在线| 婷婷综合另类小说色区| av在线一区二区三区| 26uuu国产日韩综合| 天堂久久一区二区三区| 91亚洲永久精品| 欧美国产日本韩| 久久精品av麻豆的观看方式| 亚洲欧美一区二区三区国产精品| 久久精品国产网站| 欧美顶级少妇做爰| 亚洲国产毛片aaaaa无费看| 99视频精品全部免费在线| 久久品道一品道久久精品| 日韩激情视频网站| 欧美图区在线视频| 亚洲欧美日韩中文播放| 国产高清亚洲一区| 精品国精品国产尤物美女| 日韩经典一区二区| 在线播放日韩导航| 亚洲伊人色欲综合网| 成人免费毛片嘿嘿连载视频| 国产视频一区二区在线观看| 国产精品一区二区在线播放| 精品国产精品网麻豆系列| 日本三级亚洲精品| 日韩丝袜情趣美女图片| 日本中文字幕一区二区有限公司| 欧美视频中文一区二区三区在线观看| 亚洲精品成a人| 欧美一a一片一级一片| 18成人在线视频| 色呦呦网站一区| 亚洲高清视频在线| 欧美一区二区三区在| 日韩成人一级大片| 日韩精品在线一区| 日韩亚洲欧美一区二区三区| 日本网站在线观看一区二区三区| 欧美一级免费大片| 国产在线视视频有精品| 久久久久久免费毛片精品| 成人一级片网址| 亚洲欧美激情小说另类| 欧美日韩国产综合一区二区三区 | 无吗不卡中文字幕| 91精品国产综合久久久久久久 | 国产不卡高清在线观看视频| 亚洲日本中文字幕区| 99精品视频一区| 精品国精品自拍自在线| 成人av动漫网站| 一区二区三区免费在线观看| 91精品国产综合久久福利| 免费在线成人网| 欧美激情一区在线| 欧美在线影院一区二区| 另类成人小视频在线| 中文成人av在线| 欧美日韩高清一区二区| 国产精品一区在线| 一区二区三区中文字幕精品精品| 欧美性猛片aaaaaaa做受| 美女视频黄免费的久久| 国产精品麻豆欧美日韩ww| 欧美日韩国产首页| 久久精品99国产精品日本| 国产精品久久久久一区二区三区 | 国产欧美日韩久久| 91久久精品国产91性色tv| 麻豆91在线播放| 亚洲色图欧美偷拍| 日本精品视频一区二区| 国产一区不卡在线| 午夜a成v人精品| 国产精品欧美一级免费| 色香蕉成人二区免费| 国产一区二区三区免费播放| 一区二区激情小说| 欧美激情一区二区| 日韩午夜激情av| 欧美午夜一区二区三区免费大片| 国产麻豆一精品一av一免费| 五月婷婷综合激情| 亚洲男人电影天堂| 亚洲国产岛国毛片在线| 精品国产三级电影在线观看| 欧美日韩一区二区三区四区| 国产成人夜色高潮福利影视| 日韩成人免费看| 午夜精品福利一区二区蜜股av | 成人听书哪个软件好| 日韩av中文字幕一区二区| 亚洲激情图片一区| 国产精品美女久久福利网站| 欧美成人vps| 日韩欧美在线123| 欧美一区二区视频在线观看2022| 欧美理论电影在线| 欧美日韩成人在线| 欧美日韩久久一区| 日韩欧美在线123| 久久久久久久久久久电影| 欧美激情艳妇裸体舞| 国产精品成人免费| 亚洲午夜久久久久久久久久久| 午夜精品福利视频网站| 久色婷婷小香蕉久久| 国产成人日日夜夜| 色先锋aa成人| 制服.丝袜.亚洲.中文.综合| 精品国产一区a| 日韩理论片在线| 日韩精品电影在线| 国产福利一区二区三区视频| 色综合中文综合网| 欧美一激情一区二区三区| 678五月天丁香亚洲综合网| 日韩区在线观看| 国产精品久久久久影视| 亚洲午夜电影网| 国内精品第一页| 91久久一区二区| 日韩欧美在线观看一区二区三区| 中日韩免费视频中文字幕| 亚洲国产乱码最新视频| 精品一区二区免费在线观看| 99精品久久免费看蜜臀剧情介绍| 欧美性欧美巨大黑白大战| 久久影视一区二区| 亚洲第一久久影院| 国产99精品国产| 欧美伦理电影网| 最新高清无码专区| 久久成人麻豆午夜电影| 91老司机福利 在线| 日韩欧美www| 夜夜嗨av一区二区三区中文字幕 | 亚洲一区二区三区在线| 国产最新精品免费| 欧美日韩激情在线| 国产精品女同一区二区三区| 日产国产欧美视频一区精品| 99久久久无码国产精品| 日韩欧美卡一卡二| 亚洲成人久久影院| 99精品热视频| 国产日韩精品视频一区| 日韩成人午夜精品| 在线看一区二区| 中文字幕一区二区三区在线播放| 久久国产视频网| 91精品免费在线观看| 亚洲欧美日韩系列| 成人av在线电影| 国产亚洲视频系列| 久久精品噜噜噜成人88aⅴ| 在线视频国内自拍亚洲视频| 国产精品久久福利| 国产91精品欧美| 精品久久人人做人人爽| 日韩不卡在线观看日韩不卡视频| 91豆麻精品91久久久久久| 亚洲天堂免费看| 99精品国产99久久久久久白柏| www成人在线观看| 精品一区二区国语对白| 日韩免费观看高清完整版| 午夜精品成人在线| 久久色.com| 国内精品在线播放| 久久亚洲综合色|