UB530View.cpp 31 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130
  1. // UB530View.cpp: 实现文件
  2. //
  3. #include "stdafx.h"
  4. #include "SATHelper.h"
  5. #include "UB530View.h"
  6. #include "MainFrm.h"
  7. extern CMemoryClient g_ub530;
  8. extern CMainFrame* g_pMainFrame;
  9. VOID Dbg2(CHAR* pszStr, ...)
  10. {
  11. char szData[MAX_PATH] = "[SC] ";
  12. va_list args;
  13. va_start(args, pszStr);
  14. _vsnprintf_s(szData + 5, MAX_PATH - 5, MAX_PATH - 6, pszStr, args);
  15. va_end(args);
  16. strcat_s(szData, "\n");
  17. OutputDebugStringA(szData);
  18. }
  19. // FORMAT CHANGED CALLBACK FUNCTION
  20. //
  21. QRETURN on_process_format_changed2(PVOID pDevice, ULONG nVideoInput, ULONG nAudioInput, ULONG nVideoWidth, ULONG nVideoHeight, BOOL bVideoIsInterleaved, double dVideoFrameRate, ULONG nAudioChannels, ULONG nAudioBitsPerSample, ULONG nAudioSampleFrequency, PVOID pUserData)
  22. {
  23. //Dbg("format changed Detected \n");
  24. CUB530View* pView = (CUB530View*)pUserData;
  25. if (pView == NULL) { return QCAP_RT_OK; }
  26. if (pView->GetSafeHwnd() == NULL) { return QCAP_RT_OK; }
  27. pView->m_nVideoWidth = nVideoWidth;
  28. pView->m_nVideoHeight = nVideoHeight;
  29. pView->m_bVideoIsInterleaved = bVideoIsInterleaved;
  30. pView->m_dVideoFrameRate = dVideoFrameRate;
  31. pView->m_nAudioChannels = nAudioChannels;
  32. pView->m_nAudioBitsPerSample = nAudioBitsPerSample;
  33. pView->m_nAudioSampleFrequency = nAudioSampleFrequency;
  34. // OUTPUT FORMAT CHANGED MESSAGE
  35. //
  36. CHAR strVideoInput[MAX_PATH] = { 0 };
  37. CHAR strAudioInput[MAX_PATH] = { 0 };
  38. CHAR strFrameType[MAX_PATH] = { 0 };
  39. UINT nVH = 0;
  40. if (nVideoInput == 0) { sprintf_s(strVideoInput, "COMPOSITE"); }
  41. if (nVideoInput == 1) { sprintf_s(strVideoInput, "SVIDEO"); }
  42. if (nVideoInput == 2) { sprintf_s(strVideoInput, "HDMI"); }
  43. if (nVideoInput == 3) { sprintf_s(strVideoInput, "DVI_D"); }
  44. if (nVideoInput == 4) { sprintf_s(strVideoInput, "COMPONENTS (YCBCR)"); }
  45. if (nVideoInput == 5) { sprintf_s(strVideoInput, "DVI_A (RGB / VGA)"); }
  46. if (nVideoInput == 6) { sprintf_s(strVideoInput, "SDI"); }
  47. if (nVideoInput == 7) { sprintf_s(strVideoInput, "AUTO"); }
  48. if (nAudioInput == 0) { sprintf_s(strAudioInput, "EMBEDDED_AUDIO"); }
  49. if (nAudioInput == 1) { sprintf_s(strAudioInput, "LINE_IN"); }
  50. if (bVideoIsInterleaved == TRUE) { nVH = nVideoHeight / 2; }
  51. else { nVH = nVideoHeight; }
  52. if (bVideoIsInterleaved == TRUE) { sprintf_s(strFrameType, " I "); }
  53. else { sprintf_s(strFrameType, " P "); }
  54. pView->m_strFormatChangedOutput.Format(
  55. _T("INFO : %d x %d%s @%2.3f FPS , %d CH x %d BITS x %d HZ , VIDEO INPUT : %s , AUDIO INPUT : %s"),
  56. nVideoWidth,
  57. nVH,
  58. strFrameType,
  59. dVideoFrameRate,
  60. nAudioChannels,
  61. nAudioBitsPerSample,
  62. nAudioSampleFrequency,
  63. strVideoInput,
  64. strAudioInput
  65. );
  66. Global::WriteTextLog(_T("采集卡格式变更:%d x %d%s @%2.3f FPS , %d CH x %d BITS x %d HZ , 视频输入源 : %s , 音频输入源 : %s"),
  67. nVideoWidth,
  68. nVH,
  69. strFrameType,
  70. dVideoFrameRate,
  71. nAudioChannels,
  72. nAudioBitsPerSample,
  73. nAudioSampleFrequency,
  74. strVideoInput,
  75. strAudioInput);
  76. ::SendMessage(g_pMainFrame->m_hWnd, MSG_STATUS_BAR, (WPARAM)&pView->m_strFormatChangedOutput, ID_STATUSBAR_PANE1);
  77. // NO SOURCE
  78. //
  79. if (nVideoWidth == 0 &&
  80. nVideoHeight == 0 &&
  81. dVideoFrameRate == 0.0 &&
  82. nAudioChannels == 0 &&
  83. nAudioBitsPerSample == 0 &&
  84. nAudioSampleFrequency == 0)
  85. {
  86. pView->m_bNoSignal = TRUE;
  87. }
  88. else
  89. {
  90. pView->m_bNoSignal = FALSE;
  91. }
  92. pView->SetTimer(0x00000000, 1, NULL);
  93. return QCAP_RT_OK;
  94. }
  95. // NO SIGNAL DETEACTED CALLBACK FUNCTION
  96. //
  97. QRETURN on_process_no_signal_detected2(PVOID pDevice, ULONG nVideoInput, ULONG nAudioInput, PVOID pUserData)
  98. {
  99. AFX_MANAGE_STATE(AfxGetStaticModuleState());
  100. CUB530View* pView = (CUB530View*)pUserData;
  101. //Dbg("No Signal Detected \n");
  102. if (pView == NULL) { return QCAP_RT_OK; }
  103. if (pView->GetSafeHwnd() == NULL) { return QCAP_RT_OK; }
  104. //pView->SetRibbonStatusBarText("当前采集卡无信号。", ID_STATUSBAR_PANE1);
  105. Global::WriteTextLog(_T("当前采集卡无信号"));
  106. ::SendMessage(g_pMainFrame->m_hWnd, MSG_STATUS_BAR, (WPARAM)&CString("当前采集卡无信号"), ID_STATUSBAR_PANE1);
  107. pView->m_bNoSignal = TRUE;
  108. pView->SetTimer(0x00000000, 1, NULL);
  109. return QCAP_RT_OK;
  110. }
  111. // SIGNAL REMOVED CALLBACK FUNCTION
  112. //
  113. QRETURN on_process_signal_removed2(PVOID pDevice, ULONG nVideoInput, ULONG nAudioInput, PVOID pUserData)
  114. {
  115. AFX_MANAGE_STATE(AfxGetStaticModuleState());
  116. CUB530View* pView = (CUB530View*)pUserData;
  117. if (pView == NULL) { return QCAP_RT_OK; }
  118. if (pView->GetSafeHwnd() == NULL) { return QCAP_RT_OK; }
  119. //pView->SetRibbonStatusBarText("当前采集卡信号被移除。", ID_STATUSBAR_PANE1);
  120. Global::WriteTextLog(_T("当前采集卡信号被移除"));
  121. ::SendMessage(g_pMainFrame->m_hWnd, MSG_STATUS_BAR, (WPARAM)&CString("当前采集卡信号被移除"), ID_STATUSBAR_PANE1);
  122. pView->m_bNoSignal = TRUE;
  123. pView->SetTimer(0x00000000, 1, NULL);
  124. return QCAP_RT_OK;
  125. }
  126. // PREVIEW VIDEO CALLBACK FUNCTION
  127. //
  128. QRETURN on_process_preview_video_buffer2(PVOID pDevice, double dSampleTime, BYTE* pFrameBuffer, ULONG nFrameBufferLen, PVOID pUserData)
  129. {
  130. CUB530View* pView = (CUB530View*)pUserData;
  131. if (pView)
  132. {
  133. // 尝试加锁;
  134. if (!pView->m_mut_cpature.try_lock())
  135. {
  136. #ifdef DEBUG
  137. OutputDebugStringA("!pView->m_mut_cpature.try_lock()\n");
  138. #endif
  139. return QCAP_RT_OK;
  140. }
  141. // 是否触发截图;
  142. if (pView->m_bCaptureImage)
  143. {
  144. // 加锁;
  145. std::lock_guard<std::mutex> lk(pView->m_mut_thread);
  146. // 复制数据;
  147. pView->m_dwBufferLen = nFrameBufferLen;
  148. pView->m_pBuffer = new BYTE[nFrameBufferLen];
  149. memcpy(pView->m_pBuffer, pFrameBuffer, nFrameBufferLen);
  150. // 通知线程保存图片;
  151. pView->m_thread_cond.notify_one();
  152. // 恢复截图标记,防止重复截图;
  153. pView->m_bCaptureImage = FALSE;
  154. #ifdef DEBUG
  155. OutputDebugStringA("preview_video_buffer:pView->m_bCaptureImage\n");
  156. #endif
  157. }
  158. // 解锁;
  159. pView->m_mut_cpature.unlock();
  160. }
  161. return QCAP_RT_OK;
  162. }
  163. // PREVIEW AUDIO CALLBACK FUNCTION
  164. //
  165. QRETURN on_process_preview_audio_buffer2(PVOID pDevice, double dSampleTime, BYTE* pFrameBuffer, ULONG nFrameBufferLen, PVOID pUserData)
  166. {
  167. return QCAP_RT_OK;
  168. }
  169. // VIDEO HARDARE ENCODER CALLBACK FUNCTION
  170. //
  171. QRETURN on_process_hardware_encoder_video_buffer2(PVOID pDevice, UINT iRecNum, double dSampleTime, BYTE* pFrameBuffer, ULONG nFrameBufferLen, BOOL bIsKeyFrame, PVOID pUserData)
  172. {
  173. return QCAP_RT_OK;
  174. }
  175. QRETURN on_process_snapshot_done2(PVOID pDevice, CHAR* pszFilePathName, PVOID pUserData)
  176. {
  177. return QCAP_RT_OK;
  178. }
  179. QRETURN on_process_snapshot_stream2(PVOID pDevice, CHAR* pszFilePathName, BYTE* pStreamBuffer, ULONG nStreamBufferLen, PVOID pUserData)
  180. {
  181. // 注意:在调用本回调函数前,已经保存了图片!
  182. CUB530View* pView = (CUB530View*)pUserData;
  183. if (pView->m_bHoriontal || pView->m_bVertically)
  184. Global::SaveImgByRotate(pszFilePathName, pStreamBuffer, nStreamBufferLen, pView->m_bHoriontal, pView->m_bVertically);
  185. return QCAP_RT_OK;
  186. }
  187. // CUB530View
  188. IMPLEMENT_DYNCREATE(CUB530View, CFormView)
  189. CUB530View::CUB530View(): CFormView(DLG_UB530VIEW)
  190. {
  191. m_hVideoDevice = NULL;
  192. m_bIsRecord = FALSE;
  193. m_bNoSignal = FALSE;
  194. m_bVertically = FALSE;
  195. m_bHoriontal = FALSE;
  196. m_bAppQuit = FALSE;
  197. m_pBuffer = NULL;
  198. m_bCaptureImage = FALSE;
  199. m_dwBufferLen = 0;
  200. m_bIsMp4 = TRUE;
  201. m_bSupportGPU = FALSE;
  202. }
  203. CUB530View::~CUB530View()
  204. {
  205. g_ub530.EndOfThread();
  206. m_bAppQuit = TRUE;
  207. HwUninitialize();
  208. }
  209. void CUB530View::DoDataExchange(CDataExchange* pDX)
  210. {
  211. CFormView::DoDataExchange(pDX);
  212. }
  213. BEGIN_MESSAGE_MAP(CUB530View, CFormView)
  214. ///////////////////////////////////
  215. ON_WM_TIMER()
  216. ON_COMMAND(ID_CUT_BMP, &CUB530View::OnCutBmp)
  217. ON_COMMAND(ID_CUT_JPG, &CUB530View::OnCutJpg)
  218. ON_COMMAND(ID_START_RECORD, &CUB530View::OnStartRecord)
  219. ON_COMMAND(ID_STOP_RECORD, &CUB530View::OnStopRecord)
  220. ON_COMMAND(ID_CHECK_VERTICALLY, &CUB530View::OnCheckVertically)
  221. ON_COMMAND(ID_CHECK_HORIONTAL, &CUB530View::OnCheckHoriontal)
  222. ON_UPDATE_COMMAND_UI(ID_CHECK_VERTICALLY, &CUB530View::OnUpdateCheckVertically)
  223. ON_UPDATE_COMMAND_UI(ID_CHECK_HORIONTAL, &CUB530View::OnUpdateCheckHoriontal)
  224. ON_COMMAND(ID_TRAYMENU_RECONNECT, &CUB530View::OnTraymenuReconnect)
  225. ON_COMMAND(ID_CHECK_SUPORT_GPU, &CUB530View::OnCheckSuportGpu)
  226. ON_COMMAND(ID_CHECK_FORMAT_MP4, &CUB530View::OnCheckFormatMp4)
  227. ON_COMMAND(ID_CHECK_FORMAT_AVI, &CUB530View::OnCheckFormatAvi)
  228. ON_UPDATE_COMMAND_UI(ID_CHECK_SUPORT_GPU, &CUB530View::OnUpdateCheckSuportGpu)
  229. ON_UPDATE_COMMAND_UI(ID_CHECK_FORMAT_MP4, &CUB530View::OnUpdateCheckFormatMp4)
  230. ON_UPDATE_COMMAND_UI(ID_CHECK_FORMAT_AVI, &CUB530View::OnUpdateCheckFormatAvi)
  231. ON_UPDATE_COMMAND_UI(ID_START_RECORD, &CUB530View::OnUpdateStartRecord)
  232. ON_UPDATE_COMMAND_UI(ID_STOP_RECORD, &CUB530View::OnUpdateStopRecord)
  233. END_MESSAGE_MAP()
  234. // CUB530View 诊断
  235. #ifdef _DEBUG
  236. void CUB530View::AssertValid() const
  237. {
  238. CFormView::AssertValid();
  239. }
  240. #ifndef _WIN32_WCE
  241. void CUB530View::Dump(CDumpContext& dc) const
  242. {
  243. CFormView::Dump(dc);
  244. }
  245. #endif
  246. #endif //_DEBUG
  247. // CUB530View 消息处理程序
  248. void CUB530View::OnInitialUpdate()
  249. {
  250. CFormView::OnInitialUpdate();
  251. // TODO: 在此添加专用代码和/或调用基类
  252. CMemoryClient::m_pView2 = this;
  253. g_ub530.InitMemery();
  254. g_ub530.StartThread();
  255. // TODO: 在此添加您专用的创建代码
  256. // 创建视频流,并关联指定显示窗口;
  257. HwInitialize();
  258. // 创建截图线程;
  259. std::thread t(CaptureImageThread, this);
  260. t.detach();
  261. }
  262. void CUB530View::OnDraw(CDC* pDC)
  263. {
  264. // TODO: 在此添加专用代码和/或调用基类
  265. // TO FILL IN THE TEXT
  266. //
  267. if (m_hVideoDevice == 0 || m_bNoSignal) {
  268. CFont font;
  269. ULONG nFontSize = 300;
  270. font.CreatePointFont(nFontSize, TEXT("Arial"), NULL);
  271. HFONT hOldFont = (HFONT)pDC->SelectObject(&font);
  272. pDC->SetBkMode(TRANSPARENT);
  273. pDC->SetTextColor(RGB(255, 255, 255));
  274. CRect rect_client;
  275. GetClientRect(&rect_client);
  276. CString string = _T("");
  277. if (m_hVideoDevice == 0)
  278. {
  279. CBrush brush_fill_rect(RGB(0, 0, 0));
  280. pDC->FillRect(&rect_client, &brush_fill_rect);
  281. string = TEXT("No Device");
  282. //g_pMainFrame->SetRibbonStatusBarText("当前采集卡设备被移除。", ID_STATUSBAR_PANE1);
  283. }
  284. else if (m_bNoSignal)
  285. {
  286. CBrush brush_fill_rect(RGB(0, 0, 255));
  287. pDC->FillRect(&rect_client, &brush_fill_rect);
  288. string = TEXT("No Source");
  289. //g_pMainFrame->SetRibbonStatusBarText("当前采集卡信号被移除。", ID_STATUSBAR_PANE1);
  290. }
  291. pDC->DrawText(string, &rect_client, DT_SINGLELINE | DT_CENTER | DT_VCENTER);
  292. pDC->SelectObject(&hOldFont);
  293. font.DeleteObject();
  294. }
  295. }
  296. BOOL CUB530View::HwInitialize()
  297. {
  298. if (m_hVideoDevice != NULL)
  299. return TRUE;
  300. // CALLBACK FUNCTION
  301. PF_FORMAT_CHANGED_CALLBACK pFormatChangedCB = { 0 };
  302. PF_VIDEO_PREVIEW_CALLBACK pPreviewVideoCB = { 0 };
  303. PF_AUDIO_PREVIEW_CALLBACK pPreviewAudioCB = { 0 };
  304. PF_VIDEO_HARDWARE_ENCODER_CALLBACK pHardwareEncoderVideoCB = { 0 };
  305. PF_NO_SIGNAL_DETECTED_CALLBACK pNoSignalDetectedCB = { 0 };
  306. PF_SIGNAL_REMOVED_CALLBACK pSignalRemovedCB = { 0 };
  307. PF_SNAPSHOT_DONE_CALLBACK pSnapShotDoneCB = { 0 };
  308. PF_SNAPSHOT_STREAM_CALLBACK pSnapShotStreamCB = { 0 };
  309. // CREATE CAPTURE DEVICE
  310. //
  311. if (m_hVideoDevice == NULL)
  312. QCAP_CREATE("CY3014 USB", 0, m_hWnd, &m_hVideoDevice, 1);
  313. if (m_hVideoDevice == NULL) {
  314. return FALSE;
  315. }
  316. // REGISTER FORMAT CHANGED CALLBACK FUNCTION
  317. pFormatChangedCB = on_process_format_changed2;
  318. QCAP_REGISTER_FORMAT_CHANGED_CALLBACK(m_hVideoDevice, pFormatChangedCB, this);
  319. // REGISTER PREVIEW VIDEO CALLBACK FUNCTION
  320. pPreviewVideoCB = on_process_preview_video_buffer2;
  321. QCAP_REGISTER_VIDEO_PREVIEW_CALLBACK(m_hVideoDevice, pPreviewVideoCB, this);
  322. // REGISTER PREVIEW AUDIO CALLBACK FUNCTION
  323. //pPreviewAudioCB = on_process_preview_audio_buffer;
  324. //QCAP_REGISTER_AUDIO_PREVIEW_CALLBACK(m_hVideoDevice, pPreviewAudioCB, this);
  325. // REGISTER HARDWARE ENCODER VIDEO CALLBACK FUNCTION
  326. //pHardwareEncoderVideoCB = on_process_hardware_encoder_video_buffer;
  327. //QCAP_REGISTER_VIDEO_HARDWARE_ENCODER_CALLBACK(m_hVideoDevice, 0, pHardwareEncoderVideoCB, this);
  328. // REGISTER NO SIGNAL DETECTED CALLBACK FUNCTION
  329. pNoSignalDetectedCB = on_process_no_signal_detected2;
  330. QCAP_REGISTER_NO_SIGNAL_DETECTED_CALLBACK(m_hVideoDevice, pNoSignalDetectedCB, this);
  331. // REGISTER SIGNAL REMOVED CALLBACK FUNCTION
  332. pSignalRemovedCB = on_process_signal_removed2;
  333. QCAP_REGISTER_SIGNAL_REMOVED_CALLBACK(m_hVideoDevice, pSignalRemovedCB, this);
  334. #if 1
  335. //
  336. pSnapShotDoneCB = on_process_snapshot_done2;
  337. QCAP_REGISTER_SNAPSHOT_DONE_CALLBACK(m_hVideoDevice, pSnapShotDoneCB, this);
  338. //
  339. pSnapShotStreamCB = on_process_snapshot_stream2;
  340. QCAP_REGISTER_SNAPSHOT_STREAM_CALLBACK(m_hVideoDevice, pSnapShotStreamCB, this);
  341. #endif
  342. QCAP_SET_VIDEO_DEINTERLACE_TYPE(m_hVideoDevice, QCAP_SOFTWARE_DEINTERLACE_TYPE_BLENDING);
  343. QCAP_SET_VIDEO_DEINTERLACE(m_hVideoDevice, 0);
  344. QCAP_SET_AUDIO_VOLUME(m_hVideoDevice, 100);
  345. QCAP_SET_VIDEO_HARDWARE_ENCODER_PROPERTY(m_hVideoDevice, 0, QCAP_ENCODER_FORMAT_H264, QCAP_RECORD_MODE_CBR, 8000, 12 * 1024 * 1024, 30, 0, 0, QCAP_DOWNSCALE_MODE_OFF, 0, 0);
  346. QCAP_SET_VIDEO_INPUT(m_hVideoDevice, QCAP_INPUT_TYPE_AUTO);
  347. QCAP_RUN(m_hVideoDevice);
  348. // 刷新区域;
  349. Invalidate();
  350. // UPDATE USER INTERFACE RESOURCE
  351. if (m_hVideoDevice == 0) {
  352. /*m_oSetupDialog.m_btnVideoInput.EnableWindow(FALSE);
  353. m_oSetupDialog.m_btnVideoQuality.EnableWindow(FALSE);
  354. m_oSetupDialog.m_btnAudioInput.EnableWindow(FALSE);
  355. m_oSetupDialog.m_btnSnapshot_bmp.EnableWindow(FALSE);
  356. m_oSetupDialog.m_btnSnapshot_jpg.EnableWindow(FALSE);
  357. m_oSetupDialog.m_btnRecordStart_1_1.EnableWindow(FALSE);
  358. m_oSetupDialog.m_btnRecordStop_1_1.EnableWindow(FALSE);
  359. m_oSetupDialog.m_btnRecordStart_1_2.EnableWindow(FALSE);
  360. m_oSetupDialog.m_btnRecordStop_1_2.EnableWindow(FALSE);
  361. m_oSetupDialog.m_btnRecordStart_1_3.EnableWindow(FALSE);
  362. m_oSetupDialog.m_btnRecordStop_1_3.EnableWindow(FALSE);
  363. m_oSetupDialog.m_checkGPU_1_1.EnableWindow(FALSE);
  364. m_oSetupDialog.m_checkGPU_1_1.SetCheck(0);
  365. m_oSetupDialog.m_checkGPU_1_2.EnableWindow(FALSE);
  366. m_oSetupDialog.m_checkGPU_1_2.SetCheck(0);
  367. m_oSetupDialog.m_checkGPU_1_3.EnableWindow(FALSE);
  368. m_oSetupDialog.m_checkGPU_1_3.SetCheck(0);
  369. m_oSetupDialog.m_checkAutoDeinterlace.EnableWindow(FALSE);
  370. m_oSetupDialog.m_checkAutoDeinterlace.SetCheck(0);*/
  371. }
  372. else {
  373. /*m_oSetupDialog.m_btnSnapshot_bmp.EnableWindow(TRUE);
  374. m_oSetupDialog.m_btnSnapshot_jpg.EnableWindow(TRUE);
  375. m_oSetupDialog.m_btnRecordStart_1_1.EnableWindow(TRUE);
  376. m_oSetupDialog.m_btnRecordStop_1_1.EnableWindow(FALSE);
  377. m_oSetupDialog.m_btnRecordStart_1_2.EnableWindow(TRUE);
  378. m_oSetupDialog.m_btnRecordStop_1_2.EnableWindow(FALSE);
  379. m_oSetupDialog.m_btnRecordStart_1_3.EnableWindow(TRUE);
  380. m_oSetupDialog.m_btnRecordStop_1_3.EnableWindow(FALSE);
  381. m_oSetupDialog.m_checkGPU_1_1.EnableWindow(FALSE);
  382. m_oSetupDialog.m_checkGPU_1_1.SetCheck(0);
  383. m_oSetupDialog.m_checkGPU_1_2.EnableWindow(TRUE);
  384. m_oSetupDialog.m_checkGPU_1_2.SetCheck(0);
  385. m_oSetupDialog.m_checkGPU_1_3.EnableWindow(TRUE);
  386. m_oSetupDialog.m_checkGPU_1_3.SetCheck(0);
  387. m_oSetupDialog.m_checkAutoDeinterlace.EnableWindow(TRUE);
  388. m_oSetupDialog.m_checkAutoDeinterlace.SetCheck(0);*/
  389. }
  390. return TRUE;
  391. }
  392. BOOL CUB530View::HwUninitialize()
  393. {
  394. if (m_hVideoDevice != 0) {
  395. QCAP_STOP(m_hVideoDevice);
  396. QCAP_DESTROY(m_hVideoDevice);
  397. m_hVideoDevice = NULL;
  398. }
  399. return TRUE;
  400. }
  401. void CUB530View::CaptureSingleImage(LPTSTR lpszFileName, BOOL bIsJPG)
  402. {
  403. if (m_hVideoDevice != NULL)
  404. {
  405. if (bIsJPG)
  406. {
  407. QCAP_SNAPSHOT_JPG(m_hVideoDevice, lpszFileName, 100, FALSE, 5000); //参数4:是否异步;
  408. }
  409. else
  410. {
  411. QCAP_SNAPSHOT_BMP(m_hVideoDevice, lpszFileName, FALSE, 5000);
  412. }
  413. #ifdef _DEBUG
  414. Global::WriteTextLog("完成:CaptureSingleImage");
  415. #endif
  416. }
  417. }
  418. std::string CUB530View::CaptureSingleImageAutoName(LPCTSTR lpszDir, BOOL bIsJPG)
  419. {
  420. if (m_hVideoDevice != NULL)
  421. {
  422. TCHAR szPath[MAX_PATH] = { 0 };
  423. // 毫秒级;
  424. time_point<system_clock, ::chrono::milliseconds> tp = time_point_cast<std::chrono::milliseconds>(system_clock::now());
  425. auto tt = std::chrono::system_clock::to_time_t(tp);
  426. std::tm now = { 0 };
  427. localtime_s(&now, &tt); // 时间戳转成本地时间;
  428. int msc = tp.time_since_epoch().count() % 1000;
  429. if (bIsJPG)
  430. {
  431. _stprintf_s(szPath, _T("%s%04d%02d%02d%02d%02d%02d%03d.jpg"),
  432. lpszDir ? lpszDir : Global::g_szCurModuleDir,
  433. now.tm_year + 1990,
  434. now.tm_mon + 1,
  435. now.tm_mday,
  436. now.tm_hour,
  437. now.tm_min,
  438. now.tm_sec,
  439. msc);
  440. QCAP_SNAPSHOT_JPG(m_hVideoDevice, szPath, 100, FALSE, 5000);
  441. }
  442. else
  443. {
  444. _stprintf_s(szPath, _T("%s%04d%02d%02d%02d%02d%02d%03d.bmp"),
  445. lpszDir ? lpszDir : Global::g_szCurModuleDir,
  446. now.tm_year + 1990,
  447. now.tm_mon + 1,
  448. now.tm_mday,
  449. now.tm_hour,
  450. now.tm_min,
  451. now.tm_sec,
  452. msc);
  453. QCAP_SNAPSHOT_BMP(m_hVideoDevice, szPath, FALSE, 5000);
  454. }
  455. #ifdef _DEBUG
  456. Global::WriteTextLog("完成:CaptureSingleImageAutoName");
  457. #endif
  458. return std::string(szPath);
  459. }
  460. return std::string();
  461. }
  462. void CUB530View::CaptureMultiImage(LPCTSTR lpszDir, LPCTSTR lpszPrefix, BOOL bIsJPG, int nDurationTime)
  463. {
  464. std::thread t([&](CUB530View* p, LPCTSTR lpszDir, LPCTSTR lpszPrefix, BOOL bIsJPG, int nDurationTime) {
  465. // 连续截图;
  466. TCHAR szDir[MAX_PATH] = { 0 };
  467. TCHAR szPath[MAX_PATH] = { 0 };
  468. _stprintf_s(szDir, lpszPrefix ? _T("%s%s-") : _T("%s%s"),
  469. lpszDir ? lpszDir : Global::g_szCurModuleDir,
  470. lpszPrefix ? lpszPrefix : _T(""));
  471. auto start = system_clock::now();
  472. while (true)
  473. {
  474. // C++11获取当前时间;
  475. time_point<system_clock, ::chrono::milliseconds> tp = time_point_cast<std::chrono::milliseconds>(system_clock::now());
  476. if (bIsJPG)
  477. {
  478. _stprintf_s(szPath, _T("%s%lld.jpg"), szDir, tp.time_since_epoch().count());
  479. QCAP_SNAPSHOT_JPG(m_hVideoDevice, szPath, 100, TRUE);
  480. // 等待磁盘完成写入;
  481. //Sleep(20);
  482. }
  483. else
  484. {
  485. _stprintf_s(szPath, _T("%s%lld.bmp"), szDir, tp.time_since_epoch().count());
  486. QCAP_SNAPSHOT_BMP(m_hVideoDevice, szPath, TRUE);
  487. // 等待磁盘完成写入;
  488. //Sleep(530);
  489. }
  490. auto duration = duration_cast<milliseconds>(system_clock::now() - start);
  491. if (duration.count() >= nDurationTime)
  492. break;
  493. }
  494. }, this, lpszDir, lpszPrefix, bIsJPG, nDurationTime);
  495. t.detach();
  496. }
  497. void CUB530View::CaptureSingleImageEx(LPTSTR lpszFileName, BOOL bIsJPG)
  498. {
  499. {
  500. // 加锁;
  501. std::lock_guard<std::mutex> lk(m_mut_cpature);
  502. // 标记截图;
  503. m_bCaptureImage = TRUE;
  504. // 初始化数据;
  505. ZeroMemory(&m_CaptureInfo, sizeof(CaptureInfo));
  506. m_CaptureInfo.bIsJPG = bIsJPG;
  507. m_CaptureInfo.bSingle = TRUE;
  508. m_CaptureInfo.IsAutoName = FALSE;
  509. m_CaptureInfo.nCaputerCount = 0;
  510. m_CaptureInfo.nKeepTime = 0;
  511. memset(m_CaptureInfo.szPrefix, 0, 64);
  512. //_stprintf_s(m_CaptureInfo.szSaveDir, _T("%s"), lpszFileName);
  513. _stprintf_s(m_CaptureInfo.szSaveDir, _T("%s"), lpszFileName);
  514. //m_strCaptureName = lpszFileName;
  515. }
  516. // 等待截图完成;
  517. {
  518. // 加锁;
  519. std::unique_lock<std::mutex> lk(m_mut_cpature);
  520. m_capture_cond.wait(lk, [&]() {return !m_pBuffer; });
  521. // 解锁;
  522. lk.unlock();
  523. }
  524. }
  525. std::string CUB530View::CaptureSingleImageAutoNameEx(LPCTSTR lpszDir, BOOL bIsJPG)
  526. {
  527. {
  528. // 加锁;
  529. std::lock_guard<std::mutex> lk(m_mut_cpature);
  530. // 标记截图;
  531. m_bCaptureImage = TRUE;
  532. // 初始化数据;
  533. ZeroMemory(&m_CaptureInfo, sizeof(CaptureInfo));
  534. m_CaptureInfo.bIsJPG = bIsJPG;
  535. m_CaptureInfo.bSingle = TRUE;
  536. m_CaptureInfo.IsAutoName = FALSE;
  537. m_CaptureInfo.nCaputerCount = 0;
  538. m_CaptureInfo.nKeepTime = 0;
  539. memset(m_CaptureInfo.szPrefix, 0, 64);
  540. memset(m_CaptureInfo.szSaveDir, 0, MAX_PATH);
  541. // 毫秒级;
  542. time_point<system_clock, ::chrono::milliseconds> tp = time_point_cast<std::chrono::milliseconds>(system_clock::now());
  543. auto tt = std::chrono::system_clock::to_time_t(tp);
  544. std::tm now = { 0 };
  545. localtime_s(&now, &tt); // 时间戳转成本地时间;
  546. int msc = tp.time_since_epoch().count() % 1000;
  547. if (bIsJPG)
  548. {
  549. _stprintf_s(m_CaptureInfo.szSaveDir, _T("%s%04d%02d%02d%02d%02d%02d%03d.jpg"),
  550. lpszDir ? lpszDir : Global::g_szCurModuleDir,
  551. now.tm_year + 1990,
  552. now.tm_mon + 1,
  553. now.tm_mday,
  554. now.tm_hour,
  555. now.tm_min,
  556. now.tm_sec,
  557. msc);
  558. }
  559. else
  560. {
  561. _stprintf_s(m_CaptureInfo.szSaveDir, _T("%s%04d%02d%02d%02d%02d%02d%03d.bmp"),
  562. lpszDir ? lpszDir : Global::g_szCurModuleDir,
  563. now.tm_year + 1990,
  564. now.tm_mon + 1,
  565. now.tm_mday,
  566. now.tm_hour,
  567. now.tm_min,
  568. now.tm_sec,
  569. msc);
  570. }
  571. #ifdef DEBUG
  572. OutputDebugStringA(m_CaptureInfo.szSaveDir);
  573. OutputDebugStringA("\tCVideoCaptureView::CaptureSingleImageAutoNameEx\n");
  574. #endif // DEBUG
  575. }
  576. // 等待截图完成;
  577. {
  578. // 加锁;
  579. std::unique_lock<std::mutex> lk(m_mut_cpature);
  580. m_capture_cond.wait(lk, [&]() {return !m_pBuffer; });
  581. // 解锁;
  582. lk.unlock();
  583. }
  584. return std::string(m_CaptureInfo.szSaveDir);
  585. }
  586. void CUB530View::CaptureMultiImageEx(LPCTSTR lpszDir, LPCTSTR lpszPrefix, BOOL bIsJPG, int nDurationTime)
  587. {
  588. std::thread t([&](CUB530View* p, LPCTSTR lpszDir, LPCTSTR lpszPrefix, BOOL bIsJPG, int nDurationTime) {
  589. // 连续截图;
  590. TCHAR szDir[MAX_PATH] = { 0 };
  591. _stprintf_s(szDir, lpszPrefix ? _T("%s%s-") : _T("%s%s"),
  592. lpszDir ? lpszDir : Global::g_szCurModuleDir,
  593. lpszPrefix ? lpszPrefix : _T(""));
  594. auto start = system_clock::now();
  595. while (true)
  596. {
  597. // C++11获取当前时间;
  598. time_point<system_clock, ::chrono::milliseconds> tp = time_point_cast<std::chrono::milliseconds>(system_clock::now());
  599. {
  600. // 加锁;
  601. std::lock_guard<std::mutex> lk(m_mut_cpature);
  602. // 标记截图;
  603. m_bCaptureImage = TRUE;
  604. // 初始化数据;
  605. ZeroMemory(&m_CaptureInfo, sizeof(CaptureInfo));
  606. m_CaptureInfo.bIsJPG = bIsJPG;
  607. m_CaptureInfo.bSingle = FALSE;
  608. m_CaptureInfo.IsAutoName = TRUE;
  609. m_CaptureInfo.nCaputerCount = 0;
  610. m_CaptureInfo.nKeepTime = nDurationTime;
  611. _stprintf_s(m_CaptureInfo.szPrefix, _T("%s"), lpszPrefix);
  612. if (bIsJPG)
  613. {
  614. _stprintf_s(m_CaptureInfo.szSaveDir, _T("%s%lld.jpg"), szDir, tp.time_since_epoch().count());
  615. }
  616. else
  617. {
  618. _stprintf_s(m_CaptureInfo.szSaveDir, _T("%s%lld.bmp"), szDir, tp.time_since_epoch().count());
  619. }
  620. }
  621. // 等待截图完成;
  622. {
  623. // 加锁;
  624. std::unique_lock<std::mutex> lk(m_mut_cpature);
  625. m_capture_cond.wait(lk, [&]() {return !m_pBuffer; });
  626. // 解锁;
  627. lk.unlock();
  628. }
  629. auto duration = duration_cast<milliseconds>(system_clock::now() - start);
  630. if (duration.count() >= nDurationTime)
  631. break;
  632. }
  633. }, this, lpszDir, lpszPrefix, bIsJPG, nDurationTime);
  634. t.detach();
  635. }
  636. BOOL CUB530View::SaveImageByCaptureInfo(const CaptureInfo& capInfo)
  637. {
  638. if (m_pBuffer == NULL)
  639. {
  640. return FALSE;
  641. }
  642. BOOL bRet = FALSE;
  643. // 保存截图;
  644. HGLOBAL hMemery = GlobalAlloc(GMEM_MOVEABLE, m_nVideoWidth * m_nVideoHeight * 4);
  645. if (hMemery != NULL)
  646. {
  647. BYTE* pDstFrameBuffer = NULL;
  648. pDstFrameBuffer = (BYTE*)GlobalLock(hMemery);
  649. if (pDstFrameBuffer != NULL)
  650. {
  651. QRESULT QRet = QCAP_COLORSPACE_YUY2_TO_ABGR32(m_pBuffer,
  652. m_nVideoWidth,
  653. m_nVideoHeight,
  654. 0,
  655. pDstFrameBuffer,
  656. m_nVideoWidth,
  657. m_nVideoHeight,
  658. 0);
  659. Status stat = GenericError;
  660. Bitmap* pImg = ::new Bitmap(
  661. m_nVideoWidth,
  662. m_nVideoHeight,
  663. m_nVideoWidth * 4,
  664. PixelFormat32bppRGB,
  665. pDstFrameBuffer);
  666. if (m_bHoriontal && !m_bVertically)
  667. pImg->RotateFlip(RotateNoneFlipX);// 水平翻转;
  668. else if (m_bHoriontal && m_bVertically)
  669. pImg->RotateFlip(Rotate180FlipNone);// 270度;
  670. else if (!m_bHoriontal && m_bVertically)
  671. pImg->RotateFlip(Rotate180FlipX);// 垂直翻转;
  672. CLSID encoderClsid = { 0 };
  673. CString strFileName = m_CaptureInfo.szSaveDir;
  674. // 需要判断路径是否存在,不存在创建目录;
  675. int nIndex = strFileName.ReverseFind(_T('\\'));
  676. if (nIndex != -1)
  677. {
  678. if (!PathFileExists(strFileName.Left(nIndex)))
  679. {
  680. // 如果文件夹不存在,创建;
  681. SHCreateDirectoryEx(NULL, strFileName.Left(nIndex), NULL);
  682. }
  683. }
  684. BSTR newfile = strFileName.AllocSysString();
  685. if (!capInfo.bIsJPG)
  686. {
  687. Global::GetEncoderClsid(L"image/bmp", &encoderClsid);
  688. stat = pImg->Save(newfile, &encoderClsid, NULL);
  689. }
  690. else
  691. {
  692. Global::GetEncoderClsid(L"image/jpeg", &encoderClsid);
  693. EncoderParameters encoderParameters;
  694. encoderParameters.Count = 1;
  695. encoderParameters.Parameter[0].Guid = EncoderQuality;
  696. encoderParameters.Parameter[0].Type = EncoderParameterValueTypeLong;
  697. encoderParameters.Parameter[0].NumberOfValues = 1;
  698. // Save the image as a JPEG with quality level 100.
  699. ULONG uQuality = 100;
  700. encoderParameters.Parameter[0].Value = &uQuality;
  701. stat = pImg->Save(newfile, &encoderClsid, &encoderParameters);
  702. }
  703. if (pImg)
  704. ::delete pImg;
  705. pImg = NULL;
  706. SysFreeString(newfile);
  707. bRet = (stat == 0 ? TRUE : FALSE);
  708. #ifdef DEBUG
  709. if (bRet)
  710. {
  711. OutputDebugStringA(strFileName);
  712. OutputDebugStringA("\tSave Image::Ok\n");
  713. }
  714. #endif
  715. }
  716. #ifdef DEBUG
  717. else
  718. {
  719. OutputDebugStringA("pDstFrameBuffer == NULL\n");
  720. }
  721. #endif
  722. GlobalUnlock(hMemery);
  723. }
  724. #ifdef DEBUG
  725. else
  726. {
  727. DWORD dwError = GetLastError();
  728. CString strError = _T("");
  729. strError.Format(_T("hMemery == NULL分配内存出错:%ld\n"), dwError);
  730. OutputDebugStringA(strError);
  731. }
  732. #endif
  733. if (m_pBuffer)
  734. delete[]m_pBuffer;
  735. m_pBuffer = NULL;
  736. // 必须调用GlobalFree释放;
  737. GlobalFree(hMemery);
  738. return bRet;
  739. }
  740. void CUB530View::CaptureImageThread(CUB530View* pView)
  741. {
  742. CString strFileName = _T("");
  743. while (!pView->m_bAppQuit)
  744. {
  745. std::unique_lock<std::mutex> lk(pView->m_mut_thread); // 这里使用unique_lock是为了后面方便解锁
  746. #if 1 // 避免线程虚假唤醒;
  747. pView->m_thread_cond.wait(lk, [&]() {return pView->m_pBuffer; });
  748. #else
  749. while (!pView->m_pBuffer)
  750. pView->m_data_cond.wait(lk);
  751. #endif
  752. // 保存截图;
  753. pView->SaveImageByCaptureInfo(pView->m_CaptureInfo);
  754. // 通知截图完成;
  755. pView->m_capture_cond.notify_one();
  756. // 解锁;
  757. lk.unlock();
  758. // sleep 10ms;
  759. //this_thread::sleep_for(chrono::milliseconds(10));
  760. }
  761. }
  762. void CUB530View::StartRecord(DWORD dwDuration, LPCTSTR lpSavePath)
  763. {
  764. QRESULT QRet = QCAP_RS_SUCCESSFUL;
  765. if (!m_bIsMp4) // 音频格式;
  766. {
  767. QRet = QCAP_SET_AUDIO_RECORD_PROPERTY(m_hVideoDevice, 0, QCAP_ENCODER_TYPE_SOFTWARE, QCAP_ENCODER_FORMAT_PCM);
  768. //_tcscat_s(szPath, _T(".avi"));
  769. }
  770. else
  771. {
  772. QRet = QCAP_SET_AUDIO_RECORD_PROPERTY(m_hVideoDevice, 0, QCAP_ENCODER_TYPE_SOFTWARE, QCAP_ENCODER_FORMAT_AAC);
  773. //_tcscat_s(szPath, _T(".mp4"));
  774. }
  775. // 设置视频属性;
  776. QRet = QCAP_SET_VIDEO_RECORD_PROPERTY(
  777. m_hVideoDevice,
  778. 0,
  779. m_bSupportGPU ? QCAP_ENCODER_TYPE_INTEL_MEDIA_SDK : QCAP_ENCODER_TYPE_SOFTWARE,
  780. QCAP_ENCODER_FORMAT_H264,
  781. QCAP_RECORD_MODE_CBR,
  782. 8000,
  783. 16 * 1024 * 1024, // 16最高质量;
  784. 30, // 每秒多少帧
  785. 0,
  786. 0,
  787. QCAP_DOWNSCALE_MODE_OFF);
  788. // 开始录屏;
  789. QRet = QCAP_START_RECORD(m_hVideoDevice, 0, const_cast<CHAR*>(lpSavePath), QCAP_RECORD_FLAG_FULL, 0.0, 0.0, 0.0, 0, NULL);
  790. m_bIsRecord = TRUE;
  791. }
  792. void CUB530View::StopRecord()
  793. {
  794. QCAP_STOP_RECORD(m_hVideoDevice, 0);
  795. m_bIsRecord = FALSE;
  796. }
  797. //////////////////////////////////////////////////////////////////////////
  798. void CUB530View::SetRibbonStatusBarText(CString strText, int uId)
  799. {
  800. if (g_pMainFrame)
  801. {
  802. g_pMainFrame->SetRibbonStatusBarText(strText, uId);
  803. }
  804. }
  805. void CUB530View::OnTimer(UINT_PTR nIDEvent)
  806. {
  807. // TODO: 在此添加消息处理程序代码和/或调用默认值
  808. if (nIDEvent == 0)
  809. {
  810. KillTimer(0);
  811. if (m_bNoSignal)
  812. {
  813. if (m_bIsRecord)
  814. {
  815. QCAP_STOP_RECORD(m_hVideoDevice, 0);
  816. m_bIsRecord = FALSE;
  817. }
  818. }
  819. else
  820. {
  821. }
  822. }
  823. CView::OnTimer(nIDEvent);
  824. }
  825. void CUB530View::OnCutBmp()
  826. {
  827. // TODO: 在此添加命令处理程序代码
  828. CaptureSingleImageAutoName(NULL, FALSE);
  829. }
  830. void CUB530View::OnCutJpg()
  831. {
  832. // TODO: 在此添加命令处理程序代码
  833. CaptureSingleImageAutoName(NULL, TRUE);
  834. }
  835. void CUB530View::OnStartRecord()
  836. {
  837. // TODO: 在此添加命令处理程序代码
  838. TCHAR szPath[MAX_PATH] = { 0 };
  839. // 毫秒级;
  840. time_point<system_clock, ::chrono::milliseconds> tp = time_point_cast<std::chrono::milliseconds>(system_clock::now());
  841. auto tt = std::chrono::system_clock::to_time_t(tp);
  842. std::tm now = { 0 };
  843. localtime_s(&now, &tt); // 时间戳转成本地时间;
  844. int msc = tp.time_since_epoch().count() % 1000;
  845. _stprintf_s(szPath, _T("%s%04d%02d%02d%02d%02d%02d%03d"),
  846. Global::g_szCurModuleDir,
  847. now.tm_year + 1990,
  848. now.tm_mon + 1,
  849. now.tm_mday,
  850. now.tm_hour,
  851. now.tm_min,
  852. now.tm_sec,
  853. msc);
  854. QRESULT QRet = QCAP_RS_SUCCESSFUL;
  855. if (!m_bIsMp4) // 音频格式;
  856. {
  857. QRet = QCAP_SET_AUDIO_RECORD_PROPERTY(m_hVideoDevice, 0, QCAP_ENCODER_TYPE_SOFTWARE, QCAP_ENCODER_FORMAT_PCM);
  858. _tcscat_s(szPath, _T(".avi"));
  859. }
  860. else
  861. {
  862. QRet = QCAP_SET_AUDIO_RECORD_PROPERTY(m_hVideoDevice, 0, QCAP_ENCODER_TYPE_SOFTWARE, QCAP_ENCODER_FORMAT_AAC);
  863. _tcscat_s(szPath, _T(".mp4"));
  864. }
  865. // 设置视频属性;
  866. QRet = QCAP_SET_VIDEO_RECORD_PROPERTY(
  867. m_hVideoDevice,
  868. 0,
  869. m_bSupportGPU ? QCAP_ENCODER_TYPE_INTEL_MEDIA_SDK : QCAP_ENCODER_TYPE_SOFTWARE,
  870. QCAP_ENCODER_FORMAT_H264,
  871. QCAP_RECORD_MODE_CBR,
  872. 8000,
  873. 16 * 1024 * 1024, // 16最高质量;
  874. 30, // 每秒多少帧
  875. 0,
  876. 0,
  877. QCAP_DOWNSCALE_MODE_OFF);
  878. // 开始录屏;
  879. QRet = QCAP_START_RECORD(m_hVideoDevice, 0, szPath, QCAP_RECORD_FLAG_FULL, 0.0, 0.0, 0.0, 0, NULL);
  880. m_bIsRecord = TRUE;
  881. }
  882. void CUB530View::OnStopRecord()
  883. {
  884. // TODO: 在此添加命令处理程序代码
  885. QCAP_STOP_RECORD(m_hVideoDevice, 0);
  886. m_bIsRecord = FALSE;
  887. }
  888. void CUB530View::OnCheckVertically()
  889. {
  890. // TODO: 在此添加命令处理程序代码
  891. CMainFrame* pMain = (CMainFrame*)AfxGetMainWnd();
  892. CMFCRibbonButton* pCheckbox = pMain->GetRibbonButton(ID_CHECK_VERTICALLY);
  893. m_bVertically = !pCheckbox->IsChecked();
  894. if (m_hVideoDevice)
  895. {
  896. QCAP_SET_VIDEO_MIRROR(m_hVideoDevice, m_bHoriontal, m_bVertically);
  897. }
  898. }
  899. void CUB530View::OnCheckHoriontal()
  900. {
  901. // TODO: 在此添加命令处理程序代码
  902. CMainFrame* pMain = (CMainFrame*)AfxGetMainWnd();
  903. CMFCRibbonButton* pCheckbox = pMain->GetRibbonButton(ID_CHECK_HORIONTAL);
  904. m_bHoriontal = !pCheckbox->IsChecked();
  905. if (m_hVideoDevice)
  906. {
  907. QCAP_SET_VIDEO_MIRROR(m_hVideoDevice, m_bHoriontal, m_bVertically);
  908. }
  909. }
  910. void CUB530View::OnUpdateCheckVertically(CCmdUI* pCmdUI)
  911. {
  912. // TODO: 在此添加命令更新用户界面处理程序代码
  913. pCmdUI->SetCheck(m_bVertically);
  914. }
  915. void CUB530View::OnUpdateCheckHoriontal(CCmdUI* pCmdUI)
  916. {
  917. // TODO: 在此添加命令更新用户界面处理程序代码
  918. pCmdUI->SetCheck(m_bHoriontal);
  919. }
  920. void CUB530View::OnTraymenuReconnect()
  921. {
  922. // TODO: 在此添加命令处理程序代码
  923. HwUninitialize();// 断开;
  924. Invalidate();
  925. HwInitialize();// 重连;
  926. }
  927. void CUB530View::OnCheckSuportGpu()
  928. {
  929. // TODO: 在此添加命令处理程序代码
  930. CMainFrame* pMain = (CMainFrame*)AfxGetMainWnd();
  931. CMFCRibbonButton* pCheckbox = pMain->GetRibbonButton(ID_CHECK_SUPORT_GPU);
  932. m_bSupportGPU = !pCheckbox->IsChecked();
  933. }
  934. void CUB530View::OnCheckFormatMp4()
  935. {
  936. CMainFrame* pMain = (CMainFrame*)AfxGetMainWnd();
  937. CMFCRibbonButton* pCheckbox = pMain->GetRibbonButton(ID_CHECK_FORMAT_MP4);
  938. m_bIsMp4 = !pCheckbox->IsChecked();
  939. }
  940. void CUB530View::OnCheckFormatAvi()
  941. {
  942. CMainFrame* pMain = (CMainFrame*)AfxGetMainWnd();
  943. CMFCRibbonButton* pCheckbox = pMain->GetRibbonButton(ID_CHECK_FORMAT_AVI);
  944. m_bIsMp4 = pCheckbox->IsChecked();
  945. }
  946. void CUB530View::OnUpdateCheckSuportGpu(CCmdUI* pCmdUI)
  947. {
  948. // TODO: 在此添加命令更新用户界面处理程序代码
  949. pCmdUI->SetCheck(m_bSupportGPU);
  950. }
  951. void CUB530View::OnUpdateCheckFormatMp4(CCmdUI* pCmdUI)
  952. {
  953. // TODO: 在此添加命令更新用户界面处理程序代码
  954. pCmdUI->SetCheck(m_bIsMp4);
  955. }
  956. void CUB530View::OnUpdateCheckFormatAvi(CCmdUI* pCmdUI)
  957. {
  958. // TODO: 在此添加命令更新用户界面处理程序代码
  959. pCmdUI->SetCheck(!m_bIsMp4);
  960. }
  961. void CUB530View::OnUpdateStartRecord(CCmdUI* pCmdUI)
  962. {
  963. // TODO: 在此添加命令更新用户界面处理程序代码
  964. pCmdUI->Enable(!m_bIsRecord);
  965. }
  966. void CUB530View::OnUpdateStopRecord(CCmdUI* pCmdUI)
  967. {
  968. // TODO: 在此添加命令更新用户界面处理程序代码
  969. pCmdUI->Enable(m_bIsRecord);
  970. }