CamerEs.cs 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. using Common;
  2. using MeterPlugInLibrary;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.IO;
  6. using System.Linq;
  7. using System.Runtime.InteropServices;
  8. using System.Text;
  9. using System.Threading;
  10. using System.Threading.Tasks;
  11. using System.Windows.Forms;
  12. namespace CarMeterSystem
  13. {
  14. public class CamerEs
  15. {
  16. #region
  17. private bool m_bInitSDK = false;
  18. private uint iLastErr = 0;
  19. private Int32 m_lUserID = -1;
  20. private Int32 m_lRealHandle = -1;
  21. private Int32 i = 0;
  22. private string str;
  23. private long iSelIndex = 0;
  24. private int[] iChannelNum = new int[96];
  25. private CHCNetSDK.NET_DVR_DEVICEINFO_V30 DeviceInfo;
  26. private CHCNetSDK.NET_DVR_IPPARACFG_V40 m_struIpParaCfgV40;
  27. private CHCNetSDK.NET_DVR_IPCHANINFO m_struChanInfo;
  28. private CHCNetSDK.NET_DVR_IPCHANINFO_V40 m_struChanInfoV40;
  29. public delegate void MyDebugInfo(string str);
  30. #endregion
  31. internal loginParam _lg = null;
  32. public CamerEs(loginParam lg)
  33. {
  34. _lg = lg;
  35. m_bInitSDK = CHCNetSDK.NET_DVR_Init();
  36. if (m_bInitSDK == false)
  37. {
  38. MessageBox.Show("NET_DVR_Init error!");
  39. return;
  40. }
  41. else
  42. {
  43. //保存SDK日志 To save the SDK log
  44. CHCNetSDK.NET_DVR_SetLogToFile(3, "C:\\SdkLog\\", true);
  45. for (int i = 0; i < 64; i++)
  46. {
  47. iChannelNum[i] = -1;
  48. }
  49. }
  50. }
  51. public void Login(PictureBox pb)
  52. {
  53. List<loginParam> lt = new List<loginParam>();
  54. if (_lg == null )
  55. {
  56. DebugInfo("请先载入摄像头信息");
  57. }
  58. if (m_lUserID < 0)
  59. {
  60. string DVRIPAddress = _lg.ip; //设备IP地址或者域名 Device IP
  61. Int16 DVRPortNumber = (Int16)_lg.port;
  62. string DVRUserName = _lg.userId;//设备登录用户名 User name to login
  63. string DVRPassword = _lg.pwd;//设备登录密码 Password to login
  64. //登录设备 Login the device
  65. m_lUserID = CHCNetSDK.NET_DVR_Login_V30(DVRIPAddress, DVRPortNumber, DVRUserName, DVRPassword, ref DeviceInfo);
  66. if (m_lUserID < 0)
  67. {
  68. iLastErr = CHCNetSDK.NET_DVR_GetLastError();
  69. str = "NET_DVR_Login_V30 failed, error code= " + iLastErr; //登录失败,输出错误号 Failed to login and output the error code
  70. DebugInfo(str);
  71. return;
  72. }
  73. else
  74. {
  75. //登录成功
  76. DebugInfo("NET_DVR_Login_V30 succ!");
  77. //加载预览信息
  78. CHCNetSDK.NET_DVR_PREVIEWINFO lpPreviewInfo = new CHCNetSDK.NET_DVR_PREVIEWINFO();
  79. lpPreviewInfo.hPlayWnd = pb.Handle;//预览窗口 live view window
  80. lpPreviewInfo.lChannel = 1;//预览的设备通道 the device channel number
  81. lpPreviewInfo.dwStreamType = 1;//码流类型:0-主码流,1-子码流,2-码流3,3-码流4,以此类推
  82. lpPreviewInfo.dwLinkMode = 0;//连接方式:0- TCP方式,1- UDP方式,2- 多播方式,3- RTP方式,4-RTP/RTSP,5-RSTP/HTTP
  83. lpPreviewInfo.bBlocked = true; //0- 非阻塞取流,1- 阻塞取流
  84. lpPreviewInfo.dwDisplayBufNum = 15; //播放库显示缓冲区最大帧数
  85. IntPtr pUser = IntPtr.Zero;//用户数据 user data
  86. m_lRealHandle = CHCNetSDK.NET_DVR_RealPlay_V40(m_lUserID, ref lpPreviewInfo, null/*RealData*/, pUser);
  87. }
  88. }
  89. }
  90. public void LoginOut()
  91. {
  92. //注销登录 Logout the device
  93. if (m_lRealHandle >= 0)
  94. {
  95. DebugInfo("Please stop live view firstly"); //登出前先停止预览 Stop live view before logout
  96. return;
  97. }
  98. if (!CHCNetSDK.NET_DVR_Logout(m_lUserID))
  99. {
  100. iLastErr = CHCNetSDK.NET_DVR_GetLastError();
  101. str = "NET_DVR_Logout failed, error code= " + iLastErr;
  102. DebugInfo(str);
  103. return;
  104. }
  105. DebugInfo("NET_DVR_Logout succ!");
  106. m_lUserID = -1;
  107. }
  108. public void CapturePictrue(string fileUrl)
  109. {
  110. Log.GetInstance().WriteLog(35, "完成快速仪表拍照 成功标识:" + PbCache.shotSuccess.ToString() + "车号:" + PbCache.lockCarNo + ";重量:" + PbCache.lockWgt + ";时间:" + DateTime.Now.ToLongTimeString());
  111. if (!CHCNetSDK.NET_DVR_CapturePictureBlock(m_lRealHandle, fileUrl, 100))
  112. {
  113. iLastErr = CHCNetSDK.NET_DVR_GetLastError();
  114. str = "NET_DVR_CaptureJPEGPicture failed, error code= " + iLastErr;
  115. DebugInfo(str);
  116. return;
  117. }
  118. Log.GetInstance().WriteLog(35, "结束快速仪表拍照 成功标识:" + PbCache.shotSuccess.ToString() + "车号:" + PbCache.lockCarNo + ";重量:" + PbCache.lockWgt + ";时间:" + DateTime.Now.ToLongTimeString());
  119. }
  120. public void SaveRealData(string fileUrl)
  121. {
  122. if (!CHCNetSDK.NET_DVR_SaveRealData_V30(m_lRealHandle, 0x1, fileUrl))
  123. {
  124. iLastErr = CHCNetSDK.NET_DVR_GetLastError();
  125. str = "NET_DVR_SaveRealData_V30 failed, error code= " + iLastErr;
  126. DebugInfo(str);
  127. return;
  128. }
  129. }
  130. public void StopRealData()
  131. {
  132. if (!CHCNetSDK.NET_DVR_StopSaveRealData(m_lRealHandle))
  133. {
  134. iLastErr = CHCNetSDK.NET_DVR_GetLastError();
  135. str = "NET_DVR_StopSaveRealData failed, error code= " + iLastErr;
  136. DebugInfo(str);
  137. return;
  138. }
  139. }
  140. #region
  141. protected void DebugInfo(string strMsg)
  142. {
  143. try
  144. {
  145. string m_szRunPath;
  146. m_szRunPath = System.Environment.CurrentDirectory;
  147. if (System.IO.Directory.Exists(m_szRunPath + "\\log") == false)
  148. {
  149. System.IO.Directory.CreateDirectory(m_szRunPath + "\\log");
  150. }
  151. string strDate = System.DateTime.Now.ToString("yyyyMMdd");
  152. string strPathFile = m_szRunPath + "\\log\\" + strDate;
  153. if (!Directory.Exists(strPathFile))//如果不存在就创建file文件夹
  154. {
  155. Directory.CreateDirectory(strPathFile);
  156. }
  157. System.IO.TextWriter tw = new System.IO.StreamWriter(strPathFile + "\\视频_" + strDate + ".log", true);
  158. tw.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"));
  159. tw.WriteLine(str);
  160. tw.WriteLine("\r\n");
  161. tw.Close();
  162. }
  163. catch { }
  164. }
  165. #endregion
  166. }
  167. }