視頻聯網雲平台EasyCVR是一個集視頻聯網共享、存儲、流媒體轉發、視頻轉碼、視頻上雲、智能分析統一等多種功能為一體的流媒體視頻服務融合性平台。EasyCVR可以集成海康EHome私有協議,本文講一下EasyCVR集成海康EHome協議報警模塊。
開啟監聽服務並接收設備報警信息依賴於中心管理服務(CMS)和報警管理服務(AMS)。監聽服務開啟后,當報警被觸發時,設備會自動上傳報警,因此可通過配置監聽服務(即AMS)接收報警信息。
開啟監聽服務並接收報警的接口調用流程圖:
操作基本步驟:
1、調用NET_EALARM_StartListen開啟AMS報警監聽並注冊回調函數用於接收報警信息。AMS的IP地址和端口號由CMS發送給設備。
2、當報警觸發時,從AMS注冊的回調函數中獲取報警信息進行處理。
3、調用NET_EALARM_StopListen停止AMS報警監聽。
4、調用NET_ECMS_ForceLogout強制注銷設備
前提條件:
1、請確保已調用NET_ECMS_Init和NET_EALARM_Init初始化CMS和AMS。
2、請確保已調用NET_ECMS_StartListen開啟CMS監聽以接收設備注冊信息。
如果是ehome v4 版本,設備要設置SessionKey,SessionKey可通過回調數據類型“enum_dev_sessionkey”獲得。
開啟監聽服務並接收報警的示例代碼
注:在該示例代碼中,CMS和AMS安裝在同一台電腦的同一個程序中。
#include <stdio.h> #include <Windows.h> #include "HCISUPCMS.h" #include "HCISUPAlarm.h" LONG lLoginID = -1; LONG lListenHandle = -1; // //注冊回調函數 BOOL CALLBACK RegisterCallBack(LONG lUserID, DWORD dwDataType, void *pOutBuffer, DWORD dwOutLen, void *pInBuffer, DWORD dwInLen, void *pUser) { if (ENUM_DEV_ON == dwDataType) { NET_EHOME_DEV_REG_INFO *pDevInfo = (NET_EHOME_DEV_REG_INFO *)pOutBuffer; if (pDevInfo != NULL) { lLoginID = lUserID; printf("On-line, lUserID: %d, Device ID: %s\n", lLoginID, pDevInfo->byDeviceID); } //輸入參數 NET_EHOME_SERVER_INFO *pServerInfo = (NET_EHOME_SERVER_INFO *)pInBuffer; pServerInfo->dwTimeOutCount = 6; //心跳超時次數 pServerInfo->dwKeepAliveSec = 15; //心跳間隔 memcpy(pServerInfo->struUDPAlarmSever.szIP, "10.16.2.123", sizeof("10.16.2.123")); //報警服務器IP地址(TCP協議) pServerInfo->struUDPAlarmSever.wPort = 7200; //報警服務器端口(UDP協議),需要和報警服務器啟動監聽的端口一致 pServerInfo->dwAlarmServerType = 0; //報警服務器類型:0- 只支持UDP協議上報,1- 支持UDP、TCP兩種協議上報 } else if (ENUM_DEV_OFF == dwDataType) { printf("Off-line, lUserID: %d\n", lUserID); NET_ECMS_ForceLogout(lUserID); } else { } return TRUE; } // //AMS報警回調函數 BOOL CALLBACK AlarmMSGCallBack(LONG lHandle, NET_EHOME_ALARM_MSG *pAlarmMsg, void *pUserData) { lListenHandle = lHandle; DWORD dwType = pAlarmMsg->dwAlarmType; //不同的報警類型(dwAlarmType),pAlarmInfo對應不同的報警信息類型 printf("Callback of alarm listening, dwAlarmType[%d]\n", dwType); switch(dwType) { case EHOME_ALARM_UNKNOWN://未知報警信息 printf("Unknown Alarm Type!\n"); break; case EHOME_ALARM://基本報警信息:移動偵測、視頻遮蓋、視頻丟失、PIR報警、人臉偵測、區域入侵等 NET_EHOME_ALARM_INFO struAlarmInfo; memcpy(&struAlarmInfo, pAlarmMsg->pAlarmInfo, sizeof(NET_EHOME_ALARM_INFO)); printf("Basic Alarm: Device ID[%s], szAlarmTime[%s], Alarm Type[%d], Action[%d], VideoChannel[%d]!\n", struAlarmInfo.szDeviceID, \ struAlarmInfo.szAlarmTime, struAlarmInfo.dwAlarmType, struAlarmInfo.dwAlarmAction, struAlarmInfo.dwVideoChannel); break; case EHOME_ALARM_HEATMAP_REPORT://熱度圖報告上傳 NET_EHOME_HEATMAP_REPORT struHeatmapInfo; memcpy(&struHeatmapInfo, pAlarmMsg->pAlarmInfo, sizeof(NET_EHOME_HEATMAP_REPORT)); printf("Heatmap report: Device ID[%s], StartTime[%s], StopTime[%s], dwVideoChannel[%d]!\n", struHeatmapInfo.byDeviceID, \ struHeatmapInfo.byStartTime, struHeatmapInfo.byStopTime, struHeatmapInfo.dwVideoChannel); break; case EHOME_ALARM_FACESNAP_REPORT://人臉抓拍報告上傳 NET_EHOME_FACESNAP_REPORT struFaceSnap; memcpy(&struFaceSnap, pAlarmMsg->pAlarmInfo, sizeof(NET_EHOME_FACESNAP_REPORT)); printf("Face snap: Device ID[%s], AlarmTime[%s], dwFaceScore[%d], dwVideoChannel[%d]!\n", struFaceSnap.byDeviceID, \ struFaceSnap.byAlarmTime, struFaceSnap.dwFaceScore, struFaceSnap.dwVideoChannel); break; case EHOME_ALARM_GPS://GPS信息上傳 NET_EHOME_GPS_INFO struGpsInfo; memcpy(&struGpsInfo, pAlarmMsg->pAlarmInfo, sizeof(NET_EHOME_GPS_INFO)); printf("GPS info: Device ID[%s], SampleTime[%s], Longitude[%d], Latitude[%d]!\n", struGpsInfo.byDeviceID, \ struGpsInfo.bySampleTime, struGpsInfo.dwLongitude, struGpsInfo.dwLatitude ); break; case EHOME_ALARM_CID_REPORT://報警主機CID報警信息 NET_EHOME_CID_INFO struCIDInfo; memcpy(&struCIDInfo, pAlarmMsg->pAlarmInfo, sizeof(NET_EHOME_CID_INFO)); printf("CID info: Device ID[%s], AlarmTime[%s], CID Code[%d], CID Type[%d], CID Describe[%s]!\n", struCIDInfo.byDeviceID, \ struCIDInfo.byTriggerTime, struCIDInfo.dwCIDCode, struCIDInfo.dwCIDType, struCIDInfo.byCIDDescribe ); break; default: break; } return TRUE; } void main(){ //開啟AMS報警監聽 //AMS初始化 NET_EALARM_Init(); //報警監聽參數 NET_EHOME_ALARM_LISTEN_PARAM struListen = {0}; memcpy(struListen.struAddress.szIP, "10.16.2.123", sizeof("10.16.2.123")); struListen.struAddress.wPort = 7200; //報警服務的監聽端口 struListen.fnMsgCb = AlarmMSGCallBack; //報警回調函數 struListen.pUserData = NULL; struListen.byProtocolType = 1; //0- TCP方式(保留,暫不支持),1- UDP方式 //啟動報警監聽 LONG lHandle = NET_EALARM_StartListen(&struListen); if(lHandle < -1) { printf("NET_EALARM_StartListen failed, error code: %d\n", NET_EALARM_GetLastError()); NET_EALARM_Fini(); return; } printf("NET_EALARM_StartListen!\n"); // //CMS注冊模塊初始化 NET_ECMS_Init(); //注冊監聽參數 NET_EHOME_CMS_LISTEN_PARAM struCMSListenPara = {0}; memcpy(struCMSListenPara.struAddress.szIP, "0.0.0.0", sizeof("0.0.0.0")); struCMSListenPara.struAddress.wPort = 7660; struCMSListenPara.fnCB = RegisterCallBack; //啟動監聽,接收設備注冊信息,注冊回調函數里面需要發送報警主機IP和端口給設備 LONG lListen = NET_ECMS_StartListen(&struCMSListenPara); if(lListen < -1) { printf("NET_ECMS_StartListen failed, error code: %d\n", NET_ECMS_GetLastError()); NET_ECMS_Fini(); return; } printf("NET_ECMS_StartListen!\n"); while(1) { Sleep(1000); //注冊成功之后再做后續操作 if(lLoginID >= 0) { break; } } Sleep(300000); //等待5分鍾,接收報警信息 //退出 //CMS停止監聽 if(!NET_ECMS_StopListen(lListen)) { printf("NET_ECMS_StopListen failed, error code: %d\n", NET_ECMS_GetLastError()); } //CMS反初始化,釋放資源 NET_ECMS_Fini(); //AMS停止報警監聽 if(lListenHandle >= 0) { if (!NET_EALARM_StopListen(lListenHandle)) { printf("NET_EALARM_StopListen failed, error code: %d\n", NET_ECMS_GetLastError()); } } //AMS反初始化,釋放資源 NET_EALARM_Fini(); printf("Exit!"); }
如果大家還想了解更多關於EasyCVR集成海康EHome私有協議的調用和說明,可以翻閱TSINGSEE青犀視頻往期相關文章,其中包括:設備錄像回看說明、語音對講操作流程、Ehome協議調用流程介紹等。