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

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

?? mainfrm.cpp

?? 數字圖像處理
?? 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一区二区三区免费野_久草精品视频
欧美性感一类影片在线播放| 奇米色777欧美一区二区| 国产91精品一区二区麻豆网站| 亚洲人成在线观看一区二区| 国产日韩欧美电影| 精品国产乱码久久久久久浪潮| 日韩视频免费观看高清完整版| 欧美一区二区三级| 国产91丝袜在线观看| 国产精品久久久久影院亚瑟| 91精品国产综合久久久久久久久久 | 国产精品久久久久一区| 欧美zozozo| 精品播放一区二区| 国产目拍亚洲精品99久久精品| 欧美卡1卡2卡| 国产精品99久久久久久有的能看 | 久久久av毛片精品| 久久久午夜精品| 欧美国产国产综合| 亚洲欧美偷拍另类a∨色屁股| 亚洲免费成人av| 日韩主播视频在线| 国产一区二区美女| www.欧美日韩| 欧美日韩国产乱码电影| 91在线精品一区二区三区| 天涯成人国产亚洲精品一区av| 日韩一区二区三区电影在线观看| 成人精品视频网站| 蜜臀精品一区二区三区在线观看| 国产一区二区三区黄视频| 日韩天堂在线观看| 91精品啪在线观看国产60岁| 欧美群妇大交群中文字幕| 欧美视频在线一区二区三区| 高清在线成人网| 一区二区三区自拍| 午夜精品福利一区二区蜜股av| 亚洲欧美日韩久久精品| 亚洲综合丁香婷婷六月香| 亚洲最色的网站| 婷婷中文字幕综合| 美女看a上一区| 国产真实乱对白精彩久久| 福利电影一区二区三区| eeuss影院一区二区三区| 成人免费高清视频在线观看| 色婷婷av久久久久久久| 色88888久久久久久影院按摩| 91女神在线视频| 欧美午夜精品久久久| 91精品欧美久久久久久动漫 | 欧美日韩国产片| 亚洲精品一区二区在线观看| 一本大道久久a久久精二百| av一二三不卡影片| 欧美探花视频资源| 欧美成人三级在线| 欧美电视剧在线看免费| 国产午夜精品一区二区三区嫩草| 亚洲同性gay激情无套| 三级影片在线观看欧美日韩一区二区 | 国产伦理精品不卡| 狠狠狠色丁香婷婷综合激情| 成人午夜私人影院| 欧美日产国产精品| 国产午夜亚洲精品午夜鲁丝片| 亚洲精品日韩综合观看成人91| 日韩二区三区四区| 国产尤物一区二区| www.欧美色图| 日韩欧美国产成人一区二区| 国产精品每日更新在线播放网址 | 亚洲国产日韩精品| 精品系列免费在线观看| 99re热这里只有精品免费视频| 制服丝袜国产精品| 欧美精品一区二区蜜臀亚洲| 亚洲精品国产视频| 国产真实乱对白精彩久久| 欧美在线一区二区三区| 久久久99精品免费观看| 欧美一二三区精品| 亚洲精品乱码久久久久久久久| 国内精品久久久久影院色| 99精品偷自拍| 久久久亚洲午夜电影| 日韩中文字幕一区二区三区| 国产白丝网站精品污在线入口| 欧美日韩国产在线观看| 国产精品电影院| 精品一区二区三区视频| 欧美私模裸体表演在线观看| 国产精品久久777777| 亚洲电影你懂得| 日本久久一区二区三区| 国产精品进线69影院| 成人av资源站| 国产欧美日韩三级| 丁香激情综合国产| 2023国产一二三区日本精品2022| 一区二区三区精品在线观看| 日本精品免费观看高清观看| 中文字幕亚洲在| 国产v日产∨综合v精品视频| 欧美α欧美αv大片| 亚洲色图欧美在线| 成人激情文学综合网| 国产欧美日韩另类视频免费观看| 国产成人激情av| 国产亚洲成年网址在线观看| 成人午夜免费av| 国产精品久久久久三级| 成人深夜视频在线观看| 一区二区中文字幕在线| 99国产精品久久久久久久久久 | 夜夜夜精品看看| 91久久线看在观草草青青| 亚洲午夜电影在线观看| 欧美性色欧美a在线播放| 综合电影一区二区三区 | 日日嗨av一区二区三区四区| 欧美日韩国产一级片| 蜜臀va亚洲va欧美va天堂 | www成人在线观看| 久久99国产精品麻豆| 久久综合av免费| 国产成人在线影院| 欧美v日韩v国产v| 成人18视频日本| 亚洲人成人一区二区在线观看| 欧美日本在线看| 免费在线成人网| 欧美一区2区视频在线观看| 久久99精品视频| 久久精品人人爽人人爽| 波多野洁衣一区| 亚洲精品视频在线看| 欧美性做爰猛烈叫床潮| 日本一不卡视频| 精品91自产拍在线观看一区| 白白色 亚洲乱淫| 亚洲青青青在线视频| 欧美一区二区三区影视| 精品一区免费av| 欧美v国产在线一区二区三区| 成人精品国产免费网站| 一区二区三区国产精华| 久久综合狠狠综合久久综合88| 成人午夜电影网站| 偷拍亚洲欧洲综合| 精品粉嫩超白一线天av| 床上的激情91.| 亚洲国产sm捆绑调教视频 | 日韩精品一区二| 成人涩涩免费视频| 偷拍日韩校园综合在线| 精品精品国产高清a毛片牛牛| 免费高清在线一区| 成人欧美一区二区三区| 欧美精品xxxxbbbb| 91偷拍与自偷拍精品| 免费人成网站在线观看欧美高清| 日韩一卡二卡三卡四卡| av一二三不卡影片| 日本不卡一二三区黄网| 亚洲精品ww久久久久久p站| 91精品国产手机| 91极品视觉盛宴| 国产一区二区三区四区五区入口 | 国产成a人亚洲| 一区二区三区四区不卡在线| 欧美精品一区二区蜜臀亚洲| 色婷婷av一区二区三区gif| 国产麻豆9l精品三级站| 亚洲一级片在线观看| 日韩精品一区二区三区老鸭窝| 91丨九色丨尤物| 精品亚洲成a人在线观看| 午夜精品福利视频网站| 亚洲欧洲av在线| 日韩美女在线视频| 精品视频123区在线观看| 久久99久久久久| 亚洲午夜久久久久久久久电影网 | 亚洲精品在线电影| 日韩一级高清毛片| 在线免费观看不卡av| www.日韩精品| 国产美女娇喘av呻吟久久 | 成人在线综合网| 免费观看成人av| 日韩va欧美va亚洲va久久| 亚洲天堂2016| 1024精品合集| 国产精品拍天天在线| 在线视频欧美精品| 色拍拍在线精品视频8848| 粉嫩aⅴ一区二区三区四区五区|