按每帧显示图像
UINT PlayVideo( LPVOID pParam ) { int i;//,j; BOOL bPlay = g_bPlay; BOOL bEof = FALSE; CYUVviewerDlg *pWin = (CYUVviewerDlg *)pParam; UINT picsize = pWin->m_nWidth*pWin->m_nHeight; int timespan = 1000/atoi(pWin->m_sFrameRate); if(g_nCurrentFrame < g_nStartFrame) g_nCurrentFrame = g_nStartFrame; if(g_nCurrentFrame > g_nEndFrame) g_nCurrentFrame = g_nEndFrame; for(i=0; i<pWin->m_iCount; i++) { pWin->m_pFile[i]->Seek(g_nCurrentFrame*picsize*3/2, SEEK_SET); pWin->m_pWnd[i]->nPicShowOrder = g_nCurrentFrame; } HANDLE hPlayTemp1 = OpenMutex(MUTEX_ALL_ACCESS,FALSE,"Play"); while(g_nCurrentFrame >= g_nStartFrame && g_nCurrentFrame <= g_nEndFrame && !bEof) { DWORD t2=GetTickCount(); g_nFrameNumber = g_nCurrentFrame;//j; if ( WAIT_OBJECT_0 == WaitForSingleObject(hPlayTemp1,INFINITE) ) ReleaseMutex( hPlayTemp1 ); for(i=0; i<pWin->m_iCount; i++) { pWin->m_pFile[i]->Seek(g_nCurrentFrame*picsize*3/2, SEEK_SET); if(picsize != pWin->m_pFile[i]->Read(pWin->m_pWnd[i]->Y,picsize)) { AfxMessageBox("Get to end of file"); bEof = TRUE; break; } if(1)//bColorImage) { if(picsize/4 != pWin->m_pFile[i]->Read(pWin->m_pWnd[i]->Cb,picsize/4)) { AfxMessageBox("Get to end of file"); bEof = TRUE; break; } if(picsize/4 != pWin->m_pFile[i]->Read(pWin->m_pWnd[i]->Cr,picsize/4)) { AfxMessageBox("Get to end of file"); bEof = TRUE; break; } } pWin->m_pWnd[i]->InvalidateRect (NULL,FALSE); pWin->m_pWnd[i]->UpdateWindow (); pWin->m_pWnd[i]->nPicShowOrder=g_nCurrentFrame; } if(g_bReversePlay == FALSE) g_nCurrentFrame++; else g_nCurrentFrame--; int t1=GetTickCount()-t2; if(t1 < timespan) Sleep(timespan - t1); // sleep time in milliseconds } pWin->m_pWinThread = NULL; AfxEndThread(0); return 1; }
- 1
- yangxii2012-11-29表示我是初学者,对这段代码还在学习中,不过感觉上传者很认真,谢谢
- wutongye2013-08-24怎么还使用了一种cscc.lib的库文件啊
- 粉丝: 1
- 资源: 72
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- 基于c++的个人收支管理系统设计
- docker一键安装包
- Screenshot_20240430_144340_com.ss.android.ugc.live.jpg
- 回到山沟沟.mp3
- 基于matlab实现自适应波束形成RLS及LMS算法仿真源程序1.rar
- 基于matlab实现自己编写的基于卡尔曼滤波的利用加速度传感器的计步器,测试数据是传感器放在腰部和手臂 .rar
- 基于matlab实现阵列信号处理,波束形成.rar
- 111111111111111111
- 基于matlab实现计步器编程;对当前的计步器装置的数值算法模拟 .rar
- Mdb学习查看PW;access;mdb;pw;password;patch