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

📄 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 + -