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

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

?? mainfrm.cpp

?? 上述是VIsualc++ 數字圖像處理一書的源碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// MainFrm.cpp : implementation of the CMainFrame class
//

#include "stdafx.h"
#include "Video Demo.h"
#include "Video demodoc.h"
#include "MainFrm.h"
#include "AVIHandler.h"   // AVI文件處理
#include "colortrans.h"
#include "StaticDetect.h"
#include "ChafenMul.h"
#include "POSDiag.h"
#include "MotionDetectDiag.h"
#include "GravityTrack.h"
#include "GravityCenter.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CMainFrame

IMPLEMENT_DYNCREATE(CMainFrame, CFrameWnd)

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
	//{{AFX_MSG_MAP(CMainFrame)
	ON_WM_CREATE()
	ON_COMMAND(ID_FILE_OPENVIDEO, OnFileOpenvideo)
	ON_COMMAND(ID_MOTION_SD, OnMotionSd)
	ON_COMMAND(ID_MOTION_DD, OnMotionDd)
	ON_COMMAND(ID_TRACEK_MEANSHIFT, OnTracekMeanshift)
	ON_COMMAND(ID_TRACEK_GAV, OnTracekGav)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

static UINT indicators[] =
{
	ID_SEPARATOR,           // status line indicator
	ID_INDICATOR_CAPS,
	ID_INDICATOR_NUM,
	ID_INDICATOR_SCRL,
};

/////////////////////////////////////////////////////////////////////////////
// CMainFrame construction/destruction

CMainFrame::CMainFrame()
{
	// TODO: add member initialization code here
	
}

CMainFrame::~CMainFrame()
{
}

int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
	if (CFrameWnd::OnCreate(lpCreateStruct) == -1)
		return -1;
	
	//if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP
	//	| CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
	//	!m_wndToolBar.LoadToolBar(IDR_MAINFRAME))
//	{
//		TRACE0("Failed to create toolbar\n");
//		return -1;      // fail to create
//	}

	if (!m_wndStatusBar.Create(this) ||
		!m_wndStatusBar.SetIndicators(indicators,
		  sizeof(indicators)/sizeof(UINT)))
	{
		TRACE0("Failed to create status bar\n");
		return -1;      // fail to create
	}

	// TODO: Delete these three lines if you don't want the toolbar to
	//  be dockable
	//m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
//	EnableDocking(CBRS_ALIGN_ANY);
//	DockControlBar(&m_wndToolBar);

	return 0;
}

BOOL CMainFrame::PreCreateWindow(CREATESTRUCT& cs)
{
	if( !CFrameWnd::PreCreateWindow(cs) )
		return FALSE;
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return TRUE;
}

/************************************************************************/
/* OnOpenOpenVideo                                                      */
/* 打開AVI視頻文件                                                      */
/* 基于中央數據級控架構													*/
/************************************************************************/
void CMainFrame::OnOpenOpenVideo()
{
	AVIHandler *avi = NULL;

	//添加一路視頻
	//考慮的問題是,如何將參數傳遞,到框架
	CString strFilter("Data Files (*.avi)|*.avi");
	CFileDialog diag(TRUE,NULL,NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,strFilter);
	//打開第一個文件
	int nID = diag.DoModal();
	if(nID == IDOK){
		
		// 新建一個子窗口
		POSITION pos=theApp.m_pDocManager->GetFirstDocTemplatePosition();
		// 取得一個文檔模板,我取的是第一個,你可以去任何一個模板
		CDocTemplate* pDocTempl=theApp.m_pDocManager->GetNextDocTemplate(pos);
		// 通過打開文件的方式獲得一個新窗口,并得到CDocument對象
		CVideoDemoDoc * doc = (CVideoDemoDoc *)pDocTempl->OpenDocumentFile(NULL);//theApp.m_pDocManager->OpenDocumentFile(NULL);

		// 建立視頻數據源
		avi = new AVIHandler(diag.GetFileName());    // 打開AVI文件,AVI RGB
		theApp.curVideo = new VideoData();           // 當前視頻數據源
		theApp.curVideo->doc = doc;
		theApp.curVideo->index = 0;
		theApp.curVideo->ms = (MediaSource*)avi;

		// 設置View的顯示緩沖
		ImageData *id = new ImageData();   
		id->bytes = 3;
		id->coreDoc = doc;
		id->format = IMAGE_FORMAT_RGB24;
		id->imgWidth = avi->GetFrameWidth();
		id->imgHeight = avi->GetFrameHeight();
		id->data = avi->GetSingleFrame(0);                    // 獲得第一幀圖像
		doc->SetData(id);                                     // 設置第一幀圖像

		// 設置文檔和視圖的視頻源數據
		doc->SetVideoSource(theApp.curVideo);                 // 設置Document數據
		doc->RefreshView();						              // 刷新顯示View


	}
}

/////////////////////////////////////////////////////////////////////////////
// CMainFrame diagnostics

#ifdef _DEBUG
void CMainFrame::AssertValid() const
{
	CFrameWnd::AssertValid();
}

void CMainFrame::Dump(CDumpContext& dc) const
{
	CFrameWnd::Dump(dc);
}

#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CMainFrame message handlers

/************************************************************************/
/* 打開視頻文件AVI                                                      */
/************************************************************************/
void CMainFrame::OnFileOpenvideo() 
{
	AVIHandler *avi = NULL;

	//添加一路視頻
	//考慮的問題是,如何將參數傳遞,到框架
	CString strFilter("Data Files (*.avi)|*.avi");
	CFileDialog diag(TRUE,NULL,NULL,OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,strFilter);
	//打開第一個文件
	int nID = diag.DoModal();
	if(nID == IDOK){
		
		// 新建一個子窗口
		POSITION pos=theApp.m_pDocManager->GetFirstDocTemplatePosition();
		// 取得一個文檔模板,我取的是第一個,你可以去任何一個模板
		CDocTemplate* pDocTempl=theApp.m_pDocManager->GetNextDocTemplate(pos);
		// 通過打開文件的方式獲得一個新窗口,并得到CDocument對象
		CVideoDemoDoc * doc = (CVideoDemoDoc *)pDocTempl->OpenDocumentFile(NULL);//theApp.m_pDocManager->OpenDocumentFile(NULL);

		// 建立視頻數據源
		avi = new AVIHandler(diag.GetFileName());    // 打開AVI文件,AVI RGB

		if(!avi->isLoaded())
		{
			AfxMessageBox("打開文件錯誤!");
			return;
		}

		if(avi->GetLPBM()->biBitCount != 24)
		{
			delete avi;
			AfxMessageBox("AVI文件必須是24位非壓縮彩色視頻!");
			return;
		}

		theApp.curVideo = new VideoData();           // 當前視頻數據源
		theApp.curVideo->doc = doc;
		theApp.curVideo->index = 0;
		theApp.curVideo->ms = (MediaSource*)avi;

		// 設置View的顯示緩沖
		ImageData *id = new ImageData();   
		id->bytes = 3;
		id->coreDoc = doc;
		id->format = IMAGE_FORMAT_RGB24;
		id->imgWidth = avi->GetFrameWidth();
		id->imgHeight = avi->GetFrameHeight();
		id->data = avi->GetSingleFrame(0);                    // 獲得第一幀圖像
		doc->SetData(id);                                     // 設置第一幀圖像

		// 設置文檔和視圖的視頻源數據
		doc->SetVideoSource(theApp.curVideo);                 // 設置Document數據
		doc->RefreshView();						              // 刷新顯示View


	}
}

/************************************************************************/
/* 靜止背景目標檢測                                                     */
/************************************************************************/
DWORD WINAPI StaticDetectT(LPVOID data){

	CVideoDemoDoc *doc = (CVideoDemoDoc*)data;

	int frameLength = theApp.curVideo->ms->GetFrameCount();
	MediaSource *avi = theApp.curVideo->ms;

	unsigned char *frame = avi->GetSingleFrame(0);
	int frameWidth = avi->GetFrameWidth();
	int frameHeight = avi->GetFrameHeight();

	// 色彩變換
	ColorTrans ct;

	CStatsticDetect sd(frameWidth,frameHeight);
	

	// 輸出緩沖
	unsigned char * outBuffer = new unsigned char[frameHeight * frameWidth * 3];

	for(int i = 0; i < frameLength - 1; i++)
	{
		// 獲得一幀圖像	
		frame = avi->GetSingleFrame(i);
		// 轉換到灰度圖像
		//ct.RGB2Gray8(frame,grayBuffer,frameWidth,frameHeight);

		sd.ReceiveFrame(i,frame,D_STATISTIC);		
		// 添加一幀數據
		
		ct.gray2RGB2(sd.m_pDiffImage,outBuffer,frameWidth,frameHeight);
		doc->id->data = outBuffer;
		
		doc->RefreshView();
	}


	delete[] outBuffer;
	return 0;

}

/************************************************************************/
/* 靜止背景目標檢測                                                     */
/************************************************************************/
void CMainFrame::OnMotionSd()
{
	DWORD exitCode;
	
	if(GetExitCodeThread(th,&exitCode)){
	   TerminateThread(th,exitCode);
	}

	DWORD pID;
	//控制線程播放

	int frameLength = theApp.curVideo->ms->GetFrameCount();

	MediaSource *avi = theApp.curVideo->ms;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩精品专区在线影院重磅| 51精品国自产在线| 国产美女精品一区二区三区| 日本欧美大码aⅴ在线播放| 亚洲综合一二区| 午夜精品福利一区二区蜜股av| 亚洲一二三四在线观看| 亚洲成人免费电影| 麻豆精品视频在线观看免费| 久久aⅴ国产欧美74aaa| 韩国成人福利片在线播放| 国产高清成人在线| av午夜精品一区二区三区| 色婷婷av久久久久久久| 91精品国产综合久久精品图片 | 亚洲精品一线二线三线无人区| 精品日韩欧美在线| av在线播放不卡| 国模少妇一区二区三区| 成人午夜激情视频| 色婷婷av一区二区三区大白胸| 欧美日韩国产经典色站一区二区三区| 欧美日韩亚洲综合在线| 欧美成人三级电影在线| 国产精品全国免费观看高清| 国产精品国产自产拍在线| 亚洲一区二区欧美激情| 久久se精品一区精品二区| caoporm超碰国产精品| 欧美久久久久久久久中文字幕| 欧美一级久久久久久久大片| 国产精品亲子乱子伦xxxx裸| 亚洲黄色在线视频| 麻豆免费精品视频| av一区二区三区黑人| 欧美一区二区三区四区视频| 国产亚洲一区二区三区在线观看 | 亚洲一级在线观看| 国产一区二区不卡| 91国偷自产一区二区开放时间| 精品国产青草久久久久福利| 一区二区三区蜜桃网| 国产成人av资源| 欧美日韩视频不卡| 中文字幕亚洲视频| 国产成人免费视频| 日韩欧美国产系列| 亚洲午夜精品久久久久久久久| 成人激情av网| 久久午夜老司机| 蜜臀99久久精品久久久久久软件| 色婷婷av一区二区三区gif| 久久精品亚洲乱码伦伦中文| 亚洲电影在线免费观看| 成人毛片在线观看| 欧美一区二区三级| 玉足女爽爽91| 亚洲国产wwwccc36天堂| 成人精品视频网站| 日韩欧美123| 亚洲电影在线播放| 免费在线观看一区| 色噜噜狠狠成人中文综合| 久久综合资源网| 亚洲午夜激情网页| 色综合久久六月婷婷中文字幕| 精品国产一区二区三区久久影院| 国产亚洲视频系列| 国产91精品一区二区麻豆网站 | 国产成人av一区| 制服.丝袜.亚洲.中文.综合| 一区免费观看视频| 国产综合色在线视频区| 91精品国产91热久久久做人人 | 亚洲精品高清视频在线观看| 国产99一区视频免费 | 欧美视频在线不卡| 亚洲国产美女搞黄色| 99久久99久久精品免费看蜜桃| 精品国精品国产| 蜜桃av一区二区三区电影| 欧美撒尿777hd撒尿| 亚洲乱码精品一二三四区日韩在线| 狠狠色伊人亚洲综合成人| 在线电影国产精品| 亚洲成人午夜电影| 91影院在线免费观看| 国产喷白浆一区二区三区| 精品一区二区三区欧美| 日韩午夜在线影院| 免费成人av资源网| 91精品国产日韩91久久久久久| 亚洲第一二三四区| 欧美精品777| 日韩国产精品大片| 精品久久久网站| 国产成人av电影| 亚洲三级电影全部在线观看高清| 国产精品88888| 中文字幕免费不卡| 色综合色综合色综合色综合色综合| 国产精品福利影院| 色婷婷精品大视频在线蜜桃视频| 亚洲欧洲三级电影| 欧美性大战xxxxx久久久| 免费成人在线视频观看| 久久久久久夜精品精品免费| 国产成人亚洲综合a∨婷婷图片 | 国产亚洲自拍一区| 91片黄在线观看| 午夜精品久久一牛影视| 91精品国产高清一区二区三区 | 亚洲三级电影网站| 欧美美女直播网站| 黑人巨大精品欧美一区| 国产精品进线69影院| 在线观看一区不卡| 久久精品理论片| 国产精品电影一区二区| 91国产丝袜在线播放| 亚洲高清视频在线| 国产精品久久久久一区| 欧美天天综合网| 韩国成人在线视频| 亚洲综合av网| 欧美精品一区二区三区在线| aa级大片欧美| 久久99精品国产91久久来源| 亚洲欧洲日产国产综合网| 欧美日韩高清不卡| 成人精品小蝌蚪| 美女免费视频一区| 亚洲男人天堂一区| 精品播放一区二区| 欧美亚洲动漫精品| 国产98色在线|日韩| 日韩和欧美一区二区| 亚洲三级免费电影| 欧美精品一区二区三区视频| av电影一区二区| 狠狠v欧美v日韩v亚洲ⅴ| 亚洲电影一区二区| 中文字幕一区二区三区精华液| 91精品午夜视频| 在线视频一区二区三| 国产精品亚洲成人| 国产精品99久久久久久似苏梦涵| 肉肉av福利一精品导航| ...中文天堂在线一区| 久久精品在这里| 日韩欧美国产wwwww| 在线不卡的av| 欧美影院精品一区| 色综合天天在线| 国产精品中文欧美| 日本最新不卡在线| 亚洲一区二区三区四区五区黄 | 国产精品免费久久久久| 久久久天堂av| 精品国产一区久久| 日韩欧美久久久| 欧美一级片免费看| 91麻豆精品国产自产在线观看一区| 91蜜桃在线免费视频| 成人午夜激情在线| 成人免费av网站| 天天av天天翘天天综合网| 日韩精品1区2区3区| 日本美女一区二区| 免费欧美高清视频| 久久精品999| 国产一区欧美二区| 国产在线乱码一区二区三区| 国内成人免费视频| 国产精品一区三区| 成人精品在线视频观看| jvid福利写真一区二区三区| 成人免费的视频| 色悠久久久久综合欧美99| heyzo一本久久综合| 欧美日韩一卡二卡| 日韩欧美一级二级三级久久久| 日韩午夜av一区| 久久蜜臀中文字幕| 中文字幕一区av| 亚洲永久免费视频| 日韩不卡手机在线v区| 国产尤物一区二区| 国产成人激情av| 91一区二区在线| 欧美裸体bbwbbwbbw| 制服丝袜国产精品| 亚洲色图视频免费播放| 亚洲大尺度视频在线观看| 精品系列免费在线观看| 成人黄色小视频在线观看| 欧美亚洲动漫另类| 91精品国产综合久久婷婷香蕉| 亚洲欧洲无码一区二区三区| 三级亚洲高清视频|