视频监控平台-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; // 设置文本左边界为0
        g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nTop = 6500; // 设置文本顶部边框为6500(可能是像素值)
        g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nRight = 0; // 设置文本右边界为0
        g_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; // 设置文本左边界为0
        g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nTop = 6500; // 设置文本顶部边框为6500(可能是像素值)
        g_stCustomTitle.stuCustomTitle[dahuuseindex].stuRect.nRight = 0; // 设置文本右边界为0
        g_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 微信名片”字样,就会出现我的二维码,欢迎沟通探讨。


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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ThreeJS:Mesh网格与三维变换

Mesh网格 ThreeJS中&#xff0c;Mesh表示基于以三角形为多边形网格(polygon mesh)的物体的类&#xff0c;同时也作为其它类的基类。 通过Mesh网格&#xff0c;我们可以组合Geometry几何体与Material材质属性&#xff0c;在3D世界中&#xff0c;定义一个物体。例如&#xff1a;之…

vue2(4)之scoped解决样式冲突/组件通信/非父子通信/ref和$refs/异步更新/.sync/事件总线/provide和inject

vue2 一、学习目标1.组件的三大组成部分&#xff08;结构/样式/逻辑&#xff09;2.组件通信3.综合案例&#xff1a;小黑记事本&#xff08;组件版&#xff09;4.进阶语法 二、scoped解决样式冲突**1.默认情况**&#xff1a;2.代码演示3.scoped原理4.总结 三、data必须是一个函数…

Copilot Venture Studio創始合伙人楊林苑確認出席“邊緣智能2024 - AI開發者峰會”

隨著AI技術的迅猛發展&#xff0c;全球正逐步進入邊緣計算智能化與分布式AI深度融合的新時代&#xff0c;共同書寫著分布式智能創新應用的壯麗篇章。邊緣智能&#xff0c;作為融合邊緣計算和智能技術的新興領域&#xff0c;正逐漸成為推動AI發展的關鍵力量。借助分布式和去中心…

由于找不到mfc140u.dll,无法继续执行的多种解决方法

在我们日常与计算机的密切互动中&#xff0c;或许不少用户都曾遇到过这样一个棘手的问题&#xff1a;系统突然弹出一个提示窗口&#xff0c;告知我们“找不到mfc140u.dll文件”。这个文件是Microsoft Foundation Class&#xff08;MFC&#xff09;库的一部分&#xff0c;用于支…

提升编码技能:学习如何使用 C# 和 Fizzler 获取特价机票

引言 五一假期作为中国的传统节日&#xff0c;也是旅游热门的时段之一&#xff0c;特价机票往往成为人们关注的焦点。在这个数字化时代&#xff0c;利用爬虫技术获取特价机票信息已成为一种常见的策略。通过结合C#和Fizzler库&#xff0c;我们可以更加高效地实现这一目标&…

20240502在WIN10下给X99平台上的M6000显卡安装驱动程序

20240502在WIN10下给X99平台上的M6000显卡安装驱动程序 2024/5/2 9:32 人工智能计算领域的领导者 | NVIDIA https://www.nvidia.cn/ C:\NVIDIA\DisplayDriver\552.22\Win11_Win10-DCH_64\International IMPORTANT NOTICE -- READ CAREFULLY: -------------------------------…

pmp培训机构哪个比较好,求推荐-

寻找一个自己认为比较好的PMP培训机构千万不要盲目&#xff0c;先在网上看看大家都推荐什么&#xff0c;看一下各个机构的老学员反馈&#xff0c;这些对我们的选择有非常大的帮助&#xff0c;最起码有了一些风评上的参考&#xff0c;现状就是目前线上机构的竞争比较大&#xff…

c语言从入门到函数速成(1)

温馨提醒&#xff1a;本篇文章适合人群&#xff1a;刚学c又感觉那个地方不怎么懂的同学以及以及学了一些因为自身原因停学一段时间后又继续学c的同学 好&#xff0c;正片开始。 主函数 学c时最先学的是我们c语言程序的主体函数&#xff0c;c的主函数有两种写法&#xff0c;这…

【JavaEE】Thread的方法和属性

文章目录 1、Thread的常见构造方法2、Thread的几个常见属性2.1 ID2.2 名称2.3 状态2.4 优先级2.5 是否后台线程2.6 是否存活2.7 是否被中断 3.补充说明3.1 Thread.sleep()的作用3.2 Thread.sleep()的异常处理方式 1、Thread的常见构造方法 方法说明Thread()创建线程对象Thread…

动态规划-子序列问题1

文章目录 1. 最长递增子序列&#xff08;300&#xff09;2. 摆动序列&#xff08;376&#xff09;3. 最长递增子序列的个数&#xff08;673&#xff09;4. 最长数对链&#xff08;646&#xff09; 1. 最长递增子序列&#xff08;300&#xff09; 题目描述&#xff1a; 状态表…

Linux 进程间通信之命名管道

&#x1f493;博主CSDN主页:麻辣韭菜&#x1f493;   ⏩专栏分类&#xff1a;Linux知识分享⏪   &#x1f69a;代码仓库:Linux代码练习&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学习更多Linux知识   &#x1f51d; 目录 前言 命名管道 创建一个命名管道 …

LeetCode题练习与总结:删除排序链表中的重复元素--83

一、题目描述 给定一个已排序的链表的头 head &#xff0c; 删除所有重复的元素&#xff0c;使每个元素只出现一次 。返回 已排序的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,1,2] 输出&#xff1a;[1,2]示例 2&#xff1a; 输入&#xff1a;head [1,1,2,3,3] 输…

袁庭新ES系列17节|Spring Data Elasticsearch基础

前言 为了简化对Elasticsearch的操作Spring Data提供了Spring Data Elasticsearch。Spring Data Elasticsearch是Spring Data技术对Elasticsearch原生API封装之后的产物&#xff0c;它通过对原生API的封装&#xff0c;使得程序员可以简单的对Elasticsearch进行各种操作。接下来…

InfluxDB安装使用介绍

1.介绍 InfluxDB是一个由InfluxData开发的开源时序型数据。它由Go写成&#xff0c;着力于高性能地查询与存储时序型数据。InfluxDB被广泛应用于存储系统的监控数据&#xff0c;IoT行业的实时数据等场景。 2.对常见关系型数据库&#xff08;MySQL&#xff09;的基础概念对比 1…

满上! —— 十年之约#22(ROI 48%)

原创 | 刘教链 空头在忍耐了很久之后&#xff0c;趁五一劳动节东方放假发动突袭&#xff0c;把BTC&#xff08;比特币&#xff09;打到6万刀以下。这使得我们终于终结了7个月七连涨的趋势&#xff0c;确定4月以收跌结束。 4月开盘70k&#xff0c;最高72.8k&#xff0c;最低59.6…

CPU卡园区码分析计算,根据卡号计算外部密码

生活中我们可能遇到这种情况&#xff0c;比如家里的门禁卡丢失了&#xff0c;拿着家里人的去街上 复制&#xff0c;结果对方说无法复制&#xff0c;因为这种卡是CPU卡的一种&#xff0c;必须知道园区码才可以成功复制&#xff0c;这个时候&#xff0c;我们就需要请出我们的战神…

uniapp实现点击事件跳转页面

首先定义一个点击事件 这里采用的vue3的写法&#xff0c;然后写上触发事件后要跳转的路径 function jump() {uni.switchTab({url:/pages/bangong/index})} 到这里就简单的实现uniapp的点击跳转页面了

开源农场管理软件

软件介绍 Tania是一款基于Go、Vue.JS和SQLite的开源农场日记软件。该项目始于2016年11月&#xff0c;由于无法找到适合自己需求的软件&#xff0c;开发团队决定自己搭建一套适合家庭后院花园的管理系统&#xff0c;并可以随时随地进行管理。 项目功能描述 Tania是一款免费且开源…

密码学基础练习五道 RSA、elgamal、elgamal数字签名、DSA数字签名、有限域(GF)上的四则运算

1.RSA #include <stdlib.h>#include <stdio.h>#include <string.h>#include <math.h>#include <time.h>#define PRIME_MAX 200 //生成素数范围#define EXPONENT_MAX 200 //生成指数e范围#define Element_Max 127 //加密单元的…

Java基础知识(三) -- 流程控制

不论哪种编程语言&#xff0c;都会提供两种基本的流程控制结构&#xff1a;分支结构和循环结构。其中分支结构用于实现根据条件来选择性地执行某段代码&#xff0c;循环结构则用于实现根据循环条件重复执行某段代码。 1. 顺序结构 任何编程语言中最常见的程序结构就是顺序结构…
最新文章