java实现海康NVR/DVR设备工作状态获取

2023-12-07 13:49

本文主要是介绍java实现海康NVR/DVR设备工作状态获取,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

该功能需要到JNA的知识。

通过查阅海康设备网络SDK编程指南(DVR&NVR)可以知道海康SDK的调用方法都要同过如下过程:

虚线框的流程是可选部分,不会影响其他流程和模块的功能使用。具体的模块说明可以自行参考SDK开发文件。

主要功能代码:

测试例子,因此虚线部分功能不实现

1.初始化设备SDK:对整个网络SDK 系统的初始化,内存预分配等操作。

代码:HCNetSDK sdk = HCNetSDK.INSTANCE;

     sdk.NET_DVR_Init();//返回booleaan值

2.注册设备:实现用户的注册功能,注册成功后,返回的用户ID 作为其他功能操作的唯一标识

代码: NativeLong uid=new  NativeLong(-1);

    NET_DVR_DEVICEINFO_V30 devinfo=new NET_DVR_DEVICEINFO_V30();//设备信息

    uid=sdk.NET_DVR_Login_V30((string)IP,(short)PORT,(string)user,string()pwd,devinfo);//返回一个用户编号,同时将设备信息写入devinfo

3.设备工作状态获取(参数配置模块):

代码:NET_DVR_WORKSTATE_V30 devwork=new NET_DVR_WORKSTATE_V30();

   sdk.NET_DVR_GetDVRWorkState_V30(uid, devwork);//返回Boolean值,判断是否获取设备能力

   IntByReference ibrBytesReturned = new IntByReference(0);//获取IP接入配置参数

     NET_DVR_IPPARACFG ipcfg=new  NET_DVR_IPPARACFG();

   ipcfg.write();

     Pointer lpIpParaConfig =ipcfg.getPointer();

        sdk.NET_DVR_GetDVRConfig(uid,sdk.NET_DVR_GET_IPPARACFG,new NativeLong(0),lpIpParaConfig,ipcfg.size(),ibrBytesReturned);

    ipcfg.read();

4.注销设备:

  代码:sdk.NET_DVR_Logout(uid);

5.释放SDK

  代码:sdk.NET_DVR_Cleanup();

 

详细例子:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
package ClientDemo;
import com.sun.jna.NativeLong;
import com.sun.jna.Pointer;
import com.sun.jna.ptr.IntByReference;
import ClientDemo.HCNetSDK.NET_DVR_DEVICEINFO_V30;
import ClientDemo.HCNetSDK.NET_DVR_IPPARACFG;
import ClientDemo.HCNetSDK.NET_DVR_WORKSTATE_V30;
public class Device_demo {
     public static void main(String[] args) {
         // TODO Auto-generated method stub
         HCNetSDK sdk = HCNetSDK.INSTANCE;
         if (!sdk.NET_DVR_Init()){
             System.out.println( "SDK初始化失败" );
             return ;
         }
         NativeLong uid= new  NativeLong(- 1 );
         NET_DVR_DEVICEINFO_V30 devinfo= new NET_DVR_DEVICEINFO_V30(); //设备信息
         String ip= "192.168.10.191" ;
         short port= 8000 ;
         uid=sdk.NET_DVR_Login_V30(ip,port, "admin" , "hk123456" ,devinfo); //返回一个用户编号,同时将设备信息写入devinfo
         int Iuid=uid.intValue();
         if (Iuid< 0 ){
             System.out.println( "设备注册失败" );
             return ;
         }
         NET_DVR_WORKSTATE_V30 devwork= new NET_DVR_WORKSTATE_V30();
         if (!sdk.NET_DVR_GetDVRWorkState_V30(uid, devwork)){
             //返回Boolean值,判断是否获取设备能力
             System.out.println( "返回设备状态失败" );
         }
         IntByReference ibrBytesReturned = new IntByReference( 0 ); //获取IP接入配置参数
         NET_DVR_IPPARACFG ipcfg= new NET_DVR_IPPARACFG();
         ipcfg.write();
         Pointer lpIpParaConfig =ipcfg.getPointer();
         sdk.NET_DVR_GetDVRConfig(uid,sdk.NET_DVR_GET_IPPARACFG, new NativeLong( 0 ),lpIpParaConfig,ipcfg.size(),ibrBytesReturned);
         ipcfg.read();
         System.out.print( "IP地址:" +ip);
         System.out.println( "|设备状态:" +devwork.dwDeviceStatic); //0正常,1CPU占用率过高,2硬件错误,3未知
         //显示模拟通道
         for ( int i= 0 ;i< devinfo.byChanNum;i++){
             System.out.print( "Camera" +i+ 1 ); //模拟通道号名称
             System.out.print( "|是否录像:" +devwork.struChanStatic[i].byRecordStatic); //0不录像,不录像
             System.out.print( "|信号状态:" +devwork.struChanStatic[i].bySignalStatic); //0正常,1信号丢失
             System.out.println( "|硬件状态:" +devwork.struChanStatic[i].byHardwareStatic); //0正常,1异常          
         }
         sdk.NET_DVR_Logout(uid);
         sdk.NET_DVR_Cleanup();     
     }
}

 输出:

分类: java-视频SDK开发

这篇关于java实现海康NVR/DVR设备工作状态获取的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/466118

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的