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

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

?? dipdoc.cpp

?? VC++實際編程的源代碼 多種圖像邊緣檢測與分割處理
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
	// 更改光標形狀
	BeginWaitCursor();
	
	if (PointOperation.GetMixedChannel(blue))
	{
		POSITION posTemplate = pApp->GetFirstDocTemplatePosition();
		CDocTemplate* pDocTemplate = pApp->GetNextDocTemplate(posTemplate);
		
		CDipDoc* pDocument = (CDipDoc*) pDocTemplate->OpenDocumentFile(NULL);
		pDocument->m_pDibObject = blue;
		pDocument->m_bImageLoaded = TRUE;
		CString sSplitCaption;
		AfxFormatString1(sSplitCaption, IDS_SPLIT_BLUE_CAPTION, GetTitle());
		pDocument->SetTitle(sSplitCaption);

		//獲取子框架窗口指針
		CChildFrame *pChild = (CChildFrame *) pFrame->MDIGetActive();
		pChild->m_nWidth = m_pDibObject->GetWidth(); 
		pChild->m_nHeight = m_pDibObject->GetHeight();
		pChild->SetWindowPos( NULL, 0, 0, pChild->m_nWidth + 12, 
			pChild->m_nHeight + 38, SWP_NOZORDER | SWP_NOMOVE );

		pDocument->UpdateAllViews(NULL);
		
	}
	else
		AfxMessageBox(IDS_FAIL_SPLIT);
	
	// 恢復光標
	EndWaitCursor();
}

void CDipDoc::OnChannelGreen() 
{
	//獲取應用程序類指針
	CDipApp *pApp = GetApp();
	//獲取主框架窗口指針
	CMainFrame *pFrame = GetMainFrame();

	CDibObject *green = new CDibObject(m_pDibObject);
	
	//創建點處理CPointPro類對象
	CPointPro PointOperation( m_pDibObject );
	
	// 更改光標形狀
	BeginWaitCursor();
	
	if (PointOperation.GetMixedChannel(green))
	{
		POSITION posTemplate = pApp->GetFirstDocTemplatePosition();
		CDocTemplate* pDocTemplate = pApp->GetNextDocTemplate(posTemplate);
		
		CDipDoc* pDocument = (CDipDoc*) pDocTemplate->OpenDocumentFile(NULL);
		pDocument->m_pDibObject = green;
		pDocument->m_bImageLoaded = TRUE;
		CString sSplitCaption;
		AfxFormatString1(sSplitCaption, IDS_SPLIT_GREEN_CAPTION, GetTitle());
		pDocument->SetTitle(sSplitCaption);

		//獲取子框架窗口指針
		CChildFrame *pChild = (CChildFrame *) pFrame->MDIGetActive();
		pChild->m_nWidth = m_pDibObject->GetWidth(); 
		pChild->m_nHeight = m_pDibObject->GetHeight();
		pChild->SetWindowPos( NULL, 0, 0, pChild->m_nWidth + 12, 
			pChild->m_nHeight + 38, SWP_NOZORDER | SWP_NOMOVE );

		pDocument->UpdateAllViews(NULL);
		
	}
	else
		AfxMessageBox(IDS_FAIL_SPLIT);
	
	// 恢復光標
	EndWaitCursor();
}

void CDipDoc::OnChannelMixed() 
{
	//獲取應用程序類指針
	CDipApp *pApp = GetApp();
	//獲取主框架窗口指針
	CMainFrame *pFrame = GetMainFrame();

	CDibObject *mixed = new CDibObject(m_pDibObject);
	
	//創建點處理CPointPro類對象
	CPointPro PointOperation( m_pDibObject );
	
	// 更改光標形狀
	BeginWaitCursor();
	
	if (PointOperation.GetMixedChannel(mixed))
	{
		POSITION posTemplate = pApp->GetFirstDocTemplatePosition();
		CDocTemplate* pDocTemplate = pApp->GetNextDocTemplate(posTemplate);
		
		CDipDoc* pDocument = (CDipDoc*) pDocTemplate->OpenDocumentFile(NULL);
		pDocument->m_pDibObject = mixed;
		pDocument->m_bImageLoaded = TRUE;
		CString sSplitCaption;
		AfxFormatString1(sSplitCaption, IDS_SPLIT_MIXED_CAPTION, GetTitle());
		pDocument->SetTitle(sSplitCaption);

		//獲取子框架窗口指針
		CChildFrame *pChild = (CChildFrame *) pFrame->MDIGetActive();
		pChild->m_nWidth = m_pDibObject->GetWidth(); 
		pChild->m_nHeight = m_pDibObject->GetHeight();
		pChild->SetWindowPos( NULL, 0, 0, pChild->m_nWidth + 12, 
			pChild->m_nHeight + 38, SWP_NOZORDER | SWP_NOMOVE );

		pDocument->UpdateAllViews(NULL);
		
	}
	else
		AfxMessageBox(IDS_FAIL_SPLIT);
	
	// 恢復光標
	EndWaitCursor();
}

void CDipDoc::OnChannelRed() 
{
	//獲取應用程序類指針
	CDipApp *pApp = GetApp();
	//獲取主框架窗口指針
	CMainFrame *pFrame = GetMainFrame();

	CDibObject *red = new CDibObject(m_pDibObject);
	
	//創建點處理CPointPro類對象
	CPointPro PointOperation( m_pDibObject );
	
	// 更改光標形狀
	BeginWaitCursor();
	
	if (PointOperation.GetMixedChannel(red))
	{
		POSITION posTemplate = pApp->GetFirstDocTemplatePosition();
		CDocTemplate* pDocTemplate = pApp->GetNextDocTemplate(posTemplate);
		
		CDipDoc* pDocument = (CDipDoc*) pDocTemplate->OpenDocumentFile(NULL);
		pDocument->m_pDibObject = red;
		pDocument->m_bImageLoaded = TRUE;
		CString sSplitCaption;
		AfxFormatString1(sSplitCaption, IDS_SPLIT_RED_CAPTION, GetTitle());
		pDocument->SetTitle(sSplitCaption);

		//獲取子框架窗口指針
		CChildFrame *pChild = (CChildFrame *) pFrame->MDIGetActive();
		pChild->m_nWidth = m_pDibObject->GetWidth(); 
		pChild->m_nHeight = m_pDibObject->GetHeight();
		pChild->SetWindowPos( NULL, 0, 0, pChild->m_nWidth + 12, 
			pChild->m_nHeight + 38, SWP_NOZORDER | SWP_NOMOVE );

		pDocument->UpdateAllViews(NULL);
		
	}
	else
		AfxMessageBox(IDS_FAIL_SPLIT);
	
	// 恢復光標
	EndWaitCursor();
}

void CDipDoc::OnUpdateChannelGreen(CCmdUI* pCmdUI) 
{
	pCmdUI->Enable(m_pDibObject->GetNumBits() >= 8);
}

void CDipDoc::OnUpdateChannelMixed(CCmdUI* pCmdUI) 
{
	pCmdUI->Enable(m_pDibObject->GetNumBits() >= 8);
}

void CDipDoc::OnUpdateChannelRed(CCmdUI* pCmdUI) 
{
	pCmdUI->Enable(m_pDibObject->GetNumBits() >= 8);
}

void CDipDoc::OnUpdateChannelBlue(CCmdUI* pCmdUI) 
{
	pCmdUI->Enable(m_pDibObject->GetNumBits() >= 8);
}

void CDipDoc::OnUpdateChannelSplit(CCmdUI* pCmdUI) 
{
	pCmdUI->Enable(m_pDibObject->GetNumBits() >= 8);
}

void CDipDoc::OnUpdatePointThre(CCmdUI* pCmdUI) 
{
	//判斷當前是否有圖像對象
	if( m_pDibObject == NULL ) return;
	
	//在點處理CPointPro類中創建用來繪制直方圖的數據
	CPointPro PointOperation( m_pDibObject );

	//判斷是否為256色灰度圖像
	pCmdUI->Enable(PointOperation.IsGray256());
}

void CDipDoc::OnUpdatePointPseudocolor(CCmdUI* pCmdUI) 
{
	//判斷當前是否有圖像對象
	if( m_pDibObject == NULL ) return;
	
	//在點處理CPointPro類中創建用來繪制直方圖的數據
	CPointPro PointOperation( m_pDibObject );

	//判斷是否為256色灰度圖像
	pCmdUI->Enable(PointOperation.IsGray256());
}

void CDipDoc::OnEdgeTrace() 
{
	//創建點處理CPointPro類對象
	CAreaPro AreaPro( m_pDibObject );
	// 更改光標形狀
	BeginWaitCursor();

	AreaPro.EdgeTracing();

	// 恢復光標
	EndWaitCursor();
	
	// 更新視圖
	UpdateAllViews(NULL);
}

void CDipDoc::OnEdgeContour() 
{
	//創建點處理CPointPro類對象
	CAreaPro AreaPro( m_pDibObject );
	// 更改光標形狀
	BeginWaitCursor();

	AreaPro.ContourPickUp();

	// 恢復光標
	EndWaitCursor();
	
	// 更新視圖
	UpdateAllViews(NULL);
}

void CDipDoc::OnEdgeFill() 
{
	//創建種子填充方式選擇對話框
	CDlgSeedFill seedfill;
	if(seedfill.DoModal() == IDOK)
	{
		//創建點處理CPointPro類對象
		CAreaPro AreaPro( m_pDibObject );
		// 更改光標形狀
		BeginWaitCursor();
		//選擇種子填充方法
		if(seedfill.m_iSeedMethod == 0)
			AreaPro.Feeding1();
		else
			AreaPro.Feeding2();
		// 恢復光標
		EndWaitCursor();
		
		// 更新視圖
		UpdateAllViews(NULL);
	}
}

void CDipDoc::OnUpdateEdgeTrace(CCmdUI* pCmdUI) 
{
	//創建點處理CPointPro類對象
	CPointPro PointOperation( m_pDibObject );	
	pCmdUI->Enable(PointOperation.IsBlackandWhite256());
}

void CDipDoc::OnUpdateEdgeContour(CCmdUI* pCmdUI) 
{
	//創建點處理CPointPro類對象
	CPointPro PointOperation( m_pDibObject );	
	pCmdUI->Enable(PointOperation.IsBlackandWhite256());
}

void CDipDoc::OnDetectMinus() 
{
	// TODO: Add your command handler code here
	//模板圖像數據指針
	unsigned char *pBitsTemp;

	static int nIndex = 1;

	CFileDialog FileDlg( TRUE, NULL, NULL, OFN_HIDEREADONLY, szFilter );
	FileDlg.m_ofn.nFilterIndex = (DWORD) nIndex;

	if( FileDlg.DoModal() == IDOK )
	{
		CString strPathName = FileDlg.GetPathName();
		nIndex = (int) FileDlg.m_ofn.nFilterIndex;

		//設置等待光標
		BeginWaitCursor();

		CDibObject *pTemplate = new CDibObject( strPathName.GetBuffer(3) );

		//取消等待光標
		EndWaitCursor();

		//讀入圖像文件失敗
		if( pTemplate == NULL )
		{
			AfxMessageBox("無法創建差影模板圖像類對象!");
			//返回FALSE
			return;
		}

		//在點處理CPointPro類中創建用來繪制直方圖的數據
		CPointPro PointOperation( pTemplate );
		
		//判斷是否為256色灰度圖像
		if(!PointOperation.IsGray256())
		{
			AfxMessageBox("差影模板圖像不是256級灰度圖像,無法進行操作!");
			//返回FALSE
			return;
		}

		//原始圖像大小
		int nOldWidth = m_pDibObject->GetWidth();
		int nOldHeight = m_pDibObject->GetHeight();
		
		//模板圖像大小
		int nTempWidth = pTemplate->GetWidth();
		int nTempHeight = pTemplate->GetHeight();
		
		CRect rectOld(0, 0, nOldWidth, nOldHeight);
		CRect rectTemp(0, 0, nTempWidth, nTempHeight);
		
		//兩個圖像的大小應一致
		if (rectOld != rectTemp)
		{
			AfxMessageBox("模板圖像和原圖像大小不一致,無法完成操作!");
			return;
		}

		//創建點處理CPointPro類對象
		CAreaPro AreaPro1( pTemplate );
		// 更改光標形狀
		BeginWaitCursor();
		
		pBitsTemp = AreaPro1.GetBitsPointer();
		
		// 恢復光標
		EndWaitCursor();

		//創建點處理CPointPro類對象
		CAreaPro AreaPro2( m_pDibObject );

		// 更改光標形狀
		BeginWaitCursor();
		
		AreaPro2.Minusing(pBitsTemp);
		
		// 恢復光標
		EndWaitCursor();
		
		// 更新視圖
		UpdateAllViews(NULL);
		
	}
}

void CDipDoc::OnUpdateDetectMinus(CCmdUI* pCmdUI) 
{
	//判斷當前是否有圖像對象
	if( m_pDibObject == NULL ) return;
	
	//在點處理CPointPro類中創建用來繪制直方圖的數據
	CPointPro PointOperation( m_pDibObject );

	//判斷是否為256色灰度圖像
	pCmdUI->Enable(PointOperation.IsGray256());
}

void CDipDoc::OnDetectTemplate() 
{
	// TODO: Add your command handler code here
	CDibObject *pTemplate;
	static int nIndex = 1;

	CFileDialog FileDlg( TRUE, NULL, NULL, OFN_HIDEREADONLY, szFilter );
	FileDlg.m_ofn.nFilterIndex = (DWORD) nIndex;

	if( FileDlg.DoModal() == IDOK )
	{
		CString strPathName = FileDlg.GetPathName();
		nIndex = (int) FileDlg.m_ofn.nFilterIndex;

		//設置等待光標
		BeginWaitCursor();

		pTemplate = new CDibObject( strPathName.GetBuffer(3) );

		//取消等待光標
		EndWaitCursor();

		//讀入圖像文件失敗
		if( pTemplate == NULL )
		{
			AfxMessageBox("無法創建匹配模板圖像類對象!");
			//返回FALSE
			return;
		}

		//在點處理CPointPro類中創建用來繪制直方圖的數據
		CPointPro PointOperation( pTemplate );
		
		//判斷是否為256色灰度圖像
		if(!PointOperation.IsGray256())
		{
			AfxMessageBox("匹配模板圖像不是256級灰度圖像,無法進行操作!");
			//返回FALSE
			return;
		}

		//原始圖像大小
		int nOldWidth = m_pDibObject->GetWidth();
		int nOldHeight = m_pDibObject->GetHeight();
		
		//模板圖像大小
		int nTempWidth = pTemplate->GetWidth();
		int nTempHeight = pTemplate->GetHeight();
		
		//兩個圖像的大小應一致
		if (nTempWidth > nOldWidth || nTempHeight > nOldHeight)
		{
			AfxMessageBox("模板圖像太大,無法完成操作!");
			return;
		}

		//創建點處理CPointPro類對象
		CAreaPro AreaPro( m_pDibObject );
		// 更改光標形狀
		BeginWaitCursor();
		
		AreaPro.TemplateMatch(pTemplate);
		
		// 恢復光標
		EndWaitCursor();
		
		// 更新視圖
		UpdateAllViews(NULL);
	}
}

void CDipDoc::OnUpdateDetectTemplate(CCmdUI* pCmdUI) 
{
	//判斷當前是否有圖像對象
	if( m_pDibObject == NULL ) return;
	
	//在點處理CPointPro類中創建用來繪制直方圖的數據
	CPointPro PointOperation( m_pDibObject );

	//判斷是否為256色灰度圖像
	pCmdUI->Enable(PointOperation.IsGray256());
}

void CDipDoc::OnDetectProject() 
{
	//創建投影模式選擇對話框
	CDlgProject projectmode;
	if(projectmode.DoModal() == IDOK)
	{
		//創建點處理CPointPro類對象
		CAreaPro AreaPro( m_pDibObject );
		// 更改光標形狀
		BeginWaitCursor();
		//選擇投影模式
		if(projectmode.m_iProjectMode == 0)
			AreaPro.ProjectH();
		else
			AreaPro.ProjectV();
		// 恢復光標
		EndWaitCursor();
		
		// 更新視圖
		UpdateAllViews(NULL);
	}
}

void CDipDoc::OnUpdateDetectProject(CCmdUI* pCmdUI) 
{
	//創建點處理CPointPro類對象
	CPointPro PointOperation( m_pDibObject );
	//只對8位二值圖像起作用
	pCmdUI->Enable(PointOperation.IsBlackandWhite256());
}

void CDipDoc::OnUpdateEdgeFill(CCmdUI* pCmdUI) 
{
	//創建點處理CPointPro類對象
	CPointPro PointOperation( m_pDibObject );
	//只對8位二值圖像起作用
	pCmdUI->Enable(PointOperation.IsBlackandWhite256());
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久99热国产| 亚洲日本乱码在线观看| 国产精品久久久久7777按摩| 亚洲女同女同女同女同女同69| 亚洲综合小说图片| 久久成人免费电影| 丁香婷婷综合激情五月色| 91在线国产观看| 欧美一区二区视频免费观看| 久久综合九色综合久久久精品综合| 国产精品盗摄一区二区三区| 日韩—二三区免费观看av| 国产成人av电影在线播放| 欧美伊人久久久久久午夜久久久久| 日韩美女一区二区三区四区| 亚洲特黄一级片| 老司机一区二区| 91老师片黄在线观看| 日韩午夜激情视频| 日本美女视频一区二区| 成人伦理片在线| 制服视频三区第一页精品| 欧美国产日韩a欧美在线观看 | 日本电影欧美片| 欧美精品一区二区三区四区| 亚洲乱码一区二区三区在线观看| 老鸭窝一区二区久久精品| 91成人免费网站| 国产日韩三级在线| 五月婷婷另类国产| 91免费国产在线| 精品成人a区在线观看| 亚洲国产裸拍裸体视频在线观看乱了 | 成人国产亚洲欧美成人综合网| 欧美人体做爰大胆视频| 国产精品久久久久久亚洲伦 | 精品久久国产字幕高潮| 洋洋成人永久网站入口| 成人一区二区视频| 精品国产一区二区精华 | 日韩欧美中文字幕制服| 亚洲色图一区二区三区| 成人一区二区三区视频| 欧美xxxxxxxxx| 婷婷开心激情综合| 91成人在线观看喷潮| 国产精品国产馆在线真实露脸 | 欧美激情一区在线观看| 蜜臀精品一区二区三区在线观看| 91久久精品国产91性色tv| 国产欧美久久久精品影院| 久久成人18免费观看| 在线观看av一区二区| 亚洲男女毛片无遮挡| 成人av片在线观看| 国产午夜精品一区二区| 国产在线日韩欧美| 精品久久久久久久久久久久久久久 | 国产成人av一区| 精品少妇一区二区三区在线播放| 午夜国产不卡在线观看视频| 欧美亚洲愉拍一区二区| 亚洲女女做受ⅹxx高潮| 91在线观看下载| 国产精品国产馆在线真实露脸| 国产成人亚洲精品狼色在线 | 成人av影视在线观看| 国产无遮挡一区二区三区毛片日本| 久久精品国产精品青草| 日韩欧美激情一区| 蜜臀va亚洲va欧美va天堂| 日韩一区二区三区在线视频| 免费美女久久99| 精品福利一二区| 狠狠v欧美v日韩v亚洲ⅴ| 精品日韩在线一区| 国产精品一二三四五| 中文字幕不卡的av| av资源网一区| 亚洲女女做受ⅹxx高潮| 欧美日韩一区 二区 三区 久久精品| 亚洲一区中文日韩| 欧美日韩不卡一区二区| 奇米影视在线99精品| 欧美大度的电影原声| 国产一区二区中文字幕| 中文字幕久久午夜不卡| 99国产欧美久久久精品| 亚洲另类一区二区| 欧美日韩精品一区二区三区四区 | 91啪亚洲精品| 有坂深雪av一区二区精品| 在线亚洲精品福利网址导航| 亚洲成人动漫精品| 日韩视频在线你懂得| 国内精品不卡在线| 国产精品美女久久久久久2018 | 亚洲高清免费在线| 欧美一区二区三区男人的天堂| 久草热8精品视频在线观看| 久久久精品蜜桃| 91免费小视频| 午夜不卡在线视频| 久久综合九色综合97_久久久| 国产xxx精品视频大全| 亚洲男人的天堂在线aⅴ视频| 欧美日韩中文字幕一区二区| 精品一区二区三区av| 国产精品嫩草影院av蜜臀| 欧美性猛交一区二区三区精品 | 国产人伦精品一区二区| 色综合久久久久综合体| 日韩不卡手机在线v区| 国产日韩av一区| 在线精品观看国产| 麻豆91精品视频| 国产精品久久久久久户外露出| 欧美午夜不卡视频| 国产精品自拍三区| 亚洲国产欧美一区二区三区丁香婷| 日韩欧美一区二区三区在线| 成人亚洲一区二区一| 亚洲午夜在线电影| 久久精品一区八戒影视| 欧美在线观看禁18| 国内精品伊人久久久久av一坑| 亚洲三级在线观看| 久久综合网色—综合色88| 在线观看日韩一区| 国产盗摄精品一区二区三区在线| 一区二区三区在线视频观看| 久久色视频免费观看| 在线看不卡av| 国产成人免费9x9x人网站视频| 亚洲精品va在线观看| 国产网站一区二区三区| 欧美挠脚心视频网站| 丁香五精品蜜臀久久久久99网站 | 久久久久久久久岛国免费| 欧美三级电影在线看| 不卡欧美aaaaa| 国产一区二区电影| 午夜日韩在线观看| 亚洲天堂久久久久久久| 久久久久九九视频| 欧美一区二区三区思思人| youjizz久久| 国产麻豆欧美日韩一区| 日韩在线a电影| 一区二区三区小说| 国产精品三级久久久久三级| 精品国产乱码久久久久久图片| 欧美在线综合视频| 99精品久久免费看蜜臀剧情介绍| 国产精品一区二区你懂的| 麻豆传媒一区二区三区| 亚洲成人在线观看视频| 亚洲免费资源在线播放| 中文字幕在线不卡一区| 久久综合中文字幕| 精品久久久久久久一区二区蜜臀| 欧美美女一区二区三区| 在线观看一区二区精品视频| 972aa.com艺术欧美| 不卡电影免费在线播放一区| 久久av资源网| 免费在线一区观看| 亚洲h精品动漫在线观看| 亚洲国产一区二区在线播放| 一区二区成人在线| 亚洲免费在线视频| 依依成人综合视频| 亚洲欧美另类综合偷拍| 亚洲欧美电影院| 亚洲欧美成aⅴ人在线观看| 综合久久综合久久| 亚洲免费观看在线视频| 亚洲色图一区二区三区| 亚洲日本乱码在线观看| 亚洲欧美日韩国产手机在线 | 欧美精品三级在线观看| 欧美日韩高清一区二区不卡| 欧美日韩国产高清一区二区| 欧美日韩mp4| 欧美一区二区视频网站| 欧美电影免费观看高清完整版在线| 欧美一级一区二区| 精品日产卡一卡二卡麻豆| 精品国产污污免费网站入口 | 国产成人丝袜美腿| 狠狠色狠狠色综合系列| 韩国成人在线视频| 国产91丝袜在线播放九色| 国产成人精品一区二区三区四区| 精品视频全国免费看| 欧美日韩高清一区二区三区| 日韩一区二区在线播放| 久久久亚洲高清| 国产精品毛片高清在线完整版| 亚洲视频一区二区免费在线观看|