基于大华网络摄像头SDK开发抓图工具类(C++)

2023-10-19 10:50

本文主要是介绍基于大华网络摄像头SDK开发抓图工具类(C++),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【前言】

众所周知,大华网络摄像头没有直接提供相应的ROS驱动包,所以我们理论上有两个办法在C++中获取网络摄像头图像:

一是通过OpenCV(FFmpeg)的videocapture类去抓取图像;

二是通过大华官方提供的SDK,自己封装一个抓图工具类。

这里主要讲述第二种方法。

【资源】

大华SDK下载地址

supporthttps://support.dahuatech.com/tools/sdkExploit/24

【干货】

1、先搞一个放数据结构的类

#ifndef USERDEFINE_H
#define USERDEFINE_H#include "dhnetsdk.h"
#include "dhconfigsdk.h"
#include <list>
#include <vector>typedef struct
{LLONG lRealPlayHandle;unsigned long dwStatistic;
} DH_Channel_Info;typedef struct
{LLONG lLoginHandle;int nChannelCount;char szDevIp[32];int nPort;char szUserName[32];char szPassWord[32];DH_Channel_Info channel[16];
} DH_Device_Info;typedef std::list<DH_Device_Info*> DEVICE_LIST;
extern DEVICE_LIST g_DeviceList;typedef std::vector<unsigned char> ONE_IMAGE_BUFFER;
extern ONE_IMAGE_BUFFER g_ImageBuffer;extern bool g_SnapSuccFlag;#endif

2、再搞一个接口类,用来封装SDK的API

#include "UserDefine.h"
#include <stdio.h>
#include <time.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
#include <string>
#include <map>class DHCamera
{
public:DHCamera();~DHCamera();bool initSDKClient();void initDeviceInfo(DH_Device_Info &stDeviceInfo);void loadDeviceInfo();void loginDev();void grabCamImage(LLONG loginHandle);void logoutDev();public:std::map<std::string, LLONG> devHandles_map;
};

3、再来看一下类的具体实现吧

#include "DHCamera.h"DEVICE_LIST g_DeviceList;
ONE_IMAGE_BUFFER g_ImageBuffer;
bool g_SnapSuccFlag = false;
static bool g_bNetSDKInitFlag = false;
static short g_nCmdSerial = 0;void CALLBACK DisConnectFunc(LLONG lLoginID, char *pchDVRIP, LONG nDVRPort, LDWORD dwUser)
{DHCamera* pThis = (DHCamera *)dwUser;if(NULL == pThis){return;}printf("Call DisConnectFunc\n");printf("lLoginID[0x%x]", lLoginID);if (NULL != pchDVRIP){printf("pchDVRIP[%s]\n", pchDVRIP);}printf("nDVRPort[%d]\n", nDVRPort);printf("dwUser[%p]\n", dwUser);printf("\n");return;
}void CALLBACK HaveReConnect(LLONG lLoginID, char *pchDVRIP, LONG nDVRPort, LDWORD dwUser)
{printf("Call HaveReConnect\n");printf("lLoginID[0x%x]", lLoginID);if (NULL != pchDVRIP){printf("pchDVRIP[%s]\n", pchDVRIP);}printf("nDVRPort[%d]\n", nDVRPort);printf("dwUser[%p]\n", dwUser);printf("\n");
}void CALLBACK SnapRev(LLONG lLoginID, BYTE *pBuf, UINT RevLen, UINT EncodeType, DWORD CmdSerial, LDWORD dwUser)
{std::vector<unsigned char> current_frame(pBuf, pBuf+RevLen);g_ImageBuffer.swap(current_frame);g_SnapSuccFlag = true;
}DHCamera::DHCamera()
{
}DHCamera::~DHCamera()
{DEVICE_LIST::iterator it = g_DeviceList.begin();while (it != g_DeviceList.end()){DH_Device_Info *pDeviceInfo = (*it);if (pDeviceInfo != nullptr){delete pDeviceInfo;pDeviceInfo = nullptr;}it++;}g_DeviceList.clear();
}bool DHCamera::initSDKClient()
{g_bNetSDKInitFlag = CLIENT_Init(DisConnectFunc, (LDWORD)this);CLIENT_SetAutoReconnect(HaveReConnect, 0);return g_bNetSDKInitFlag;
}void DHCamera::initDeviceInfo(DH_Device_Info &stDeviceInfo)
{stDeviceInfo.lLoginHandle = 0UL;stDeviceInfo.nChannelCount = 0;stDeviceInfo.nPort = 0;memset(&stDeviceInfo.szDevIp , 0 , sizeof(stDeviceInfo.szDevIp));memset(&stDeviceInfo.szUserName , 0 , sizeof(stDeviceInfo.szUserName));memset(&stDeviceInfo.szPassWord , 0 , sizeof(stDeviceInfo.szPassWord));memset(&stDeviceInfo.channel , 0 , sizeof(stDeviceInfo.channel));
}void DHCamera::loadDeviceInfo()
{DEVICE_LIST::iterator it = g_DeviceList.begin();while (it != g_DeviceList.end()){DH_Device_Info *pDeviceInfo = (*it);if (pDeviceInfo != nullptr){delete pDeviceInfo;pDeviceInfo = nullptr;}it++;}g_DeviceList.clear();int start_ip = 150;int connect_num = 12;int port = 37777;for(int i = start_ip; i < (start_ip + connect_num); i++){DH_Device_Info* device_info = new DH_Device_Info;initDeviceInfo(*device_info);std::string ip = "192.168.1.";strncpy(device_info->szDevIp, (ip+std::to_string(i)).c_str(), sizeof(device_info->szDevIp)-1);device_info->nPort = port;strncpy(device_info->szUserName, "admin", sizeof(device_info->szUserName)-1);strncpy(device_info->szPassWord, "admin123", sizeof(device_info->szPassWord)-1);g_DeviceList.push_back(device_info);}printf("Init Dev's Num : %d\n", g_DeviceList.size());
}void DHCamera::loginDev()
{DEVICE_LIST::iterator it = g_DeviceList.begin();while(it != g_DeviceList.end()){DH_Device_Info *pDeviceInfo = (*it);if(pDeviceInfo == NULL){it++;continue;}NET_IN_LOGIN_WITH_HIGHLEVEL_SECURITY stInparam;memset(&stInparam, 0, sizeof(stInparam));stInparam.dwSize = sizeof(stInparam);strncpy(stInparam.szIP, pDeviceInfo->szDevIp, sizeof(stInparam.szIP) - 1);strncpy(stInparam.szPassword, pDeviceInfo->szPassWord, sizeof(stInparam.szPassword) - 1);strncpy(stInparam.szUserName, pDeviceInfo->szUserName, sizeof(stInparam.szUserName) - 1);stInparam.nPort = pDeviceInfo->nPort;stInparam.emSpecCap = EM_LOGIN_SPEC_CAP_TCP;NET_OUT_LOGIN_WITH_HIGHLEVEL_SECURITY stOutparam;memset(&stOutparam, 0, sizeof(stOutparam));stOutparam.dwSize = sizeof(stOutparam);pDeviceInfo->lLoginHandle = CLIENT_LoginWithHighLevelSecurity(&stInparam, &stOutparam);if(pDeviceInfo->lLoginHandle != 0){devHandles_map.emplace(pDeviceInfo->szDevIp, pDeviceInfo->lLoginHandle);printf("CLIENT_LoginWithHighLevelSecurity %s[%d] Success\n" , pDeviceInfo->szDevIp , pDeviceInfo->nPort);usleep(500000);}else {printf("Failed to login IP[%s]\n", pDeviceInfo->szDevIp);}}
}void DHCamera::logoutDev()
{DEVICE_LIST::iterator it = g_DeviceList.begin();while(it != g_DeviceList.end()){if((*it)->lLoginHandle != 0){CLIENT_Logout((*it)->lLoginHandle);}}if (TRUE == g_bNetSDKInitFlag){CLIENT_Cleanup();g_bNetSDKInitFlag = FALSE;}
}void DHCamera::grabCamImage(long loginHandle)
{if (0 == loginHandle){return;}// 设置抓图回调函数CLIENT_SetSnapRevCallBack(SnapRev, NULL);//事例中默认通道 ID 为 0、抓图模式为抓一幅图,用户可根据实际情况自行选择int nChannelId = 0;int nSnapType = 0; // 抓图模式;-1:表示停止抓图, 0:表示请求一帧, 1:表示定时发送请求, 2:表示连续请求// 发送抓图命令给前端设备SNAP_PARAMS stuSnapParams;stuSnapParams.Channel = nChannelId;stuSnapParams.mode = nSnapType;stuSnapParams.CmdSerial = ++g_nCmdSerial; // 请求序列号,有效值范围 0~65535,超过范围会被截断为 unsigned shortif (FALSE == CLIENT_SnapPictureEx(loginHandle, &stuSnapParams)){printf("CLIENT_SnapPictureEx Failed!Last Error[%x]\n", CLIENT_GetLastError());return;}else{printf("CLIENT_SnapPictureEx succ\n");}
}

【后言】

如果这篇博客对你有帮助,就点个赞呗!

这篇关于基于大华网络摄像头SDK开发抓图工具类(C++)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:https://blog.csdn.net/weixin_39538031/article/details/131008912
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/239278

相关文章

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

C++/类与对象/默认成员函数@构造函数的用法

《C++/类与对象/默认成员函数@构造函数的用法》:本文主要介绍C++/类与对象/默认成员函数@构造函数的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录名词概念默认成员函数构造函数概念函数特征显示构造函数隐式构造函数总结名词概念默认构造函数:不用传参就可以

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

Linux系统之stress-ng测压工具的使用

《Linux系统之stress-ng测压工具的使用》:本文主要介绍Linux系统之stress-ng测压工具的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、理论1.stress工具简介与安装2.语法及参数3.具体安装二、实验1.运行8 cpu, 4 fo