视频监控平台-OSD源代码解释和分享:通过大华SDK设置大华设备的OSD

2024-05-03 05:44

本文主要是介绍视频监控平台-OSD源代码解释和分享:通过大华SDK设置大华设备的OSD,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

一、OSD介绍

(一)OSD的定义

(二)OSD的设置

1、自定义文本

2、图标和符号

3、定位和叠加

二、代码和解释

(一)代码和注释

(二)代码解释

1、概述

2、代码详细解释


一、OSD介绍

(一)OSD的定义

        网络摄像机的OSDOn-Screen Display)定义为在视频输出上叠加文本、图形、图像等信息的显示技术。它主要用于为摄像头用户提供实时的操作反馈、设置信息以及其他重要数据。

        通过OSD设置,用户可以自定义要显示在视频画面上的内容,如日期、时间、摄像头分辨率、帧率、亮度、对比度等。这些设置允许用户根据具体需求调整摄像机的输出内容,从而提高监控视频的可读性和可用性。

(二)OSD的设置

        网络摄像机的OSD设置允许用户自定义和显示在摄像机视频画面上的各种信息或图标。这些设置通常用于增强摄像机的功能和用户体验。以下介绍OSD设置的一些常见选项。

1、自定义文本

        用户可以在OSD设置中定义要显示在视频画面上的文本信息,如日期、时间、位置标识符、摄像机名称等。这有助于在查看监控视频时快速识别摄像机的位置和记录的时间。

2、图标和符号

        OSD设置还允许用户添加各种图标和符号,如移动侦测图标、警报状态图标等。这些图标可以直观地显示摄像机的状态或功能,使用户更容易理解。

3、定位和叠加

        用户可以通过OSD设置调整文本和图标的位置、大小、颜色等属性,以确保它们不会遮挡视频画面中的重要信息。此外,一些高级OSD设置还支持文本和图标的叠加效果,可以将多个信息项组合在一起显示。

二、代码和解释

(一)代码和注释

       以下部分C++代码是用于设置视频流的OSD(On Screen Display,屏幕显示)信息,如用户名等。具体如下:

/***************************************************************************// 设置OSD的函数// 参数://   bStart:是否开始显示OSD//   LoginID:登录ID//   channelid:通道ID//   pExtPtzInfo:指向TExtPtzInfo结构的指针,可能包含用户名等信息*****************************************************************************/int CNetSdkForDaHua::SetOSD(bool bStart, long LoginID, int channelid, TExtPtzInfo* pExtPtzInfo)
{if(m_bIsSetOSD == false)return 0;// 如果m_bIsSetOSD标志为false,则不执行任何操作并返回NET_OSD_CUSTOM_TITLE g_stCustomTitle; // 定义OSD自定义标题结构体NET_OSD_CUSTOM_TITLE_TEXT_ALIGN g_stTextAlign; // 定义OSD文本对齐结构体int channel = channelid - 1; // 通道ID减1,因为通常ID从0开始// 获取g_stCustomTitle.dwSize = sizeof(g_stCustomTitle); // 设置结构体大小g_stCustomTitle.emOsdBlendType = NET_EM_OSD_BLEND_TYPE_MAIN; // 设置OSD混合类型为主bool r = CLIENT_GetConfig(LoginID, NET_EM_CFG_CUSTOMTITLE, channel, &g_stCustomTitle, sizeof(g_stCustomTitle)); // 获取配置if (r == false){DBGPrint(M_DevCtrl, ERROR_LEVEL,"%s fail: error = %llu", __FUNCTION__, _EC(CLIENT_GetLastError())); // 如果获取失败,打印错误信息return  -1; // 返回-1表示错误}g_stCustomTitle.nCustomTitleNum = dahuuseindex + 1; // 设置自定义标题编号g_stCustomTitle.dwSize = sizeof(g_stCustomTitle); // 重新设置结构体大小if (bStart){// 设置char szOSDString[DH_VIDEO_OSD_NAME_NUM] = {0}; // 初始化OSD字符串数组int iUserNameLength = pExtPtzInfo->UserName.size(); // 获取用户名长度if(iUserNameLength <= 0){memset(szOSDString, 0, sizeof(szOSDString)); // 如果用户名为空,将OSD字符串数组设置为空}else{strncpy(szOSDString, pExtPtzInfo->UserName.c_str(), DH_VIDEO_OSD_NAME_NUM-1); // 否则,复制用户名到OSD字符串// 以下注释掉的代码可能是另一种格式化用户名的方式// snprintf(szOSDString, DH_VIDEO_OSD_NAME_NUM-1, "用户:%s",pExtPtzInfo->UserName.c_str());}char OSDOutBuf[DH_VIDEO_OSD_NAME_NUM] = {0}; // 初始化OSD输出缓冲区CCodeConvertMgr::CodeConverterToUTF8((unsigned char*)szOSDString,strlen(szOSDString), (unsigned char*)OSDOutBuf, sizeof(OSDOutBuf)); // 将UTF-8转换为另一种编码g_stCustomTitle.stuCustomTitle[dahuuseindex].bEncodeBlend = true; // 设置编码混合为真g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nLeft = 0; // 设置文本左边界为0g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nTop = 6500; // 设置文本顶部边框为6500(可能是像素值)g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nRight = 0; // 设置文本右边界为0g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nBottom = 6500; // 设置文本底部边框为6500(可能是像素值)strcpy(g_stCustomTitle.stuCustomTitle[dahuuseindex].szText, OSDOutBuf); // 将转换后的UTF-8字符串复制到OSD文本缓冲区}else{// 如果不启动OSD,则重置相关参数g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nLeft = 0; // 设置文本左边界为0g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nTop = 6500; // 设置文本顶部边框为6500(可能是像素值)g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nRight = 0; // 设置文本右边界为0g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nBottom = 6500; // 设置文本底部边框为6500(可能是像素值)g_stCustomTitle.stuCustomTitle[dahuuseindex].bEncodeBlend = false; // 设置编码混合为假}// 设置配置r = CLIENT_SetConfig(LoginID, NET_EM_CFG_CUSTOMTITLE, channel, &g_stCustomTitle, sizeof(g_stCustomTitle)); // 应用配置if (r == false){DBGPrint(M_DevCtrl, ERROR_LEVEL,"%s fail: error = %lu", __FUNCTION__, _EC(CLIENT_GetLastError())); // 如果设置失败,打印错误信息return -1; // 返回-1表示错误}// 获取文本对齐信息g_stTextAlign.dwSize = sizeof(g_stTextAlign); // 设置结构体大小r = CLIENT_GetConfig(LoginID, NET_EM_CFG_CUSTOMTITLETEXTALIGN, channel, &g_stTextAlign, sizeof(g_stTextAlign)); // 获取对齐配置if (r == false){DBGPrint(M_DevCtrl, ERROR_LEVEL,"%s fail: error = %lu", __FUNCTION__, _EC(CLIENT_GetLastError())); // 如果获取失败,打印错误信息return -1; // 返回-1表示错误}// 设置文本对齐g_stTextAlign.nCustomTitleNum = dahuuseindex + 1; // 设置自定义标题编号g_stTextAlign.emTextAlign[dahuuseindex] = EM_TEXT_ALIGNTYPE_LEFT; // 设置文本对齐类型为左对齐r = CLIENT_SetConfig(LoginID, NET_EM_CFG_CUSTOMTITLETEXTALIGN, channel, &g_stTextAlign, sizeof(g_stTextAlign)); // 应用对齐配置if (r == false){DBGPrint(M_DevCtrl, ERROR_LEVEL,"%s fail: error = %lu", __FUNCTION__, _EC(CLIENT_GetLastError())); // 如果设置失败,打印错误信息return -1; // 返回-1表示错误}DBGPrint(M_DevCtrl, DEBUG_LEVEL,"%s dahua net sdk set OSD succeed!", __FUNCTION__); // 如果一切成功,打印成功信息return 0; // 返回0表示成功}

(二)代码解释

1、概述

        这段C++代码是一个函数,名为CNetSdkForDaHua::SetOSD,其作用是设置视频流的OSDOn Screen Display,屏幕显示)信息。是大华视频设备OSD设置的一个例子,涉及到了与设备交互、错误处理和日志记录等多个方面。

2、代码详细解释

1)函数原型

        int CNetSdkForDaHua::SetOSD(bool bStart, long LoginID, int channelid, TExtPtzInfo* pExtPtzInfo) 这个函数接受五个参数:一个布尔值bStart,表示是否开始OSD显示;一个长整型LoginID,可能用于登录设备;一个整型channelid,表示视频通道号;一个指向TExtPtzInfo结构的指针pExtPtzInfo,该结构可能包含了用户名等额外信息。

2)初始检查

        if(m_bIsSetOSD == false) return 0; 如果m_bIsSetOSD标志为false,则表示不允许设置OSD,函数直接返回0

3)变量定义

        NET_OSD_CUSTOM_TITLE g_stCustomTitle; NET_OSD_CUSTOM_TITLE_TEXT_ALIGN g_stTextAlign; 定义了两个结构体变量,用于存储OSD的定制标题和文本对齐信息。

4)通道号处理

        int channel = channelid - 1; channelid1后作为通道号使用。

5)获取OSD配置

        通过CLIENT_GetConfig函数获取当前的OSD配置。

6)设置OSD显示

  • 如果bStarttrue,则开始OSD显示。
  • 创建一个字符数组szOSDString来存储OSD显示的文本。
  • pExtPtzInfo中的用户名复制到szOSDString,并对其进行编码转换以适配UTF-8格式。
  • 设置定制标题的显示位置和文本。

7)关闭OSD显示

        如果bStartfalse,则关闭OSD显示,这通过重置相关变量实现。

8)应用配置

        使用CLIENT_SetConfig函数将OSD配置应用到设备上。

9)获取和设置文本对齐

        获取当前的文本对齐设置。

        设置新的文本对齐方式。

10)错误处理

        在获取和设置配置的过程中,如果发生错误,函数会打印错误信息并返回-1

11)成功提示

        如果设置成功,打印成功信息。

12)返回值

        函数最终返回0表示成功,返回-1表示发生错误。

13)注意

  • 代码中存在一些未定义的宏,如DH_VIDEO_OSD_NAME_NUM、EM_TEXT_ALIGNTYPE_LEFT等,这些应该是在其他地方定义的常量。
  • TExtPtzInfo类型未在代码中定义,应该是外部结构体或类。
  • CLIENT_GetConfig和CLIENT_SetConfig可能是特定于某个SDK的函数,用于与视频设备进行交互。
  • DBGPrint函数用于打印日志,可能是自定义的日志函数。
  • _EC函数用于获取错误代码,也可能是特定SDK的函数。

文章正下方可以看到我的联系方式:鼠标“点击” 下面的 “威迪斯特-就是video system 微信名片”字样,就会出现我的二维码,欢迎沟通探讨。


这篇关于视频监控平台-OSD源代码解释和分享:通过大华SDK设置大华设备的OSD的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

用js控制视频播放进度基本示例代码

《用js控制视频播放进度基本示例代码》写前端的时候,很多的时候是需要支持要网页视频播放的功能,下面这篇文章主要给大家介绍了关于用js控制视频播放进度的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言html部分:JavaScript部分:注意:总结前言在javascript中控制视频播放

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Python解析器安装指南分享(Mac/Windows/Linux)

《Python解析器安装指南分享(Mac/Windows/Linux)》:本文主要介绍Python解析器安装指南(Mac/Windows/Linux),具有很好的参考价值,希望对大家有所帮助,如有... 目NMNkN录1js. 安装包下载1.1 python 下载官网2.核心安装方式3. MACOS 系统安