From 3edac3da8bd95d40768bcf4962a93cdf9ebe073d Mon Sep 17 00:00:00 2001 From: Frank <3224536684@qq.com> Date: Wed, 20 Sep 2023 14:53:43 +0800 Subject: [PATCH] :sparkles: version0.0.2 init --- .gitignore | 35 + .mvn/wrapper/maven-wrapper.jar | Bin 0 -> 59925 bytes .mvn/wrapper/maven-wrapper.properties | 18 + mvnw | 316 + mvnw.cmd | 188 + pom.xml | 103 + .../starter/config/HkSupSdkConfiguration.java | 38 + .../starter/config/HkSupSdkProperties.java | 96 + .../hksup/starter/model/FaceInfoParam.java | 39 + .../starter/model/SearchFaceInfoParam.java | 41 + .../javase/hksup/starter/model/UserInfo.java | 70 + .../hksup/starter/model/UserInfoDetail.java | 31 + .../javase/hksup/starter/sdk/HCISUPAlarm.java | 483 + .../javase/hksup/starter/sdk/HCISUPCMS.java | 1018 ++ .../javase/hksup/starter/sdk/HCISUPSS.java | 429 + .../hksup/starter/sdk/HCISUPStream.java | 227 + .../javase/hksup/starter/sdk/HCNetSDK.java | 10533 ++++++++++++++++ .../hksup/starter/service/CmsServer.java | 580 + .../hksup/starter/service/SsServer.java | 373 + .../hksup/starter/utils/CommonMethod.java | 63 + .../hksup/starter/utils/ConfigFileUtil.java | 83 + .../hksup/starter/utils/SystemUtil.java | 24 + 22 files changed, 14788 insertions(+) create mode 100644 .gitignore create mode 100644 .mvn/wrapper/maven-wrapper.jar create mode 100644 .mvn/wrapper/maven-wrapper.properties create mode 100755 mvnw create mode 100644 mvnw.cmd create mode 100644 pom.xml create mode 100644 src/main/java/net/javase/hksup/starter/config/HkSupSdkConfiguration.java create mode 100644 src/main/java/net/javase/hksup/starter/config/HkSupSdkProperties.java create mode 100644 src/main/java/net/javase/hksup/starter/model/FaceInfoParam.java create mode 100644 src/main/java/net/javase/hksup/starter/model/SearchFaceInfoParam.java create mode 100644 src/main/java/net/javase/hksup/starter/model/UserInfo.java create mode 100644 src/main/java/net/javase/hksup/starter/model/UserInfoDetail.java create mode 100755 src/main/java/net/javase/hksup/starter/sdk/HCISUPAlarm.java create mode 100755 src/main/java/net/javase/hksup/starter/sdk/HCISUPCMS.java create mode 100755 src/main/java/net/javase/hksup/starter/sdk/HCISUPSS.java create mode 100755 src/main/java/net/javase/hksup/starter/sdk/HCISUPStream.java create mode 100755 src/main/java/net/javase/hksup/starter/sdk/HCNetSDK.java create mode 100644 src/main/java/net/javase/hksup/starter/service/CmsServer.java create mode 100644 src/main/java/net/javase/hksup/starter/service/SsServer.java create mode 100755 src/main/java/net/javase/hksup/starter/utils/CommonMethod.java create mode 100755 src/main/java/net/javase/hksup/starter/utils/ConfigFileUtil.java create mode 100755 src/main/java/net/javase/hksup/starter/utils/SystemUtil.java diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..8b1360c --- /dev/null +++ b/.gitignore @@ -0,0 +1,35 @@ +HELP.md +target/ +!.mvn/wrapper/maven-wrapper.jar +!**/src/main/**/target/ +!**/src/test/**/target/ + +### STS ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans +.sts4-cache + +### IntelliJ IDEA ### +.idea +*.iws +*.iml +*.ipr + +### NetBeans ### +/nbproject/private/ +/nbbuild/ +/dist/ +/nbdist/ +/.nb-gradle/ +build/ +!**/src/main/**/build/ +!**/src/test/**/build/ + +### VS Code ### +.vscode/ + +.DS_Store \ No newline at end of file diff --git a/.mvn/wrapper/maven-wrapper.jar b/.mvn/wrapper/maven-wrapper.jar new file mode 100644 index 0000000000000000000000000000000000000000..bf82ff01c6cdae4a1bb754a6e062954d77ac5c11 GIT binary patch literal 59925 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

dy!05UMhSKsK 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 VCNKd3JGtOvEm(5t0lFyE{{i--k}m)N literal 0 HcmV?d00001 diff --git a/.mvn/wrapper/maven-wrapper.properties b/.mvn/wrapper/maven-wrapper.properties new file mode 100644 index 0000000..ca5ab4b --- /dev/null +++ b/.mvn/wrapper/maven-wrapper.properties @@ -0,0 +1,18 @@ +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.8.7/apache-maven-3.8.7-bin.zip +wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.1/maven-wrapper-3.1.1.jar diff --git a/mvnw b/mvnw new file mode 100755 index 0000000..8a8fb22 --- /dev/null +++ b/mvnw @@ -0,0 +1,316 @@ +#!/bin/sh +# ---------------------------------------------------------------------------- +# Licensed to the Apache Software Foundation (ASF) under one +# or more contributor license agreements. See the NOTICE file +# distributed with this work for additional information +# regarding copyright ownership. The ASF licenses this file +# to you under the Apache License, Version 2.0 (the +# "License"); you may not use this file except in compliance +# with the License. You may obtain a copy of the License at +# +# https://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, +# software distributed under the License is distributed on an +# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +# KIND, either express or implied. See the License for the +# specific language governing permissions and limitations +# under the License. +# ---------------------------------------------------------------------------- + +# ---------------------------------------------------------------------------- +# Maven Start Up Batch script +# +# Required ENV vars: +# ------------------ +# JAVA_HOME - location of a JDK home dir +# +# Optional ENV vars +# ----------------- +# M2_HOME - location of maven2's installed home dir +# MAVEN_OPTS - parameters passed to the Java VM when running Maven +# e.g. to debug Maven itself, use +# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 +# MAVEN_SKIP_RC - flag to disable loading of mavenrc files +# ---------------------------------------------------------------------------- + +if [ -z "$MAVEN_SKIP_RC" ] ; then + + if [ -f /usr/local/etc/mavenrc ] ; then + . /usr/local/etc/mavenrc + fi + + if [ -f /etc/mavenrc ] ; then + . /etc/mavenrc + fi + + if [ -f "$HOME/.mavenrc" ] ; then + . "$HOME/.mavenrc" + fi + +fi + +# OS specific support. $var _must_ be set to either true or false. +cygwin=false; +darwin=false; +mingw=false +case "`uname`" in + CYGWIN*) cygwin=true ;; + MINGW*) mingw=true;; + Darwin*) darwin=true + # Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home + # See https://developer.apple.com/library/mac/qa/qa1170/_index.html + if [ -z "$JAVA_HOME" ]; then + if [ -x "/usr/libexec/java_home" ]; then + export JAVA_HOME="`/usr/libexec/java_home`" + else + export JAVA_HOME="/Library/Java/Home" + fi + fi + ;; +esac + +if [ -z "$JAVA_HOME" ] ; then + if [ -r /etc/gentoo-release ] ; then + JAVA_HOME=`java-config --jre-home` + fi +fi + +if [ -z "$M2_HOME" ] ; then + ## resolve links - $0 may be a link to maven's home + PRG="$0" + + # need this for relative symlinks + while [ -h "$PRG" ] ; do + ls=`ls -ld "$PRG"` + link=`expr "$ls" : '.*-> \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG="`dirname "$PRG"`/$link" + fi + done + + saveddir=`pwd` + + M2_HOME=`dirname "$PRG"`/.. + + # make it fully qualified + M2_HOME=`cd "$M2_HOME" && pwd` + + cd "$saveddir" + # echo Using m2 at $M2_HOME +fi + +# For Cygwin, ensure paths are in UNIX format before anything is touched +if $cygwin ; then + [ -n "$M2_HOME" ] && + M2_HOME=`cygpath --unix "$M2_HOME"` + [ -n "$JAVA_HOME" ] && + JAVA_HOME=`cygpath --unix "$JAVA_HOME"` + [ -n "$CLASSPATH" ] && + CLASSPATH=`cygpath --path --unix "$CLASSPATH"` +fi + +# For Mingw, ensure paths are in UNIX format before anything is touched +if $mingw ; then + [ -n "$M2_HOME" ] && + M2_HOME="`(cd "$M2_HOME"; pwd)`" + [ -n "$JAVA_HOME" ] && + JAVA_HOME="`(cd "$JAVA_HOME"; pwd)`" +fi + +if [ -z "$JAVA_HOME" ]; then + javaExecutable="`which javac`" + if [ -n "$javaExecutable" ] && ! [ "`expr \"$javaExecutable\" : '\([^ ]*\)'`" = "no" ]; then + # readlink(1) is not available as standard on Solaris 10. + readLink=`which readlink` + if [ ! `expr "$readLink" : '\([^ ]*\)'` = "no" ]; then + if $darwin ; then + javaHome="`dirname \"$javaExecutable\"`" + javaExecutable="`cd \"$javaHome\" && pwd -P`/javac" + else + javaExecutable="`readlink -f \"$javaExecutable\"`" + fi + javaHome="`dirname \"$javaExecutable\"`" + javaHome=`expr "$javaHome" : '\(.*\)/bin'` + JAVA_HOME="$javaHome" + export JAVA_HOME + fi + fi +fi + +if [ -z "$JAVACMD" ] ; then + if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD="$JAVA_HOME/jre/sh/java" + else + JAVACMD="$JAVA_HOME/bin/java" + fi + else + JAVACMD="`\\unset -f command; \\command -v java`" + fi +fi + +if [ ! -x "$JAVACMD" ] ; then + echo "Error: JAVA_HOME is not defined correctly." >&2 + echo " We cannot execute $JAVACMD" >&2 + exit 1 +fi + +if [ -z "$JAVA_HOME" ] ; then + echo "Warning: JAVA_HOME environment variable is not set." +fi + +CLASSWORLDS_LAUNCHER=org.codehaus.plexus.classworlds.launcher.Launcher + +# traverses directory structure from process work directory to filesystem root +# first directory with .mvn subdirectory is considered project base directory +find_maven_basedir() { + + if [ -z "$1" ] + then + echo "Path not specified to find_maven_basedir" + return 1 + fi + + basedir="$1" + wdir="$1" + while [ "$wdir" != '/' ] ; do + if [ -d "$wdir"/.mvn ] ; then + basedir=$wdir + break + fi + # workaround for JBEAP-8937 (on Solaris 10/Sparc) + if [ -d "${wdir}" ]; then + wdir=`cd "$wdir/.."; pwd` + fi + # end of workaround + done + echo "${basedir}" +} + +# concatenates all lines of a file +concat_lines() { + if [ -f "$1" ]; then + echo "$(tr -s '\n' ' ' < "$1")" + fi +} + +BASE_DIR=`find_maven_basedir "$(pwd)"` +if [ -z "$BASE_DIR" ]; then + exit 1; +fi + +########################################################################################## +# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central +# This allows using the maven wrapper in projects that prohibit checking in binary data. +########################################################################################## +if [ -r "$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" ]; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found .mvn/wrapper/maven-wrapper.jar" + fi +else + if [ "$MVNW_VERBOSE" = true ]; then + echo "Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..." + fi + if [ -n "$MVNW_REPOURL" ]; then + jarUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + else + jarUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + fi + while IFS="=" read key value; do + case "$key" in (wrapperUrl) jarUrl="$value"; break ;; + esac + done < "$BASE_DIR/.mvn/wrapper/maven-wrapper.properties" + if [ "$MVNW_VERBOSE" = true ]; then + echo "Downloading from: $jarUrl" + fi + wrapperJarPath="$BASE_DIR/.mvn/wrapper/maven-wrapper.jar" + if $cygwin; then + wrapperJarPath=`cygpath --path --windows "$wrapperJarPath"` + fi + + if command -v wget > /dev/null; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found wget ... using wget" + fi + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + wget "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" + else + wget --http-user=$MVNW_USERNAME --http-password=$MVNW_PASSWORD "$jarUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" + fi + elif command -v curl > /dev/null; then + if [ "$MVNW_VERBOSE" = true ]; then + echo "Found curl ... using curl" + fi + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + curl -o "$wrapperJarPath" "$jarUrl" -f + else + curl --user $MVNW_USERNAME:$MVNW_PASSWORD -o "$wrapperJarPath" "$jarUrl" -f + fi + + else + if [ "$MVNW_VERBOSE" = true ]; then + echo "Falling back to using Java to download" + fi + javaClass="$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.java" + # For Cygwin, switch paths to Windows format before running javac + if $cygwin; then + javaClass=`cygpath --path --windows "$javaClass"` + fi + if [ -e "$javaClass" ]; then + if [ ! -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then + if [ "$MVNW_VERBOSE" = true ]; then + echo " - Compiling MavenWrapperDownloader.java ..." + fi + # Compiling the Java class + ("$JAVA_HOME/bin/javac" "$javaClass") + fi + if [ -e "$BASE_DIR/.mvn/wrapper/MavenWrapperDownloader.class" ]; then + # Running the downloader + if [ "$MVNW_VERBOSE" = true ]; then + echo " - Running MavenWrapperDownloader.java ..." + fi + ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$MAVEN_PROJECTBASEDIR") + fi + fi + fi +fi +########################################################################################## +# End of extension +########################################################################################## + +export MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"} +if [ "$MVNW_VERBOSE" = true ]; then + echo $MAVEN_PROJECTBASEDIR +fi +MAVEN_OPTS="$(concat_lines "$MAVEN_PROJECTBASEDIR/.mvn/jvm.config") $MAVEN_OPTS" + +# For Cygwin, switch paths to Windows format before running java +if $cygwin; then + [ -n "$M2_HOME" ] && + M2_HOME=`cygpath --path --windows "$M2_HOME"` + [ -n "$JAVA_HOME" ] && + JAVA_HOME=`cygpath --path --windows "$JAVA_HOME"` + [ -n "$CLASSPATH" ] && + CLASSPATH=`cygpath --path --windows "$CLASSPATH"` + [ -n "$MAVEN_PROJECTBASEDIR" ] && + MAVEN_PROJECTBASEDIR=`cygpath --path --windows "$MAVEN_PROJECTBASEDIR"` +fi + +# Provide a "standardized" way to retrieve the CLI args that will +# work with both Windows and non-Windows executions. +MAVEN_CMD_LINE_ARGS="$MAVEN_CONFIG $@" +export MAVEN_CMD_LINE_ARGS + +WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain + +exec "$JAVACMD" \ + $MAVEN_OPTS \ + $MAVEN_DEBUG_OPTS \ + -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \ + "-Dmaven.home=${M2_HOME}" \ + "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \ + ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@" diff --git a/mvnw.cmd b/mvnw.cmd new file mode 100644 index 0000000..1d8ab01 --- /dev/null +++ b/mvnw.cmd @@ -0,0 +1,188 @@ +@REM ---------------------------------------------------------------------------- +@REM Licensed to the Apache Software Foundation (ASF) under one +@REM or more contributor license agreements. See the NOTICE file +@REM distributed with this work for additional information +@REM regarding copyright ownership. The ASF licenses this file +@REM to you under the Apache License, Version 2.0 (the +@REM "License"); you may not use this file except in compliance +@REM with the License. You may obtain a copy of the License at +@REM +@REM https://www.apache.org/licenses/LICENSE-2.0 +@REM +@REM Unless required by applicable law or agreed to in writing, +@REM software distributed under the License is distributed on an +@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +@REM KIND, either express or implied. See the License for the +@REM specific language governing permissions and limitations +@REM under the License. +@REM ---------------------------------------------------------------------------- + +@REM ---------------------------------------------------------------------------- +@REM Maven Start Up Batch script +@REM +@REM Required ENV vars: +@REM JAVA_HOME - location of a JDK home dir +@REM +@REM Optional ENV vars +@REM M2_HOME - location of maven2's installed home dir +@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands +@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending +@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven +@REM e.g. to debug Maven itself, use +@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000 +@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files +@REM ---------------------------------------------------------------------------- + +@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on' +@echo off +@REM set title of command window +title %0 +@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on' +@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO% + +@REM set %HOME% to equivalent of $HOME +if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%") + +@REM Execute a user defined script before this one +if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre +@REM check for pre script, once with legacy .bat ending and once with .cmd ending +if exist "%USERPROFILE%\mavenrc_pre.bat" call "%USERPROFILE%\mavenrc_pre.bat" %* +if exist "%USERPROFILE%\mavenrc_pre.cmd" call "%USERPROFILE%\mavenrc_pre.cmd" %* +:skipRcPre + +@setlocal + +set ERROR_CODE=0 + +@REM To isolate internal variables from possible post scripts, we use another setlocal +@setlocal + +@REM ==== START VALIDATION ==== +if not "%JAVA_HOME%" == "" goto OkJHome + +echo. +echo Error: JAVA_HOME not found in your environment. >&2 +echo Please set the JAVA_HOME variable in your environment to match the >&2 +echo location of your Java installation. >&2 +echo. +goto error + +:OkJHome +if exist "%JAVA_HOME%\bin\java.exe" goto init + +echo. +echo Error: JAVA_HOME is set to an invalid directory. >&2 +echo JAVA_HOME = "%JAVA_HOME%" >&2 +echo Please set the JAVA_HOME variable in your environment to match the >&2 +echo location of your Java installation. >&2 +echo. +goto error + +@REM ==== END VALIDATION ==== + +:init + +@REM Find the project base dir, i.e. the directory that contains the folder ".mvn". +@REM Fallback to current working directory if not found. + +set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR% +IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir + +set EXEC_DIR=%CD% +set WDIR=%EXEC_DIR% +:findBaseDir +IF EXIST "%WDIR%"\.mvn goto baseDirFound +cd .. +IF "%WDIR%"=="%CD%" goto baseDirNotFound +set WDIR=%CD% +goto findBaseDir + +:baseDirFound +set MAVEN_PROJECTBASEDIR=%WDIR% +cd "%EXEC_DIR%" +goto endDetectBaseDir + +:baseDirNotFound +set MAVEN_PROJECTBASEDIR=%EXEC_DIR% +cd "%EXEC_DIR%" + +:endDetectBaseDir + +IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig + +@setlocal EnableExtensions EnableDelayedExpansion +for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a +@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS% + +:endReadAdditionalConfig + +SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe" +set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar" +set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain + +set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + +FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( + IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B +) + +@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central +@REM This allows using the maven wrapper in projects that prohibit checking in binary data. +if exist %WRAPPER_JAR% ( + if "%MVNW_VERBOSE%" == "true" ( + echo Found %WRAPPER_JAR% + ) +) else ( + if not "%MVNW_REPOURL%" == "" ( + SET DOWNLOAD_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar" + ) + if "%MVNW_VERBOSE%" == "true" ( + echo Couldn't find %WRAPPER_JAR%, downloading it ... + echo Downloading from: %DOWNLOAD_URL% + ) + + powershell -Command "&{"^ + "$webclient = new-object System.Net.WebClient;"^ + "if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^ + "$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^ + "}"^ + "[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^ + "}" + if "%MVNW_VERBOSE%" == "true" ( + echo Finished downloading %WRAPPER_JAR% + ) +) +@REM End of extension + +@REM Provide a "standardized" way to retrieve the CLI args that will +@REM work with both Windows and non-Windows executions. +set MAVEN_CMD_LINE_ARGS=%* + +%MAVEN_JAVA_EXE% ^ + %JVM_CONFIG_MAVEN_PROPS% ^ + %MAVEN_OPTS% ^ + %MAVEN_DEBUG_OPTS% ^ + -classpath %WRAPPER_JAR% ^ + "-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" ^ + %WRAPPER_LAUNCHER% %MAVEN_CONFIG% %* +if ERRORLEVEL 1 goto error +goto end + +:error +set ERROR_CODE=1 + +:end +@endlocal & set ERROR_CODE=%ERROR_CODE% + +if not "%MAVEN_SKIP_RC%"=="" goto skipRcPost +@REM check for post script, once with legacy .bat ending and once with .cmd ending +if exist "%USERPROFILE%\mavenrc_post.bat" call "%USERPROFILE%\mavenrc_post.bat" +if exist "%USERPROFILE%\mavenrc_post.cmd" call "%USERPROFILE%\mavenrc_post.cmd" +:skipRcPost + +@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on' +if "%MAVEN_BATCH_PAUSE%"=="on" pause + +if "%MAVEN_TERMINATE_CMD%"=="on" exit %ERROR_CODE% + +cmd /C exit /B %ERROR_CODE% diff --git a/pom.xml b/pom.xml new file mode 100644 index 0000000..25bd8a2 --- /dev/null +++ b/pom.xml @@ -0,0 +1,103 @@ + + + 4.0.0 + + org.springframework.boot + spring-boot-starter-parent + 2.7.15 + + + net.javase.hk + hk-sup-spring-boot-starter + 0.0.2 + hk-sup-spring-boot-starter + hk-sup-spring-boot-starter + + 1.8 + + + + org.springframework.boot + spring-boot-starter + + + + org.springframework.boot + spring-boot-autoconfigure + provided + + + + org.projectlombok + lombok + true + provided + + + + net.dreamlu + mica-auto + 2.3.2 + provided + + + + org.springframework.boot + spring-boot-starter-test + test + + + com.alibaba + fastjson + 2.0.26 + + + + com.sun.jna + jna + 3.0.9 + + + + org.apache.commons + commons-text + 1.10.0 + + + + + + gitea + https://gitea.52it.vip/api/packages/Frank/maven + + + + + + gitea + https://gitea.52it.vip/api/packages/Frank/maven + + + + gitea + https://gitea.52it.vip/api/packages/Frank/maven + + + + + + + org.apache.maven.plugins + maven-compiler-plugin + 3.8.1 + + ${java.version} + ${java.version} + ${project.build.sourceEncoding} + + + + + + diff --git a/src/main/java/net/javase/hksup/starter/config/HkSupSdkConfiguration.java b/src/main/java/net/javase/hksup/starter/config/HkSupSdkConfiguration.java new file mode 100644 index 0000000..ef6e702 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/config/HkSupSdkConfiguration.java @@ -0,0 +1,38 @@ +package net.javase.hksup.starter.config; + +import lombok.RequiredArgsConstructor; +import lombok.extern.slf4j.Slf4j; +import net.javase.hksup.starter.service.CmsServer; +import net.javase.hksup.starter.service.SsServer; +import org.springframework.boot.context.properties.EnableConfigurationProperties; +import org.springframework.context.ApplicationContext; +import org.springframework.context.annotation.Bean; +import org.springframework.context.annotation.Configuration; + +/** + * HkSupSdkConfiguration + * + * @author Frank + */ +@Slf4j +@Configuration +@RequiredArgsConstructor +@EnableConfigurationProperties(HkSupSdkProperties.class) +public class HkSupSdkConfiguration { + + private final HkSupSdkProperties hkSupSdkProperties; + + private final ApplicationContext applicationContext; + + + @Bean(initMethod = "startCmsServer", destroyMethod = "stopCmsServer") + public CmsServer cmsServer() { + return new CmsServer(hkSupSdkProperties, applicationContext); + } + + + @Bean(initMethod = "startSsServer", destroyMethod = "stopSsServer") + public SsServer ssServer() { + return new SsServer(hkSupSdkProperties, applicationContext); + } +} diff --git a/src/main/java/net/javase/hksup/starter/config/HkSupSdkProperties.java b/src/main/java/net/javase/hksup/starter/config/HkSupSdkProperties.java new file mode 100644 index 0000000..8ed09f9 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/config/HkSupSdkProperties.java @@ -0,0 +1,96 @@ +package net.javase.hksup.starter.config; + +import lombok.Getter; +import lombok.Setter; +import org.springframework.boot.context.properties.ConfigurationProperties; + +/** + * HkSupSdkProperties + * + * @author Frank + */ +@Getter +@Setter +@ConfigurationProperties("hk.sup") +public class HkSupSdkProperties { + + private String cmsServerIp; + + private Integer cmsServerPort = 7660; + + private String dasServerIp; + + private Integer dasServerPort = 7660; + + private String smsServerIp; + + private Integer smsServerPort = 7665; + + private String smsServerListenIp = "127.0.0.1"; + + private Integer smsServerListenPort = 7665; + + private String smsBackServerIp; + + private Integer smsBackServerPort = 8000; + + private String smsBackServerListenIp = "127.0.0.1"; + + private Integer smsBackServerListenPort = 8000; + + private String voiceSmsServerIp; + + private Integer voiceSmsServerPort = 7500; + + private String voiceSmsServerListenIp = "127.0.0.1"; + + private Integer voiceSmsServerListenPort = 7500; + + private String alarmServerIp; + + private Integer alarmServerTCPPort = 7663; + + private Integer alarmServerUDPPort = 7662; + + private Integer alarmServerType; + + private String alarmServerListenIp = "127.0.0.1"; + + private Integer alarmServerListenTcpPort = 7663; + + private Integer alarmServerListenUdpPort = 7662; + + private String picServerIp; + + private Integer picServerPort = 6011; + + private Integer picServerType; + + private String picServerListenIp = "127.0.0.1"; + + private Integer picServerListenPort = 6011; + + private String kmsUsername = "test"; + + private String kmsPassword = "12345"; + + private String szAk = "test"; + + private String szSk = "12345"; + + /** + * ISUP5.0登录秘钥 + */ + private String key; + + /** + * lib目录 + */ + private String libPath; + + private Boolean jnaDebug = false; + + private String sdkLogPath; + + +} diff --git a/src/main/java/net/javase/hksup/starter/model/FaceInfoParam.java b/src/main/java/net/javase/hksup/starter/model/FaceInfoParam.java new file mode 100644 index 0000000..26f795c --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/model/FaceInfoParam.java @@ -0,0 +1,39 @@ +package net.javase.hksup.starter.model; + +import lombok.AllArgsConstructor; +import lombok.Getter; +import lombok.NoArgsConstructor; +import lombok.Setter; + +import java.io.Serializable; + +/** + * FaceInfoParam + * + * @author Frank + */ +@Getter +@Setter +@NoArgsConstructor +@AllArgsConstructor +public class FaceInfoParam implements Serializable { + + /** + * 人脸图片URL,ISUP协议下发人脸使用URL方式 + */ + private String faceURL; + + private String faceLibType = "blackFD"; + + private String FDID = "1"; + + /** + * 人员工号,以人为中心方式,下发人脸前需要先下发人员工号,人脸绑定在工号上 + */ + private String FPID; + + public FaceInfoParam(String faceURL, String FPID) { + this.faceURL = faceURL; + this.FPID = FPID; + } +} diff --git a/src/main/java/net/javase/hksup/starter/model/SearchFaceInfoParam.java b/src/main/java/net/javase/hksup/starter/model/SearchFaceInfoParam.java new file mode 100644 index 0000000..9d9866a --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/model/SearchFaceInfoParam.java @@ -0,0 +1,41 @@ +package net.javase.hksup.starter.model; + +import lombok.Getter; +import lombok.Setter; + +import java.io.Serializable; + +/** + * SearchFaceInfoParam + * + * @author Frank + */ +@Getter +@Setter +public class SearchFaceInfoParam implements Serializable { + + private Integer searchResultPosition = 0; + + private Integer maxResults = 30; + + private String faceLibType = "blackFD"; + + private String FDID = "1"; + + private String FPID; + + public SearchFaceInfoParam() { + } + + public SearchFaceInfoParam(String FPID) { + this.FPID = FPID; + } + + public SearchFaceInfoParam(Integer searchResultPosition, Integer maxResults, String faceLibType, String FDID, String FPID) { + this.searchResultPosition = searchResultPosition; + this.maxResults = maxResults; + this.faceLibType = faceLibType; + this.FDID = FDID; + this.FPID = FPID; + } +} diff --git a/src/main/java/net/javase/hksup/starter/model/UserInfo.java b/src/main/java/net/javase/hksup/starter/model/UserInfo.java new file mode 100644 index 0000000..d53504b --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/model/UserInfo.java @@ -0,0 +1,70 @@ +package net.javase.hksup.starter.model; + +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Getter; +import lombok.Setter; + +import java.io.Serializable; +import java.util.List; + +/** + * UserInfo + * + * @author Frank + */ +@Getter +@Setter +@Builder +public class UserInfo implements Serializable { + + private String employeeNo; + + private String name; + + @Builder.Default + private String userType = "normal"; + + private Valid Valid; + + @Builder.Default + private String doorRight = "1"; + + private List RightPlan; + + @Builder.Default + private String gender = "male"; + + @Builder.Default + private Boolean localUIRight = false; + + + @Getter + @Setter + public static class Valid { + private Boolean enable = true; + + private String beginTime = "2023-01-01T00:00:00"; + + private String endTime = "2050-12-30T23:59:59"; + + private String timeType = "local"; + + } + + + @Getter + @Setter + @AllArgsConstructor + public static class RightPlan { + + private Long doorNo; + + private String planTemplateNo = "1"; + + public RightPlan(Long doorNo) { + this.doorNo = doorNo; + } + } + +} diff --git a/src/main/java/net/javase/hksup/starter/model/UserInfoDetail.java b/src/main/java/net/javase/hksup/starter/model/UserInfoDetail.java new file mode 100644 index 0000000..accb770 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/model/UserInfoDetail.java @@ -0,0 +1,31 @@ +package net.javase.hksup.starter.model; + +import lombok.AllArgsConstructor; +import lombok.Getter; +import lombok.Setter; + +import java.io.Serializable; +import java.util.List; + +/** + * UserInfoDetail + * + * @author Frank + */ +@Getter +@Setter +public class UserInfoDetail implements Serializable { + + private String mode; + + private List EmployeeNoList; + + @Getter + @Setter + @AllArgsConstructor + public static class EmployeeNo { + + private String employeeNo; + } + +} diff --git a/src/main/java/net/javase/hksup/starter/sdk/HCISUPAlarm.java b/src/main/java/net/javase/hksup/starter/sdk/HCISUPAlarm.java new file mode 100755 index 0000000..9bdfe92 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/sdk/HCISUPAlarm.java @@ -0,0 +1,483 @@ +package net.javase.hksup.starter.sdk; + +import com.sun.jna.Callback; +import com.sun.jna.Library; +import com.sun.jna.Pointer; +import com.sun.jna.Structure; + +//SDK接口说明,HCNetSDK.dll + +//windows gdi接口,gdi32.dll in system32 folder, 在设置遮挡区域,移动侦测区域等情况下使用 +public interface HCISUPAlarm extends Library { + + /***宏定义***/ + //常量 + public static final int MAX_DEVICE_ID_LEN = 256; //设备ID长度 + public static final int NAME_LEN = 32; //用户名长度(在HCNetSDK的头文件中也有定义) + public static final int NET_EHOME_SERIAL_LEN = 12; //设备序列号长度 + + public static final int MAX_TIME_LEN = 32; //时间字符串长度 + public static final int MAX_REMARK_LEN = 64; //报警备注长度 + public static final int MAX_URL_LEN = 512; //URL长度 + public static final int CID_DES_LEN = 32; //CID报警描述长度 + public static final int MAX_FILE_PATH_LEN = 256; + public static final int MAX_UUID_LEN = 64; //最大UUID长度 + public static final int CID_DES_LEN_EX = 256; //CID报警描述长度扩展 + public static final int MAX_PICTURE_NUM = 5; //最大图片数量 + public static final int MAX_VIDEO_TYPE_LEN = 16; + public static final int MAX_SUBSYSTEM_LEN = 64; //子系统个数最大值 + + // 报警事件 + public static final int EHOME_ALARM_UNKNOWN = 0; //未知报警类型 + public static final int EHOME_ALARM = 1; //Ehome基本报警 + public static final int EHOME_ALARM_HEATMAP_REPORT = 2; //热度图报告 + public static final int EHOME_ALARM_FACESNAP_REPORT = 3; //人脸抓拍报告 + public static final int EHOME_ALARM_GPS = 4; //GPS信息上传 + public static final int EHOME_ALARM_CID_REPORT = 5; //报警主机CID告警上传 + public static final int EHOME_ALARM_NOTICE_PICURL = 6; //图片URL上报 + public static final int EHOME_ALARM_NOTIFY_FAIL = 7; //异步失败通知 + public static final int EHOME_ALARM_SELFDEFINE = 9; //自定义报警上传 + public static final int EHOME_ALARM_DEVICE_NETSWITCH_REPORT = 10; //设备网络切换上传 + public static final int EHOME_ALARM_ACS = 11; //门禁事件上报 + public static final int EHOME_ALARM_WIRELESS_INFO = 12; //无线网络信息上传 + public static final int EHOME_ISAPI_ALARM = 13; //ISAPI报警上传 + public static final int EHOME_INFO_RELEASE_PRIVATE = 14; //为了兼容信息发布产品的私有EHome协议报警(不再维护) + public static final int EHOME_ALARM_MPDCDATA = 15; //车载设备的客流数据 + public static final int EHOME_ALARM_QRCODE = 20; //二维码报警上传 + public static final int EHOME_ALARM_FACETEMP = 21; //人脸测温报警上传 + + public static final int ALARM_TYPE_DEV_CHANGED_STATUS = 700; //700-设备状态改变报警上传 + public static final int ALARM_TYPE_CHAN_CHANGED_STATUS = 701; //701-通道状态改变报警上报 + public static final int ALARM_TYPE_HD_CHANGED_STATUS = 702; //702-磁盘状态改变报警上报 + public static final int ALARM_TYPE_DEV_TIMING_STATUS = 703; //703-定时上报设备状态信息 + public static final int ALARM_TYPE_CHAN_TIMING_STATUS = 704; //704-定时上报通道状态信息 + public static final int ALARM_TYPE_HD_TIMING_STATUS = 705; //705-定时上报磁盘状态信息 + public static final int ALARM_TYPE_RECORD_ABNORMAL = 706; //706-录像异常,当前时间点本来应该是在执行录像的,结果因为异常原因导致设备无法正常录像。 + + /** + * 地址信息结构体 + */ + public static class NET_EHOME_IPADDRESS extends Structure { + /** + * IP地址 + */ + public byte[] szIP = new byte[128]; + /** + * 端口号 + */ + public short wPort; //端口 + /** + * 保留,设为 0 + */ + public byte[] byRes = new byte[2]; + } + + public static class BYTE_ARRAY extends Structure { + public byte[] byValue; + + public BYTE_ARRAY(int iLen) { + byValue = new byte[iLen]; + } + } + + /** + * 报警信息结构体 + */ + public static class NET_EHOME_ALARM_MSG extends Structure { + /** + * 报警类型 + */ + public int dwAlarmType; //报警类型,见EN_ALARM_TYPE + + /** + * 报警信息详情,不同报警类型对应不同报警详情 + */ + public Pointer pAlarmInfo; //报警内容(结构体) + + /** + * 保存报警信息详情所需的缓冲区大小 + */ + public int dwAlarmInfoLen; //结构体报警内容长度 + + /** + * XML 格式的报警信息报文 + */ + public Pointer pXmlBuf; //报警内容(XML) + + /** + * 保存报警信息 XML 报文所需的缓冲区大小 + */ + public int dwXmlBufLen; //xml报警内容长度 + + /** + * 设备序列号。最大长度为 12 字节(对应宏定义为“NET_EHOME_SERIAL_LEN”) + */ + public byte[] sSerialNumber = new byte[NET_EHOME_SERIAL_LEN]; //设备序列号,用于进行Token认证 + + /** + * URL + */ + public Pointer pHttpUrl; + + /** + * URL 大小 + */ + public int dwHttpUrlLen; + + /** + * 保留,设为 0。最大长度为 12 字节 + */ + public byte[] byRes = new byte[12]; + } + + public static class NET_EHOME_ALARM_ISAPI_INFO extends Structure { + public Pointer pAlarmData; // 报警数据 + public int dwAlarmDataLen; // 报警数据长度 + public byte byDataType; // 0-invalid,1-xml,2-json + public byte byPicturesNumber; // 图片数量 + public byte[] byRes = new byte[2]; + public Pointer pPicPackData; // 图片变长部分,byPicturesNumber个NET_EHOME_ALARM_ISAPI_PICDATA + public byte[] byRes1 = new byte[32]; + } + + public static class NET_EHOME_HEATMAP_REPORT extends Structure { + public int dwSize; + public byte[] byDeviceID = new byte[MAX_DEVICE_ID_LEN]; //设备注册ID + public int dwVideoChannel; //通道号 + public byte[] byStartTime = new byte[MAX_TIME_LEN]; //开始时间(设备本地时间),格式:YYYY-MM-DD HH:MM:SS + public byte[] byStopTime = new byte[MAX_TIME_LEN]; //结束时间(设备本地时间),格式:YYYY-MM-DD HH:MM:SS + public NET_EHOME_HEATMAP_VALUE struHeatmapValue; //热度值 + public NET_EHOME_PIXEL_ARRAY_SIZE struPixelArraySize; //热度图大小 + public byte[] byPixelArrayData = new byte[MAX_URL_LEN]; //热度图数据索引 + public byte byRetransFlag; //重传标记,0-实时包,1-重传包 + public byte byTimeDiffH; //byStartTime,byStopTime与国际标准时间(UTC)的时差(小时),-12 ... +14,0xff表示无效 + public byte byTimeDiffM; //byStartTime,byStopTime与国际标准时间(UTC)的时差(分钟),-30,0, 30, 45, 0xff表示无效 + public byte[] byRes = new byte[61]; + } + + public static class NET_EHOME_HEATMAP_VALUE extends Structure { + public int dwMaxHeatMapValue; //最大热度值 + public int dwMinHeatMapValue; //最小热度值 + public int dwTimeHeatMapValue; //平均热度值 + } + + public static class NET_EHOME_PIXEL_ARRAY_SIZE extends Structure { + public int dwLineValue; //像素点行值 + public int dwColumnValue; //像素点列值 + } + + public static class NET_EHOME_FACESNAP_REPORT extends Structure { + public int dwSize; + public byte[] byDeviceID = new byte[MAX_DEVICE_ID_LEN]; //设备注册ID + public int dwVideoChannel; //通道号 + public byte[] byAlarmTime = new byte[MAX_TIME_LEN]; //报警时间(设备本地时间),格式:YYYY-MM-DD HH:MM:SS + public int dwFacePicID; //人脸图ID + public int dwFaceScore; //人脸评分,0-100 + public int dwTargetID; //目标ID + public NET_EHOME_ZONE struTarketZone; //目标区域,归一化坐标:数值为当前画面的百分比大小*1000,精度为小数点后三位 + public NET_EHOME_ZONE struFacePicZone; //人脸子图区域,归一化坐标:数值为当前画面的百分比大小*1000,精度为小数点后三位 + public NET_EHOME_HUMAN_FEATURE struHumanFeature;//人属性 + public int dwStayDuration; //停留画面中时间 + public int dwFacePicLen; //人脸图长度,单位:字节 + public byte[] byFacePicUrl = new byte[MAX_URL_LEN]; //人脸子图数据索引 + public int dwBackgroudPicLen; //背景图片长度,单位:字节 + public byte[] byBackgroudPicUrl = new byte[MAX_URL_LEN]; //背景图片数据索引 + public byte byRetransFlag; //重传标记,0-实时包,1-重传包 + public byte byTimeDiffH; //byAlamTime与国际标准时间(UTC)的时差(小时),-12 ... +14,0xff表示无效 + public byte byTimeDiffM; //byAlamTime与国际标准时间(UTC)的时差(分钟),-30,0, 30, 45, 0xff表示无效 + public byte[] byRes = new byte[61]; + } + + public static class NET_EHOME_ZONE extends Structure { + public int dwX; //X轴坐标 + public int dwY; //Y轴坐标 + public int dwWidth; //宽度 + public int dwHeight; //高度 + } + + public static class NET_EHOME_HUMAN_FEATURE extends Structure { + public byte byAgeGroup; //年龄属性,1-婴幼儿,2-儿童,3-少年,4-青少年,5-青年,6-壮年,7-中年,8-中老年,9-老年 + public byte bySex; //性别属性,1-男,2-女 + public byte byEyeGlass; //是否戴眼睛,1-不戴,2-戴 + public byte byMask; //是否戴口罩,1-不戴,2-戴 + public byte[] byRes = new byte[12]; + } + + public static class NET_EHOME_GPS_INFO extends Structure { + public int dwSize; + public byte[] bySampleTime = new byte[MAX_TIME_LEN]; //GPS采样时间,设备本地时间,格式:YYYY-MM-DD HH:MM:SS + public byte[] byDeviceID = new byte[MAX_DEVICE_ID_LEN]; //设备注册ID + public byte[] byDivision = new byte[2]; //division[0]:'E'or'W'(东经/西经), division[1]:'N'or'S'(北纬/南纬) + public byte bySatelites;//卫星数量 + public byte byPrecision; //精度因子,原始值*100 + public int dwLongitude; //经度,取值范围为(0~180*3600*100),转换公式为:longitude= 实际度*3600*100+实际分*60*100+实际秒*100 + public int dwLatitude; //纬度,取值范围为(0~90*3600*100),转换公式为:latitude = 实际度*3600*100+实际分*60*100+实际秒*100 + public int dwDirection; //方向,取值范围为(0~359.9*100),正北方向为0,转换公式为:direction= 实际方向*100 + public int dwSpeed;//速度,取值范围为(0~999.9*100000),转换公式为:speed =实际速度*100000,相当于cm/h + public int dwHeight; //高度,单位:cm + public byte byRetransFlag; //重传标记,0-实时包,1-重传包 + public byte byLocateMode; //定位模式(初值0),仅NMEA0183 3.00版本输出,值:0-自主定位,1- 差分,2- 估算,3- 数据无效 + public byte byTimeDiffH; //bySampleTime与国际标准时间(UTC)的时差(小时),-12 ... +14,0xff表示无效 + public byte byTimeDiffM; //bySampleTimee与国际标准时间(UTC)的时差(分钟),-30,0, 30, 45, 0xff表示无效 + public int dwMileage; //设备里程数统计,单位为米,整型,每天第一次开机或者00:00:00时清零,后续累加当天里程数上报到中心 + public byte[] byRes = new byte[56]; + } + + public static class NET_EHOME_CID_INFO extends Structure { + public int dwSize; + public byte[] byDeviceID = new byte[MAX_DEVICE_ID_LEN];//设备注册ID + public int dwCIDCode; //CID报告代码 + public int dwCIDType; //CID报警类型 + public int dwSubSysNo; //产生报告的子系统号,0为全局报告,子系统范围0~32 + public byte[] byCIDDescribe = new byte[CID_DES_LEN]; //CID报警描述 + public byte[] byTriggerTime = new byte[MAX_TIME_LEN]; //CID报警发生时间(设备本地时间),格式:YYYY-MM-DD HH:MM:SS + public byte[] byUploadTime = new byte[MAX_TIME_LEN];//CID报告上传时间(设备本地时间),格式:YYYY-MM-DD HH:MM:SS + public NET_EHOME_CID_PARAM struCIDParam; //CID报警参数 + public byte byTimeDiffH;//byTriggerTime,byUploadTime与国际标准时间(UTC)的时差(小时),-12 ... +14,0xff表示无效 + public byte byTimeDiffM;//byTriggerTime,byUploadTime与国际标准时间(UTC)的时差(分钟),-30,0, 30, 45, 0xff表示无效 + public byte byExtend;//是否有扩展字段 + public byte[] byRes1 = new byte[5]; + public Pointer pCidInfoEx; //byExtend为1是有效,指向NET_EHOME_CID_INFO_INTERNAL_EX结构体 + public Pointer pPicInfoEx; + public byte[] byRes = new byte[44]; + } + + public static class NET_EHOME_CID_PARAM extends Structure { + public int dwUserType; //用户类型,1键盘用户 2网络用户,其他值表示无效 + public int lUserNo; //用户类型,-1表示无效 + public int lZoneNo; //防区号,-1表示无效 + public int lKeyboardNo; //键盘号 + public int lVideoChanNo; //视频通道号 + public int lDiskNo; //硬盘号 + public int lModuleAddr; //模块地址 + public byte[] byUserName = new byte[NAME_LEN]; //用户名 + public byte[] byRes = new byte[32]; + } + + public static class NET_EHOME_CID_INFO_INTERNAL_EX extends Structure { + public byte byRecheck; //是否是视频复核报警 1-复核报警,0-普通报警 + public byte[] byRes = new byte[3]; + public byte[] byUUID = new byte[MAX_UUID_LEN]; //报警唯一ID,区分是否属于同一个报警;不支持视频复核报警时,该字段为0; + public byte[] byVideoURL = new byte[MAX_URL_LEN]; // byRecheck为1时有效,视频复核报警中视频的URL地址,用于从存储服务器获取视频;(复核报警第二次上报该URL) + public byte[] byCIDDescribeEx = new byte[CID_DES_LEN_EX]; //CID报警描述扩展 + public byte[] byVideoType = new byte[MAX_VIDEO_TYPE_LEN]; + public byte[] byLinkageSubSystem = new byte[MAX_SUBSYSTEM_LEN]; //关联的子系统 + public byte[] byRes1 = new byte[176]; + } + + public static class NET_EHOME_CID_INFO_PICTUREINFO_EX extends Structure { + public byte[][] byPictureURL = new byte[MAX_PICTURE_NUM][MAX_URL_LEN];//图片URL + public byte[] byRes1 = new byte[512]; + } + + /** + * 报警回调函数 + */ + public static interface EHomeMsgCallBack extends Callback { + + /** + * 报警回调函数 + * + * @param iHandle 报警监听句柄 + * @param pAlarmMsg 报警信息,详情参见结构体 {@link NET_EHOME_ALARM_MSG} + * @param pUser 用户参数 + * @return true | false + */ + public boolean invoke(int iHandle, NET_EHOME_ALARM_MSG pAlarmMsg, Pointer pUser); + } + + /** + * 报警监听参数结构体 + */ + public static class NET_EHOME_ALARM_LISTEN_PARAM extends Structure { + /** + * 本地监听信息。IP 为 0.0.0.0 的情况下,默认 + * 为本地地址,多个网卡的情况下,默认为从操 + * 作系统获取到的第一个地址 + */ + public NET_EHOME_IPADDRESS struAddress; + public EHomeMsgCallBack fnMsgCb; //报警信息回调函数 + public Pointer pUserData; //用户数据 + public byte byProtocolType; //协议类型,0-TCP,1-UDP + public byte byUseCmsPort; //是否复用CMS端口,0-不复用,非0-复用,如果复用cms端口,协议类型字段无效(此时本地监听信息struAddress填本地回环地址) + public byte byUseThreadPool; //0-回调报警时,使用线程池,1-回调报警时,不使用线程池,默认情况下,报警回调的时候,使用线程池 + public byte byRes[] = new byte[29]; + ; + } + + public static class NET_EHOME_LOCAL_GENERAL_CFG extends Structure { + public byte byAlarmPictureSeparate; //控制透传ISAPI报警数据和图片是否分离,0-不分离,1-分离(分离后走EHOME_ISAPI_ALARM回调返回) + public byte[] byRes = new byte[127]; + } + + public static class NET_EHOME_ALARM_INFO extends Structure { + public int dwSize; + public byte[] szAlarmTime = new byte[MAX_TIME_LEN]; //报警触发时间(设备本地时间),格式,YYYY-MM-DD HH:MM:SS + public byte[] szDeviceID = new byte[MAX_DEVICE_ID_LEN]; //设备注册ID + public int dwAlarmType; //报警类型见EN_ALARM_TYPE枚举变量 + public int dwAlarmAction; //报警动作0:开始 1:停止 + public int dwVideoChannel;//各报警中的意义见注释 + public int dwAlarmInChannel;//各报警中的意义见注释 + public int dwDiskNumber; //各报警中的意义见注释 + public byte[] byRemark = new byte[MAX_REMARK_LEN]; //重传标记,0-实时包,1-重传包 + public byte byRetransFlag; //重传标记,0-实时包,1-重传包 + public byte byTimeDiffH; //重传标记,0-实时包,1-重传包 + public byte byTimeDiffM;//szAlarmTime,szAlarmUploadTime与国际标准时间(UTC)的时差(小时),-12 ... +14,0xff表示无效 + public byte byRes1; + public byte[] szAlarmUploadTime = new byte[MAX_TIME_LEN]; //报警上传时间(设备本地时间),时间格式,YYYY-MM-DD HH:MM:SS + public NET_EHOME_ALARM_STATUS_UNION uStatusUnion; + public byte[] byRes2 = new byte[16]; + } + + /** + * 报警状态联合体 + */ + public static class NET_EHOME_ALARM_STATUS_UNION extends Structure { + public byte[] byRes = new byte[12]; // 联合体大小 + public NET_EHOME_DEV_STATUS_CHANGED struDevStatusChanged; + public NET_EHOME_CHAN_STATUS_CHANGED struChanStatusChanged; + public NET_EHOME_HD_STATUS_CHANGED struHdStatusChanged; + public NET_EHOME_DEV_TIMING_STATUS struDevTimeStatus; + public NET_EHOME_CHAN_TIMING_STATUS_SINGLE struChanTimeStatus; + public NET_EHOME_HD_TIMING_STATUS_SINGLE struHdTimeStatus; + } + + /** + * 设备状态改变信息结构体 + */ + public static class NET_EHOME_DEV_STATUS_CHANGED extends Structure { + /** + * 设备状态:0-正常;1-CPU 使用率超过 85%;2-硬件错误,如串口异常 + */ + public byte byDeviceStatus; + + /** + * 保留。最大长度为 11 字节 + */ + public byte[] byRes = new byte[11]; + } + + public static class NET_EHOME_CHAN_STATUS_CHANGED extends Structure { + public short wChanNO; // 通道号 + public byte byChanStatus; //通道状态,按位表示 + //bit0:启用状态,0-禁用/删除,1-启用/添加 + //模拟通道由禁用到启用,或者启用到禁用,上报该字段 + //数字通道添加到删除,或者删除到重新添加,上报该字段 + //bit1:在线状态,0-不在线,1-在线 + //bit2:信号状态,0-无信号,1-有信号 + //bit3:录像状态,0-不在录像 1-在录像 + //bit4:IP通道信息改变状态,0-未改变 1-有改变,这位表示该通道的配 + //置信息发生了改变,比如添加的IPC有过更换,通知上层更新能力集 + + public byte[] byRes = new byte[9]; + } + + // 磁盘状态改变 + public static class NET_EHOME_HD_STATUS_CHANGED extends Structure { + public int dwVolume; //硬盘容量,单位:MB + public short wHDNo; //硬盘号 + public byte byHDStatus; //硬盘的状态, 0-活动1-休眠,2-异常,3-休眠硬盘出错,4-未格式化, 5-未连接状态(网络硬盘),6-硬盘正在格式化 + public byte[] byRes = new byte[5]; //保留 + } + + // 定时上报设备状态项 + public static class NET_EHOME_DEV_TIMING_STATUS extends Structure { + public int dwMemoryTotal; // 内存总量,单位Kbyte + public int dwMemoryUsage; // 内存使用量,单位Kbyte + public byte byCPUUsage; // CPU使用率,0-100 + public byte byMainFrameTemp; // 机箱温度,单位:摄氏度 + public byte byBackPanelTemp; // 背板温度,单位:摄氏度 + public byte byRes; + } + + // 定时上报通道状态项-单个通道 + public static class NET_EHOME_CHAN_TIMING_STATUS_SINGLE extends Structure { + public int dwBitRate; // 实际码率,单位kbps + public short wChanNO; // 通道号 + public byte byLinkNum; // 客户端连接的个数 + public byte[] byRes = new byte[5]; + } + + // 定时上报磁盘状态项 + public static class NET_EHOME_HD_TIMING_STATUS_SINGLE extends Structure { + public int dwHDFreeSpace; // 硬盘剩余空间,单位:MB + public short wHDNo; // 磁盘号 + public byte[] byRes = new byte[6]; + } + + /** + * 初始化报警管理服务器(AMS)的报警库
+ * 如果初始化失败,请检查加载库文件的路径和系统环境
+ * 该接口必须与 {@link HCISUPAlarm#NET_EALARM_Fini} 配套调用 + * + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_EALARM_Init(); + + /** + * 反初始化报警库并释放报警管理服务器(AMS)占用的资源
+ * 该接口必须与 {@link HCISUPAlarm#NET_EALARM_Init} 配套调用 + * + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_EALARM_Fini(); + + /** + * 设置报警管理服务器(AMS)的本地配置参数 + * + * @param enumType 支持的本地配置类型宏定义值:-1,0,1,2,3 和 4,参见枚举定义 NET_EHOME_LOCAL_CFG_TYPE + * @param lpInbuffer 本地配置参数,与本地配置类型(enumType)相关 + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPAlarm#NET_EALARM_GetLastError} 获取错误码 + */ + boolean NET_EALARM_SetSDKLocalCfg(int enumType, Pointer lpInbuffer); + + /** + * 启用报警管理服务器(AMS)监听并注册回调函数以接收报警信息 + * + * @param pAlarmListenParam 开启监听后用于接收报警信息的输入参数,详情参见结构体 {@link NET_EHOME_ALARM_LISTEN_PARAM} + * @return 返回-1 表示失败,返回其他值表示 {@link HCISUPAlarm#NET_EALARM_StopListen} 的句柄。如果返回-1,请调用 {@link HCISUPAlarm#NET_EALARM_GetLastError} 获取错误码 + */ + int NET_EALARM_StartListen(NET_EHOME_ALARM_LISTEN_PARAM pAlarmListenParam); + + /** + * 如果调用失败或完成,可获取错误码 + * + * @return 返回值是错误码 + */ + int NET_EALARM_GetLastError(); + + /** + * 停止报警管理服务器(AMS)的监听 + * + * @param iListenHandle 报警监听句柄,由 {@link HCISUPAlarm#NET_EALARM_StartListen} 返回 + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPAlarm#NET_EALARM_GetLastError} 获取错误码 + */ + boolean NET_EALARM_StopListen(int iListenHandle); + + /** + * 为设备设置会话密钥 + * + * @param pDeviceKey 支持 5.0 版本 ISUP 设备的会话密钥信息,详情参见 NET_EHOME_DEV_SESSIONKEY + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPAlarm#NET_EALARM_GetLastError} 获取错误码 + */ + boolean NET_EALARM_SetDeviceSessionKey(Pointer pDeviceKey); + + /** + * 设置参数以启用报警管理服务器(AMS)的日志功能 + * + * @param iLogLevel 日志类型。0-启用日志功能(默认),1-错误日志,2-错误和调试日志,3-错误、调试和信息日志。 + * @param strLogDir 日志文件保存路径。Windows 操作系统中的默认保存路径为“C:\\SdkLog\\”,Linux 操作系统中的默认保存路径为“/home/sdklog/”。如果要使用默认保存路径,请将该参数设置为“NULL”。 + * @param bAutoDel 是否在一段时间后自动删除日志文件:“TRUE”-是(默认),“FALSE”-否。当为“FALSE”时,会启动日志压缩,每生成 50 个日志文件时,将会进行一次日志压缩(将这生成的 50 个日志文件压缩成一个压缩文件) + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPAlarm#NET_EALARM_GetLastError} 获取错误码 + */ + boolean NET_EALARM_SetLogToFile(int iLogLevel, String strLogDir, boolean bAutoDel); + + /** + * 设置报警管理服务器(AMS)的初始化参数 + * + * @param enumType 初始化配置类型,详见枚举 NET_EHOME_EALARM_INIT_CFG_TYPE + * @param lpInBuff 初始化配置参数,取决于配置类型(enumType) + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_EALARM_SetSDKInitCfg(int enumType, Pointer lpInBuff); +} diff --git a/src/main/java/net/javase/hksup/starter/sdk/HCISUPCMS.java b/src/main/java/net/javase/hksup/starter/sdk/HCISUPCMS.java new file mode 100755 index 0000000..80933b3 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/sdk/HCISUPCMS.java @@ -0,0 +1,1018 @@ +/* + * To change this template, choose Tools | Templates + * and open the template in the editor. + */ + +/* + * HCNetSDK.java + * + * Created on 2009-9-14, 19:31:34 + */ + +/** + * @author Xubinfeng + */ +package net.javase.hksup.starter.sdk; + +import com.sun.jna.*; + +import java.util.Arrays; +import java.util.List; + +//SDK接口说明,HCNetSDK.dll +public interface HCISUPCMS extends Library { + + /***宏定义***/ + //常量 + public static final int NET_SDK_MAX_FILE_PATH = 256; + + public static class NET_DVR_LOCAL_SDK_PATH extends Structure { + public byte[] sPath = new byte[NET_SDK_MAX_FILE_PATH]; + public byte[] byRes = new byte[128]; + } + + + public static final int MAX_NAMELEN = 16; //DVR本地登陆名 + public static final int MAX_RIGHT = 32; //设备支持的权限(1-12表示本地权限,13-32表示远程权限) + public static final int NAME_LEN = 32; //用户名长度 + public static final int PASSWD_LEN = 16; //密码长度 + public static final int MAX_MASTER_KEY_LEN = 16; + public static final int MAX_DEVICE_ID_LEN = 256; //设备ID长度 + public static final int MAX_DEVNAME_LEN = 32; //设备名最大长度 + public static final int MAX_DEVNAME_LEN_EX = 64; //设备名最大长度 + + public static final int MAX_FULL_SERIAL_NUM_LEN = 64; //最大完整序列号长度 + public static final int NET_EHOME_SERIAL_LEN = 12; //序列号长度 + + public static final int MAX_ANALOG_CHANNUM = 32; + public static final int MAX_DIGIT_CHANNUM = 480; + public static final int MAX_ANALOG_ALARMOUT = 32; + + + public static interface EHOME_REGISTER_TYPE { + public static final int ENUM_DEV_ON = 0; //设备上线回调 + public static final int ENUM_DEV_OFF = 1; //设备下线回调 + public static final int ENUM_DEV_ADDRESS_CHANGED = 2; //设备地址发生变化 + public static final int ENUM_DEV_AUTH = 3; //Ehome5.0设备认证回调 + public static final int ENUM_DEV_SESSIONKEY = 4; //Ehome5.0设备Sessionkey回调 + public static final int ENUM_DEV_DAS_REQ = 5; //Ehome5.0设备重定向请求回调 + public static final int ENUM_DEV_SESSIONKEY_REQ = 6; //EHome5.0设备sessionkey请求回调 + public static final int ENUM_DEV_DAS_REREGISTER = 7; //设备重注册回调 + public static final int ENUM_DEV_DAS_PINGREO = 8; //设备注册心跳 + public static final int ENUM_DEV_DAS_EHOMEKEY_ERROR = 9; //校验密码失败 + public static final int ENUM_DEV_SESSIONKEY_ERROR = 10; //Sessionkey交互异常 + public static final int ENUM_DEV_SLEEP = 11; //设备进入休眠状态(注:休眠状态下,设备无法做预览、回放、语音对讲、配置等CMS中的信令作响应;设备可通过NET_ECMS_WakeUp接口进行唤醒) + } + + /** + * 支持 5.0 版本 ISUP 的设备会话密钥信息结构体 + */ + public static class NET_EHOME_DEV_SESSIONKEY extends Structure { + /** + * 设备 ID。最大长度为 256 字节 + */ + public byte[] sDeviceID = new byte[MAX_DEVICE_ID_LEN]; //设备ID/*256*/ + /** + * 设备会话密钥。最大长度为 16 字节 + */ + public byte[] sSessionKey = new byte[MAX_MASTER_KEY_LEN]; //设备Sessionkey/*16*/ + + } + + + public static class NET_EHOME_DEV_REG_INFO_V12 extends Structure { + public NET_EHOME_DEV_REG_INFO struRegInfo; + public NET_EHOME_IPADDRESS struRegAddr; + public byte[] sDevName = new byte[MAX_DEVNAME_LEN_EX]; + public byte[] byDeviceFullSerial = new byte[MAX_FULL_SERIAL_NUM_LEN]; + public byte[] byRes = new byte[128]; + + } + + + public static class NET_EHOME_DEV_REG_INFO extends Structure { + public int dwSize; + public int dwNetUnitType; + public byte[] byDeviceID = new byte[MAX_DEVICE_ID_LEN]; + public byte[] byFirmwareVersion = new byte[24]; + public NET_EHOME_IPADDRESS struDevAdd; + public int dwDevType; + public int dwManufacture; + public byte[] byPassWord = new byte[32]; + public byte[] sDeviceSerial = new byte[NET_EHOME_SERIAL_LEN]; + public byte byReliableTransmission; + public byte byWebSocketTransmission; + public byte bySupportRedirect; //设备支持重定向注册 0-不支持 1-支持 + public byte[] byDevProtocolVersion = new byte[6]; //设备协议版本 + public byte[] bySessionKey = new byte[16];//Ehome5.0设备SessionKey + public byte byMarketType; //0-无效(未知类型),1-经销型,2-行业型 + public byte[] byRes = new byte[26]; + } + + public static class NET_EHOME_SERVER_INFO extends Structure { + public int dwSize; + public int dwKeepAliveSec; + public int dwTimeOutCount; + public NET_EHOME_IPADDRESS struTCPAlarmSever = new NET_EHOME_IPADDRESS(); + public NET_EHOME_IPADDRESS struUDPAlarmSever = new NET_EHOME_IPADDRESS(); + public int dwAlarmServerType; + public NET_EHOME_IPADDRESS struNTPSever = new NET_EHOME_IPADDRESS(); + public int dwNTPInterval; + public NET_EHOME_IPADDRESS struPictureSever = new NET_EHOME_IPADDRESS(); + public int dwPicServerType; + public NET_EHOME_BLACKLIST_SEVER struBlackListServer = new NET_EHOME_BLACKLIST_SEVER(); + public byte[] byRes = new byte[128]; + } + + public static class NET_EHOME_SERVER_INFO_V50 extends Structure { + public int dwSize; + public int dwKeepAliveSec; //心跳间隔(单位:秒,0:默认为15S) + public int dwTimeOutCount; //心跳超时次数(0:默认为6) + public NET_EHOME_IPADDRESS struTCPAlarmSever = new NET_EHOME_IPADDRESS(); //报警服务器地址(TCP协议) + public NET_EHOME_IPADDRESS struUDPAlarmSever = new NET_EHOME_IPADDRESS(); //报警服务器地址(UDP协议) + public int dwAlarmServerType; //报警服务器类型0-只支持UDP协议上报,1-支持UDP、TCP两种协议上报 + public NET_EHOME_IPADDRESS struNTPSever = new NET_EHOME_IPADDRESS(); //NTP服务器地址 + public int dwNTPInterval; //NTP校时间隔(单位:秒) + public NET_EHOME_IPADDRESS struPictureSever = new NET_EHOME_IPADDRESS(); //图片服务器地址 + public int dwPicServerType; //图片服务器类型图片服务器类型,1-VRB图片服务器,0-Tomcat图片服务,2-云存储3,3-KMS + public NET_EHOME_BLACKLIST_SEVER struBlackListServer = new NET_EHOME_BLACKLIST_SEVER();//黑名单服务器 + public NET_EHOME_IPADDRESS struRedirectSever = new NET_EHOME_IPADDRESS(); //Redirect Server + public byte[] byClouldAccessKey = new byte[64]; //云存储AK + public byte[] byClouldSecretKey = new byte[64]; //云存储SK + public byte byClouldHttps; //云存储HTTPS使能 1-HTTPS 0-HTTP + public byte[] byRes1 = new byte[3]; + public int dwAlarmKeepAliveSec; //报警心跳间隔(单位:秒,0:默认为30s) + public int dwAlarmTimeOutCount; //报警心跳超时次数(0:默认为3) + public int dwClouldPoolId; //云存储PoolId + public byte[] byRes = new byte[368]; + } + + + public static class NET_EHOME_BLACKLIST_SEVER extends Structure { + public NET_EHOME_IPADDRESS struAdd = new NET_EHOME_IPADDRESS(); + public byte[] byServerName = new byte[32]; + public byte[] byUserName = new byte[32]; + public byte[] byPassWord = new byte[32]; + public byte[] byRes = new byte[64]; + } + + public static class NET_EHOME_LOCAL_ACCESS_SECURITY extends Structure { + public int dwSize; + public byte byAccessSecurity; + public byte[] byRes = new byte[127]; + } + + public static class NET_EHOME_AMS_ADDRESS extends Structure { + public int dwSize; + public byte byEnable; + public byte[] byRes1 = new byte[3]; + public NET_EHOME_IPADDRESS struAddress = new NET_EHOME_IPADDRESS(); + public byte[] byRes2 = new byte[32]; + } + + public static class NET_EHOME_IPADDRESS extends Structure { + public byte[] szIP = new byte[128]; + public short wPort; //端口 + public byte[] byRes = new byte[2]; + } + + public static class NET_EHOME_VOICE_TALK_IN extends Structure { + public int dwVoiceChan; //通道号 + public NET_EHOME_IPADDRESS struStreamSever; //流媒体地址 + public byte[] byEncodingType = new byte[9]; //语音对讲编码类型 + public byte byLinkEncrypt; // + public byte byBroadcast; //语音广播标识,设备接收到本标识为1后不进行音频采集发送给对端 + public byte byBroadLevel;//语音广播优先级标识,0~15优先级从低到高,当存在byBroadcast为1时,0标识最低优先级。当存在byBroadcast为0时,本节点无意义为保留字节 + public byte byBroadVolume; //语音广播音量,0~15音量从低到高,当存在byBroadcast为1时,0标识最低音量。当存在byBroadcast为0时,本节点无意义为保留字节 + public byte byAudioSamplingRate; //音频采样率 0-默认, 1-16kHZ, 2-32kHZ, 3-48kHZ, 4-44.1kHZ, 5-8kHZ + public byte[] byRes = new byte[114]; + } + + public static class NET_EHOME_VOICE_TALK_OUT extends Structure { + /** + * 语音对讲请求的会话ID,由设备返回 + */ + public int lSessionID; + /** + * 输出参数句柄,在异步模式中作为异步回调的 + * 标识。对应 NET_EHOME_CMSCB_DATA 中的 + * dwHandle。 + */ + public int lHandle; + /** + * 保留,设为0。最大长度为124 字节。 + */ + public byte[] byRes = new byte[124]; + } + + + /** + * 注册回调 + */ + public static interface DEVICE_REGISTER_CB extends Callback { + + /** + * 注册回调 + * + * @param lUserID 用户 ID,由 SDK 分配 + * @param dwDataType 回调数据类型 + * @param pOutBuffer 输出缓冲区 + * @param dwOutLen 输出缓冲区大小 + * @param pInBuffer 输入缓冲区 + * @param dwInLen 输入缓冲区大小 + * @param pUser 用户参数 + * @return {@link Boolean} + */ + public boolean invoke(int lUserID, int dwDataType, Pointer pOutBuffer, int dwOutLen, Pointer pInBuffer, int dwInLen, Pointer pUser); + } + + + /** + * 中心管理服务器监听参数结构体 + */ + public static class NET_EHOME_CMS_LISTEN_PARAM extends Structure { + public NET_EHOME_IPADDRESS struAddress; //本地监听信息,IP为0.0.0.0的情况下,默认为本地地址,多个网卡的情况下,默认为从操作系统获取到的第一个 + public DEVICE_REGISTER_CB fnCB; //报警信息回调函数 + public Pointer pUserData; //用户数据 + public byte[] byRes = new byte[32]; + } + + + /** + * 音频数据的回调函数 + */ + public static interface fVoiceDataCallBack extends Callback { + /** + * 回调 + * + * @param iVoiceHandle 语音对讲或音频转发句柄,由 NET_ECMS_StartVoiceTalk 返回 + * @param pRecvDataBuffer 保存音频文件的缓冲区的指针 + * @param dwBufSize 音频数据大小 + * @param dwEncodeType 音频数据编码类型:0-G.722,1-G.711U,2-G.711A,3-G.726,4-AAC,5-MP2L2,6-PCM + * @param byAudioFlag 音频数据源。0-本地采集,1-来自设备 + * @param pUser 用户参数 + */ + public void invoke(int iVoiceHandle, byte[] pRecvDataBuffer, int dwBufSize, int dwEncodeType, byte byAudioFlag, Pointer pUser); + } + + /** + * 语音对讲或语音转发参数结构体 + */ + public static class NET_EHOME_VOICETALK_PARA extends Structure { + public boolean bNeedCBNoEncData; //需要回调的语音类型:0-编码后语音,1-编码前语音(语音转发时不支持) + public fVoiceDataCallBack cbVoiceDataCallBack; //用于回调音频数据的回调函数 + public int dwEncodeType; //SDK赋值,SDK的语音编码类型,0- OggVorbis,1-G711U,2-G711A,3-G726,4-AAC,5-MP2L2,6-PCM + public Pointer pUser; //用户参数 + public byte byVoiceTalk; //0-语音对讲,1-语音转发 + public byte byDevAudioEnc; //输出参数,设备的音频编码方式 0- OggVorbis,1-G711U,2-G711A,3-G726,4-AAC,5-MP2L2,6-PCM + public byte[] byRes = new byte[62];//Reserved, set as 0. 0 + } + + /** + * 预览请求 输入参数结构体 + */ + public static class NET_EHOME_PREVIEWINFO_IN extends Structure { + public int iChannel; //通道号 + public int dwStreamType; // 码流类型,0-主码流,1-子码流, 2-第三码流 + public int dwLinkMode; // 0:TCP方式,1:UDP方式,2: HRUDP方式 + public NET_EHOME_IPADDRESS struStreamSever; //流媒体地址 + } + + + /** + * 预览请求的输入参数结构体 + */ + public static class NET_EHOME_PREVIEWINFO_IN_V11 extends Structure { + /** + * 通道号 + */ + public int iChannel; + /** + * 码流类型:0-主码流,1-子码流,2-第三码流 + */ + public int dwStreamType; + /** + * 接入方式:0-TCP,1-UDP,2-HRUDP(可靠传 + * 输) + */ + public int dwLinkMode; + + /** + * 流媒体服务器的地址信息 + */ + public NET_EHOME_IPADDRESS struStreamSever; + /** + * 预览模式:0-获取实时码流,1-获取延迟码 + * 流 + */ + public byte byDelayPreview; + /** + * 码流是否加密:0-否,1-是 + */ + public byte byEncrypt; + /** + * 保留,设为 0。最大长度为 30 字节 + */ + public byte[] byRes = new byte[31]; + } + + /** + * 预览请求的输出参数结构体 + */ + public static class NET_EHOME_PREVIEWINFO_OUT extends Structure { + /** + * 预览请求的会话 ID + */ + public int lSessionID; + /** + * 保留,设为 0 + */ + public byte[] byRes = new byte[128]; + } + + /** + * 实时流传输请求的输入参数结构体 + */ + public static class NET_EHOME_PUSHSTREAM_IN extends Structure { + /** + * 结构体大小 + */ + public int dwSize; + /** + * 预览请求的会话 ID,由{@link HCISUPCMS#NET_ECMS_StartGetRealStreamV11}返回 + */ + public int lSessionID; + /** + * 保留,设为 0 + */ + public byte[] byRes = new byte[128]; + } + + + public static class NET_EHOME_PUSHVOICE_IN extends Structure { + public int dwSize; + public int lSessionID; + public byte[] byToken = new byte[64]; + public byte[] byRes = new byte[64]; + } + + public static class NET_EHOME_PUSHVOICE_OUT extends Structure { + public int dwSize; + public int lHandle; + public byte[] byRes = new byte[124]; + } + + + public static class NET_EHOME_PUSHSTREAM_OUT extends Structure { + public int dwSize; + public byte[] byRes = new byte[128]; + } + + + /** + * 传输参数结构体 + */ + public static class NET_EHOME_PTXML_PARAM extends Structure { + public Pointer pRequestUrl; //请求URL + public int dwRequestUrlLen; //请求URL长度 + public Pointer pCondBuffer; //条件缓冲区(XML格式数据) + public int dwCondSize; //条件缓冲区大小 + public Pointer pInBuffer; //输入缓冲区(XML格式数据) + public int dwInSize; //输入缓冲区大小 + public Pointer pOutBuffer; //输出缓冲区(XML格式数据) + public int dwOutSize; //输出缓冲区大小 + public int dwReturnedXMLLen; //实际从设备接收到的XML数据的长度 + public int dwRecvTimeOut; //默认5000ms + public int dwHandle; //(输出参数)设置了回放异步回调之后,该值为消息句柄,回调中用于标识(新增) + public byte[] byRes = new byte[24]; //保留 + } + + + public static class NET_EHOME_XML_CFG extends Structure { + public Pointer pCmdBuf; //字符串格式命令,参见1.2.3 + public int dwCmdLen; //pCmdBuf长度 + public Pointer pInBuf; //输入数据,远程配置报文公用定义 + public int dwInSize; //输入数据长度 + public Pointer pOutBuf; //输出缓冲 + public int dwOutSize; //输出缓冲区长度 + public int dwSendTimeOut; //数据发送超时时间,单位ms,默认5s + public int dwRecvTimeOut; //数据接收超时时间,单位ms,默认5s + public Pointer pStatusBuf; //返回的状态参数(XML格式),如果不需要,可以置NULL + public int dwStatusSize; //状态缓冲区大小(内存大小) + public byte[] byRes = new byte[24]; + } + + public static class NET_EHOME_XML_REMOTE_CTRL_PARAM extends Structure { + public int dwSize; + public Pointer lpInbuffer; + public int dwInBufferSize; + public int dwSendTimeOut; + public int dwRecvTimeOut; + public Pointer lpOutBuffer; //输出缓冲区 + public int dwOutBufferSize; //输出缓冲区大小 + public Pointer lpStatusBuffer; //状态缓冲区,若不需要可置为NULL + public int dwStatusBufferSize; //状态缓冲区大小 + public byte[] byRes = new byte[16]; + } + + ; + + //云台相关结构体 + public static final int NET_EHOME_PTZ_CTRL = 1000; //云镜控制 + + /** + * 控制参数结构体 + */ + public static class NET_EHOME_REMOTE_CTRL_PARAM extends Structure { + public int dwSize; + public Pointer lpCondBuffer; //条件参数缓冲区 + public int dwCondBufferSize; //条件参数缓冲区长度 + public Pointer lpInbuffer; //控制参数缓冲区 + public int dwInBufferSize; //控制参数缓冲区长度 + public byte[] byRes = new byte[32]; + } + + ; + + public static class NET_EHOME_PTZ_PARAM extends Structure { + public int dwSize; + public byte byPTZCmd; //云台命令,参见EN_PTZ_CMD + public byte byAction; //云台动作,0-开始云台动作,1-停止云台动作 + public byte bySpeed; //云台速度,0-7,数值越大速度越快 + public byte[] byRes = new byte[29]; + } + + ; + + + public static class NET_DVR_STRING_POINTER extends Structure { + public byte[] byString = new byte[2 * 1024]; + } + + + public static class NET_EHOME_ALARMIN_COND extends Structure { + public int dwSize; + public int dwAlarmInNum; + public int dwPTZChan; + public byte[] byRes = new byte[20]; + } + + public static class NET_EHOME_ALARMIN_CFG extends Structure { + public int dwSize; //结构体大小 + public byte[] sAlarmInName = new byte[NAME_LEN]; //报警输入名称 + public byte byAlarmInType; //报警器类型:0:常开;1:常闭 + public byte byUseAlarmIn; //是否处理,0:不使用;1:使用 + public byte[] byRes1 = new byte[2]; //保留 + public NET_EHOME_ALARMIN_LINKAGE_TYPE struLinkageType = new NET_EHOME_ALARMIN_LINKAGE_TYPE(); //联动模式 + public NET_EHOME_RECORD_CHAN struRecordChan = new NET_EHOME_RECORD_CHAN();//关联录像通道 + public byte[] byRes2 = new byte[128]; //保留 + } + + public static class NET_EHOME_RECORD_CHAN extends Structure { + public byte byAnalogChanNum; //只读,模拟通道数 + public byte[] byAnalogChan = new byte[MAX_ANALOG_CHANNUM]; //模拟通道,0:不使用;1:使用 + public byte[] byRes1 = new byte[3]; //保留 + public short wDigitChanNum; //只读,数字通道数 + public byte[] byDigitChan = new byte[MAX_DIGIT_CHANNUM]; //数字通道,0:不使用;1:使用 + public byte[] byRes2 = new byte[62]; + } + + public static class NET_EHOME_ALARMIN_LINKAGE_TYPE extends Structure { + public byte byMonitorAlarm; //监视器上警告,0:不使用;1:使用 + public byte bySoundAlarm; //声音报警,0:不使用;1:使用 + public byte byUpload; //上传中心,0:不使用;1:使用 + public byte byAlarmout; //触发报警输出,0:不使用;1:使用- + public byte byEmail; //邮件联动,0:不使用;1:使用 + public byte[] byRes1 = new byte[3]; //保留 + public NET_EHOME_LINKAGE_PTZ struPTZLinkage = new NET_EHOME_LINKAGE_PTZ(); //PTZ联动 + public NET_EHOME_LINKAGE_ALARMOUT struAlarmOut = new NET_EHOME_LINKAGE_ALARMOUT(); //报警输出联动 + public byte[] byRes = new byte[128]; + } + + + public static class NET_EHOME_LINKAGE_PTZ extends Structure { + public byte byUsePreset; //是否调用预置点,0:不使用;1:使用 + public byte byUseCurise; //是否调用巡航,0:不使用;1:使用 + public byte byUseTrack; //是否调用轨迹,0:不使用;1:使用 + public byte byRes1; //保留 + public short wPresetNo; //预置点号,范围:1~256,协议中规定是1~256,实际已有设备支持300 + public short wCuriseNo; //巡航路径号,范围:1~16 + public short wTrackNo; //轨迹号,范围:1~16 + public byte[] byRes2 = new byte[6]; //保留 + } + + public static class NET_EHOME_LINKAGE_ALARMOUT extends Structure { + public int dwAnalogAlarmOutNum; //只读,模拟报警数量 + public byte[] byAnalogAlarmOut = new byte[MAX_ANALOG_ALARMOUT]; //模拟报警输出,0:不使用;1:使用 + public byte[] byRes = new byte[5000]; + } + + public static class NET_EHOME_CONFIG extends Structure { + public Pointer pCondBuf; + public int dwCondSize; + public Pointer pInBuf; + public int dwInSize; + public Pointer pOutBuf; + public int dwOutSize; + public byte[] byRes = new byte[40]; + } + + public static class NET_EHOME_DEVICE_CFG extends Structure { + public int dwSize; + public byte[] sServerName = new byte[32]; + public int dwServerID; + public int dwRecycleRecord; + public int dwServerType; + public int dwChannelNum; + public int dwHardDiskNum; + public int dwAlarmInNum; + public int dwAlarmOutNum; + public int dwRS232Num; + public int dwRS485Num; + public int dwNetworkPortNum; + public int dwAuxoutNum; + public int dwAudioNum; + public byte[] sSerialNumber = new byte[128]; + public int dwMajorScale; + public int dwMinorScale; + public byte[] byRes = new byte[292]; + } + + public static class NET_EHOME_DEVICE_INFO extends Structure { + public int dwSize; + public int dwChannelNumber; + public int dwChannelAmount; + public int dwDevType; + public int dwDiskNumber; + public byte[] sSerialNumber = new byte[128]; + public int dwAlarmInPortNum; + public int dwAlarmInAmount; + public int dwAlarmOutPortNum; + public int dwAlarmOutAmount; + public int dwStartChannel; + public int dwAudioChanNum; + public int dwMaxDigitChannelNum; + public int dwAudioEncType; + public byte[] sSIMCardSN = new byte[128]; + public byte[] sSIMCardPhoneNum = new byte[32]; + public int dwSupportZeroChan; + public int dwStartZeroChan; + public int dwSmartType; + public byte[] byRes = new byte[160]; + } + + ; + + public static class NET_EHOME_REC_FILE_COND extends Structure { + public int dwChannel; //通道号 + public int dwRecType;//录像类型:0xff-全部类型,0-定时录像,1-移动报警,2-报警触发,3-报警|动测,4-报警&动测,5-命令触发,6-手动录像,7-震动报警,8-环境报警,9-智能报警(或者取证录像),10(0x0a)-PIR报警,11(0x0b)-无线报警,12(0x0c)-呼救报警,13(0x0d)-全部报警 + public NET_EHOME_TIME struStartTime = new NET_EHOME_TIME();//开始时间 + public NET_EHOME_TIME struStopTime = new NET_EHOME_TIME();//结束时间 + public int dwStartIndex;//查询起始位置,从0开始 + public int dwMaxFileCountPer;//单次搜索最大文件个数,最大文件个数,需要确定实际网络环境,建议最大个数为8 + public byte[] byRes = new byte[64]; + } + + ; + + public static class NET_EHOME_REC_FILE extends Structure { + public int dwSize; + public byte[] sFileName = new byte[100]; + public NET_EHOME_TIME struStartTime = new NET_EHOME_TIME(); + public NET_EHOME_TIME struStopTime = new NET_EHOME_TIME(); + public int dwFileSize; + public int dwFileMainType; + public int dwFileSubType; + public int dwFileIndex; + public byte[] byRes = new byte[128]; + } + + ; + + public static class NET_EHOME_TIME extends Structure { + public short wYear;//年 + public byte byMonth;//月 + public byte byDay;//日 + public byte byHour;//时 + public byte byMinute;//分 + public byte bySecond;//秒 + public byte byRes1;//保留 + public short wMSecond;//毫秒 + public byte[] byRes2 = new byte[2]; + } + + + /** + * 回放请求的输入参数结构体 + */ + public static class NET_EHOME_PLAYBACK_INFO_IN extends Structure { + public int dwSize; + public int dwChannel; //回放的通道号 + public byte byPlayBackMode; //回放下载模式 0-按名字 1-按时间 + public byte byStreamPackage; //回放码流类型,设备端发出的码流格式 0-PS(默认) 1-RTP + public byte[] byRes = new byte[2]; + public NET_EHOME_PLAYBACKMODE unionPlayBackMode; + public NET_EHOME_IPADDRESS struStreamSever; + } + + public static class NET_EHOME_PLAYBACKMODE extends Union { + public byte[] byLen = new byte[512]; + public NET_EHOME_PLAYBACKBYNAME struPlayBackbyName; + public NET_EHOME_PLAYBACKBYTIME struPlayBackbyTime; + } + + public static class NET_EHOME_PLAYBACKBYNAME extends Structure { + public byte[] szFileName = new byte[100/*MAX_FILE_NAME_LEN*/]; //回放的文件名 + public int dwSeekType; //0-按字节长度计算偏移量 1-按时间(秒数)计算偏移量 + public int dwFileOffset; //文件偏移量,从哪个位置开始下载,如果dwSeekType为0,偏移则以字节计算,为1则以秒数计算 + public int dwFileSpan; //下载的文件大小,为0时,表示下载直到该文件结束为止,如果dwSeekType为0,大小则以字节计算,为1则以秒数计算 + } + + public static class NET_EHOME_PLAYBACKBYTIME extends Structure { + public NET_EHOME_TIME struStartTime; // 按时间回放的开始时间 + public NET_EHOME_TIME struStopTime; // 按时间回放的结束时间 + public byte byLocalOrUTC; //0-设备本地时间,即设备OSD时间 1-UTC时间 + public byte byDuplicateSegment; //byLocalOrUTC为1时无效 0-重复时间段的前段 1-重复时间段后端 + } + + public static class NET_EHOME_PLAYBACK_INFO_OUT extends Structure { + public int lSessionID; //目前协议不支持,返回-1 + public int lHandle; //设置了回放异步回调之后,该值为消息句柄,回调中用于标识 + public byte[] byRes = new byte[124]; + } + + + public static class NET_EHOME_PLAYBACK_PAUSE_RESTART_PARAM extends Structure { + public int lSessionID; + public int lHandle; + public byte[] byRes = new byte[120]; + } + + /** + * 控制回放,例如暂停回放和恢复回放 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param enumMode 控制操作类型 + * @param pOperateParam 控制操作参数,取决于控制操作类型(enumMode)。关于暂停或恢复回放的参数,详情请参见结构体 {@link NET_EHOME_PLAYBACK_PAUSE_RESTART_PARAM} + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_PlayBackOperate(int lUserID, int enumMode, Pointer pOperateParam); + + /** + * 回放码流传输请求的输入参数结构体 + */ + public static class NET_EHOME_PUSHPLAYBACK_IN extends Structure { + /** + * 结构体大小 + */ + public int dwSize; + + /** + * 会话 ID,由 {@link HCISUPCMS#NET_ECMS_StartPlayBack} 返回 + */ + public int lSessionID; + + /** + * 码流加密密钥,通过两次 MD5 计算获得 + */ + public byte[] byKeyMD5 = new byte[32];//码流加密秘钥,两次MD5 + + /** + * 保留,设为 0。最大长度为 96 字节 + */ + public byte[] byRes = new byte[96]; + } + + /** + * 回放码流传输请求的输出参数结构体 + */ + public static class NET_EHOME_PUSHPLAYBACK_OUT extends Structure { + /** + * 结构体大小 + */ + public int dwSize; + /** + * 异步回调的消息句柄 + */ + public int lHandle; + /** + * 保留,设为 0 + */ + public byte[] byRes = new byte[124]; + } + + public static class BYTE_ARRAY extends Structure { + public byte[] byValue; + + public BYTE_ARRAY(int iLen) { + byValue = new byte[iLen]; + } + + @Override + protected List getFieldOrder() { + return Arrays.asList("byValue"); + } + } + + + /** + * 初始化注册模块库
+ * 如果初始化失败,请检查加载库文件的路径和系统环境
+ * 该接口必须与 {@link HCISUPCMS#NET_ECMS_Fini} 配套调用
+ * 该接口调用之前可以调用 {@link HCISUPCMS#NET_ECMS_SetSDKInitCfg} 接口,其他接口均需要在该接口之后调用 + * + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_ECMS_Init(); + + /** + * 反初始化注册库并释放中央管理服务器(CMS)占用的资源
+ * 该接口必须与 {@link HCISUPCMS#NET_ECMS_Init} 配套调用 + * + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_ECMS_Fini(); + + /** + * 设置中心管理服务器(CMS)初始化参数
+ * 该接口必须在初始化 {@link HCISUPCMS#NET_ECMS_Init} 之前调用,否则 SDK 不能保证设置生效 + * + * @param enumType 初始化配置类型 + * @param lpInBuff 初始化配置参数,取决于配置类型(enumType) + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_ECMS_SetSDKInitCfg(int enumType, Pointer lpInBuff); + + /** + * 如果调用失败或完成,获取错误码
+ * 该接口需要在 {@link HCISUPCMS#NET_ECMS_Init} 之后调用。 + * + * @return 错误码 + */ + int NET_ECMS_GetLastError(); + + /** + * 获取中央管理服务器(CMS)的版本信息 + * + * @return 返回版本号,高两位字节表示主版本,低两位字节表示次版本,例如:0x02040001(2.4.0.1版本) + */ + int NET_ECMS_GetBuildVersion(); + + /** + * 设置中心管理服务器(CMS)的本地配置参数 + * + * @param enumType 支持的本地配置类型宏定义值:0,1,2,3,4,5 和 6 + * @param lpInBuff 本地配置参数,与本地配置类型(enumType)相关 + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_SetSDKLocalCfg(int enumType, Pointer lpInBuff); + + /** + * 获取中心管理服务器(CMS)的本地配置参数 + * + * @param enumType 支持的本地配置类型宏定义值:-1,0,1,2,3,4,5 和 6 + * @param lpOutBuff 本地配置参数,与本地配置类型(enumType)有关 + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_GetSDKLocalCfg(int enumType, Pointer lpOutBuff); + + /** + * 设置支持 5.0 版本 ISUP 的设备会话密钥 + * + * @param pDeviceKey 支持 5.0 版本 ISUP 的设备会话密钥信息 情参见结构体 {@link NET_EHOME_DEV_SESSIONKEY} + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_SetDeviceSessionKey(Pointer pDeviceKey); + + + /** + * 启用中心管理服务器(CMS)的监听并注册回调函数以接收设备注册信息 + * + * @param lpCMSListenPara 监听参数,详情参见结构体 {@link NET_EHOME_CMS_LISTEN_PARAM} + * @return 返回-1 表示失败,返回其他值表示 {@link HCISUPCMS#NET_ECMS_StopListen} 的句柄参数。如果返回-1,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + int NET_ECMS_StartListen(NET_EHOME_CMS_LISTEN_PARAM lpCMSListenPara); + + /** + * 停止中心管理服务器(CMS)的监听 + * + * @param iHandle 监听句柄,由 {@link HCISUPCMS#NET_ECMS_StartListen} 返回 + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StopListen(int iHandle); + + /** + * 获取设备参数 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param dwCommand 配置命令 + * @param lpConfig 输入或输出配置参数,不同的配置命令对应于不同的输入或输出配置参数。请参见结构体 {@link NET_EHOME_CONFIG} 了解参数格式 + * @param dwConfigSize lpConfig指向的结构体的大小 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_GetDevConfig(int lUserID, int dwCommand, Pointer lpConfig, int dwConfigSize); + + /** + * 强制注销设备且设备状态变为离线 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 配置的回调函数返回 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_ForceLogout(int lUserID); + + /** + * 设置启用中心管理服务器(CMS)日志功能的参数 + * + * @param iLogLevel 日志类型:0-启用日志功能(默认),1-错误日志,2-错误和调试日志,3-错误、调试和信息日志 + * @param strLogDir 日志文件保存路径。Windows 操作系统中的默认保存路径为"C:\\SdkLog\\",Linux 操作系统中的默认保存路径为"/home/sdklog/"。如果要使用默认保存路径,请将该参数设置为"NULL" + * @param bAutoDel 是否在一段时间后自动删除日志文件:"TRUE"-是(默认),"FALSE"-否。当为"FALSE"时,会启动日志压缩,每生成 50 个日志文件时,将会进行一次日志压缩(将这生成的 50 个日志文件压缩成一个压缩文件) + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_SetLogToFile(int iLogLevel, String strLogDir, boolean bAutoDel); + + /** + * 开始语音对讲或转发音频 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的回调函数返回 + * @param dwVoiceChan 语音对讲通道号 + * @param pVoiceTalkPara 语音对讲或音频转发的参数,详情参见结构体 {@link NET_EHOME_VOICETALK_PARA} + * @return 返回-1 表示失败,返回其他值表示 NET_ECMS_StopVoiceTalk 的句柄。如果返回-1,请调用 NET_ECMS_GetLastError 获取错误码 + */ + int NET_ECMS_StartVoiceTalk(int lUserID, int dwVoiceChan, NET_EHOME_VOICETALK_PARA pVoiceTalkPara); + + /** + * 请求通过流媒体服务器(SMS)开始语音对讲 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的回调函数返回 + * @param lpVoiceTalkIn 语音对讲请求的输入参数,详情参见结构体 {@link NET_EHOME_VOICE_TALK_IN} + * @param lpVoiceTalkOut 语音对讲请求的输出参数,详情参见结构体 {@link NET_EHOME_VOICE_TALK_OUT} + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StartVoiceWithStmServer(int lUserID, NET_EHOME_VOICE_TALK_IN lpVoiceTalkIn, NET_EHOME_VOICE_TALK_OUT lpVoiceTalkOut); + + /** + * 中心管理服务器(CMS)向设备发送请求,设备开始传输语音对讲的音频码流 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的回调函数返回 + * @param lpPushParamIn 音频码流传输请求的输入参数,详情参见结构体 {@link NET_EHOME_PUSHVOICE_IN} + * @param lpPushParamOut 音频码流传输请求的输出参数,详情参见结构体 {@link NET_EHOME_PUSHVOICE_OUT} + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StartPushVoiceStream(int lUserID, NET_EHOME_PUSHVOICE_IN lpPushParamIn, NET_EHOME_PUSHVOICE_OUT lpPushParamOut); + + /** + * 停止语音对讲或转发音频 + * + * @param iVoiceHandle 语音对讲或音频转发的句柄,由 {@link HCISUPCMS#NET_ECMS_StartVoiceTalk} 返回 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StopVoiceTalk(int iVoiceHandle); + + /** + * 请求停止通过流媒体服务器(SMS)进行语音对讲 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的回调函数返回 + * @param lSessionID 会话 ID,由 {@link HCISUPCMS#NET_ECMS_StartVoiceWithStmServer} 返回 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StopVoiceTalkWithStmServer(int lUserID, int lSessionID); + + /** + * 将音频数据转发到设备 + * + * @param iVoiceHandle 音频转发句柄,由 {@link HCISUPCMS#NET_ECMS_StartVoiceTalk} 返回 + * @param pSendBuf 保存音频数据的缓冲区的指针 + * @param dwBufSize 缓冲区中的数据大小 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_SendVoiceTransData(int iVoiceHandle, String pSendBuf, int dwBufSize); + + /** + * 预览接口-开始预览 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param pPreviewInfoIn 预览请求的输入参数,详情参见结构体 NET_EHOME_PREVIEWINFO_IN + * @param pPreviewInfoOut 预览请求的输出参数,详情参见结构体 NET_EHOME_PREVIEWINFO_OUT + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StartGetRealStream(int lUserID, NET_EHOME_PREVIEWINFO_IN pPreviewInfoIn, NET_EHOME_PREVIEWINFO_OUT pPreviewInfoOut); //lUserID由SDK分配的用户ID,由设备注册回调时fDeviceRegisterCallBack返回 + + /** + * 请求开始预览 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回。 + * @param pPreviewInfoIn 预览请求的输入参数,详情参见结构体 {@link NET_EHOME_PREVIEWINFO_IN_V11} + * @param pPreviewInfoOut 预览请求的输出参数,详情参见结构体 {@link NET_EHOME_PREVIEWINFO_OUT} + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StartGetRealStreamV11(int lUserID, NET_EHOME_PREVIEWINFO_IN_V11 pPreviewInfoIn, NET_EHOME_PREVIEWINFO_OUT pPreviewInfoOut); + + /** + * 请求停止预览 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param lSessionID 会话 ID,由 NET_ECMS_StartGetRealStreamV11 或 NET_ECMS_StartGetRealStream 返回。 + * 由返回。 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StopGetRealStream(int lUserID, int lSessionID); + + /** + * 中心管理服务器(CMS)向设备发送请求,设备开始传输预览实时码流 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回。 + * @param pPushInfoIn 实时码流传输请求的输入参数,详情参见结构体 NET_EHOME_PUSHSTREAM_IN + * @param pPushInfoOut 实时码流传输请求的输出参数,详情参见结构体 NET_EHOME_PUSHSTREAM_OUT + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StartPushRealStream(int lUserID, NET_EHOME_PUSHSTREAM_IN pPushInfoIn, NET_EHOME_PUSHSTREAM_OUT pPushInfoOut); + + boolean NET_ESTREAM_StopListenPreview(int lPreivewListenHandle); + + boolean NET_ECMS_GetPTXMLConfig(int iUserID, NET_EHOME_PTXML_PARAM lpPTXMLParam); + + boolean NET_ECMS_PutPTXMLConfig(int iUserID, NET_EHOME_PTXML_PARAM lpPTXMLParam); + + boolean NET_ECMS_PostPTXMLConfig(int iUserID, NET_EHOME_PTXML_PARAM lpPTXMLParam); + + boolean NET_ECMS_DeletePTXMLConfig(int iUserID, NET_EHOME_PTXML_PARAM lpPTXMLParam); + + boolean NET_ECMS_XMLConfig(int iUserID, NET_EHOME_XML_CFG pXmlCfg, int dwConfigSize); + + /** + * 传输 ISUP(智能安全上行协议)的控制命令和 XML 报文 + * + * @param lUserID 用户 ID, 由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数( {@link DEVICE_REGISTER_CB} )返回 + * @param lpCtrlParam 控制参数,详情参见 {@link NET_EHOME_XML_REMOTE_CTRL_PARAM} + * @param dwCtrlSize 保存控制参数的缓冲区的大小。该缓冲区的大小等于结构体 {@link NET_EHOME_XML_REMOTE_CTRL_PARAM} 的大小 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_XMLRemoteControl(int lUserID, NET_EHOME_XML_REMOTE_CTRL_PARAM lpCtrlParam, int dwCtrlSize); + + /** + * 传输命令,包括请求 URL 和操作方法(如 GET、PUT、POST、DELETE) + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param lpParam 被传输的参数,详情参见结构体 {@link NET_EHOME_PTXML_PARAM} + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_ISAPIPassThrough(int lUserID, NET_EHOME_PTXML_PARAM lpParam); + + /** + * 执行远程控制 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param dwCommand 控制命令 + * @param lpCtrlParam 控制参数,取决于控制命令,详情参见结构体 {@link NET_EHOME_REMOTE_CTRL_PARAM} + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_RemoteControl(int lUserID, int dwCommand, NET_EHOME_REMOTE_CTRL_PARAM lpCtrlParam); + + + /** + * 回放接口-开始查找文件 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param lSearchType 检索类型,参见枚举定义 SEARCH_TYPE + * @param pFindCond 保存检索条件的缓冲区,不同的检索类型对应于不同的检索条件 + * @param dwCondSize 检索条件缓冲区大小 + * @return 返回-1 表示失败,返回其他值表示 {@link HCISUPCMS#NET_ECMS_FindNextFile_V11} 和 {@link HCISUPCMS#NET_ECMS_StopFindFile} 的句柄。如果返回-1,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码。 + */ + int NET_ECMS_StartFindFile_V11(int lUserID, int lSearchType, Pointer pFindCond, int dwCondSize); + + int NET_ECMS_FindNextFile_V11(int lHandle, Pointer pFindData, int dwDataSize); + + boolean NET_ECMS_StopFindFile(int lHandle); + + /** + * 回放接口-请求开始回放 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param pPlaybackInfoIn 回放请求的输入参数,详情参见结构体 NET_EHOME_PLAYBACK_INFO_IN + * @param pPlaybackInfoOut 回放请求的输出参数,详情参见结构体 NET_EHOME_PLAYBACK_INFO_OUT + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StartPlayBack(int lUserID, NET_EHOME_PLAYBACK_INFO_IN pPlaybackInfoIn, NET_EHOME_PLAYBACK_INFO_OUT pPlaybackInfoOut); + + /** + * 中心管理服务器(CMS)向设备发送请求,设备开始传输回放码流 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param struPushPlayBackIn 回放码流传输请求的输入参数,详情参见结构体 {@link NET_EHOME_PUSHPLAYBACK_IN} + * @param struPushPlayBackOut 回放码流传输请求的输出参数,详情参见结构体 {@link NET_EHOME_PUSHPLAYBACK_OUT} + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StartPushPlayBack(int lUserID, NET_EHOME_PUSHPLAYBACK_IN struPushPlayBackIn, NET_EHOME_PUSHPLAYBACK_OUT struPushPlayBackOut); + + /** + * 请求停止回放 + * + * @param lUserID 用户 ID,由 {@link HCISUPCMS#NET_ECMS_StartListen} 注册的注册回调函数返回 + * @param lSessionID 会话 ID,由 {@link HCISUPCMS#NET_ECMS_StartPlayBack} 返回 + * @return 返回 TRUE 成功,返回 FALSE 表示失败。如果返回 FALSE,请调用 {@link HCISUPCMS#NET_ECMS_GetLastError} 获取错误码 + */ + boolean NET_ECMS_StopPlayBack(int lUserID, int lSessionID); + + +} + diff --git a/src/main/java/net/javase/hksup/starter/sdk/HCISUPSS.java b/src/main/java/net/javase/hksup/starter/sdk/HCISUPSS.java new file mode 100755 index 0000000..37a76cb --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/sdk/HCISUPSS.java @@ -0,0 +1,429 @@ +/* + * To change this license header, choose License Headers in Project Properties. + * To change this template file, choose Tools | Templates + * and open the template in the editor. + */ +package net.javase.hksup.starter.sdk; + +import com.sun.jna.*; +import com.sun.jna.ptr.IntByReference; +import com.sun.jna.ptr.PointerByReference; +import net.javase.hksup.starter.utils.CommonMethod; + +import java.util.Arrays; +import java.util.List; + +public interface HCISUPSS extends Library { + + /***宏定义***/ + //常量 + + public static final int MAX_URL_LEN_SS = 4096; //图片服务器回调URL长度 + public static final int MAX_KMS_USER_LEN = 512; //KMS用户名最大长度 + public static final int MAX_KMS_PWD_LEN = 512; //KMS密码最大长度 + public static final int MAX_CLOUD_AK_SK_LEN = 64; //EHome5.0存储协议AK SK最大长度 + public static final int MAX_PATH = 260; //设备ID长度 + + /** + * 数据库密钥(字符串类型),最大长度32 + */ + int SS_DB_KEY_MAX_LEN = 32; + public static final int NET_EHOME_SERIAL_LEN = 12; //设备序列号长度 + + //NET_EHOME_SS_MSG_TYPE + public static final int NET_EHOME_SS_MSG_TOMCAT = 1;//Tomcat回调函数 + public static final int NET_EHOME_SS_MSG_KMS_USER_PWD = 2;//KMS用户名密码校验 + public static final int NET_EHOME_SS_MSG_CLOUD_AK = 3;//EHome5.0存储协议AK回调 + + //NET_EHOME_SS_CLIENT_TYPE + public static final int NET_EHOME_SS_CLIENT_TYPE_TOMCAT = 1; //Tomcat图片上传客户端 + public static final int NET_EHOME_SS_CLIENT_TYPE_VRB = 2;//VRB图片上传客户端 + public static final int NET_EHOME_SS_CLIENT_TYPE_KMS = 3;//KMS图片上传客户端 + public static final int NET_EHOME_SS_CLIENT_TYPE_CLOUD = 4;//EHome5.0存储协议客户端 + + //NET_EHOME_SS_INIT_CFG_TYPE + public static final int NET_EHOME_SS_INIT_CFG_SDK_PATH = 1;//设置SS组件加载路径(仅Linux版本支持) + public static final int NET_EHOME_SS_INIT_CFG_CLOUD_TIME_DIFF = 2;//设置运存储的请求时间差值,默认15分钟,最小5分钟,最大60分钟 + + public enum NET_EHOME_SS_MSG_TYPE { + NET_EHOME_SS_MSG_TOMCAT, //Tomcat回调函数 + NET_EHOME_SS_MSG_KMS_USER_PWD, //KMS用户名密码校验 + NET_EHOME_SS_MSG_CLOUD_AK //EHome5.0存储协议AK回调 + } + + public enum NET_EHOME_SS_CLIENT_TYPE { + NET_EHOME_SS_CLIENT_TYPE_TOMCAT, //Tomcat图片上传客户端 + NET_EHOME_SS_CLIENT_TYPE_VRB, //VRB图片上传客户端 + NET_EHOME_SS_CLIENT_TYPE_KMS, //KMS图片上传客户端 + NET_EHOME_SS_CLIENT_TYPE_CLOUD //EHome5.0存储协议客户端 + } + + public enum NET_EHOME_SS_INIT_CFG_TYPE { + NET_EHOME_SS_INIT_CFG_SDK_PATH, //设置SS组件加载路径(仅Linux版本支持) + NET_EHOME_SS_INIT_CFG_CLOUD_TIME_DIFF //设置运存储的请求时间差值,默认15分钟,最小5分钟,最大60分钟 + } + + /** + * Tomcat图片服务器回调信息 + */ + public static class NET_EHOME_SS_TOMCAT_MSG extends Structure { + public byte[] szDevUri = new byte[MAX_URL_LEN_SS]; //设备请求的URI + public int dwPicNum; //图片数 + public String pPicURLs; //图片URL,每个URL MAX_URL_LEN_SS长度 + public byte[] byRes = new byte[64]; + } + + /** + * 监听参数 + */ + public static class NET_EHOME_SS_LISTEN_PARAM extends Structure { + public NET_EHOME_IPADDRESS struAddress = new NET_EHOME_IPADDRESS(); //本地监听信息,IP为0.0.0.0的情况下,默认为本地地址,多个网卡的情况下,默认为从操作系统获取到的第一个 + public byte[] szKMS_UserName = new byte[MAX_KMS_USER_LEN]; //KMS用户名 + public byte[] szKMS_Password = new byte[MAX_KMS_PWD_LEN]; //KMS用户名 + public EHomeSSStorageCallBack fnSStorageCb;//图片服务器信息存储回调函数 + public EHomeSSMsgCallBack fnSSMsgCb; //图片服务器信息Tomcat回调函数 + public byte[] szAccessKey = new byte[MAX_CLOUD_AK_SK_LEN]; //EHome5.0存储协议AK + public byte[] szSecretKey = new byte[MAX_CLOUD_AK_SK_LEN]; //EHome5.0存储协议SK + public Pointer pUserData; //用户参数 + public byte byHttps; //是否启用HTTPs + public byte[] byRes1 = new byte[3]; + public EHomeSSRWCallBack fnSSRWCb;//读写回调函数 + public EHomeSSRWCallBackEx fnSSRWCbEx; + public byte bySecurityMode; + public byte[] byRes = new byte[51]; + } + + /** + * IP地址结构体 + */ + public static class NET_EHOME_IPADDRESS extends Structure { + public byte[] szIP = new byte[128]; //IP地址 + public short wPort; //端口号 + public byte[] byRes = new byte[2]; //保留,置为0 + } + + /** + * 监听Https参数 + */ + public static class NET_EHOME_SS_LISTEN_HTTPS_PARAM extends Structure { + public byte byHttps; //0-不启用HTTPS 1-启用HTTPS + public byte byVerifyMode; //0-单向认证(暂只支持单向认证) + public byte byCertificateFileType; //证书类型0-pem, 1-ANS1 + public byte byPrivateKeyFileType; //私钥类型0-pem, 1-ANS1 + public byte[] szUserCertificateFile = new byte[MAX_PATH]; //用户名 + public byte[] szUserPrivateKeyFile = new byte[32]; //密码 + public int dwSSLVersion;//SSL Method版本 + //0 - SSL23, 1 - SSL2, 2 - SSL3, 3 - TLS1.0, 4 - TLS1.1, 5 - TLS1.2 + //SSL23是兼容模式,会协商客户端和服务端使用的最高版本 + public byte[] byRes3 = new byte[360]; + } + + /** + * 图片上传客户端参数 + */ + public static class NET_EHOME_SS_CLIENT_PARAM extends Structure { + public int enumType; //图片上传客户端类型 NET_EHOME_SS_CLIENT_TYPE + public NET_EHOME_IPADDRESS struAddress; //图片服务器地址 + public byte byHttps;//是否启用HTTPs + public byte[] byRes = new byte[63]; + } + + public static class NET_EHOME_SS_LOCAL_SDK_PATH extends Structure { + public byte[] sPath = new byte[MAX_PATH]; + public byte[] byRes = new byte[128]; + } + + public static class NET_EHOME_SS_RW_PARAM extends Structure { + public Pointer pFileName; //文件名 + public Pointer pFileBuf; //文件内容 + public IntByReference dwFileLen; //文件大小 + public Pointer pFileUrl; //文件url + public Pointer pUser; // + public byte byAct; //读写操作:0-写文件,1-读文件 + public byte byUseRetIndex; //是否使用上层返回的pRetIndex:0-不使用,1-使用 + public byte[] byRes1 = new byte[2]; + public Pointer pRetIndex; //上层设置的索引,pRetIndex为0时,可不设置,pRetIndex为1时候,设置 + public byte[] byRes = new byte[56]; + } + + public static class StringPointer extends Structure { + public byte[] sData; + + public StringPointer() { + } + + public StringPointer(int dwLength) { + if (dwLength == 0) { + throw new NullPointerException("Data length can`t be zero"); + } + + this.sData = new byte[dwLength]; + } + + public StringPointer(String sContent) { + if (sContent == null) { + throw new NullPointerException("Content can`t be null"); + } + + this.sData = new byte[256]; + System.arraycopy(sContent.getBytes(), 0, this.sData, 0, sContent.length()); + } + + public StringPointer(byte[] byData) { + this.sData = new byte[256]; + System.arraycopy(byData, 0, this.sData, 0, byData.length); + } + + public String GetString() { + return CommonMethod.byteToString(this.sData); + } + + public byte[] GetByteArray() { + return this.sData; + } + + @Override + protected List getFieldOrder() { + return Arrays.asList("sData"); + } + } + + public static class NET_EHOME_SS_EX_PARAM extends Structure { + public byte byProtoType; + public byte[] byRes = new byte[23]; + public NET_EHOME_SS_Union unionStoreInfo = new NET_EHOME_SS_Union(); + } + + /** + * 初始化参数结构体 + */ + class NET_EHOME_SS_INIT_PARAM extends Structure { + /** + * 数据库密钥 + */ + public byte[] szKey = new byte[SS_DB_KEY_MAX_LEN]; + public byte[] byRes = new byte[224]; + } + + public static class NET_EHOME_SS_Union extends Union { + public NET_EHOME_SS_CLOUD_PARAM struCloud = new NET_EHOME_SS_CLOUD_PARAM(); + } + + public static class NET_EHOME_SS_CLOUD_PARAM extends Structure { + public String pPoolId; + public byte byPoolIdLength; + public int dwErrorCode; + public byte[] byRes = new byte[503]; + } + + + /** + * 初始化存储管理模块库 + * + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_ESS_Init(); + + /** + * 反初始化存储管理库并释放存储服务器(SS)占用的资源 + * + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 + */ + boolean NET_ESS_Fini(); + + /** + * 文件信息回调函数 + */ + public static interface EHomeSSMsgCallBack extends Callback { + + /** + * 文件信息回调 + * + * @param iHandle [OUT]句柄 + * @param enumType 回调数据类型 + * @param pOutBuffer [OUT]保存输出参数的缓冲区,取决于被回调的数据的类型(enumType) + * @param dwOutLen [OUT]输出缓冲区大小 + * @param pInBuffer 保存输入参数的缓冲区,取决于被回调的数据的类型(enumType) + * @param dwInLen 输入缓冲区大小 + * @param pUser [OUT]用户参数 + * @return + */ + public boolean invoke(int iHandle, int enumType, Pointer pOutBuffer, int dwOutLen, Pointer pInBuffer, int dwInLen, Pointer pUser); + } + + /** + * 存储回调函数 + */ + public static interface EHomeSSStorageCallBack extends Callback { + + /** + * 存储信息回调函数 + * + * @param iHandle [OUT] 存储句柄 + * @param pFileName [OUT] 文件名 + * @param pFileBuf [OUT] 保存文件的缓冲区大小 + * @param dwOutLen [OUT] 文件保存路径 + * @param pFilePath [IN] 输入缓冲区大小 + * @param pUser [OUT] 用户参数 + */ + public boolean invoke(int iHandle, String pFileName, Pointer pFileBuf, int dwOutLen, Pointer pFilePath, Pointer pUser); + } + + /** + * 读写回调函数 byAct 0-读 1-写 2-删 + */ + public static interface EHomeSSRWCallBack extends Callback { + /** + * 读写回调 + * + * @param iHandle [OUT] 句柄 + * @param byAct [OUT] 操作类型:0-写,1-读,2-删除 + * @param pFileName [OUT] 文件名 + * @param pFileBuf [IN][OUT] 保存文件的缓冲区 + * @param dwFileLen [IN][OUT] 文件大小 + * @param pFileUrl [OUT] 文件 URL + * @param pUser [OUT] 用户参数 + * @return + */ + public boolean invoke(int iHandle, byte byAct, String pFileName, Pointer pFileBuf, int dwFileLen, String pFileUrl, Pointer pUser); + } + + /** + * 读写回调函数扩展 + */ + public static interface EHomeSSRWCallBackEx extends Callback { + + /** + * 回调 + * + * @param iHandle 存储组件服务端监听句柄, NET_ESS_StartListen 的返回值 + * @param pRwParam 用于传递四种存储协议共用字段, 参见 NET_EHOME_SS_RW_PARAM + * @param pExStruct 用于传递存储协议特有字段, 参见 NET_EHOME_SS_EX_PARAM + * @return + */ + public boolean invoke(int iHandle, NET_EHOME_SS_RW_PARAM pRwParam, NET_EHOME_SS_EX_PARAM pExStruct); + } + + + /** + * 获取错误码 + */ + int NET_ESS_GetLastError(); + + /** + * 日志 + * + * @param iLogLevel + * @param strLogDir + * @param bAutoDel + * @return + */ + boolean NET_ESS_SetLogToFile(int iLogLevel, String strLogDir, boolean bAutoDel); + + boolean NET_ESS_SetSDKInitCfg(int enumType, Pointer lpInBuff); + + /** + * 获取版本号 + * + * @return + */ + int NET_ESS_GetBuildVersion(); + + /** + * 设置HTTP监听的Https参数 + * + * @param pSSHttpsParam + * @return + */ + boolean NET_ESS_SetListenHttpsParam(NET_EHOME_SS_LISTEN_HTTPS_PARAM pSSHttpsParam); + + /** + * 开启监听 + * + * @param pSSListenParam + * @return + */ + int NET_ESS_StartListen(NET_EHOME_SS_LISTEN_PARAM pSSListenParam); + + /** + * 关闭监听 + * + * @param lListenHandle + * @return + */ + boolean NET_ESS_StopListen(int lListenHandle); + + /** + * 设置初始化参数 + */ + boolean NET_ESS_Init_V11(NET_EHOME_SS_INIT_PARAM pParam); + + /** + * 创建图片上传/下载客户端 + * + * @param pClientParam + * @return + */ + int NET_ESS_CreateClient(NET_EHOME_SS_CLIENT_PARAM pClientParam); + + /** + * 设置图片上传/下载客户端超时时间,单位ms,默认为5s + * + * @param lHandle + * @param dwSendTimeout + * @param dwRecvTimeout + * @return + */ + boolean NET_ESS_ClientSetTimeout(int lHandle, int dwSendTimeout, int dwRecvTimeout); + + /** + * 设置图片上传/下载客户端参数 + * + * @param lHandle + * @param strParamName + * @param strParamVal + * @return + */ + boolean NET_ESS_ClientSetParam(int lHandle, String strParamName, String strParamVal); + + /** + * 图片上传/下载客户端执行上传 + * + * @param lHandle + * @param strUrl + * @param dwUrlLen + * @return + */ + boolean NET_ESS_ClientDoUpload(int lHandle, byte[] strUrl, int dwUrlLen); + + /** + * 图片上传/下载客户端执行下载 + * + * @param lHandle + * @param strUrl + * @param pFileContent + * @param dwContentLen + * @return + */ + boolean NET_ESS_ClientDoDownload(int lHandle, String strUrl, PointerByReference pFileContent, IntByReference dwContentLen); + + /** + * 销毁客户端 + * + * @param lHandle [IN] 客户端句柄,由 {@link HCISUPSS#NET_ESS_CreateClient} 返回 + * @return + */ + boolean NET_ESS_DestroyClient(int lHandle); + + /** + * 计算 HMAC-SHA256 的值 + * + * @param pSrc [IN] 输入数据,一般指向设备 ID + * @param pSecretKey [IN] 密钥,一般指向 EHomeKey + * @param pSingatureOut [IN/OUT] 目的数据缓冲区 + * @param dwSingatureLen [IN] 目的数据缓冲区长度 + * @return 返回 TRUE 表示成功,返回 FALSE 表示失败 如果返回 FALSE,请调用 {@link HCISUPSS#NET_ESS_GetLastError} 获取错误码 + */ + boolean NET_ESS_HAMSHA256(String pSrc, String pSecretKey, String pSingatureOut, int dwSingatureLen); + +} diff --git a/src/main/java/net/javase/hksup/starter/sdk/HCISUPStream.java b/src/main/java/net/javase/hksup/starter/sdk/HCISUPStream.java new file mode 100755 index 0000000..bed78d9 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/sdk/HCISUPStream.java @@ -0,0 +1,227 @@ +package net.javase.hksup.starter.sdk; + +import com.sun.jna.Callback; +import com.sun.jna.Library; +import com.sun.jna.Pointer; +import com.sun.jna.Structure; + +import java.util.Arrays; +import java.util.List; + +public interface HCISUPStream extends Library { + + + public static class BYTE_ARRAY extends Structure { + public byte[] byValue; + + public BYTE_ARRAY(int iLen) { + byValue = new byte[iLen]; + } + + @Override + protected List getFieldOrder() { + // TODO Auto-generated method stub + return Arrays.asList("byValue"); + } + } + + public class NET_EHOME_PLAYBACK_LISTEN_PARAM extends Structure { + public HCISUPCMS.NET_EHOME_IPADDRESS struIPAdress; //本地监听信息,IP为0.0.0.0的情况下,默认为本地地址,多个网卡的情况下,默认为从操作系统获取到的第一个 + public PLAYBACK_NEWLINK_CB fnNewLinkCB; //预览请求回调函数,当收到预览连接请求后,SDK会回调该回调函数。 + public Pointer pUser; // 用户参数,在fnNewLinkCB中返回出来 + public byte byLinkMode; //0:TCP,1:UDP 2: HRUDP方式 + public byte[] byRes = new byte[127]; + } + + + public class NET_EHOME_LISTEN_PREVIEW_CFG extends Structure { + public HCISUPCMS.NET_EHOME_IPADDRESS struIPAdress; //本地监听信息,IP为0.0.0.0的情况下,默认为本地地址,多个网卡的情况下,默认为从操作系统获取到的第一个 + public PREVIEW_NEWLINK_CB fnNewLinkCB; //预览请求回调函数,当收到预览连接请求后,SDK会回调该回调函数。 + public Pointer pUser; // 用户参数,在fnNewLinkCB中返回出来 + public byte byLinkMode; //0:TCP,1:UDP 2: HRUDP方式 + public byte[] byRes = new byte[127]; + } + + public class NET_EHOME_NEWLINK_CB_MSG extends Structure { + public byte[] szDeviceID = new byte[HCISUPCMS.MAX_DEVICE_ID_LEN]; //设备标示符 + public int iSessionID; //设备分配给该取流会话的ID + public int dwChannelNo; //设备通道号 + public byte byStreamType; //0-主码流,1-子码流 + public byte[] byRes1 = new byte[3]; + public byte[] sDeviceSerial = new byte[HCISUPCMS.NET_EHOME_SERIAL_LEN]; //设备序列号,数字序列号 + public byte[] byRes = new byte[112]; + } + + public class NET_EHOME_PREVIEW_CB_MSG extends Structure { + public byte byDataType; //NET_DVR_SYSHEAD(1)-码流头,NET_DVR_STREAMDATA(2)-码流数据 + public byte[] byRes1 = new byte[3]; + public Pointer pRecvdata; //码流头或者数据 + public int dwDataLen; //数据长度 + public byte[] byRes2 = new byte[128]; + } + + public class NET_EHOME_PREVIEW_DATA_CB_PARAM extends Structure { + public PREVIEW_DATA_CB fnPreviewDataCB; //数据回调函数 + public Pointer pUserData; //用户参数, 在fnPreviewDataCB回调出来 + public byte[] byRes = new byte[128]; //保留 + } + + public static final int NET_EHOME_DEVICEID_LEN = 256; //设备ID长度 + public static final int NET_EHOME_SERIAL_LEN = 12; + + public class NET_EHOME_PLAYBACK_NEWLINK_CB_INFO extends Structure { + public byte[] szDeviceID = new byte[NET_EHOME_DEVICEID_LEN]; + public int lSessionID; //设备分配给该回放会话的ID,0表示无效(出参) + public int dwChannelNo; //设备通道号,0表示无效(出参) + public byte[] sDeviceSerial = new byte[NET_EHOME_SERIAL_LEN/*12*/]; //设备序列号,数字序列号(出参) + public byte byStreamFormat; //码流封装格式:0-PS 1-RTP(入参) + public byte[] byRes1 = new byte[3]; + public PLAYBACK_DATA_CB fnPlayBackDataCB; + public Pointer pUserData; + public byte[] byRes = new byte[88]; + } + + + public class NET_EHOME_PLAYBACK_DATA_CB_PARAM extends Structure + { + public PLAYBACK_DATA_CB fnPlayBackDataCB; //数据回调函数 + public Pointer pUserData; //用户参数, 在fnPlayBackDataCB回调出来 + public byte byStreamFormat; //码流封装格式:0-PS 1-RTP + public byte[] byRes=new byte[127]; //保留 + } + + public class NET_EHOME_PLAYBACK_DATA_CB_INFO extends Structure { + public int dwType; //类型 1-头信息 2-码流数据 + public Pointer pData; //数据指针 + public int dwDataLen; //数据长度 + public byte[] byRes = new byte[128]; //保留 + } + + + public interface PLAYBACK_DATA_CB extends Callback { + public boolean invoke(int iPlayBackLinkHandle, NET_EHOME_PLAYBACK_DATA_CB_INFO pDataCBInfo, Pointer pUserData); + } + + public interface PREVIEW_NEWLINK_CB extends Callback { + public boolean invoke(int lLinkHandle, NET_EHOME_NEWLINK_CB_MSG pNewLinkCBMsg, Pointer pUserData); + } + + public interface PLAYBACK_NEWLINK_CB extends Callback { + public boolean invoke(int lPlayBackLinkHandle, NET_EHOME_PLAYBACK_NEWLINK_CB_INFO pNewLinkCBMsg, Pointer pUserData); + } + + + public interface PREVIEW_DATA_CB extends Callback { + public void invoke(int iPreviewHandle, NET_EHOME_PREVIEW_CB_MSG pPreviewCBMsg, Pointer pUserData); + } + + public interface fExceptionCallBack extends Callback { + public void invoke(int dwType, int iUserID, int iHandle, Pointer pUser); + } + + public interface VOICETALK_NEWLINK_CB extends Callback { + public boolean invoke(int lHandle, NET_EHOME_VOICETALK_NEWLINK_CB_INFO pNewLinkCBInfo, Pointer pUserData); + } + + public interface VOICETALK_DATA_CB extends Callback { + public boolean invoke(int lHandle, NET_EHOME_VOICETALK_DATA_CB_INFO pNewLinkCBInfo, Pointer pUserData); + } + + + public static class StringPointer extends Structure { + public byte[] data; + + public StringPointer() { + } + + public StringPointer(String sInput) { + this.data = new byte[sInput.length()]; + this.data = sInput.getBytes(); + } + } + + public static class NET_EHOME_LISTEN_VOICETALK_CFG extends Structure { + public HCISUPCMS.NET_EHOME_IPADDRESS struIPAdress; //本地监听信息,IP为0.0.0.0的情况下,默认为本地地址, + //多个网卡的情况下,默认为从操作系统获取到的第一个 + public VOICETALK_NEWLINK_CB fnNewLinkCB; //新连接回调函数 + public Pointer pUser; //用户参数,在fnNewLinkCB中返回出来 + public byte byLinkMode; //0:TCP,1:UDP (UDP保留) + public byte byLinkEncrypt; //是否启用链路加密,TCP通过TLS传输,UDP(包括NPQ)使用DTLS传输,0-不启用,1-启用 + public byte[] byRes = new byte[126]; + } + + public static class NET_EHOME_VOICETALK_NEWLINK_CB_INFO extends Structure { + public byte[] szDeviceID = new byte[NET_EHOME_DEVICEID_LEN/*256*/]; //设备标示符(出参) + public int dwEncodeType; // //SDK赋值,当前对讲设备的语音编码类型,0- G722_1,1-G711U,2-G711A,3-G726,4-AAC,5-MP2L2,6-PCM, 7-MP3, 8-G723, 9-MP1L2, 10-ADPCM, 99-RAW(未识别类型)(出参) + public byte[] sDeviceSerial = new byte[NET_EHOME_SERIAL_LEN/*12*/]; //设备序列号,数字序列号(出参) + public int dwAudioChan; //对讲通道(出参) + public int lSessionID; //设备分配给该回放会话的ID,0表示无效(出参) + public byte[] byToken = new byte[64]; + public VOICETALK_DATA_CB fnVoiceTalkDataCB; //数据回调函数(入参) + public Pointer pUserData; //用户参数, 在fnVoiceTalkDataCB回调出来(入参) + public byte[] byRes = new byte[48]; + } + + + public static class NET_EHOME_VOICETALK_DATA_CB_PARAM extends Structure { + public VOICETALK_DATA_CB fnVoiceTalkDataCB; //数据回调函数 + public Pointer pUserData; //用户参数, 在fnVoiceTalkDataCB回调出来 + public byte[] byRes = new byte[128]; //保留 + } + + public static class NET_EHOME_VOICETALK_DATA_CB_INFO extends Structure { + public Pointer pData; //数据指针 + public int dwDataLen; //数据长度 + public byte[] byRes = new byte[128]; //保留 + } + + + public static class NET_EHOME_VOICETALK_DATA extends Structure { + public Pointer pData; //数据指针 + public int dwDataLen; //数据长度 + public byte[] byRes = new byte[128]; //保留 + } + + + public boolean NET_ESTREAM_Init(); + + public boolean NET_ESTREAM_SetSDKLocalCfg(int enumType, Pointer lpInBuff); + + public boolean NET_ESTREAM_SetSDKInitCfg(int enumType, Pointer lpInBuff); + + + public boolean NET_ESTREAM_Fini(); + + public int NET_ESTREAM_GetLastError(); + + public boolean NET_ESTREAM_SetExceptionCallBack(int dwMessage, int hWnd, fExceptionCallBack cbExceptionCallBack, Pointer pUser); + + public boolean NET_ESTREAM_SetLogToFile(int iLogLevel, String strLogDir, boolean bAutoDel); + + //获取版本号 + public int NET_ESTREAM_GetBuildVersion(); + + public int NET_ESTREAM_StartListenPreview(NET_EHOME_LISTEN_PREVIEW_CFG pListenParam); + + public int NET_ESTREAM_StartListenPlayBack(NET_EHOME_PLAYBACK_LISTEN_PARAM pListenParam); + public boolean NET_ESTREAM_SetPlayBackDataCB(int iPlayBackLinkHandle, NET_EHOME_PLAYBACK_DATA_CB_PARAM pDataCBParam); + + public boolean NET_ESTREAM_StopListenPreview(int iListenHandle); + + public boolean NET_ESTREAM_StopListenVoiceTalk(int lListenHandle); + + public boolean NET_ESTREAM_StopPreview(int iPreviewHandle); + + public boolean NET_ESTREAM_StopVoiceTalk(int lHandle); + + public boolean NET_ESTREAM_SetPreviewDataCB(int iHandle, NET_EHOME_PREVIEW_DATA_CB_PARAM pStruCBParam); + boolean NET_ESTREAM_StopPlayBack(int iPlayBackLinkHandle); + boolean NET_ESTREAM_StopListenPlayBack(int iPlaybackListenHandle); + public int NET_ESTREAM_StartListenVoiceTalk(NET_EHOME_LISTEN_VOICETALK_CFG pListenParam); + + public boolean NET_ESTREAM_SetVoiceTalkDataCB(int lHandle, NET_EHOME_VOICETALK_DATA_CB_PARAM pStruCBParam); + + public int NET_ESTREAM_SendVoiceTalkData(int lHandle, NET_EHOME_VOICETALK_DATA pVoicTalkData); + + +} diff --git a/src/main/java/net/javase/hksup/starter/sdk/HCNetSDK.java b/src/main/java/net/javase/hksup/starter/sdk/HCNetSDK.java new file mode 100755 index 0000000..e2472c7 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/sdk/HCNetSDK.java @@ -0,0 +1,10533 @@ +package net.javase.hksup.starter.sdk; + +import com.sun.jna.*; +import com.sun.jna.ptr.ByteByReference; +import com.sun.jna.ptr.IntByReference; +import com.sun.jna.ptr.ShortByReference; + +import java.util.Arrays; +import java.util.List; + +//SDK接口说明,HCNetSDK.dll +public interface HCNetSDK extends Library { + + /*** 宏定义 ***/ + //常量 + + public static final int MAX_NAMELEN = 16; //DVR本地登陆名 + public static final int MAX_RIGHT = 32; //设备支持的权限(1-12表示本地权限,13-32表示远程权限) + public static final int NAME_LEN = 32; //用户名长度 + public static final int PASSWD_LEN = 16; //密码长度 + public static final int SERIALNO_LEN = 48; //序列号长度 + public static final int MACADDR_LEN = 6; //mac地址长度 + public static final int MAX_ETHERNET = 2; //设备可配以太网络 + public static final int PATHNAME_LEN = 128; //路径长度 + public static final int MAX_TIMESEGMENT_V30 = 8; //9000设备最大时间段数 + public static final int MAX_TIMESEGMENT = 4; //8000设备最大时间段数 + public static final int MAX_SHELTERNUM = 4; //8000设备最大遮挡区域数 + public static final int MAX_DAYS = 7; //每周天数 + public static final int PHONENUMBER_LEN = 32; //pppoe拨号号码最大长度 + public static final int MAX_DISKNUM_V30 = 33; //9000设备最大硬盘数/* 最多33个硬盘(包括16个内置SATA硬盘、1个eSATA硬盘和16个NFS盘) */ + public static final int MAX_DISKNUM = 16; //8000设备最大硬盘数 + public static final int MAX_DISKNUM_V10 = 8; //1.2版本之前版本 + public static final int MAX_WINDOW_V30 = 32; //9000设备本地显示最大播放窗口数 + public static final int MAX_WINDOW = 16; //8000设备最大硬盘数 + public static final int MAX_VGA_V30 = 4; //9000设备最大可接VGA数 + public static final int MAX_VGA = 1; //8000设备最大可接VGA数 + public static final int MAX_USERNUM_V30 = 32; //9000设备最大用户数 + public static final int MAX_USERNUM = 16; //8000设备最大用户数 + public static final int MAX_EXCEPTIONNUM_V30 = 32; //9000设备最大异常处理数 + public static final int MAX_EXCEPTIONNUM = 16; //8000设备最大异常处理数 + public static final int MAX_LINK = 6; //8000设备单通道最大视频流连接数 + public static final int MAX_DECPOOLNUM = 4; //单路解码器每个解码通道最大可循环解码数 + public static final int MAX_DECNUM = 4; //单路解码器的最大解码通道数(实际只有一个,其他三个保留) + public static final int MAX_TRANSPARENTNUM = 2; //单路解码器可配置最大透明通道数 + public static final int MAX_CYCLE_CHAN = 16; //单路解码器最大轮循通道数 + public static final int MAX_DIRNAME_LENGTH = 80; //最大目录长度 + public static final int MAX_STRINGNUM_V30 = 8; //9000设备最大OSD字符行数数 + public static final int MAX_STRINGNUM = 4; //8000设备最大OSD字符行数数 + public static final int MAX_STRINGNUM_EX = 8; //8000定制扩展 + public static final int MAX_AUXOUT_V30 = 16; //9000设备最大辅助输出数 + public static final int MAX_AUXOUT = 4; //8000设备最大辅助输出数 + public static final int MAX_HD_GROUP = 16; //9000设备最大硬盘组数 + public static final int MAX_NFS_DISK = 8; //8000设备最大NFS硬盘数 + public static final int IW_ESSID_MAX_SIZE = 32; //WIFI的SSID号长度 + public static final int IW_ENCODING_TOKEN_MAX = 32; //WIFI密锁最大字节数 + public static final int MAX_SERIAL_NUM = 64; //最多支持的透明通道路数 + public static final int MAX_DDNS_NUMS = 10; //9000设备最大可配ddns数 + public static final int MAX_DOMAIN_NAME = 64; /* 最大域名长度 */ + + public static final int MAX_EMAIL_ADDR_LEN = 48; //最大email地址长度 + public static final int MAX_EMAIL_PWD_LEN = 32; //最大email密码长度 + public static final int MAXPROGRESS = 100; //回放时的最大百分率 + public static final int MAX_SERIALNUM = 2; //8000设备支持的串口数 1-232, 2-485 + public static final int CARDNUM_LEN = 20; //卡号长度 + public static final int MAX_VIDEOOUT_V30 = 4; //9000设备的视频输出数 + public static final int MAX_VIDEOOUT = 2; //8000设备的视频输出数 + public static final int MAX_PRESET_V30 = 256; /* 9000设备支持的云台预置点数 */ + public static final int MAX_TRACK_V30 = 256; /* 9000设备支持的云台轨迹数 */ + public static final int MAX_CRUISE_V30 = 256; /* 9000设备支持的云台巡航数 */ + public static final int MAX_PRESET = 128; /* 8000设备支持的云台预置点数 */ + public static final int MAX_TRACK = 128; /* 8000设备支持的云台轨迹数 */ + public static final int MAX_CRUISE = 128; /* 8000设备支持的云台巡航数 */ + public static final int CRUISE_MAX_PRESET_NUMS = 32; /* 一条巡航最多的巡航点 */ + public static final int MAX_SERIAL_PORT = 8; //9000设备支持232串口数 + public static final int MAX_PREVIEW_MODE = 8; /* 设备支持最大预览模式数目 1画面,4画面,9画面,16画面.... */ + public static final int MAX_MATRIXOUT = 16; /* 最大模拟矩阵输出个数 */ + public static final int LOG_INFO_LEN = 11840; /* 日志附加信息 */ + public static final int DESC_LEN = 16; /* 云台描述字符串长度 */ + public static final int PTZ_PROTOCOL_NUM = 200; /* 9000最大支持的云台协议数 */ + public static final int MAX_AUDIO = 1; //8000语音对讲通道数 + public static final int MAX_AUDIO_V30 = 2; //9000语音对讲通道数 + public static final int MAX_CHANNUM = 16; //8000设备最大通道数 + public static final int MAX_ALARMIN = 16; //8000设备最大报警输入数 + public static final int MAX_ALARMOUT = 4; //8000设备最大报警输出数 + //9000 IPC接入 + public static final int MAX_ANALOG_CHANNUM = 32; //最大32个模拟通道 + public static final int MAX_ANALOG_ALARMOUT = 32; //最大32路模拟报警输出 + public static final int MAX_ANALOG_ALARMIN = 32; //最大32路模拟报警输入 + public static final int MAX_IP_ALARMIN_V40 = 4096; //允许加入的最多报警输入数 + public static final int MAX_IP_ALARMOUT_V40 = 4096; //允许加入的最多报警输出数 + public static final int MAX_ALARMOUT_V40 = (MAX_IP_ALARMOUT_V40 + MAX_ANALOG_ALARMOUT); //4128 + public static final int MAX_ALARMIN_V40 = (MAX_IP_ALARMIN_V40 + MAX_ANALOG_ALARMOUT); //4128 + public static final int MAX_CHANNUM_V40 = 512; + public static final int MAX_IP_DEVICE = 32; //允许接入的最大IP设备数 + public static final int MAX_IP_CHANNEL = 32; //允许加入的最多IP通道数 + public static final int MAX_IP_ALARMIN = 128; //允许加入的最多报警输入数 + public static final int MAX_IP_ALARMOUT = 64; //允许加入的最多报警输出数 + + /* 最大支持的通道数 最大模拟加上最大IP支持 */ + public static final int MAX_CHANNUM_V30 = (MAX_ANALOG_CHANNUM + MAX_IP_CHANNEL);//64 + public static final int MAX_ALARMOUT_V30 = (MAX_ANALOG_ALARMOUT + MAX_IP_ALARMOUT);//96 + public static final int MAX_ALARMIN_V30 = (MAX_ANALOG_ALARMIN + MAX_IP_ALARMIN);//160 + public static final int MAX_IP_DEVICE_V40 = 64; + public static final int STREAM_ID_LEN = 32; + + public static final int MAX_LICENSE_LEN = 16; + public static final int MAX_LICENSE_LEN_EX = 32; //车牌号最大长度 + public static final int MAX_CARDNO_LEN = 48; //卡号最大长度 + public static final int VCA_MAX_POLYGON_POINT_NUM = 10; + + public static final int MAX_ID_NUM_LEN = 32; //最大身份证号长度 + public static final int MAX_ID_NAME_LEN = 128; //最大姓名长度 + public static final int MAX_ID_ADDR_LEN = 280; //最大住址长度 + public static final int MAX_ID_ISSUING_AUTHORITY_LEN = 128; //最大签发机关长度 + public static final int MAX_CARD_READER_NUM_512 = 512; //最大读卡器数 + public static final int ERROR_MSG_LEN = 32; //下发错误信息 + public static final int MAX_FACE_NUM = 2; //最大人脸数 + public static final int MAX_FINGER_PRINT_LEN = 768; //最大指纹长度 + + public static final int DEV_TYPE_NAME_LEN = 24; //设备类型名称长度 + public static final int MAX_FACE_PIC_NUM = 30; /*人脸子图个数*/ + public static final int CARDNUM_LEN_V30 = 40; + + public static final int MAX_NOTICE_NUMBER_LEN = 32; //公告编号最大长度 + public static final int MAX_NOTICE_THEME_LEN = 64; //公告主题最大长度 + public static final int MAX_NOTICE_DETAIL_LEN = 1024; //公告详情最大长度 + public static final int MAX_NOTICE_PIC_NUM = 6; //公告信息最大图片数量 + public static final int MAX_DEV_NUMBER_LEN = 32; //设备编号最大长度 + public static final int LOCK_NAME_LEN = 32; //锁名称 + + public static final int NET_SDK_EMPLOYEE_NO_LEN = 32; //工号长度 + public static final int NET_SDK_UUID_LEN = 36; //UUID长度 + + public static final int MAX_INQUEST_CDRW_NUM = 4; //最大刻录机数目 + public static final int INQUEST_MESSAGE_LEN = 44; //审讯重点标记信息长度 + public static final int INQUEST_MAX_ROOM_NUM = 2; //最大审讯室个数 + public static final int MAX_RESUME_SEGMENT = 2; //支持同时恢复的片段数目 + + public static final int SUPPORT_PD_NUM = 16; + public static final int SUPPORT_ARRAY_NUM = 8; + public static final int SUPPORT_VD_NUM = 128; + public static final int SUPPORT_PD_NUM_ = 16; + public static final int SUPPORT_PD_NUM_PARTTWO = 8; + + public static final int CARDNUM_LEN_OUT = 32; //外部结构体卡号长度 + public static final int GUID_LEN = 16; //GUID长度 + + public static final int MAX_ROIDETECT_NUM = 8; //支持的ROI区域数 + public static final int MAX_LANERECT_NUM = 5; //最大车牌识别区域数 + public static final int MAX_FORTIFY_NUM = 10; //最大布防个数 + public static final int MAX_INTERVAL_NUM = 4; //最大时间间隔个数 + public static final int MAX_CHJC_NUM = 3; //最大车辆省份简称字符个数 + public static final int MAX_VL_NUM = 5; //最大虚拟线圈个数 + public static final int MAX_DRIVECHAN_NUM = 16; //最大车道数 + public static final int MAX_COIL_NUM = 3; //最大线圈个数 + public static final int MAX_SIGNALLIGHT_NUM = 6; //最大信号灯个数 + public static final int MAX_IOSPEED_GROUP_NUM = 4; //IO测速组个数 + public static final int MAX_IOOUT_NUM = 4; //最大IO输出口个数 + public static final int MAX_IOIN_NUM = 8; //最大IO输入口个数 + public static final int MAX_RELAY_NUM = 12; //继电器控制设备最大数 2013-11-04 + public static final int MAX_VEHICLE_TYPE_NUM = 8; //车辆信息管控最大数2013-11-04 + public static final int MAX_IOIN_NUMEX = 10; //最大IO输入口个数(扩展) + public static final int MAX_ITC_LANE_NUM = 6; //最大车道个数 + public static final int MAX_LANEAREA_NUM = 2; //单车道最大区域个数 + public static final int ITC_MAX_POLYGON_POINT_NUM = 20; //检测区域最多支持20个点的多边形 + public static final int MAX_ITC_SERIALCHECK_NUM = 8; //串口校验类型个数 + public static final int MAX_LIGHT_NUM = 6; //最大交通灯数 + public static final int MAX_VIDEO_INTERVAL_NUM = 2; //最大抓拍间隔数 + public static final int MAX_VIDEO_DETECT_LIGHT_NUM = 12; //视频检测的最大检测区域 + public static final int MAX_CALIB_RECOG_NUM = 2; //标定区域个数 + public static final int MAX_RS485_NUM = 12; //485口最大支持数 + public static final int MAX_MOBILE_POLYGON_NUM = 3; //移动布控支持最大牌识区域个数 + public static final int MAX_MOBILE_DETECTLINE_NUM = 3; //移动布控支持最大违规检测线个数 + public static final int MAX_IOOUT_K_NUM = 8; //K系列最大IO输出口个数 + + public static final int NET_SDK_MAX_FDID_LEN = 256; //人脸库ID最大长度 + public static final int NET_SDK_MAX_PICID_LEN = 256; //人脸ID最大长度 + public static final int NET_SDK_MAX_INDENTITY_KEY_LEN = 64; //交互操作口令长度 + + public static final int SEARCH_EVENT_INFO_LEN = 300; //事件信息长度 + public static final int SEARCH_EVENT_INFO_LEN_V40 = 800; + public static final int MAX_POS_KEYWORDS_NUM = 3; //支持关键字查找条数 + public static final int MAX_POS_KEYWORD_LEN = 128; //每条关键字长度 + public static final int INQUEST_CASE_LEN = 64; //审讯信息长度 + + public static final int SEARCH_CASE_NO_LEN = 56; + public static final int SEARCH_CASE_NAME_LEN = 100; + public static final int SEARCH_LITIGANT_LEN = 32; + public static final int SEARCH_CHIEF_JUDGE_LEN = 32; + public static final int CASE_NO_RET_LEN = 52; + public static final int CASE_NAME_RET_LEN = 64; + public static final int LITIGANT_RET_LEN = 24; + public static final int CHIEF_JUDGE_RET_LEN = 24; + public static final int NET_SDK_CASETYPE_LEN = 32; + public static final int NET_SDK_MAX_TAPE_INDEX_LEN = 32; //磁带编号最大长度 + public static final int NET_SDK_MAX_FILE_LEN = 256; //文件名最大长度 + /******************************************************************/ + + /******************* + * 全局错误码 begin + **********************/ + public static final int NET_DVR_NOERROR = 0; //没有错误 + public static final int NET_DVR_PASSWORD_ERROR = 1; //用户名密码错误 + public static final int NET_DVR_NOENOUGHPRI = 2;//权限不足 + public static final int NET_DVR_NOINIT = 3;//没有初始化 + public static final int NET_DVR_CHANNEL_ERROR = 4; //通道号错误 + public static final int NET_DVR_OVER_MAXLINK = 5; //连接到DVR的客户端个数超过最大 + public static final int NET_DVR_VERSIONNOMATCH = 6; //版本不匹配 + public static final int NET_DVR_NETWORK_FAIL_CONNECT = 7;//连接服务器失败 + public static final int NET_DVR_NETWORK_SEND_ERROR = 8; //向服务器发送失败 + public static final int NET_DVR_NETWORK_RECV_ERROR = 9; //从服务器接收数据失败 + public static final int NET_DVR_NETWORK_RECV_TIMEOUT = 10; //从服务器接收数据超时 + public static final int NET_DVR_NETWORK_ERRORDATA = 11; //传送的数据有误 + public static final int NET_DVR_ORDER_ERROR = 12; //调用次序错误 + public static final int NET_DVR_OPERNOPERMIT = 13; //无此权限 + public static final int NET_DVR_COMMANDTIMEOUT = 14; //DVR命令执行超时 + public static final int NET_DVR_ERRORSERIALPORT = 15; //串口号错误 + public static final int NET_DVR_ERRORALARMPORT = 16; //报警端口错误 + public static final int NET_DVR_PARAMETER_ERROR = 17;//参数错误 + public static final int NET_DVR_CHAN_EXCEPTION = 18; //服务器通道处于错误状态 + public static final int NET_DVR_NODISK = 19; //没有硬盘 + public static final int NET_DVR_ERRORDISKNUM = 20; //硬盘号错误 + public static final int NET_DVR_DISK_FULL = 21; //服务器硬盘满 + public static final int NET_DVR_DISK_ERROR = 22;//服务器硬盘出错 + public static final int NET_DVR_NOSUPPORT = 23;//服务器不支持 + public static final int NET_DVR_BUSY = 24;//服务器忙 + public static final int NET_DVR_MODIFY_FAIL = 25;//服务器修改不成功 + public static final int NET_DVR_PASSWORD_FORMAT_ERROR = 26;//密码输入格式不正确 + public static final int NET_DVR_DISK_FORMATING = 27; //硬盘正在格式化,不能启动操作 + public static final int NET_DVR_DVRNORESOURCE = 28; //DVR资源不足 + public static final int NET_DVR_DVROPRATEFAILED = 29; //DVR操作失败 + public static final int NET_DVR_OPENHOSTSOUND_FAIL = 30; //打开PC声音失败 + public static final int NET_DVR_DVRVOICEOPENED = 31; //服务器语音对讲被占用 + public static final int NET_DVR_TIMEINPUTERROR = 32; //时间输入不正确 + public static final int NET_DVR_NOSPECFILE = 33; //回放时服务器没有指定的文件 + public static final int NET_DVR_CREATEFILE_ERROR = 34; //创建文件出错 + public static final int NET_DVR_FILEOPENFAIL = 35; //打开文件出错 + public static final int NET_DVR_OPERNOTFINISH = 36; //上次的操作还没有完成 + public static final int NET_DVR_GETPLAYTIMEFAIL = 37; //获取当前播放的时间出错 + public static final int NET_DVR_PLAYFAIL = 38; //播放出错 + public static final int NET_DVR_FILEFORMAT_ERROR = 39;//文件格式不正确 + public static final int NET_DVR_DIR_ERROR = 40; //路径错误 + public static final int NET_DVR_ALLOC_RESOURCE_ERROR = 41;//资源分配错误 + public static final int NET_DVR_AUDIO_MODE_ERROR = 42; //声卡模式错误 + public static final int NET_DVR_NOENOUGH_BUF = 43; //缓冲区太小 + public static final int NET_DVR_CREATESOCKET_ERROR = 44; //创建SOCKET出错 + public static final int NET_DVR_SETSOCKET_ERROR = 45; //设置SOCKET出错 + public static final int NET_DVR_MAX_NUM = 46; //个数达到最大 + public static final int NET_DVR_USERNOTEXIST = 47; //用户不存在 + public static final int NET_DVR_WRITEFLASHERROR = 48;//写FLASH出错 + public static final int NET_DVR_UPGRADEFAIL = 49;//DVR升级失败 + public static final int NET_DVR_CARDHAVEINIT = 50; //解码卡已经初始化过 + public static final int NET_DVR_PLAYERFAILED = 51; //调用播放库中某个函数失败 + public static final int NET_DVR_MAX_USERNUM = 52; //设备端用户数达到最大 + public static final int NET_DVR_GETLOCALIPANDMACFAIL = 53;//获得客户端的IP地址或物理地址失败 + public static final int NET_DVR_NOENCODEING = 54; //该通道没有编码 + public static final int NET_DVR_IPMISMATCH = 55; //IP地址不匹配 + public static final int NET_DVR_MACMISMATCH = 56;//MAC地址不匹配 + public static final int NET_DVR_UPGRADELANGMISMATCH = 57;//升级文件语言不匹配 + public static final int NET_DVR_MAX_PLAYERPORT = 58;//播放器路数达到最大 + public static final int NET_DVR_NOSPACEBACKUP = 59;//备份设备中没有足够空间进行备份 + public static final int NET_DVR_NODEVICEBACKUP = 60; //没有找到指定的备份设备 + public static final int NET_DVR_PICTURE_BITS_ERROR = 61; //图像素位数不符,限24色 + public static final int NET_DVR_PICTURE_DIMENSION_ERROR = 62;//图片高*宽超限, 限128*256 + public static final int NET_DVR_PICTURE_SIZ_ERROR = 63; //图片大小超限,限100K + public static final int NET_DVR_LOADPLAYERSDKFAILED = 64; //载入当前目录下Player Sdk出错 + public static final int NET_DVR_LOADPLAYERSDKPROC_ERROR = 65; //找不到Player Sdk中某个函数入口 + public static final int NET_DVR_LOADDSSDKFAILED = 66; //载入当前目录下DSsdk出错 + public static final int NET_DVR_LOADDSSDKPROC_ERROR = 67; //找不到DsSdk中某个函数入口 + public static final int NET_DVR_DSSDK_ERROR = 68; //调用硬解码库DsSdk中某个函数失败 + public static final int NET_DVR_VOICEMONOPOLIZE = 69; //声卡被独占 + public static final int NET_DVR_JOINMULTICASTFAILED = 70; //加入多播组失败 + public static final int NET_DVR_CREATEDIR_ERROR = 71; //建立日志文件目录失败 + public static final int NET_DVR_BINDSOCKET_ERROR = 72; //绑定套接字失败 + public static final int NET_DVR_SOCKETCLOSE_ERROR = 73; //socket连接中断,此错误通常是由于连接中断或目的地不可达 + public static final int NET_DVR_USERID_ISUSING = 74; //注销时用户ID正在进行某操作 + public static final int NET_DVR_SOCKETLISTEN_ERROR = 75; //监听失败 + public static final int NET_DVR_PROGRAM_EXCEPTION = 76; //程序异常 + public static final int NET_DVR_WRITEFILE_FAILED = 77; //写文件失败 + public static final int NET_DVR_FORMAT_READONLY = 78;//禁止格式化只读硬盘 + public static final int NET_DVR_WITHSAMEUSERNAME = 79;//用户配置结构中存在相同的用户名 + public static final int NET_DVR_DEVICETYPE_ERROR = 80; /*导入参数时设备型号不匹配*/ + public static final int NET_DVR_LANGUAGE_ERROR = 81; /*导入参数时语言不匹配*/ + public static final int NET_DVR_PARAVERSION_ERROR = 82; /*导入参数时软件版本不匹配*/ + public static final int NET_DVR_IPCHAN_NOTALIVE = 83; /*预览时外接IP通道不在线*/ + public static final int NET_DVR_RTSP_SDK_ERROR = 84; /*加载高清IPC通讯库StreamTransClient.dll失败*/ + public static final int NET_DVR_CONVERT_SDK_ERROR = 85; /*加载转码库失败*/ + public static final int NET_DVR_IPC_COUNT_OVERFLOW = 86; /*超出最大的ip接入通道数*/ + public static final int NET_PLAYM4_NOERROR = 500; //no error + public static final int NET_PLAYM4_PARA_OVER = 501;//input parameter is invalid; + public static final int NET_PLAYM4_ORDER_ERROR = 502;//The order of the function to be called is error. + public static final int NET_PLAYM4_TIMER_ERROR = 503;//Create multimedia clock failed; + public static final int NET_PLAYM4_DEC_VIDEO_ERROR = 504;//Decode video data failed. + public static final int NET_PLAYM4_DEC_AUDIO_ERROR = 505;//Decode audio data failed. + public static final int NET_PLAYM4_ALLOC_MEMORY_ERROR = 506; //Allocate memory failed. + public static final int NET_PLAYM4_OPEN_FILE_ERROR = 507; //Open the file failed. + public static final int NET_PLAYM4_CREATE_OBJ_ERROR = 508;//Create thread or event failed + public static final int NET_PLAYM4_CREATE_DDRAW_ERROR = 509;//Create DirectDraw object failed. + public static final int NET_PLAYM4_CREATE_OFFSCREEN_ERROR = 510;//failed when creating off-screen surface. + public static final int NET_PLAYM4_BUF_OVER = 511; //buffer is overflow + public static final int NET_PLAYM4_CREATE_SOUND_ERROR = 512; //failed when creating audio device. + public static final int NET_PLAYM4_SET_VOLUME_ERROR = 513;//Set volume failed + public static final int NET_PLAYM4_SUPPORT_FILE_ONLY = 514;//The function only support play file. + public static final int NET_PLAYM4_SUPPORT_STREAM_ONLY = 515;//The function only support play stream. + public static final int NET_PLAYM4_SYS_NOT_SUPPORT = 516;//System not support. + public static final int NET_PLAYM4_FILEHEADER_UNKNOWN = 517; //No file header. + public static final int NET_PLAYM4_VERSION_INCORRECT = 518; //The version of decoder and encoder is not adapted. + public static final int NET_PALYM4_INIT_DECODER_ERROR = 519; //Initialize decoder failed. + public static final int NET_PLAYM4_CHECK_FILE_ERROR = 520; //The file data is unknown. + public static final int NET_PLAYM4_INIT_TIMER_ERROR = 521; //Initialize multimedia clock failed. + public static final int NET_PLAYM4_BLT_ERROR = 522;//Blt failed. + public static final int NET_PLAYM4_UPDATE_ERROR = 523;//Update failed. + public static final int NET_PLAYM4_OPEN_FILE_ERROR_MULTI = 524; //openfile error, streamtype is multi + public static final int NET_PLAYM4_OPEN_FILE_ERROR_VIDEO = 525; //openfile error, streamtype is video + public static final int NET_PLAYM4_JPEG_COMPRESS_ERROR = 526; //JPEG compress error + public static final int NET_PLAYM4_EXTRACT_NOT_SUPPORT = 527; //Don't support the version of this file. + public static final int NET_PLAYM4_EXTRACT_DATA_ERROR = 528; //extract video data failed. + /*******************全局错误码 end**********************/ + /************************************************* + * NET_DVR_IsSupport()返回值 + * 1-9位分别表示以下信息(位与是TRUE)表示支持; + **************************************************/ + public static final int NET_DVR_SUPPORT_DDRAW = 0x01;//支持DIRECTDRAW,如果不支持,则播放器不能工作; + public static final int NET_DVR_SUPPORT_BLT = 0x02;//显卡支持BLT操作,如果不支持,则播放器不能工作; + public static final int NET_DVR_SUPPORT_BLTFOURCC = 0x04;//显卡BLT支持颜色转换,如果不支持,播放器会用软件方法作RGB转换; + public static final int NET_DVR_SUPPORT_BLTSHRINKX = 0x08;//显卡BLT支持X轴缩小;如果不支持,系统会用软件方法转换; + public static final int NET_DVR_SUPPORT_BLTSHRINKY = 0x10;//显卡BLT支持Y轴缩小;如果不支持,系统会用软件方法转换; + public static final int NET_DVR_SUPPORT_BLTSTRETCHX = 0x20;//显卡BLT支持X轴放大;如果不支持,系统会用软件方法转换; + public static final int NET_DVR_SUPPORT_BLTSTRETCHY = 0x40;//显卡BLT支持Y轴放大;如果不支持,系统会用软件方法转换; + public static final int NET_DVR_SUPPORT_SSE = 0x80;//CPU支持SSE指令,Intel Pentium3以上支持SSE指令; + public static final int NET_DVR_SUPPORT_MMX = 0x100;//CPU支持MMX指令集,Intel Pentium3以上支持SSE指令; + /********************** + * 云台控制命令 begin + *************************/ + public static final int LIGHT_PWRON = 2; /* 接通灯光电源 */ + public static final int WIPER_PWRON = 3; /* 接通雨刷开关 */ + public static final int FAN_PWRON = 4; /* 接通风扇开关 */ + public static final int HEATER_PWRON = 5; /* 接通加热器开关 */ + public static final int AUX_PWRON1 = 6; /* 接通辅助设备开关 */ + public static final int AUX_PWRON2 = 7; /* 接通辅助设备开关 */ + public static final int SET_PRESET = 8; /* 设置预置点 */ + public static final int CLE_PRESET = 9; /* 清除预置点 */ + public static final int ZOOM_IN = 11; /* 焦距以速度SS变大(倍率变大) */ + public static final int ZOOM_OUT = 12; /* 焦距以速度SS变小(倍率变小) */ + public static final int FOCUS_NEAR = 13; /* 焦点以速度SS前调 */ + public static final int FOCUS_FAR = 14; /* 焦点以速度SS后调 */ + public static final int IRIS_OPEN = 15; /* 光圈以速度SS扩大 */ + public static final int IRIS_CLOSE = 16; /* 光圈以速度SS缩小 */ + public static final int TILT_UP = 21; /* 云台以SS的速度上仰 */ + public static final int TILT_DOWN = 22; /* 云台以SS的速度下俯 */ + public static final int PAN_LEFT = 23; /* 云台以SS的速度左转 */ + public static final int PAN_RIGHT = 24; /* 云台以SS的速度右转 */ + public static final int UP_LEFT = 25; /* 云台以SS的速度上仰和左转 */ + public static final int UP_RIGHT = 26; /* 云台以SS的速度上仰和右转 */ + public static final int DOWN_LEFT = 27; /* 云台以SS的速度下俯和左转 */ + public static final int DOWN_RIGHT = 28; /* 云台以SS的速度下俯和右转 */ + public static final int PAN_AUTO = 29; /* 云台以SS的速度左右自动扫描 */ + public static final int FILL_PRE_SEQ = 30; /* 将预置点加入巡航序列 */ + public static final int SET_SEQ_DWELL = 31; /* 设置巡航点停顿时间 */ + public static final int SET_SEQ_SPEED = 32; /* 设置巡航速度 */ + public static final int CLE_PRE_SEQ = 33;/* 将预置点从巡航序列中删除 */ + public static final int STA_MEM_CRUISE = 34;/* 开始记录轨迹 */ + public static final int STO_MEM_CRUISE = 35;/* 停止记录轨迹 */ + public static final int RUN_CRUISE = 36; /* 开始轨迹 */ + public static final int RUN_SEQ = 37; /* 开始巡航 */ + public static final int STOP_SEQ = 38; /* 停止巡航 */ + public static final int GOTO_PRESET = 39; /* 快球转到预置点 */ + + /**********************云台控制命令 end*************************/ + /************************************************* + * 回放时播放控制命令宏定义 + * NET_DVR_PlayBackControl + * NET_DVR_PlayControlLocDisplay + * NET_DVR_DecPlayBackCtrl的宏定义 + * 具体支持查看函数说明和代码 + **************************************************/ + public static final int NET_DVR_PLAYSTART = 1;//开始播放 + public static final int NET_DVR_PLAYSTOP = 2;//停止播放 + public static final int NET_DVR_PLAYPAUSE = 3;//暂停播放 + public static final int NET_DVR_PLAYRESTART = 4;//恢复播放 + public static final int NET_DVR_PLAYFAST = 5;//快放 + public static final int NET_DVR_PLAYSLOW = 6;//慢放 + public static final int NET_DVR_PLAYNORMAL = 7;//正常速度 + public static final int NET_DVR_PLAYFRAME = 8;//单帧放 + public static final int NET_DVR_PLAYSTARTAUDIO = 9;//打开声音 + public static final int NET_DVR_PLAYSTOPAUDIO = 10;//关闭声音 + public static final int NET_DVR_PLAYAUDIOVOLUME = 11;//调节音量 + public static final int NET_DVR_PLAYSETPOS = 12;//改变文件回放的进度 + public static final int NET_DVR_PLAYGETPOS = 13;//获取文件回放的进度 + public static final int NET_DVR_PLAYGETTIME = 14;//获取当前已经播放的时间(按文件回放的时候有效) + public static final int NET_DVR_PLAYGETFRAME = 15;//获取当前已经播放的帧数(按文件回放的时候有效) + public static final int NET_DVR_GETTOTALFRAMES = 16;//获取当前播放文件总的帧数(按文件回放的时候有效) + public static final int NET_DVR_GETTOTALTIME = 17;//获取当前播放文件总的时间(按文件回放的时候有效) + public static final int NET_DVR_THROWBFRAME = 20;//丢B帧 + public static final int NET_DVR_SETSPEED = 24;//设置码流速度 + public static final int NET_DVR_KEEPALIVE = 25;//保持与设备的心跳(如果回调阻塞,建议2秒发送一次) + public static final int NET_DVR_SET_TRANS_TYPE = 32; //设置转码格式 + + //远程按键定义如下: + /* key value send to CONFIG program */ + public static final int KEY_CODE_1 = 1; + public static final int KEY_CODE_2 = 2; + public static final int KEY_CODE_3 = 3; + public static final int KEY_CODE_4 = 4; + public static final int KEY_CODE_5 = 5; + public static final int KEY_CODE_6 = 6; + public static final int KEY_CODE_7 = 7; + public static final int KEY_CODE_8 = 8; + public static final int KEY_CODE_9 = 9; + public static final int KEY_CODE_0 = 10; + public static final int KEY_CODE_POWER = 11; + public static final int KEY_CODE_MENU = 12; + public static final int KEY_CODE_ENTER = 13; + public static final int KEY_CODE_CANCEL = 14; + public static final int KEY_CODE_UP = 15; + public static final int KEY_CODE_DOWN = 16; + public static final int KEY_CODE_LEFT = 17; + public static final int KEY_CODE_RIGHT = 18; + public static final int KEY_CODE_EDIT = 19; + public static final int KEY_CODE_ADD = 20; + public static final int KEY_CODE_MINUS = 21; + public static final int KEY_CODE_PLAY = 22; + public static final int KEY_CODE_REC = 23; + public static final int KEY_CODE_PAN = 24; + public static final int KEY_CODE_M = 25; + public static final int KEY_CODE_A = 26; + public static final int KEY_CODE_F1 = 27; + public static final int KEY_CODE_F2 = 28; + + /* for PTZ control */ + public static final int KEY_PTZ_UP_START = KEY_CODE_UP; + public static final int KEY_PTZ_UP_STO = 32; + public static final int KEY_PTZ_DOWN_START = KEY_CODE_DOWN; + public static final int KEY_PTZ_DOWN_STOP = 33; + public static final int KEY_PTZ_LEFT_START = KEY_CODE_LEFT; + public static final int KEY_PTZ_LEFT_STOP = 34; + public static final int KEY_PTZ_RIGHT_START = KEY_CODE_RIGHT; + public static final int KEY_PTZ_RIGHT_STOP = 35; + public static final int KEY_PTZ_AP1_START = KEY_CODE_EDIT;/* 光圈+ */ + public static final int KEY_PTZ_AP1_STOP = 36; + public static final int KEY_PTZ_AP2_START = KEY_CODE_PAN;/* 光圈- */ + public static final int KEY_PTZ_AP2_STOP = 37; + public static final int KEY_PTZ_FOCUS1_START = KEY_CODE_A;/* 聚焦+ */ + public static final int KEY_PTZ_FOCUS1_STOP = 38; + public static final int KEY_PTZ_FOCUS2_START = KEY_CODE_M;/* 聚焦- */ + public static final int KEY_PTZ_FOCUS2_STOP = 39; + public static final int KEY_PTZ_B1_START = 40;/* 变倍+ */ + public static final int KEY_PTZ_B1_STOP = 41; + public static final int KEY_PTZ_B2_START = 42;/* 变倍- */ + public static final int KEY_PTZ_B2_STOP = 43; + //9000新增 + public static final int KEY_CODE_11 = 44; + public static final int KEY_CODE_12 = 45; + public static final int KEY_CODE_13 = 46; + public static final int KEY_CODE_14 = 47; + public static final int KEY_CODE_15 = 48; + public static final int KEY_CODE_16 = 49; + /************************* + * 参数配置命令 begin + *******************************/ +//用于NET_DVR_SetDVRConfig和NET_DVR_GetDVRConfig,注意其对应的配置结构 + public static final int NET_DVR_GET_DEVICECFG = 100; //获取设备参数 + public static final int NET_DVR_SET_DEVICECFG = 101; //设置设备参数 + public static final int NET_DVR_GET_DEVICECFG_V40 = 1100; //获取扩展设备参数 + public static final int NET_DVR_SET_DEVICECFG_V40 = 1101; //设置扩展设备参数 + public static final int NET_DVR_GET_NETCFG = 102; //获取网络参数 + public static final int NET_DVR_SET_NETCFG = 103; //设置网络参数 + public static final int NET_DVR_GET_PICCFG = 104; //获取图象参数 + public static final int NET_DVR_SET_PICCFG = 105; //设置图象参数 + public static final int NET_DVR_GET_COMPRESSCFG = 106; //获取压缩参数 + public static final int NET_DVR_SET_COMPRESSCFG = 107; //设置压缩参数 + public static final int NET_DVR_GET_RECORDCFG = 108; //获取录像时间参数 + public static final int NET_DVR_SET_RECORDCFG = 109; //设置录像时间参数 + public static final int NET_DVR_GET_DECODERCFG = 110; //获取解码器参数 + public static final int NET_DVR_SET_DECODERCFG = 111; //设置解码器参数 + public static final int NET_DVR_GET_RS232CFG = 112; //获取232串口参数 + public static final int NET_DVR_SET_RS232CFG = 113; //设置232串口参数 + public static final int NET_DVR_GET_ALARMINCFG = 114; //获取报警输入参数 + public static final int NET_DVR_SET_ALARMINCFG = 115; //设置报警输入参数 + public static final int NET_DVR_GET_ALARMOUTCFG = 116; //获取报警输出参数 + public static final int NET_DVR_SET_ALARMOUTCFG = 117; //设置报警输出参数 + public static final int NET_DVR_GET_TIMECFG = 118; //获取DVR时间 + public static final int NET_DVR_SET_TIMECFG = 119; //设置DVR时间 + public static final int NET_DVR_GET_PREVIEWCFG = 120; //获取预览参数 + public static final int NET_DVR_SET_PREVIEWCFG = 121; //设置预览参数 + public static final int NET_DVR_GET_VIDEOOUTCFG = 122; //获取视频输出参数 + public static final int NET_DVR_SET_VIDEOOUTCFG = 123; //设置视频输出参数 + public static final int NET_DVR_GET_USERCFG = 124; //获取用户参数 + public static final int NET_DVR_SET_USERCFG = 125; //设置用户参数 + public static final int NET_DVR_GET_EXCEPTIONCFG = 126; //获取异常参数 + public static final int NET_DVR_SET_EXCEPTIONCFG = 127; //设置异常参数 + public static final int NET_DVR_GET_ZONEANDDST = 128; //获取时区和夏时制参数 + public static final int NET_DVR_SET_ZONEANDDST = 129; //设置时区和夏时制参数 + public static final int NET_DVR_GET_SHOWSTRING = 130; //获取叠加字符参数 + public static final int NET_DVR_SET_SHOWSTRING = 131; //设置叠加字符参数 + public static final int NET_DVR_GET_EVENTCOMPCFG = 132; //获取事件触发录像参数 + public static final int NET_DVR_SET_EVENTCOMPCFG = 133; //设置事件触发录像参数 + public static final int NET_DVR_GET_AUXOUTCFG = 140; //获取报警触发辅助输出设置(HS设备辅助输出2006-02-28) + public static final int NET_DVR_SET_AUXOUTCFG = 141; //设置报警触发辅助输出设置(HS设备辅助输出2006-02-28) + public static final int NET_DVR_GET_PREVIEWCFG_AUX = 142; //获取-s系列双输出预览参数(-s系列双输出2006-04-13) + public static final int NET_DVR_SET_PREVIEWCFG_AUX = 143; //设置-s系列双输出预览参数(-s系列双输出2006-04-13) + public static final int NET_DVR_GET_PICCFG_EX = 200; //获取图象参数(SDK_V14扩展命令) + public static final int NET_DVR_SET_PICCFG_EX = 201; //设置图象参数(SDK_V14扩展命令) + public static final int NET_DVR_GET_USERCFG_EX = 202; //获取用户参数(SDK_V15扩展命令) + public static final int NET_DVR_SET_USERCFG_EX = 203; //设置用户参数(SDK_V15扩展命令) + public static final int NET_DVR_GET_COMPRESSCFG_EX = 204; //获取压缩参数(SDK_V15扩展命令2006-05-15) + public static final int NET_DVR_SET_COMPRESSCFG_EX = 205; //设置压缩参数(SDK_V15扩展命令2006-05-15) + public static final int NET_DVR_GET_NETAPPCFG = 222; //获取网络应用参数 NTP/DDNS/EMAIL + public static final int NET_DVR_SET_NETAPPCFG = 223; //设置网络应用参数 NTP/DDNS/EMAIL + public static final int NET_DVR_GET_NTPCFG = 224; //获取网络应用参数 NTP + public static final int NET_DVR_SET_NTPCFG = 225; //设置网络应用参数 NTP + public static final int NET_DVR_GET_DDNSCFG = 226; //获取网络应用参数 DDNS + public static final int NET_DVR_SET_DDNSCFG = 227; //设置网络应用参数 DDNS + //对应NET_DVR_EMAILPARA + public static final int NET_DVR_GET_EMAILCFG = 228; //获取网络应用参数 EMAIL + public static final int NET_DVR_SET_EMAILCFG = 229; //设置网络应用参数 EMAIL + public static final int NET_DVR_GET_NFSCFG = 230; /* NFS disk config */ + public static final int NET_DVR_SET_NFSCFG = 231; /* NFS disk config */ + public static final int NET_DVR_GET_SHOWSTRING_EX = 238; //获取叠加字符参数扩展(支持8条字符) + public static final int NET_DVR_SET_SHOWSTRING_EX = 239; //设置叠加字符参数扩展(支持8条字符) + public static final int NET_DVR_GET_NETCFG_OTHER = 244; //获取网络参数 + public static final int NET_DVR_SET_NETCFG_OTHER = 245; //设置网络参数 + //对应NET_DVR_EMAILCFG结构 + public static final int NET_DVR_GET_EMAILPARACFG = 250; //Get EMAIL parameters + public static final int NET_DVR_SET_EMAILPARACFG = 251; //Setup EMAIL parameters + public static final int NET_DVR_GET_DDNSCFG_EX = 274;//获取扩展DDNS参数 + public static final int NET_DVR_SET_DDNSCFG_EX = 275;//设置扩展DDNS参数 + public static final int NET_DVR_SET_PTZPOS = 292; //云台设置PTZ位置 + public static final int NET_DVR_GET_PTZPOS = 293; //云台获取PTZ位置 + public static final int NET_DVR_GET_PTZSCOPE = 294;//云台获取PTZ范围 + + public static final int NET_DVR_COMPLETE_RESTORE_CTRL = 3420; //设置完全恢复出厂值 + /*************************** + * DS9000新增命令(_V30) begin + *****************************/ +//网络(NET_DVR_NETCFG_V30结构) + public static final int NET_DVR_GET_NETCFG_V30 = 1000; //获取网络参数 + public static final int NET_DVR_SET_NETCFG_V30 = 1001; //设置网络参数 + //图象(NET_DVR_PICCFG_V30结构) + public static final int NET_DVR_GET_PICCFG_V30 = 1002; //获取图象参数 + public static final int NET_DVR_SET_PICCFG_V30 = 1003; //设置图象参数 + public static final int NET_DVR_GET_PICCFG_V40 = 6179; //获取图象参数 + public static final int NET_DVR_SET_PICCFG_V40 = 6180; //设置图象参数 + public static final int NET_DVR_GET_AES_KEY = 6113; //获取设备AES加密密钥 + //录像时间(NET_DVR_RECORD_V30结构) + public static final int NET_DVR_GET_RECORDCFG_V30 = 1004; //获取录像参数 + public static final int NET_DVR_SET_RECORDCFG_V30 = 1005; //设置录像参数 + //用户(NET_DVR_USER_V30结构) + public static final int NET_DVR_GET_USERCFG_V30 = 1006; //获取用户参数 + public static final int NET_DVR_SET_USERCFG_V30 = 1007; //设置用户参数 + //9000DDNS参数配置(NET_DVR_DDNSPARA_V30结构) + public static final int NET_DVR_GET_DDNSCFG_V30 = 1010; //获取DDNS(9000扩展) + public static final int NET_DVR_SET_DDNSCFG_V30 = 1011; //设置DDNS(9000扩展) + //EMAIL功能(NET_DVR_EMAILCFG_V30结构) + public static final int NET_DVR_GET_EMAILCFG_V30 = 1012;//获取EMAIL参数 + public static final int NET_DVR_SET_EMAILCFG_V30 = 1013;//设置EMAIL参数 + //巡航参数 (NET_DVR_CRUISE_PARA结构) + public static final int NET_DVR_GET_CRUISE = 1020; + public static final int NET_DVR_SET_CRUISE = 1021; + //报警输入结构参数 (NET_DVR_ALARMINCFG_V30结构) + public static final int NET_DVR_GET_ALARMINCFG_V30 = 1024; + public static final int NET_DVR_SET_ALARMINCFG_V30 = 1025; + //报警输出结构参数 (NET_DVR_ALARMOUTCFG_V30结构) + public static final int NET_DVR_GET_ALARMOUTCFG_V30 = 1026; + public static final int NET_DVR_SET_ALARMOUTCFG_V30 = 1027; + //视频输出结构参数 (NET_DVR_VIDEOOUT_V30结构) + public static final int NET_DVR_GET_VIDEOOUTCFG_V30 = 1028; + public static final int NET_DVR_SET_VIDEOOUTCFG_V30 = 1029; + //叠加字符结构参数 (NET_DVR_SHOWSTRING_V30结构) + public static final int NET_DVR_GET_SHOWSTRING_V30 = 1030; + public static final int NET_DVR_SET_SHOWSTRING_V30 = 1031; + //异常结构参数 (NET_DVR_EXCEPTION_V30结构) + public static final int NET_DVR_GET_EXCEPTIONCFG_V30 = 1034; + public static final int NET_DVR_SET_EXCEPTIONCFG_V30 = 1035; + //串口232结构参数 (NET_DVR_RS232CFG_V30结构) + public static final int NET_DVR_GET_RS232CFG_V30 = 1036; + public static final int NET_DVR_SET_RS232CFG_V30 = 1037; + //压缩参数 (NET_DVR_COMPRESSIONCFG_V30结构) + public static final int NET_DVR_GET_COMPRESSCFG_V30 = 1040; + public static final int NET_DVR_SET_COMPRESSCFG_V30 = 1041; + //获取485解码器参数 (NET_DVR_DECODERCFG_V30结构) + public static final int NET_DVR_GET_DECODERCFG_V30 = 1042; //获取解码器参数 + public static final int NET_DVR_SET_DECODERCFG_V30 = 1043; //设置解码器参数 + //获取预览参数 (NET_DVR_PREVIEWCFG_V30结构) + public static final int NET_DVR_GET_PREVIEWCFG_V30 = 1044; //获取预览参数 + public static final int NET_DVR_SET_PREVIEWCFG_V30 = 1045; //设置预览参数 + //辅助预览参数 (NET_DVR_PREVIEWCFG_AUX_V30结构) + public static final int NET_DVR_GET_PREVIEWCFG_AUX_V30 = 1046; //获取辅助预览参数 + public static final int NET_DVR_SET_PREVIEWCFG_AUX_V30 = 1047; //设置辅助预览参数 + //IP接入配置参数 (NET_DVR_IPPARACFG结构) + public static final int NET_DVR_GET_IPPARACFG = 1048; //获取IP接入配置信息 + public static final int NET_DVR_SET_IPPARACFG = 1049; //设置IP接入配置信息 + //IP接入配置参数V40 (NET_DVR_IPPARACFG_V40结构) + public static final int NET_DVR_GET_IPPARACFG_V40 = 1062; //获取IP接入配置信息 + public static final int NET_DVR_SET_IPPARACFG_V40 = 1063; //设置IP接入配置信息 + //IP报警输入接入配置参数 (NET_DVR_IPALARMINCFG结构) + public static final int NET_DVR_GET_IPALARMINCFG = 1050; //获取IP报警输入接入配置信息 + public static final int NET_DVR_SET_IPALARMINCFG = 1051; //设置IP报警输入接入配置信息 + //IP报警输出接入配置参数 (NET_DVR_IPALARMOUTCFG结构) + public static final int NET_DVR_GET_IPALARMOUTCFG = 1052; //获取IP报警输出接入配置信息 + public static final int NET_DVR_SET_IPALARMOUTCFG = 1053; //设置IP报警输出接入配置信息 + //硬盘管理的参数获取 (NET_DVR_HDCFG结构) + public static final int NET_DVR_GET_HDCFG = 1054; //获取硬盘管理配置参数 + public static final int NET_DVR_SET_HDCFG = 1055; //设置硬盘管理配置参数 + //盘组管理的参数获取 (NET_DVR_HDGROUP_CFG结构) + public static final int NET_DVR_GET_HDGROUP_CFG = 1056; //获取盘组管理配置参数 + public static final int NET_DVR_SET_HDGROUP_CFG = 1057; //设置盘组管理配置参数 + //设备编码类型配置(NET_DVR_COMPRESSION_AUDIO结构) + public static final int NET_DVR_GET_COMPRESSCFG_AUD = 1058; //获取设备语音对讲编码参数 + public static final int NET_DVR_SET_COMPRESSCFG_AUD = 1059; //设置设备语音对讲编码参数 + + public static final int NET_SDK_FINDMEDICALFILE = 3954; //慧影科技智慧医疗查找录像文件 + public static final int NET_SDK_FINDMEDICALPICTURE = 3955; //慧影科技智慧医疗查找图片文件 + + public static final int NET_DVR_GET_RAPIDMOVE_DETECTION = 3539; //获取快速运动侦测配置 + public static final int NET_DVR_SET_RAPIDMOVE_DETECTION = 3540; //设置快速运动侦测配置 + + public static final int NET_DVR_GET_RAPIDMOVE_TRIGGER = 3543; //获取快速运动联动配置 + public static final int NET_DVR_SET_RAPIDMOVE_TRIGGER = 3544; //设置快速运动联动配置 + public static final int NET_DVR_GET_RAPIDMOVE_SCHEDULE = 3545; //获取快速运动的布防时间配置 + public static final int NET_DVR_SET_RAPIDMOVE_SCHEDULE = 3546; //设置快速运动的布防时间配置 + + public static final int NET_DVR_GET_PRESET_NAME = 3383; //获取预置点名称 + public static final int NET_DVR_SET_PRESET_NAME = 3382; //设置预置点名称 + public static final int NET_DVR_GET_RULECFG_V42 = 5049; //获取行为分析参数(支持16条规则扩展) + public static final int NET_DVR_SET_RULECFG_V42 = 5050; //设置行为分析参数(支持16条规则扩展) + + //车牌识别(NET_VCA_PLATE_CFG); + public static final int NET_DVR_SET_PLATECFG = 150;//设置车牌识别参数 + + public static final int NET_DVR_GET_PLATECFG = 151; //获取车牌识别参数 + //行为对应(NET_VCA_RULECFG) + public static final int NET_DVR_SET_RULECFG = 152; //设置行为分析规则 + public static final int NET_DVR_GET_RULECFG = 153;//获取行为分析规则 + //双摄像机标定参数(NET_DVR_LF_CFG) + public static final int NET_DVR_SET_LF_CFG = 160;//设置双摄像机的配置参数 + public static final int NET_DVR_GET_LF_CFG = 161;//获取双摄像机的配置参数 + //智能分析仪取流配置结构 + public static final int NET_DVR_SET_IVMS_STREAMCFG = 162; //设置智能分析仪取流参数 + public static final int NET_DVR_GET_IVMS_STREAMCFG = 163; //获取智能分析仪取流参数 + //智能控制参数结构 + public static final int NET_DVR_SET_VCA_CTRLCFG = 164; //设置智能控制参数 + public static final int NET_DVR_GET_VCA_CTRLCFG = 165; //获取智能控制参数 + //屏蔽区域NET_VCA_MASK_REGION_LIST + public static final int NET_DVR_SET_VCA_MASK_REGION = 166; //设置屏蔽区域参数 + public static final int NET_DVR_GET_VCA_MASK_REGION = 167; //获取屏蔽区域参数 + //ATM进入区域 NET_VCA_ENTER_REGION + public static final int NET_DVR_SET_VCA_ENTER_REGION = 168; //设置进入区域参数 + public static final int NET_DVR_GET_VCA_ENTER_REGION = 169; //获取进入区域参数 + //标定线配置NET_VCA_LINE_SEGMENT_LIST + public static final int NET_DVR_SET_VCA_LINE_SEGMENT = 170; //设置标定线 + public static final int NET_DVR_GET_VCA_LINE_SEGMENT = 171; //获取标定线 + // ivms屏蔽区域NET_IVMS_MASK_REGION_LIST + public static final int NET_DVR_SET_IVMS_MASK_REGION = 172; //设置IVMS屏蔽区域参数 + public static final int NET_DVR_GET_IVMS_MASK_REGION = 173; //获取IVMS屏蔽区域参数 + // ivms进入检测区域NET_IVMS_ENTER_REGION + public static final int NET_DVR_SET_IVMS_ENTER_REGION = 174; //设置IVMS进入区域参数 + public static final int NET_DVR_GET_IVMS_ENTER_REGION = 175; //获取IVMS进入区域参数 + public static final int NET_DVR_SET_IVMS_BEHAVIORCFG = 176;//设置智能分析仪行为规则参数 + public static final int NET_DVR_GET_IVMS_BEHAVIORCFG = 177; //获取智能分析仪行为规则参数 + public static final int NET_DVR_GET_TRAVERSE_PLANE_DETECTION = 3360; //获取越界侦测配置 + public static final int NET_DVR_SET_TRAVERSE_PLANE_DETECTION = 3361; + public static final int NET_DVR_GET_FIELD_DETECTION = 3362; //获取区域侦测配置 + public static final int NET_DVR_SET_FIELD_DETECTION = 3363; //设置区域侦测配置 + + public static final int NET_DVR_GET_STREAM_INFO = 6023; //获取已添加流ID信息 + public static final int NET_DVR_GET_STREAM_RECORD_STATUS = 6021; //获取流状态信息 + + public static final int NET_DVR_GET_ALL_VEHICLE_CONTROL_LIST = 3124; //获取所有车辆禁止和允许名单信息 + public static final int NET_DVR_VEHICLELIST_CTRL_START = 3133; //设置车辆禁止和允许名单信息(批量) + public static final int ENUM_SENDDATA = 0x0; //发送数据 + + public static final int NET_DVR_GET_LEDDISPLAY_CFG = 3673; + public static final int NET_DVR_SET_LEDDISPLAY_CFG = 3672; + public static final int NET_DVR_SET_VOICEBROADCAST_CFG = 3675; + public static final int NET_DVR_SET_CHARGE_ACCOUNTINFO = 3662; + + public static final int NET_DVR_GET_TRAFFIC_DATA = 3141; //长连接获取交通数据 + public static final int NET_DVR_GET_TRAFFIC_FLOW = 3142; //长连接获取交通流量 + + public static final int NET_DVR_GET_CCDPARAMCFG_EX = 3368;//获取前端参数(扩展) + public static final int NET_DVR_SET_CCDPARAMCFG_EX = 3369;//设置前端参数(扩展) + public static final int NET_DVR_GET_FOCUSMODECFG = 3305;//获取快球聚焦模式信息 + public static final int NET_DVR_SET_FOCUSMODECFG = 3306;//设置快球聚焦模式信息 + + public static final int NET_DVR_GET_SUPPLEMENTLIGHT = 3728; //获取内置补光灯配置协议 + public static final int NET_DVR_SET_SUPPLEMENTLIGHT = 3729; //设置内置补光灯配置协议 + + public static final int NET_DVR_GET_FACECONTRAST_TRIGGER = 3965;//获取人脸比对联动配置 + public static final int NET_DVR_SET_FACECONTRAST_TRIGGER = 3966;//设置人脸比对联动配置 + + public static final int NET_DVR_GET_FACECONTRAST_SCHEDULE = 3968;//获取人脸比对布防时间配置 + public static final int NET_DVR_SET_FACECONTRAST_SCHEDULE = 3969;//设置人脸比对布防时间配置 + + public static final int NET_DVR_INQUEST_GET_CDW_STATUS = 6350; //获取审讯机刻录状态-长连接 + + public static final int NET_DVR_GET_REALTIME_THERMOMETRY = 3629; //实时温度检测 + public static final int NET_DVR_GET_MANUALTHERM_INFO = 6706; //手动测温实时获取 + public static final int NET_DVR_GET_THERMOMETRY_MODE = 6765;//获取测温模式参数 + public static final int NET_DVR_SET_THERMOMETRY_MODE = 6766;//设置测温模式参数 + public static final int NET_DVR_GET_PTZABSOLUTEEX = 6696; + public static final int NET_DVR_GET_THERMOMETRY_PRESETINFO = 3624; //获取测温预置点关联配置参数 + public static final int NET_DVR_SET_THERMOMETRY_PRESETINFO = 3625; //设置测温预置点关联配置参数 + public static final int NET_DVR_GET_THERMOMETRYRULE_TEMPERATURE_INFO = 23001;//手动获取测温规则温度信息 + public static final int NET_DVR_SET_DEVSERVER_CFG = 3258;//设置模块服务配置 + + public static final int NET_DVR_GET_PHY_DISK_INFO = 6306; //获取物理磁盘信息 + public static final int NET_DVR_GET_WORK_STATUS = 6189; //获取设备工作状态 + public static final int NET_DVR_GET_MONTHLY_RECORD_DISTRIBUTION = 6164; //获取月历录像分布 + + public static final int NET_DVR_GET_CURTRIGGERMODE = 3130; //获取设备当前触发模式 + public static final int NET_ITC_GET_TRIGGERCFG = 3003; //获取触发参数 + public static final int NET_ITC_SET_TRIGGERCFG = 3004; //设置触发参数 + public static final int NET_ITC_GET_VIDEO_TRIGGERCFG = 3017; //获取视频电警触发参数 + public static final int NET_ITC_SET_VIDEO_TRIGGERCFG = 3018; //设置视频电警触发参数 + + public static final int NET_DVR_GET_MULTI_STREAM_COMPRESSIONCFG = 3216;//远程获取多码流压缩参数 + public static final int NET_DVR_SET_MULTI_STREAM_COMPRESSIONCFG = 3217;//远程设置多码流压缩参数 + + public static final int NET_DVR_GET_CMS_CFG = 2070; + public static final int NET_DVR_SET_CMS_CFG = 2071; + + public static final int NET_DVR_GET_ALARM_INFO = 4193; //获取报警事件数据 + /***************************DS9000新增命令(_V30) end *****************************/ + + /*************************参数配置命令 end*******************************/ + /*************************************人脸识别门禁一体机1.0 begin**************************************/ + public static final int NET_DVR_GET_CARD_CFG = 2116; //获取卡参数 + public static final int NET_DVR_SET_CARD_CFG = 2117; //设置卡参数 + public static final int NET_DVR_GET_CARD_CFG_V50 = 2178; //获取新卡参数(V50) + public static final int NET_DVR_SET_CARD_CFG_V50 = 2179; //设置新卡参数(V50) + public static final int NET_DVR_GET_FACE_PARAM_CFG = 2507; //获取人脸参数 + public static final int NET_DVR_SET_FACE_PARAM_CFG = 2508; //设置人脸参数 + public static final int NET_DVR_DEL_FACE_PARAM_CFG = 2509; //删除人脸参数 + public static final int NET_DVR_CLEAR_ACS_PARAM = 2118; //清空门禁主机参数 + public static final int NET_DVR_DEL_FINGERPRINT_CFG = 2152; //删除指纹参数 + public static final int NET_DVR_GET_FINGERPRINT_CFG_V50 = 2183; //获取指纹参数V50 + public static final int NET_DVR_SET_FINGERPRINT_CFG_V50 = 2184; //设置指纹参数V50 + public static final int NET_DVR_DEL_FINGERPRINT_CFG_V50 = 2517; //删除指纹参数V50 + public static final int NET_DVR_GET_CARD_RIGHT_WEEK_PLAN_V50 = 2304; //获取卡权限周计划参数V50 + public static final int NET_DVR_SET_CARD_RIGHT_WEEK_PLAN_V50 = 2305; //设置卡权限周计划参数V50 + public static final int NET_DVR_GET_CARD_RIGHT_PLAN_TEMPLATE_V50 = 2322; //获取卡权限计划模板参数V50 + public static final int NET_DVR_SET_CARD_RIGHT_PLAN_TEMPLATE_V50 = 2323;//设置卡权限计划模板参数V50 + public static final int NET_DVR_SET_DOOR_STATUS_PLAN_TEMPLATE = 2107; //设置门状态计划模板参数 + public static final int NET_DVR_GET_DOOR_CFG = 2108; //获取门参数 + public static final int NET_DVR_SET_DOOR_CFG = 2109; //设置门参数 + public static final int NET_DVR_GET_DOOR_STATUS_PLAN = 2110; //获取门状态计划参数 + public static final int NET_DVR_SET_DOOR_STATUS_PLAN = 2111; //设置门状态计划参数 + public static final int NET_DVR_GET_WEEK_PLAN_CFG = 2100; //获取门状态周计划参数 + public static final int NET_DVR_SET_WEEK_PLAN_CFG = 2101; //设置门状态周计划参数 + public static final int NET_DVR_GET_EVENT_CARD_LINKAGE_CFG_V50 = 2181; //获取事件卡号联动配置参数(V50) + public static final int NET_DVR_SET_EVENT_CARD_LINKAGE_CFG_V50 = 2182; //设置事件卡号联动配置参数(V50) + public static final int NET_DVR_CAPTURE_FACE_INFO = 2510; //采集人脸信息 + public static final int NET_DVR_CAPTURE_FINGERPRINT_INFO = 2504; //采集指纹信息 + public static final int NET_DVR_GET_ACS_EVENT = 2514;//设备事件获取 + public static final int NET_DVR_GET_CARD_READER_CFG_V50 = 2505; //获取读卡器参数(V50) + public static final int NET_DVR_SET_CARD_READER_CFG_V50 = 2506; //设置读卡器参数(V50) + public static final int NET_DVR_GET_REGISTER_INFO = 2511; //登记信息获取 + public static final int NET_DVR_GET_SMSRELATIVEPARA_V50 = 2512; //获取短信相关参数 + public static final int NET_DVR_SET_SMSRELATIVEPARA_V50 = 2513; //设置短信相关参数 + public static final int NET_DVR_GET_MULTI_CARD_CFG_V50 = 2515; //获取多重卡参数V50 + public static final int NET_DVR_SET_MULTI_CARD_CFG_V50 = 2516; //设置多重卡参数V5 + public static final int NET_DVR_GET_EVENT_CARD_LINKAGE_CFG_V51 = 2518; //获取事件卡号联动配置参数(V51) + public static final int NET_DVR_SET_EVENT_CARD_LINKAGE_CFG_V51 = 2519; //设置事件卡号联动配置参数(V51) + + public static final int NET_DVR_SET_EXAM_INFO = 2530; //考试信息下发 + public static final int NET_DVR_SET_EXAMINEE_INFO = 2531; //考生信息下发 + public static final int NET_DVR_SEARCH_EXAM_COMPARE_RESULT = 2532; //考试比对结果查询 + public static final int NET_DVR_BULK_CHECK_FACE_PICTURE = 2533; //批量校验人脸图片 + public static final int NET_DVR_JSON_CONFIG = 2550; //JSON透传数据 + public static final int NET_DVR_FACE_DATA_RECORD = 2551; //添加人脸数据到人脸库 + public static final int NET_DVR_FACE_DATA_SEARCH = 2552; //查询人脸库中的人脸数据 + public static final int NET_DVR_FACE_DATA_MODIFY = 2553; //修改人脸库中的人脸数据 + public static final int NET_DVR_CAPTURE_DATA_SEARCH = 2554; //查询离线采集数据集中数据 + public static final int NET_DVR_SET_FORM_DATA = 2555; //长连接设置表单数据 + public static final int NET_DVR_GET_FORM_DATA = 2556; //长连接获取表单数据 + public static final int NET_DVR_GET_CARD = 2560; + public static final int NET_DVR_SET_CARD = 2561; + public static final int NET_DVR_GET_FACE = 2566; + public static final int NET_DVR_SET_FACE = 2567; + public static final int NET_DVR_DEL_CARD = 2562; + public static final int NET_DVR_GET_FINGERPRINT = 2563; + public static final int NET_DVR_SET_FINGERPRINT = 2564; //下发指纹 + public static final int NET_DVR_DEL_FINGERPRINT = 2565; //删除指纹 + public static final int NET_DVR_GET_ACS_WORK_STATUS_V50 = 2180; //获取门禁主机工作状态 + public static final int NET_DVR_GET_ACS_CFG = 2159; //获取门禁主机参数 + public static final int NET_DVR_SET_ACS_CFG = 2160; //设置门禁主机参数 + public static final int NET_DVR_BULK_UPLOAD_ID_BLOCKLIST = 2521; //批量上传身份证禁止名单 + + /*************************************人脸识别门禁一体机1.0 end**************************************/ + public static final int NET_DVR_SET_SENSOR_CFG = 1180;//设置模拟量参数 + public static final int NET_DVR_GET_SENSOR_CFG = 1181;//获取模拟量参数 + public static final int NET_DVR_SET_ALARMIN_PARAM = 1182;//设置报警输入参数 + public static final int NET_DVR_GET_ALARMIN_PARAM = 1183; + ;//获取报警输入参数 + public static final int NET_DVR_SET_ALARMOUT_PARAM = 1184;//设置报警输出参数 + public static final int NET_DVR_GET_ALARMOUT_PARAM = 1185;//获取报警输出参数 + public static final int NET_DVR_SET_SIREN_PARAM = 1186;//设置警号参数 + public static final int NET_DVR_GET_SIREN_PARAM = 1187;//获取警号参数 + public static final int NET_DVR_SET_ALARM_RS485CFG = 1188;//设置报警主机485参数 + public static final int NET_DVR_GET_ALARM_RS485CFG = 1189;//获取报警主机485参数 + public static final int NET_DVR_GET_ALARMHOST_MAIN_STATUS = 1190;//获取报警主机主要状态 + public static final int NET_DVR_GET_ALARMHOST_OTHER_STATUS = 1191;//获取报警主机其他状态 + public static final int NET_DVR_SET_ALARMHOST_ENABLECFG = 1192;//获取报警主机使能状态 + public static final int NET_DVR_GET_ALARMHOST_ENABLECFG = 1193;//设置报警主机使能状态 + public static final int NET_DVR_SET_ALARM_CAMCFG = 1194;//设置视频综合平台报警触发CAM操作配置 + public static final int NET_DVR_GET_ALARM_CAMCFG = 1195;//设置视频综合平台报警触发CAM操作配置 + public static final int NET_DVR_SET_ALARMHOST_RS485_SLOT_CFG = 2055;// 设置报警主机485槽位参数 + public static final int NET_DVR_GET_ALARMHOST_RS485_SLOT_CFG = 2056;// 获取报警主机485槽位参数 + public static final int NET_DVR_SET_VIDEOWALLDISPLAYMODE = 1730;//设置电视墙拼接模式 + public static final int NET_DVR_GET_VIDEOWALLDISPLAYMODE = 1731;//获取电视墙拼接模式 + public static final int NET_DVR_GET_VIDEOWALLDISPLAYNO = 1732;//获取设备显示输出号 + public static final int NET_DVR_SET_VIDEOWALLDISPLAYPOSITION = 1733;//设置显示输出位置参数 + public static final int NET_DVR_GET_VIDEOWALLDISPLAYPOSITION = 1734;//获取显示输出位置参数 + public static final int NET_DVR_GET_VIDEOWALLWINDOWPOSITION = 1735;//获取电视墙窗口参数 + public static final int NET_DVR_SET_VIDEOWALLWINDOWPOSITION = 1736;//设置电视墙窗口参数 + public static final int NET_DVR_VIDEOWALLWINDOW_CLOSEALL = 1737;//电视墙关闭所有窗口 + public static final int NET_DVR_SET_VIRTUALLED = 1738;//虚拟LED设置 + public static final int NET_DVR_GET_VIRTUALLED = 1739;//虚拟LED获取 + public static final int NET_DVR_GET_IMAGE_CUT_MODE = 1740;//获取图像切割模式 + public static final int NET_DVR_SET_IMAGE_CUT_MODE = 1741;//设置图像切割模式 + public static final int NET_DVR_GET_USING_SERIALPORT = 1742;//获取当前使用串口 + public static final int NET_DVR_SET_USING_SERIALPORT = 1743;//设置当前使用串口 + public static final int NET_DVR_SCENE_CONTROL = 1744;//场景控制 + public static final int NET_DVR_GET_CURRENT_SCENE = 1745;//获取当前场景号 + public static final int NET_DVR_GET_VW_SCENE_PARAM = 1746;//获取电视墙场景模式参数 + public static final int NET_DVR_SET_VW_SCENE_PARAM = 1747;//设置电视墙场景模式参数 + public static final int NET_DVR_DISPLAY_CHANNO_CONTROL = 1748;//电视墙显示编号控制 + public static final int NET_DVR_GET_WIN_DEC_INFO = 1749;//获取窗口解码信息(批量) + public static final int NET_DVR_RESET_VIDEOWALLDISPLAYPOSITION = 1750; //解除电视墙输出接口绑定 + public static final int NET_DVR_SET_VW_AUDIO_CFG = 1752; //设置音频切换参数 + public static final int NET_DVR_GET_VW_AUDIO_CFG = 1753; //获取音频切换参数 + public static final int NET_DVR_GET_GBT28181_DECCHANINFO_CFG = 1754; //获取GBT28181协议接入设备的解码通道信息 + public static final int NET_DVR_SET_GBT28181_DECCHANINFO_CFG = 1755; //设置GBT28181协议接入设备的解码通道信息 + public static final int NET_DVR_SET_MAINBOARD_SERIAL = 1756; //设置主控板串口参数 + public static final int NET_DVR_GET_MAINBOARD_SERIAL = 1757;//获取主控板串口参数 + public static final int NET_DVR_GET_SUBBOARD_INFO = 1758; //获取子板信息 + public static final int NET_DVR_GET_SUBBOARD_EXCEPTION = 1759; //获取异常子板异常信息 + /*****************************电视墙 start****************************/ + public static final int NET_DVR_MATRIX_WALL_SET = 9001; //设置电视墙中屏幕参数 + public static final int NET_DVR_MATRIX_WALL_GET = 9002; //获取电视墙中屏幕参数 + public static final int NET_DVR_WALLWIN_GET = 9003; //电视墙中获取窗口参数 + public static final int NET_DVR_WALLWIN_SET = 9004; //电视墙中设置窗口参数 + public static final int NET_DVR_WALLWINPARAM_SET = 9005; + ; //设置电视墙窗口相关参数 + public static final int NET_DVR_WALLWINPARAM_GET = 9006; //获取电视墙窗口相关参数 + public static final int NET_DVR_WALLSCENEPARAM_GET = 9007; //设置场景模式参数 + public static final int NET_DVR_WALLSCENEPARAM_SET = 9008; //获取场景模式参数 + public static final int NET_DVR_MATRIX_GETWINSTATUS = 9009; //获取窗口解码状态 + public static final int NET_DVR_GET_WINASSOCIATEDDEVINFO = 9010; //电视墙中获取对应资源信息 + public static final int NET_DVR_WALLOUTPUT_GET = 9011; //电视墙中获取显示输出参数 + public static final int NET_DVR_WALLOUTPUT_SET = 9012; //电视墙中设置显示输出参数 + public static final int NET_DVR_GET_UNITEDMATRIXSYSTEM = 9013; //电视墙中获取对应资源 + public static final int NET_DVR_GET_WALL_CFG = 9014; //获取电视墙全局参数 + public static final int NET_DVR_SET_WALL_CFG = 9015; //设置电视墙全局参数 + public static final int NET_DVR_CLOSE_ALL_WND = 9016; //关闭所有窗口 + public static final int NET_DVR_SWITCH_WIN_TOP = 9017; //窗口置顶 + public static final int NET_DVR_SWITCH_WIN_BOTTOM = 9018; //窗口置底 + + public static final int NET_DVR_CLOSE_ALL_WND_V41 = 9019; //电视墙关闭所有窗口v41(有多个电视墙) + public static final int NET_DVR_GET_WALL_WINDOW_V41 = 9020; //获取电视墙中的窗口v41 + public static final int NET_DVR_SET_WALL_WINDOW_V41 = 9021; //设置电视墙中的窗口v41 + public static final int NET_DVR_GET_CURRENT_SCENE_V41 = 9022; //获取当前电视墙中正在使用的场景v41 + public static final int NET_DVR_GET_WALL_SCENE_PARAM_V41 = 9023; //获取当前电视墙中正在使用的场景v41 + public static final int NET_DVR_SET_WALL_SCENE_PARAM_V41 = 9024; //设置当前电视墙中正在使用的场景v41 + public static final int NET_DVR_GET_MATRIX_LOGO_CFG = 9025; //获取logo参数 + public static final int NET_DVR_SET_MATRIX_LOGO_CFG = 9026; //设置logo参数 + public static final int NET_DVR_GET_WIN_LOGO_CFG = 9027; //获取窗口logo参数 + public static final int NET_DVR_SET_WIN_LOGO_CFG = 9028; //设置窗口logo参数 + public static final int NET_DVR_DELETE_LOGO = 9029; //删除logo + public static final int NET_DVR_SET_DISPLAY_EFFECT_CFG = 9030; //设置显示输出效果参数v41 + public static final int NET_DVR_GET_DISPLAY_EFFECT_CFG = 9031; //获取显示输出效果参数v41 + public static final int NET_DVR_DEC_PLAY_REMOTE_FILE = 9032; //解码播放远程文件 + public static final int NET_DVR_DEC_PLAY_REMOTE_FILE_V50 = 9314; //解码播放远程文件V50 + public static final int NET_DVR_GET_WIN_ZOOM_STATUS = 9033; //获取窗口电子放大状态 + public static final int NET_DVR_GET_ALL_MATRIX_LOGOCFG = 9034; //获取所有logo参数 + +/*****************************电视墙 end******************************/ + + /******************* + * 查找文件和日志函数返回值 + *************************/ + public static final int NET_DVR_FILE_SUCCESS = 1000; //获得文件信息 + public static final int NET_DVR_FILE_NOFIND = 1001; //没有文件 + public static final int NET_DVR_ISFINDING = 1002;//正在查找文件 + public static final int NET_DVR_NOMOREFILE = 1003;//查找文件时没有更多的文件 + public static final int NET_DVR_FILE_EXCEPTION = 1004;//查找文件时异常 + /********************* + * 回调函数类型 begin + ************************/ + public static final int COMM_ALARM = 0x1100; //8000报警信息主动上传 + public static final int COMM_TRADEINFO = 0x1500; //ATMDVR主动上传交易信息 + public static final int COMM_ALARM_V30 = 0x4000;//9000报警信息主动上传 + public static final int COMM_ALARM_V40 = 0x4007; + public static final int COMM_ALARM_RULE = 0x1102;//行为分析信息上传 + public static final int COMM_ALARM_PDC = 0x1103;//客流量统计报警上传 + public static final int COMM_UPLOAD_PLATE_RESULT = 0x2800;//交通抓拍结果上传 + public static final int COMM_ITS_PLATE_RESULT = 0x3050;//交通抓拍的终端图片上传 + public static final int COMM_IPCCFG = 0x4001;//9000设备IPC接入配置改变报警信息主动上传 + public static final int COMM_ITS_PARK_VEHICLE = 0x3056;//停车场数据上传 + public static final int COMM_VEHICLE_CONTROL_ALARM = 0x3059;//车辆报警上传 + public static final int COMM_ALARM_TFS = 0x1113; //交通取证报警信息 + public static final int COMM_ALARM_TPS_V41 = 0x1114; //交通事件报警信息扩展 + public static final int COMM_ALARM_AID_V41 = 0x1115; //交通事件报警信息扩展 + public static final int COMM_UPLOAD_FACESNAP_RESULT = 0x1112; //人脸识别结果上传 + public static final int COMM_SNAP_MATCH_ALARM = 0x2902; //人脸比对结果上传 + public static final int COMM_ALARM_ACS = 0x5002; //门禁主机报警信息 + public static final int COMM_ID_INFO_ALARM = 0x5200; //门禁身份证刷卡信息 + public static final int COMM_VCA_ALARM = 0x4993; //智能检测通用报警 + public static final int COMM_ISAPI_ALARM = 0x6009;//ISAPI协议报警信息 + public static final int COMM_ALARM_TPS_STATISTICS = 0x3082; //TPS统计过车数据上传 + public static final int COMM_ALARM_TPS_REAL_TIME = 0x3081; //TPS实时过车数据上传 + public static final int COMM_ALARMHOST_CID_ALARM = 0x1127; //报告报警上传 + public static final int COMM_SENSOR_VALUE_UPLOAD = 0x1120; //模拟量数据实时上传 + public static final int COMM_SENSOR_ALARM = 0x1121; //模拟量报警上传 + public static final int COMM_SWITCH_ALARM = 0x1122; //开关量报警 + public static final int COMM_ALARMHOST_EXCEPTION = 0x1123; //报警主机故障报警 + public static final int COMM_ALARMHOST_OPERATEEVENT_ALARM = 0x1124; //操作事件报警上传 + public static final int COMM_ALARMHOST_SAFETYCABINSTATE = 0x1125; //防护舱状态 + public static final int COMM_ALARMHOST_ALARMOUTSTATUS = 0x1126; //报警输出口/警号状态 + public static final int COMM_ALARMHOST_DATA_UPLOAD = 0x1129; //报警数据上传 + + public static final int COMM_UPLOAD_VIDEO_INTERCOM_EVENT = 0x1132; //可视对讲事件记录上传 + public static final int COMM_ALARM_VIDEO_INTERCOM = 0x1133; //可视对讲报警上传 + public static final int COMM_THERMOMETRY_ALARM = 0x5212; //温度报警上传 + public static final int COMM_FIREDETECTION_ALARM = 0x4991; //火点报警上传 + public static final int COMM_THERMOMETRY_DIFF_ALARM = 0x5111; //温差报警 + public static final int COMM_ALARM_SHIPSDETECTION = 0x4521; //船只检测报警 + public static final int COMM_UPLOAD_AIOP_VIDEO = 0x4021; //设备支持AI开放平台接入,上传视频检测数据 + public static final int COMM_UPLOAD_AIOP_PICTURE = 0x4022; //设备支持AI开放平台接入,上传图片检测数据 + public static final int COMM_UPLOAD_AIOP_POLLING_SNAP = 0x4023; //设备支持AI开放平台接入,上传轮巡抓图图片检测数据 对应的结构体(NET_AIOP_POLLING_PICTURE_HEAD) + public static final int COMM_UPLOAD_AIOP_POLLING_VIDEO = 0x4024; //设备支持AI开放平台接入,上传轮巡视频检测数据 对应的结构体(NET_AIOP_POLLING_VIDEO_HEAD) + public static final int COMM_IPC_AUXALARM_RESULT = 0x2820; //PIR报警、无线报警、呼救报警信息 + /************* + * 操作异常类型(消息方式, 回调方式(保留)) + ****************/ + public static final int EXCEPTION_EXCHANGE = 0x8000;//用户交互时异常 + public static final int EXCEPTION_AUDIOEXCHANGE = 0x8001;//语音对讲异常 + public static final int EXCEPTION_ALARM = 0x8002;//报警异常 + public static final int EXCEPTION_PREVIEW = 0x8003;//网络预览异常 + public static final int EXCEPTION_SERIAL = 0x8004;//透明通道异常 + public static final int EXCEPTION_RECONNECT = 0x8005; //预览时重连 + public static final int EXCEPTION_ALARMRECONNECT = 0x8006;//报警时重连 + public static final int EXCEPTION_SERIALRECONNECT = 0x8007;//透明通道重连 + public static final int EXCEPTION_PLAYBACK = 0x8010;//回放异常 + public static final int EXCEPTION_DISKFMT = 0x8011;//硬盘格式化 + /******************** + * 预览回调函数 + *********************/ + public static final int NET_DVR_SYSHEAD = 1;//系统头数据 + public static final int NET_DVR_STREAMDATA = 2;//视频流数据(包括复合流和音视频分开的视频流数据) + public static final int NET_DVR_AUDIOSTREAMDATA = 3;//音频流数据 + public static final int NET_DVR_STD_VIDEODATA = 4;//标准视频流数据 + public static final int NET_DVR_STD_AUDIODATA = 5;//标准音频流数据 + //回调预览中的状态和消息 + public static final int NET_DVR_REALPLAYEXCEPTION = 111;//预览异常 + public static final int NET_DVR_REALPLAYNETCLOSE = 112;//预览时连接断开 + public static final int NET_DVR_REALPLAY5SNODATA = 113;//预览5s没有收到数据 + public static final int NET_DVR_REALPLAYRECONNECT = 114;//预览重连 + /******************** + * 回放回调函数 + *********************/ + public static final int NET_DVR_PLAYBACKOVER = 101;//回放数据播放完毕 + public static final int NET_DVR_PLAYBACKEXCEPTION = 102;//回放异常 + public static final int NET_DVR_PLAYBACKNETCLOSE = 103;//回放时候连接断开 + public static final int NET_DVR_PLAYBACK5SNODATA = 104; //回放5s没有收到数据 + /********************* + * 回调函数类型 end + ************************/ +//设备型号(DVR类型) + /* 设备类型 */ + public static final int DVR = 1; /*对尚未定义的dvr类型返回NETRET_DVR*/ + public static final int ATMDVR = 2; /*atm dvr*/ + public static final int DVS = 3; /*DVS*/ + public static final int DEC = 4; /* 6001D */ + public static final int ENC_DEC = 5; /* 6001F */ + public static final int DVR_HC = 6; /*8000HC*/ + public static final int DVR_HT = 7; /*8000HT*/ + public static final int DVR_HF = 8; /*8000HF*/ + public static final int DVR_HS = 9; /* 8000HS DVR(no audio) */ + public static final int DVR_HTS = 10; /* 8016HTS DVR(no audio) */ + public static final int DVR_HB = 11; /* HB DVR(SATA HD) */ + public static final int DVR_HCS = 12; /* 8000HCS DVR */ + public static final int DVS_A = 13; /* 带ATA硬盘的DVS */ + public static final int DVR_HC_S = 14; /* 8000HC-S */ + public static final int DVR_HT_S = 15; /* 8000HT-S */ + public static final int DVR_HF_S = 16; /* 8000HF-S */ + public static final int DVR_HS_S = 17; /* 8000HS-S */ + public static final int ATMDVR_S = 18; /* ATM-S */ + public static final int LOWCOST_DVR = 19; /*7000H系列*/ + public static final int DEC_MAT = 20; /*多路解码器*/ + public static final int DVR_MOBILE = 21; /* mobile DVR */ + public static final int DVR_HD_S = 22; /* 8000HD-S */ + public static final int DVR_HD_SL = 23; /* 8000HD-SL */ + public static final int DVR_HC_SL = 24; /* 8000HC-SL */ + public static final int DVR_HS_ST = 25; /* 8000HS_ST */ + public static final int DVS_HW = 26; /* 6000HW */ + public static final int IPCAM = 30; /*IP 摄像机*/ + public static final int MEGA_IPCAM = 31; /*X52MF系列,752MF,852MF*/ + public static final int IPCAM_X62MF = 32; /*X62MF系列可接入9000设备,762MF,862MF*/ + public static final int IPDOME = 40; /*IP标清快球*/ + public static final int MEGA_IPDOME = 41; /*IP高清快球*/ + public static final int IPMOD = 50; /*IP 模块*/ + public static final int DS71XX_H = 71; /* DS71XXH_S */ + public static final int DS72XX_H_S = 72; /* DS72XXH_S */ + public static final int DS73XX_H_S = 73; /* DS73XXH_S */ + public static final int DS81XX_HS_S = 81; /* DS81XX_HS_S */ + public static final int DS81XX_HL_S = 82; /* DS81XX_HL_S */ + public static final int DS81XX_HC_S = 83; /* DS81XX_HC_S */ + public static final int DS81XX_HD_S = 84; /* DS81XX_HD_S */ + public static final int DS81XX_HE_S = 85; /* DS81XX_HE_S */ + public static final int DS81XX_HF_S = 86; /* DS81XX_HF_S */ + public static final int DS81XX_AH_S = 87; /* DS81XX_AH_S */ + public static final int DS81XX_AHF_S = 88; /* DS81XX_AHF_S */ + public static final int DS90XX_HF_S = 90; /*DS90XX_HF_S*/ + public static final int DS91XX_HF_S = 91; /*DS91XX_HF_S*/ + public static final int DS91XX_HD_S = 92; /*91XXHD-S(MD)*/ + + /* 操作 */ +//主类型 + public static final int MAJOR_OPERATION = 0x3; + //次类型 + public static final int MINOR_START_DVR = 0x41; /* 开机 */ + public static final int MINOR_STOP_DVR = 0x42;/* 关机 */ + public static final int MINOR_STOP_ABNORMAL = 0x43;/* 异常关机 */ + public static final int MINOR_REBOOT_DVR = 0x44; /*本地重启设备*/ + public static final int MINOR_LOCAL_LOGIN = 0x50; /* 本地登陆 */ + public static final int MINOR_LOCAL_LOGOUT = 0x51; /* 本地注销登陆 */ + public static final int MINOR_LOCAL_CFG_PARM = 0x52; /* 本地配置参数 */ + public static final int MINOR_LOCAL_PLAYBYFILE = 0x53; /* 本地按文件回放或下载 */ + public static final int MINOR_LOCAL_PLAYBYTIME = 0x54; /* 本地按时间回放或下载*/ + public static final int MINOR_LOCAL_START_REC = 0x55; /* 本地开始录像 */ + public static final int MINOR_LOCAL_STOP_REC = 0x56; /* 本地停止录像 */ + public static final int MINOR_LOCAL_PTZCTRL = 0x57; /* 本地云台控制 */ + public static final int MINOR_LOCAL_PREVIEW = 0x58;/* 本地预览 (保留不使用)*/ + public static final int MINOR_LOCAL_MODIFY_TIME = 0x59;/* 本地修改时间(保留不使用) */ + public static final int MINOR_LOCAL_UPGRADE = 0x5a;/* 本地升级 */ + public static final int MINOR_LOCAL_RECFILE_OUTPUT = 0x5b; /* 本地备份录象文件 */ + public static final int MINOR_LOCAL_FORMAT_HDD = 0x5c; /* 本地初始化硬盘 */ + public static final int MINOR_LOCAL_CFGFILE_OUTPUT = 0x5d; /* 导出本地配置文件 */ + public static final int MINOR_LOCAL_CFGFILE_INPUT = 0x5e; /* 导入本地配置文件 */ + public static final int MINOR_LOCAL_COPYFILE = 0x5f; /* 本地备份文件 */ + public static final int MINOR_LOCAL_LOCKFILE = 0x60; /* 本地锁定录像文件 */ + public static final int MINOR_LOCAL_UNLOCKFILE = 0x61; /* 本地解锁录像文件 */ + public static final int MINOR_LOCAL_DVR_ALARM = 0x62; /* 本地手动清除和触发报警*/ + public static final int MINOR_IPC_ADD = 0x63; /* 本地添加IPC */ + public static final int MINOR_IPC_DEL = 0x64; /* 本地删除IPC */ + public static final int MINOR_IPC_SET = 0x65; /* 本地设置IPC */ + public static final int MINOR_LOCAL_START_BACKUP = 0x66; /* 本地开始备份 */ + public static final int MINOR_LOCAL_STOP_BACKUP = 0x67;/* 本地停止备份*/ + public static final int MINOR_LOCAL_COPYFILE_START_TIME = 0x68;/* 本地备份开始时间*/ + public static final int MINOR_LOCAL_COPYFILE_END_TIME = 0x69; /* 本地备份结束时间*/ + public static final int MINOR_REMOTE_LOGIN = 0x70;/* 远程登录 */ + public static final int MINOR_REMOTE_LOGOUT = 0x71;/* 远程注销登陆 */ + public static final int MINOR_REMOTE_START_REC = 0x72;/* 远程开始录像 */ + public static final int MINOR_REMOTE_STOP_REC = 0x73;/* 远程停止录像 */ + public static final int MINOR_START_TRANS_CHAN = 0x74;/* 开始透明传输 */ + public static final int MINOR_STOP_TRANS_CHAN = 0x75; /* 停止透明传输 */ + public static final int MINOR_REMOTE_GET_PARM = 0x76;/* 远程获取参数 */ + public static final int MINOR_REMOTE_CFG_PARM = 0x77;/* 远程配置参数 */ + public static final int MINOR_REMOTE_GET_STATUS = 0x78;/* 远程获取状态 */ + public static final int MINOR_REMOTE_ARM = 0x79; /* 远程布防 */ + public static final int MINOR_REMOTE_DISARM = 0x7a;/* 远程撤防 */ + public static final int MINOR_REMOTE_REBOOT = 0x7b; /* 远程重启 */ + public static final int MINOR_START_VT = 0x7c;/* 开始语音对讲 */ + public static final int MINOR_STOP_VT = 0x7d;/* 停止语音对讲 */ + public static final int MINOR_REMOTE_UPGRADE = 0x7e; /* 远程升级 */ + public static final int MINOR_REMOTE_PLAYBYFILE = 0x7f; /* 远程按文件回放 */ + public static final int MINOR_REMOTE_PLAYBYTIME = 0x80; /* 远程按时间回放 */ + public static final int MINOR_REMOTE_PTZCTRL = 0x81; /* 远程云台控制 */ + public static final int MINOR_REMOTE_FORMAT_HDD = 0x82; /* 远程格式化硬盘 */ + public static final int MINOR_REMOTE_STOP = 0x83; /* 远程关机 */ + public static final int MINOR_REMOTE_LOCKFILE = 0x84;/* 远程锁定文件 */ + public static final int MINOR_REMOTE_UNLOCKFILE = 0x85;/* 远程解锁文件 */ + public static final int MINOR_REMOTE_CFGFILE_OUTPUT = 0x86; /* 远程导出配置文件 */ + public static final int MINOR_REMOTE_CFGFILE_INTPUT = 0x87; /* 远程导入配置文件 */ + public static final int MINOR_REMOTE_RECFILE_OUTPUT = 0x88; /* 远程导出录象文件 */ + public static final int MINOR_REMOTE_DVR_ALARM = 0x89; /* 远程手动清除和触发报警*/ + public static final int MINOR_REMOTE_IPC_ADD = 0x8a; /* 远程添加IPC */ + public static final int MINOR_REMOTE_IPC_DEL = 0x8b;/* 远程删除IPC */ + public static final int MINOR_REMOTE_IPC_SET = 0x8c; /* 远程设置IPC */ + public static final int MINOR_REBOOT_VCA_LIB = 0x8d; /*重启智能库*/ + + /*日志附加信息*/ +//主类型 + public static final int MAJOR_INFORMATION = 0x4; /*附加信息*/ + //次类型 + public static final int MINOR_HDD_INFO = 0xa1;/*硬盘信息*/ + public static final int MINOR_SMART_INFO = 0xa2; /*SMART信息*/ + public static final int MINOR_REC_START = 0xa3; /*开始录像*/ + public static final int MINOR_REC_STOP = 0xa4;/*停止录像*/ + public static final int MINOR_REC_OVERDUE = 0xa5;/*过期录像删除*/ + public static final int MINOR_LINK_START = 0xa6; // ivms多路解码器等连接前端设备 + public static final int MINOR_LINK_STOP = 0xa7;// ivms多路解码器等断开前端设备  + //当日志的主类型为MAJOR_OPERATION=03,次类型为MINOR_LOCAL_CFG_PARM=0x52或者MINOR_REMOTE_GET_PARM=0x76或者MINOR_REMOTE_CFG_PARM=0x77时,dwParaType:参数类型有效,其含义如下: + public static final int PARA_VIDEOOUT = 0x1; + public static final int PARA_IMAGE = 0x2; + public static final int PARA_ENCODE = 0x4; + public static final int PARA_NETWORK = 0x8; + public static final int PARA_ALARM = 0x10; + public static final int PARA_EXCEPTION = 0x20; + public static final int PARA_DECODER = 0x40; /*解码器*/ + public static final int PARA_RS232 = 0x80; + public static final int PARA_PREVIEW = 0x100; + public static final int PARA_SECURITY = 0x200; + public static final int PARA_DATETIME = 0x400; + public static final int PARA_FRAMETYPE = 0x800; /*帧格式*/ + public static final int PARA_VCA_RULE = 0x1000; //行为规则 + //SDK_V222 +//智能设备类型 + public static final int DS6001_HF_B = 60;//行为分析:DS6001-HF/B + public static final int DS6001_HF_P = 61;//车牌识别:DS6001-HF/P + public static final int DS6002_HF_B = 62;//双机跟踪:DS6002-HF/B + public static final int DS6101_HF_B = 63;//行为分析:DS6101-HF/B + public static final int IVMS_2000 = 64;//智能分析仪 + public static final int DS9000_IVS = 65;//9000系列智能DVR + public static final int DS8004_AHL_A = 66;//智能ATM, DS8004AHL-S/A + public static final int DS6101_HF_P = 67;//车牌识别:DS6101-HF/P + //能力获取命令 + public static final int VCA_DEV_ABILITY = 0x100;//设备智能分析的总能力 + public static final int VCA_CHAN_ABILITY = 0x110;//行为分析能力 + public static final int DEVICE_ABILITY_INFO = 0x011; //设备通用能力类型,具体能力根据发送的能力节点来区分 + public static final int NET_DVR_CHECK_USER_STATUS = 20005; //检测设备是否在线 + /**********************设备类型 end***********************/ + + /************************************************* + * 参数配置结构、参数(其中_V30为9000新增) + **************************************************/ + + ///////////////////////////////////////////////////////////////////////// + //校时结构参数 + public static class NET_DVR_TIME extends Structure {//校时结构参数 + public int dwYear; //年 + public int dwMonth; //月 + public int dwDay; //日 + public int dwHour; //时 + public int dwMinute; //分 + public int dwSecond; //秒 + + public String toString() { + return "NET_DVR_TIME.dwYear: " + dwYear + "\n" + "NET_DVR_TIME.dwMonth: \n" + dwMonth + "\n" + "NET_DVR_TIME.dwDay: \n" + dwDay + "\n" + "NET_DVR_TIME.dwHour: \n" + dwHour + "\n" + "NET_DVR_TIME.dwMinute: \n" + dwMinute + "\n" + "NET_DVR_TIME.dwSecond: \n" + dwSecond; + } + + //用于列表中显示 + public String toStringTime() { + return String.format("%02d/%02d/%02d%02d:%02d:%02d", dwYear, dwMonth, dwDay, dwHour, dwMinute, dwSecond); + } + + //存储文件名使用 + public String toStringTitle() { + return String.format("Time%02d%02d%02d%02d%02d%02d", dwYear, dwMonth, dwDay, dwHour, dwMinute, dwSecond); + } + } + + public static class NET_DVR_SCHEDTIME extends Structure { + public byte byStartHour; //开始时间 + public byte byStartMin; + public byte byStopHour; //结束时间 + public byte byStopMin; + + + } + + public static class NET_DVR_HANDLEEXCEPTION_V30 extends Structure { + public int dwHandleType; /*处理方式,处理方式的"或"结果*//*0x00: 无响应*//*0x01: 监视器上警告*//*0x02: 声音警告*//*0x04: 上传中心*/ /*0x08: 触发报警输出*//*0x20: 触发抓图*/ //(JPEG定制) + public byte[] byRelAlarmOut = new byte[MAX_ALARMOUT_V30]; //报警触发的输出通道,报警触发的输出,为1表示触发该输出 + + } + + //报警和异常处理结构(子结构)(多处使用) + public static class NET_DVR_HANDLEEXCEPTION extends Structure { + public int dwHandleType; /*处理方式,处理方式的"或"结果*//*0x00: 无响应*//*0x01: 监视器上警告*//*0x02: 声音警告*//*0x04: 上传中心*/ /*0x08: 触发报警输出*//*0x20: 触发抓图*/ //(JPEG定制) + public byte[] byRelAlarmOut = new byte[MAX_ALARMOUT]; //报警触发的输出通道,报警触发的输出,为1表示触发该输出 + + } + + //DVR设备参数 + public static class NET_DVR_DEVICECFG extends Structure { + public int dwSize; + public byte[] sDVRName = new byte[NAME_LEN]; //DVR名称 + public int dwDVRID; //DVR ID,用于遥控器 //V1.4(0-99), V1.5(0-255) + public int dwRecycleRecord; //是否循环录像,0:不是; 1:是 + //以下不可更改 + public byte[] sSerialNumber = new byte[SERIALNO_LEN]; //序列号 + public int dwSoftwareVersion; //软件版本号,高16位是主版本,低16位是次版本 + public int dwSoftwareBuildDate; //软件生成日期,0xYYYYMMDD + public int dwDSPSoftwareVersion; //DSP软件版本,高16位是主版本,低16位是次版本 + public int dwDSPSoftwareBuildDate; // DSP软件生成日期,0xYYYYMMDD + public int dwPanelVersion; // 前面板版本,高16位是主版本,低16位是次版本 + public int dwHardwareVersion; // 硬件版本,高16位是主版本,低16位是次版本 + public byte byAlarmInPortNum; //DVR报警输入个数 + public byte byAlarmOutPortNum; //DVR报警输出个数 + public byte byRS232Num; //DVR 232串口个数 + public byte byRS485Num; //DVR 485串口个数 + public byte byNetworkPortNum; //网络口个数 + public byte byDiskCtrlNum; //DVR 硬盘控制器个数 + public byte byDiskNum; //DVR 硬盘个数 + public byte byDVRType; //DVR类型, 1:DVR 2:ATM DVR 3:DVS ...... + public byte byChanNum; //DVR 通道个数 + public byte byStartChan; //起始通道号,例如DVS-1,DVR - 1 + public byte byDecordChans; //DVR 解码路数 + public byte byVGANum; //VGA口的个数 + public byte byUSBNum; //USB口的个数 + public byte byAuxoutNum; //辅口的个数 + public byte byAudioNum; //语音口的个数 + public byte byIPChanNum; //最大数字通道数 + + + } + + //DVR设备参数 + public static class NET_DVR_DEVICECFG_V40 extends Structure { + public int dwSize; + public byte[] sDVRName = new byte[NAME_LEN]; //DVR名称 + public int dwDVRID; //DVR ID,用于遥控器 //V1.4(0-99), V1.5(0-255) + public int dwRecycleRecord; //是否循环录像,0:不是; 1:是 + //以下不可更改 + public byte[] sSerialNumber = new byte[SERIALNO_LEN]; //序列号 + public int dwSoftwareVersion; //软件版本号,高16位是主版本,低16位是次版本 + public int dwSoftwareBuildDate; //软件生成日期,0xYYYYMMDD + public int dwDSPSoftwareVersion; //DSP软件版本,高16位是主版本,低16位是次版本 + public int dwDSPSoftwareBuildDate; // DSP软件生成日期,0xYYYYMMDD + public int dwPanelVersion; // 前面板版本,高16位是主版本,低16位是次版本 + public int dwHardwareVersion; // 硬件版本,高16位是主版本,低16位是次版本 + public byte byAlarmInPortNum; //DVR报警输入个数 + public byte byAlarmOutPortNum; //DVR报警输出个数 + public byte byRS232Num; //DVR 232串口个数 + public byte byRS485Num; //DVR 485串口个数 + public byte byNetworkPortNum; //网络口个数 + public byte byDiskCtrlNum; //DVR 硬盘控制器个数 + public byte byDiskNum; //DVR 硬盘个数 + public byte byDVRType; //DVR类型, 1:DVR 2:ATM DVR 3:DVS ...... + public byte byChanNum; //DVR 通道个数 + public byte byStartChan; //起始通道号,例如DVS-1,DVR - 1 + public byte byDecordChans; //DVR 解码路数 + public byte byVGANum; //VGA口的个数 + public byte byUSBNum; //USB口的个数 + public byte byAuxoutNum; //辅口的个数 + public byte byAudioNum; //语音口的个数 + public byte byIPChanNum; //最大数字通道数 低8位,高8位见byHighIPChanNum + public byte byZeroChanNum; //零通道编码个数 + public byte bySupport; //能力,位与结果为0表示不支持,1表示支持, + public byte byEsataUseage; //Esata的默认用途,0-默认备份,1-默认录像 + public byte byIPCPlug; //0-关闭即插即用,1-打开即插即用 + public byte byStorageMode; //0-盘组模式,1-磁盘配额, 2抽帧模式, 3-自动 + public byte bySupport1; //能力,位与结果为0表示不支持,1表示支持 + public short wDevType;//设备型号 + public byte[] byDevTypeName = new byte[DEV_TYPE_NAME_LEN];//设备型号名称 + public byte bySupport2; //能力集扩展,位与结果为0表示不支持,1表示支持 + //bySupport2 & 0x1, 表示是否支持扩展的OSD字符叠加(终端和抓拍机扩展区分) + public byte byAnalogAlarmInPortNum; //模拟报警输入个数 + public byte byStartAlarmInNo; //模拟报警输入起始号 + public byte byStartAlarmOutNo; //模拟报警输出起始号 + public byte byStartIPAlarmInNo; //IP报警输入起始号 + public byte byStartIPAlarmOutNo; //IP报警输出起始号 + public byte byHighIPChanNum; //数字通道个数,高8位 + public byte byEnableRemotePowerOn;//是否启用在设备休眠的状态下远程开机功能,0-不启用,1-启用 + public short wDevClass; //设备大类备是属于哪个产品线,0 保留,1-50 DVR,51-100 DVS,101-150 NVR,151-200 IPC,65534 其他,具体分类方法见《设备类型对应序列号和类型值.docx》 + public byte[] byRes2 = new byte[6]; //保留 + + + } + + public static class NET_DVR_IPADDR extends Structure { + public byte[] sIpV4 = new byte[16]; + public byte[] byRes = new byte[128]; + + public String toString() { + return "NET_DVR_IPADDR.sIpV4: " + new String(sIpV4) + "\n" + "NET_DVR_IPADDR.byRes: " + new String(byRes) + "\n"; + } + + + } + + + //网络数据结构(子结构)(9000扩展) + public static class NET_DVR_ETHERNET_V30 extends Structure { + public NET_DVR_IPADDR struDVRIP; + public NET_DVR_IPADDR struDVRIPMask; + public int dwNetInterface; + public short wDVRPort; + public short wMTU; + public byte[] byMACAddr = new byte[6]; + + public String toString() { + return "NET_DVR_ETHERNET_V30.struDVRIP: \n" + struDVRIP + "\n" + "NET_DVR_ETHERNET_V30.struDVRIPMask: \n" + struDVRIPMask + "\n" + "NET_DVR_ETHERNET_V30.dwNetInterface: " + dwNetInterface + "\n" + "NET_DVR_ETHERNET_V30.wDVRPort: " + wDVRPort + "\n" + "NET_DVR_ETHERNET_V30.wMTU: " + wMTU + "\n" + "NET_DVR_ETHERNET_V30.byMACAddr: " + new String(byMACAddr) + "\n"; + } + + + } + + public static class NET_DVR_ETHERNET extends Structure {//网络数据结构(子结构) + public byte[] sDVRIP = new byte[16]; //DVR IP地址 + public byte[] sDVRIPMask = new byte[16]; //DVR IP地址掩码 + public int dwNetInterface; //网络接口 1-10MBase-T 2-10MBase-T全双工 3-100MBase-TX 4-100M全双工 5-10M/100M自适应 + public short wDVRPort; //端口号 + public byte[] byMACAddr = new byte[MACADDR_LEN]; //服务器的物理地址 + + + } + + public static class NET_DVR_PPPOECFG extends Structure {//PPPoe + public int dwPPPoE; + public byte[] sPPPoEUser = new byte[32]; + public byte[] sPPPoEPassword = new byte[16]; + public NET_DVR_IPADDR struPPPoEIP; + + + } + + public static class NET_DVR_NETCFG_V30 extends Structure { + public int dwSize; + public NET_DVR_ETHERNET_V30[] struEtherNet = new NET_DVR_ETHERNET_V30[2]; + public NET_DVR_IPADDR[] struRes1 = new NET_DVR_IPADDR[2]; + public NET_DVR_IPADDR struAlarmHostIpAddr; + public short[] wRes2 = new short[2]; + public short wAlarmHostIpPort; + public byte byUseDhcp; + public byte byRes3; + public NET_DVR_IPADDR struDnsServer1IpAddr; + public NET_DVR_IPADDR struDnsServer2IpAddr; + public byte[] byIpResolver = new byte[64]; + public short wIpResolverPort; + public short wHttpPortNo; + public NET_DVR_IPADDR struMulticastIpAddr; + public NET_DVR_IPADDR struGatewayIpAddr; + public NET_DVR_PPPOECFG struPPPoE; + public byte[] byRes = new byte[64]; + + public String toString() { + return "NET_DVR_NETCFG_V30.dwSize: " + dwSize + "\n" + "NET_DVR_NETCFG_V30.struEtherNet[0]: \n" + struEtherNet[0] + "\n" + "NET_DVR_NETCFG_V30.struAlarmHostIpAddr: \n" + struAlarmHostIpAddr + "\n" + "NET_DVR_NETCFG_V30.wAlarmHostIpPort: " + wAlarmHostIpPort + "\n" + "NET_DVR_NETCFG_V30.wHttpPortNo: " + wHttpPortNo + "\n" + "NET_DVR_NETCFG_V30.struGatewayIpAddr: \n" + struGatewayIpAddr + "\n"; + } + + + } + + + public static class NET_DVR_NETCFG extends Structure {//网络配置结构 + public int dwSize; + public NET_DVR_ETHERNET[] struEtherNet = new NET_DVR_ETHERNET[MAX_ETHERNET]; /* 以太网口 */ + public byte[] sManageHostIP = new byte[16]; //远程管理主机地址 + public short wManageHostPort; //远程管理主机端口号 + public byte[] sIPServerIP = new byte[16]; //IPServer服务器地址 + public byte[] sMultiCastIP = new byte[16]; //多播组地址 + public byte[] sGatewayIP = new byte[16]; //网关地址 + public byte[] sNFSIP = new byte[16]; //NFS主机IP地址 + public byte[] sNFSDirectory = new byte[PATHNAME_LEN];//NFS目录 + public int dwPPPOE; //0-不启用,1-启用 + public byte[] sPPPoEUser = new byte[NAME_LEN]; //PPPoE用户名 + public byte[] sPPPoEPassword = new byte[PASSWD_LEN];// PPPoE密码 + public byte[] sPPPoEIP = new byte[16]; //PPPoE IP地址(只读) + + + } + + //通道图象结构 + public static class NET_DVR_SCHEDTIMEWEEK extends Structure { + public NET_DVR_SCHEDTIME[] struAlarmTime = new NET_DVR_SCHEDTIME[8]; + + + } + + public static class byte96 extends Structure { + public byte[] byMotionScope = new byte[96]; + + + } + + public static class NET_DVR_MOTION_V30 extends Structure {//移动侦测(子结构)(9000扩展) + public byte96[] byMotionScope = new byte96[64]; /*侦测区域,0-96位,表示64行,共有96*64个小宏块,为1表示是移动侦测区域,0-表示不是*/ + public byte byMotionSensitive; /*移动侦测灵敏度, 0 - 5,越高越灵敏,oxff关闭*/ + public byte byEnableHandleMotion; /* 是否处理移动侦测 0-否 1-是*/ + public byte byPrecision; /* 移动侦测算法的进度: 0--16*16, 1--32*32, 2--64*64 ... */ + public byte reservedData; + public NET_DVR_HANDLEEXCEPTION_V30 struMotionHandleType; /* 处理方式 */ + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS]; /*布防时间*/ + public byte[] byRelRecordChan = new byte[64]; /* 报警触发的录象通道*/ + + + } + + public static class NET_DVR_MOTION extends Structure {//移动侦测(子结构) + public byte[] byMotionScope = new byte[18 * 22]; /*侦测区域,共有22*18个小宏块,为1表示改宏块是移动侦测区域,0-表示不是*/ + public byte byMotionSensitive; /*移动侦测灵敏度, 0 - 5,越高越灵敏,0xff关闭*/ + public byte byEnableHandleMotion; /* 是否处理移动侦测 */ + public byte[] reservedData = new byte[2]; + public NET_DVR_HANDLEEXCEPTION strMotionHandleType; /* 处理方式 */ + public byte[] byRelRecordChan = new byte[MAX_CHANNUM]; //报警触发的录象通道,为1表示触发该通道 + + + } + + public static class NET_DVR_HIDEALARM_V30 extends Structure {//遮挡报警 + public int dwEnableHideAlarm; /* 是否启动遮挡报警 ,0-否,1-低灵敏度 2-中灵敏度 3-高灵敏度*/ + public short wHideAlarmAreaTopLeftX; /* 遮挡区域的x坐标 */ + public short wHideAlarmAreaTopLeftY; /* 遮挡区域的y坐标 */ + public short wHideAlarmAreaWidth; /* 遮挡区域的宽 */ + public short wHideAlarmAreaHeight; /*遮挡区域的高*/ + public NET_DVR_HANDLEEXCEPTION_V30 strHideAlarmHandleType; /* 处理方式 */ + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS];//布防时间 + + + } + + public static class NET_DVR_HIDEALARM extends Structure {//遮挡报警(子结构) 区域大小704*576 + public int dwEnableHideAlarm; /* 是否启动遮挡报警 ,0-否,1-低灵敏度 2-中灵敏度 3-高灵敏度*/ + public short wHideAlarmAreaTopLeftX; /* 遮挡区域的x坐标 */ + public short wHideAlarmAreaTopLeftY; /* 遮挡区域的y坐标 */ + public short wHideAlarmAreaWidth; /* 遮挡区域的宽 */ + public short wHideAlarmAreaHeight; /*遮挡区域的高*/ + public NET_DVR_HANDLEEXCEPTION strHideAlarmHandleType; /* 处理方式 */ + + + } + + public static class NET_DVR_VILOST_V30 extends Structure { //信号丢失报警(子结构)(9000扩展) + public byte byEnableHandleVILost; /* 是否处理信号丢失报警 */ + public NET_DVR_HANDLEEXCEPTION_V30 strVILostHandleType; /* 处理方式 */ + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS];//布防时间 + + } + + public static class NET_DVR_VILOST extends Structure { //信号丢失报警(子结构) + public byte byEnableHandleVILost; /* 是否处理信号丢失报警 */ + public NET_DVR_HANDLEEXCEPTION strVILostHandleType; /* 处理方式 */ + + } + + public static class NET_DVR_SHELTER extends Structure { //遮挡区域(子结构) + public short wHideAreaTopLeftX; /* 遮挡区域的x坐标 */ + public short wHideAreaTopLeftY; /* 遮挡区域的y坐标 */ + public short wHideAreaWidth; /* 遮挡区域的宽 */ + public short wHideAreaHeight; /* 遮挡区域的高*/ + + + } + + public static class NET_DVR_COLOR extends Structure { + public byte byBrightness; /*亮度,0-255*/ + public byte byContrast; /*对比度,0-255*/ + public byte bySaturation; /*饱和度,0-255*/ + public byte byHue; /*色调,0-255*/ + + + } + + public static class NET_DVR_VICOLOR extends Structure { + public NET_DVR_COLOR[] struColor = new NET_DVR_COLOR[MAX_TIMESEGMENT_V30];/*图象参数(第一个有效,其他三个保留)*/ + public NET_DVR_SCHEDTIME[] struHandleTime = new NET_DVR_SCHEDTIME[MAX_TIMESEGMENT_V30];/*处理时间段(保留)*/ + + + } + + //信号丢失 + public static class NET_DVR_VILOST_V40 extends Structure { + public int dwEnableVILostAlarm; /* 是否启动信号丢失报警 ,0-否,1-是*/ + /* 信号丢失触发报警输出 */ + public int dwHandleType; //异常处理,异常处理方式的"或"结果 + /*0x00: 无响应*/ + /*0x01: 监视器上警告*/ + /*0x02: 声音警告*/ + /*0x04: 上传中心*/ + /*0x08: 触发报警输出*/ + /*0x10: 触发JPRG抓图并上传Email*/ + /*0x20: 无线声光报警器联动*/ + /*0x40: 联动电子地图(目前只有PCNVR支持)*/ + /*0x200: 抓图并上传FTP*/ + /*0x1000:抓图上传到云*/ + public int dwMaxRelAlarmOutChanNum; //触发的报警输出通道数(只读)最大支持数量 + public int[] dwRelAlarmOut = new int[MAX_ALARMOUT_V40]; /*触发报警输出号,按值表示,采用紧凑型排列,从下标0 - dwRelAlarmOut -1有效,如果中间遇到0xffffffff,则后续无效*/ + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS]; /*布防时间*/ + public byte byVILostAlarmThreshold; /*信号丢失报警阈值,当值低于阈值,认为信号丢失,取值0-99*/ + public byte[] byRes = new byte[63]; //保留 + + + } + + public static class NET_DVR_DNMODE extends Structure { + public byte byObjectSize;//占比参数(0~100) + public byte byMotionSensitive; /*移动侦测灵敏度, 0 - 5,越高越灵敏,0xff关闭*/ + public byte[] byRes = new byte[6]; + + + } + + public static class NET_DVR_MOTION_MULTI_AREAPARAM extends Structure { + public byte byAreaNo;//区域编号(IPC- 1~8) + public byte[] byRes = new byte[3]; + public NET_VCA_RECT struRect = new NET_VCA_RECT();//单个区域的坐标信息(矩形) size = 16; + public NET_DVR_DNMODE struDayNightDisable = new NET_DVR_DNMODE();//关闭模式 + public NET_DVR_DNMODE struDayModeParam = new NET_DVR_DNMODE();//白天模式 + public NET_DVR_DNMODE struNightModeParam = new NET_DVR_DNMODE();//夜晚模式 + public byte[] byRes1 = new byte[8]; + + + } + + public static final int MAX_MULTI_AREA_NUM = 24; + + public static class NET_DVR_MOTION_MULTI_AREA extends Structure { + public byte byDayNightCtrl;//日夜控制 0~关闭,1~自动切换,2~定时切换(默认关闭) + public byte byAllMotionSensitive; /*移动侦测灵敏度, 0 - 5,越高越灵敏,0xff关闭,全部区域的灵敏度范围*/ + public byte[] byRes = new byte[2];// + public NET_DVR_SCHEDULE_DAYTIME struScheduleTime = new NET_DVR_SCHEDULE_DAYTIME();//切换时间 16 + public NET_DVR_MOTION_MULTI_AREAPARAM[] struMotionMultiAreaParam = new NET_DVR_MOTION_MULTI_AREAPARAM[MAX_MULTI_AREA_NUM];//最大支持24个区域 + public byte[] byRes1 = new byte[60]; + + + } + + public static class NET_DVR_MOTION_SINGLE_AREA extends Structure { + public byte[] byMotionScope = new byte[64 * 96]; /*侦测区域,0-96位,表示64行,共有96*64个小宏块,目前有效的是22*18,为1表示是移动侦测区域,0-表示不是*/ + public byte byMotionSensitive; /*移动侦测灵敏度, 0 - 5,越高越灵敏,0xff关闭*/ + public byte[] byRes = new byte[3]; + + + } + + public static class NET_DVR_MOTION_MODE_PARAM extends Structure { + public NET_DVR_MOTION_SINGLE_AREA struMotionSingleArea = new NET_DVR_MOTION_SINGLE_AREA(); //普通模式下的单区域设 + public NET_DVR_MOTION_MULTI_AREA struMotionMultiArea = new NET_DVR_MOTION_MULTI_AREA(); //专家模式下的多区域设置 + + + } + + public static class NET_DVR_MOTION_V40 extends Structure { + public NET_DVR_MOTION_MODE_PARAM struMotionMode = new NET_DVR_MOTION_MODE_PARAM(); //(5.1.0新增) + public byte byEnableHandleMotion; /* 是否处理移动侦测 0-否 1-是*/ + public byte byEnableDisplay; /*启用移动侦测高亮显示,0-否,1-是*/ + public byte byConfigurationMode; //0~普通,1~专家(5.1.0新增) + public byte byKeyingEnable; //启用键控移动侦测 0-不启用,1-启用 + /* 异常处理方式 */ + public int dwHandleType; //异常处理,异常处理方式的"或"结果 + /*0x00: 无响应*/ + /*0x01: 监视器上警告*/ + /*0x02: 声音警告*/ + /*0x04: 上传中心*/ + /*0x08: 触发报警输出*/ + /*0x10: 触发JPRG抓图并上传Email*/ + /*0x20: 无线声光报警器联动*/ + /*0x40: 联动电子地图(目前只有PCNVR支持)*/ + /*0x200: 抓图并上传FTP*/ + /*0x1000: 抓图上传到云*/ + public int dwMaxRelAlarmOutChanNum; //触发的报警输出通道数(只读)最大支持数量 + public int[] dwRelAlarmOut = new int[MAX_ALARMOUT_V40]; //实际触发的报警输出号,按值表示,采用紧凑型排列,从下标0 - dwRelAlarmOut -1有效,如果中间遇到0xffffffff,则后续无效 + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS]; /*布防时间*/ + /*触发的录像通道*/ + public int dwMaxRecordChanNum; //设备支持的最大关联录像通道数-只读 + public int[] dwRelRecordChan = new int[MAX_CHANNUM_V40]; /* 实际触发录像通道,按值表示,采用紧凑型排列,从下标0 - dwRelRecordChan -1有效,如果中间遇到0xffffffff,则后续无效*/ + public byte byDiscardFalseAlarm; //启用去误报 0-无效,1-不启用,2-启用 + public byte[] byRes = new byte[127]; //保留字节 + + + } + + public static class NET_DVR_RGB_COLOR extends Structure { + public byte byRed; //RGB颜色三分量中的红色 + public byte byGreen; //RGB颜色三分量中的绿色 + public byte byBlue; //RGB颜色三分量中的蓝色 + public byte byRes; //保留 + + + } + + public static class NET_DVR_HIDEALARM_V40 extends Structure { + public int dwEnableHideAlarm; /* 是否启动遮挡报警,0-否,1-低灵敏度,2-中灵敏度,3-高灵敏度*/ + public short wHideAlarmAreaTopLeftX; /* 遮挡区域的x坐标 */ + public short wHideAlarmAreaTopLeftY; /* 遮挡区域的y坐标 */ + public short wHideAlarmAreaWidth; /* 遮挡区域的宽 */ + public short wHideAlarmAreaHeight; /*遮挡区域的高*/ + /* 信号丢失触发报警输出 */ + public int dwHandleType; //异常处理,异常处理方式的"或"结果 + /*0x00: 无响应*/ + /*0x01: 监视器上警告*/ + /*0x02: 声音警告*/ + /*0x04: 上传中心*/ + /*0x08: 触发报警输出*/ + /*0x10: 触发JPRG抓图并上传Email*/ + /*0x20: 无线声光报警器联动*/ + /*0x40: 联动电子地图(目前只有PCNVR支持)*/ + /*0x200: 抓图并上传FTP*/ + /*0x1000:抓图上传到云*/ + public int dwMaxRelAlarmOutChanNum; //触发的报警输出通道数(只读)最大支持数量 + public int[] dwRelAlarmOut = new int[MAX_ALARMOUT_V40]; /*触发报警输出号,按值表示,采用紧凑型排列,从下标0 - dwRelAlarmOut -1有效,如果中间遇到0xffffffff,则后续无效*/ + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS]; /*布防时间*/ + public byte[] byRes = new byte[64]; //保留 + + + }//遮挡报警 + + public static class NET_DVR_PICCFG_V40 extends Structure { + public int dwSize; + public byte[] sChanName = new byte[NAME_LEN]; + public int dwVideoFormat; /* 只读 视频制式 1-NTSC 2-PAL */ + public NET_DVR_VICOLOR struViColor = new NET_DVR_VICOLOR();// 图像参数按时间段设置 + //显示通道名 + public int dwShowChanName; // 预览的图象上是否显示通道名称,0-不显示,1-显示 + public short wShowNameTopLeftX; /* 通道名称显示位置的x坐标 */ + public short wShowNameTopLeftY; /* 通道名称显示位置的y坐标 */ + //隐私遮挡 + public int dwEnableHide; /* 是否启动遮挡 ,0-否,1-是*/ + public NET_DVR_SHELTER[] struShelter = new NET_DVR_SHELTER[MAX_SHELTERNUM]; + //OSD + public int dwShowOsd;// 预览的图象上是否显示OSD,0-不显示,1-显示 + public short wOSDTopLeftX; /* OSD的x坐标 */ + public short wOSDTopLeftY; /* OSD的y坐标 */ + public byte byOSDType; /* OSD类型(主要是年月日格式) */ + /* 0: XXXX-XX-XX 年月日 */ + /* 1: XX-XX-XXXX 月日年 */ + /* 2: XXXX年XX月XX日 */ + /* 3: XX月XX日XXXX年 */ + /* 4: XX-XX-XXXX 日月年*/ + /* 5: XX日XX月XXXX年 */ + /*6: xx/xx/xxxx(月/日/年) */ + /*7: xxxx/xx/xx(年/月/日) */ + /*8: xx/xx/xxxx(日/月/年)*/ + public byte byDispWeek; /* 是否显示星期 */ + public byte byOSDAttrib; /* OSD属性:透明,闪烁 */ + /* 0: 不显示OSD */ + /* 1: 透明,闪烁 */ + /* 2: 透明,不闪烁 */ + /* 3: 不透明,闪烁 */ + /* 4: 不透明,不闪烁 */ + public byte byHourOSDType; /* OSD小时制:0-24小时制,1-12小时制 */ + public byte byFontSize; //16*16(中)/8*16(英),1-32*32(中)/16*32(英),2-64*64(中)/32*64(英) 3-48*48(中)/24*48(英) 4-24*24(中)/12*24(英) 5-96*96(中)/48*96(英) 6-128*128(中)/64*128(英) 7-80*80(中)/40*80(英) 8-112*112(中)/56*112(英) 0xff-自适应(adaptive) + public byte byOSDColorType; //0-默认(黑白);1-自定义 + public byte byAlignment;//对齐方式 0-自适应,1-右对齐, 2-左对齐,3-国标模式,4-全部右对齐(包含叠加字符、时间以及标题等所有OSD字符),5-全部左对齐(包含叠加字符、时间以及标题等所有OSD字符) + public byte byOSDMilliSecondEnable;//视频叠加时间支持毫秒;0~不叠加, 1-叠加 + public NET_DVR_VILOST_V40 struVILost = new NET_DVR_VILOST_V40(); //视频信号丢失报警(支持组) + public NET_DVR_VILOST_V40 struAULost = new NET_DVR_VILOST_V40(); /*音频信号丢失报警(支持组)*/ + public NET_DVR_MOTION_V40 struMotion = new NET_DVR_MOTION_V40(); //移动侦测报警(支持组) + public NET_DVR_HIDEALARM_V40 struHideAlarm = new NET_DVR_HIDEALARM_V40(); //遮挡报警(支持组) + public NET_DVR_RGB_COLOR struOsdColor = new NET_DVR_RGB_COLOR();//OSD颜色 + public int dwBoundary; //边界值,左对齐,右对齐以及国标模式的边界值,0-表示默认值,单位:像素;在国标模式下,单位修改为字符个数(范围是,0,1,2) + public NET_DVR_RGB_COLOR struOsdBkColor = new NET_DVR_RGB_COLOR(); //自定义OSD背景色 + public byte byOSDBkColorMode; //OSD背景色模式,0-默认,1-自定义OSD背景色 + public byte byUpDownBoundary; //上下最小边界值选项,单位为字符个数(范围是,0,1,2),国标模式下无效。byAlignment=3该字段无效,通过dwBoundary进行边界配置,.byAlignment不等于3的情况下, byUpDownBoundary/byLeftRightBoundary配置成功后,dwBoundary值将不生效 + public byte byLeftRightBoundary; //左右最小边界值选项,单位为字符个数(范围是,0,1,2), 国标模式下无效。byAlignment=3该字段无效,通过dwBoundary进行边界配置,.byAlignment不等于3的情况下, byUpDownBoundary/byLeftRightBoundary配置成功后,dwBoundary值将不生效 + public byte[] byRes = new byte[113]; + + + } + + public static class NET_DVR_PICCFG_V30 extends Structure { + public int dwSize; + public byte[] sChanName = new byte[NAME_LEN]; + public int dwVideoFormat; /* 只读 视频制式 1-NTSC 2-PAL*/ + public NET_DVR_VICOLOR struViColor; // 图像参数按时间段设置 + public int dwShowChanName; // 预览的图象上是否显示通道名称,0-不显示,1-显示 区域大小704*576 + public short wShowNameTopLeftX; /* 通道名称显示位置的x坐标 */ + public short wShowNameTopLeftY; /* 通道名称显示位置的y坐标 */ + public NET_DVR_VILOST_V30 struVILost; //视频信号丢失报警 + public NET_DVR_VILOST_V30 struAULost; /*音频信号丢失报警(保留)*/ + public NET_DVR_MOTION_V30 struMotion; //移动侦测 + public NET_DVR_HIDEALARM_V30 struHideAlarm;//遮挡报警 + public int dwEnableHide; /* 是否启动遮盖(区域大小704*576) ,0-否,1-是*/ + public NET_DVR_SHELTER[] struShelter = new NET_DVR_SHELTER[4]; + public int dwShowOsd; //预览的图象上是否显示OSD,0-不显示,1-显示 区域大小704*576 + public short wOSDTopLeftX; /* OSD的x坐标 */ + public short wOSDTopLeftY; /* OSD的y坐标 */ + public byte byOSDType; /* OSD类型(主要是年月日格式) */ + public byte byDispWeek; /* 是否显示星期 */ + public byte byOSDAttrib; /* OSD属性:透明,闪烁 */ + public byte byHourOSDType; /* OSD小时制:0-24小时制,1-12小时制 */ + public byte[] byRes = new byte[64]; + + + } + + public static class NET_DVR_PICCFG_EX extends Structure {//通道图象结构SDK_V14扩展 + public int dwSize; + public byte[] sChanName = new byte[NAME_LEN]; + public int dwVideoFormat; /* 只读 视频制式 1-NTSC 2-PAL*/ + public byte byBrightness; /*亮度,0-255*/ + public byte byContrast; /*对比度,0-255*/ + public byte bySaturation; /*饱和度,0-255 */ + public byte byHue; /*色调,0-255*/ + //显示通道名 + public int dwShowChanName; // 预览的图象上是否显示通道名称,0-不显示,1-显示 区域大小704*576 + public short wShowNameTopLeftX; /* 通道名称显示位置的x坐标 */ + public short wShowNameTopLeftY; /* 通道名称显示位置的y坐标 */ + //信号丢失报警 + public NET_DVR_VILOST struVILost; + //移动侦测 + public NET_DVR_MOTION struMotion; + //遮挡报警 + public NET_DVR_HIDEALARM struHideAlarm; + //遮挡 区域大小704*576 + public int dwEnableHide; /* 是否启动遮挡 ,0-否,1-是*/ + public NET_DVR_SHELTER[] struShelter = new NET_DVR_SHELTER[MAX_SHELTERNUM]; + //OSD + public int dwShowOsd;// 预览的图象上是否显示OSD,0-不显示,1-显示 区域大小704*576 + public short wOSDTopLeftX; /* OSD的x坐标 */ + public short wOSDTopLeftY; /* OSD的y坐标 */ + public byte byOSDType; /* OSD类型(主要是年月日格式) */ + /* 0: XXXX-XX-XX 年月日 */ + /* 1: XX-XX-XXXX 月日年 */ + /* 2: XXXX年XX月XX日 */ + /* 3: XX月XX日XXXX年 */ + /* 4: XX-XX-XXXX 日月年*/ + /* 5: XX日XX月XXXX年 */ + public byte byDispWeek; /* 是否显示星期 */ + public byte byOSDAttrib; /* OSD属性:透明,闪烁 */ + /* 0: 不显示OSD */ + /* 1: 透明,闪烁 */ + /* 2: 透明,不闪烁 */ + /* 3: 闪烁,不透明 */ + /* 4: 不透明,不闪烁 */ + public byte byHourOsdType; //小时制:0表示24小时制,1-12小时制或am/pm + + + } + + + public static class NET_DVR_PICCFG extends Structure { //通道图象结构(SDK_V13及之前版本) + public int dwSize; + public byte[] sChanName = new byte[NAME_LEN]; + public int dwVideoFormat; /* 只读 视频制式 1-NTSC 2-PAL*/ + public byte byBrightness; /*亮度,0-255*/ + public byte byContrast; /*对比度,0-255*/ + public byte bySaturation; /*饱和度,0-255 */ + public byte byHue; /*色调,0-255*/ + //显示通道名 + public int dwShowChanName; // 预览的图象上是否显示通道名称,0-不显示,1-显示 区域大小704*576 + public short wShowNameTopLeftX; /* 通道名称显示位置的x坐标 */ + public short wShowNameTopLeftY; /* 通道名称显示位置的y坐标 */ + //信号丢失报警 + public NET_DVR_VILOST struVILost; + //移动侦测 + public NET_DVR_MOTION struMotion; + //遮挡报警 + public NET_DVR_HIDEALARM struHideAlarm; + //遮挡 区域大小704*576 + public int dwEnableHide; /* 是否启动遮挡 ,0-否,1-是*/ + public short wHideAreaTopLeftX; /* 遮挡区域的x坐标 */ + public short wHideAreaTopLeftY; /* 遮挡区域的y坐标 */ + public short wHideAreaWidth; /* 遮挡区域的宽 */ + public short wHideAreaHeight; /*遮挡区域的高*/ + //OSD + public int dwShowOsd;// 预览的图象上是否显示OSD,0-不显示,1-显示 区域大小704*576 + public short wOSDTopLeftX; /* OSD的x坐标 */ + public short wOSDTopLeftY; /* OSD的y坐标 */ + public byte byOSDType; /* OSD类型(主要是年月日格式) */ + /* 0: XXXX-XX-XX 年月日 */ + /* 1: XX-XX-XXXX 月日年 */ + /* 2: XXXX年XX月XX日 */ + /* 3: XX月XX日XXXX年 */ + /* 4: XX-XX-XXXX 日月年*/ + /* 5: XX日XX月XXXX年 */ + byte byDispWeek; /* 是否显示星期 */ + byte byOSDAttrib; /* OSD属性:透明,闪烁 */ + /* 0: 不显示OSD */ + /* 1: 透明,闪烁 */ + /* 2: 透明,不闪烁 */ + /* 3: 闪烁,不透明 */ + /* 4: 不透明,不闪烁 */ + public byte reservedData2; + + + } + + public static class NET_DVR_MULTI_STREAM_COMPRESSIONCFG_COND extends Structure { + public int dwSize; + public NET_DVR_STREAM_INFO struStreamInfo = new NET_DVR_STREAM_INFO(); + public int dwStreamType; + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_MULTI_STREAM_COMPRESSIONCFG extends Structure { + public int dwSize; + public int dwStreamType; + public NET_DVR_COMPRESSION_INFO_V30 struStreamPara = new NET_DVR_COMPRESSION_INFO_V30(); + public byte[] byRes = new byte[80]; + } + + //码流压缩参数(子结构)(9000扩展) + public static class NET_DVR_COMPRESSION_INFO_V30 extends Structure { + public byte byStreamType; //码流类型 0-视频流, 1-复合流 + public byte byResolution; //分辨率0-DCIF 1-CIF, 2-QCIF, 3-4CIF, 4-2CIF 5(保留)16-VGA(640*480) 17-UXGA(1600*1200) 18-SVGA (800*600)19-HD720p(1280*720)20-XVGA 21-HD900p + public byte byBitrateType; //码率类型 0:定码率,1:变码率 + public byte byPicQuality; //图象质量 0-最好 1-次好 2-较好 3-一般 4-较差 5-差 + public int dwVideoBitrate; //视频码率 0-保留 1-16K 2-32K 3-48k 4-64K 5-80K 6-96K 7-128K 8-160k 9-192K 10-224K 11-256K 12-320K 13-384K 14-448K 15-512K 16-640K 17-768K 18-896K 19-1024K 20-1280K 21-1536K 22-1792K 23-2048最高位(31位)置成1表示是自定义码流, 0-30位表示码流值。 + public int dwVideoFrameRate; //帧率 0-全部; 1-1/16; 2-1/8; 3-1/4; 4-1/2; 5-1; 6-2; 7-4; 8-6; 9-8; 10-10; 11-12; 12-16; 13-20; V2.0版本中新加14-15; 15-18; 16-22; + public short wIntervalFrameI; //I帧间隔 + public byte byIntervalBPFrame;//0-BBP帧; 1-BP帧; 2-单P帧 + public byte byENumber; //E帧数量(保留) + public byte byVideoEncType;//视频编码类型 0 hik264;1标准h264; 2标准mpeg4; + public byte byAudioEncType;//音频编码类型 0 G722 + public byte[] byres = new byte[10]; + + + } + + //通道压缩参数(9000扩展) + public static class NET_DVR_COMPRESSIONCFG_V30 extends Structure { + public int dwSize; + public NET_DVR_COMPRESSION_INFO_V30 struNormHighRecordPara; //录像 对应8000的普通 + public NET_DVR_COMPRESSION_INFO_V30 struRes; //保留 String[28]; + public NET_DVR_COMPRESSION_INFO_V30 struEventRecordPara; //事件触发压缩参数 + public NET_DVR_COMPRESSION_INFO_V30 struNetPara; //网传(子码流) + + + } + + + public static class NET_DVR_COMPRESSION_INFO extends Structure {//码流压缩参数(子结构) + public byte byStreamType; //码流类型0-视频流,1-复合流,表示压缩参数时最高位表示是否启用压缩参数 + public byte byResolution; //分辨率0-DCIF 1-CIF, 2-QCIF, 3-4CIF, 4-2CIF, 5-2QCIF(352X144)(车载专用) + public byte byBitrateType; //码率类型0:变码率,1:定码率 + public byte byPicQuality; //图象质量 0-最好 1-次好 2-较好 3-一般 4-较差 5-差 + public int dwVideoBitrate; //视频码率 0-保留 1-16K(保留) 2-32K 3-48k 4-64K 5-80K 6-96K 7-128K 8-160k 9-192K 10-224K 11-256K 12-320K + // 13-384K 14-448K 15-512K 16-640K 17-768K 18-896K 19-1024K 20-1280K 21-1536K 22-1792K 23-2048K + //最高位(31位)置成1表示是自定义码流, 0-30位表示码流值(MIN-32K MAX-8192K)。 + public int dwVideoFrameRate; //帧率 0-全部; 1-1/16; 2-1/8; 3-1/4; 4-1/2; 5-1; 6-2; 7-4; 8-6; 9-8; 10-10; 11-12; 12-16; 13-20; + + + } + + public static class NET_DVR_COMPRESSIONCFG extends Structure {//通道压缩参数 + public int dwSize; + public NET_DVR_COMPRESSION_INFO struRecordPara; //录像/事件触发录像 + public NET_DVR_COMPRESSION_INFO struNetPara; //网传/保留 + + + } + + + public static class NET_DVR_COMPRESSION_INFO_EX extends Structure {//码流压缩参数(子结构)(扩展) 增加I帧间隔 + public byte byStreamType; //码流类型0-视频流, 1-复合流 + public byte byResolution; //分辨率0-DCIF 1-CIF, 2-QCIF, 3-4CIF, 4-2CIF, 5-2QCIF(352X144)(车载专用) + public byte byBitrateType; //码率类型0:变码率,1:定码率 + public byte byPicQuality; //图象质量 0-最好 1-次好 2-较好 3-一般 4-较差 5-差 + public int dwVideoBitrate; //视频码率 0-保留 1-16K(保留) 2-32K 3-48k 4-64K 5-80K 6-96K 7-128K 8-160k 9-192K 10-224K 11-256K 12-320K + // 13-384K 14-448K 15-512K 16-640K 17-768K 18-896K 19-1024K 20-1280K 21-1536K 22-1792K 23-2048K + //最高位(31位)置成1表示是自定义码流, 0-30位表示码流值(MIN-32K MAX-8192K)。 + public int dwVideoFrameRate; //帧率 0-全部; 1-1/16; 2-1/8; 3-1/4; 4-1/2; 5-1; 6-2; 7-4; 8-6; 9-8; 10-10; 11-12; 12-16; 13-20, //V2.0增加14-15, 15-18, 16-22; + public short wIntervalFrameI; //I帧间隔 + //2006-08-11 增加单P帧的配置接口,可以改善实时流延时问题 + public byte byIntervalBPFrame;//0-BBP帧; 1-BP帧; 2-单P帧 + public byte byENumber;//E帧数量 + + + } + + public static class NET_DVR_RECORDSCHED extends Structure //时间段录像参数配置(子结构) + { + public NET_DVR_SCHEDTIME struRecordTime = new NET_DVR_SCHEDTIME(); + public byte byRecordType; //0:定时录像,1:移动侦测,2:报警录像,3:动测|报警,4:动测&报警, 5:命令触发, 6: 智能录像 + public byte[] reservedData = new byte[3]; + + + } + + public static class NET_DVR_RECORDDAY extends Structure //全天录像参数配置(子结构) + { + public short wAllDayRecord; /* 是否全天录像 0-否 1-是*/ + public byte byRecordType; /* 录象类型 0:定时录像,1:移动侦测,2:报警录像,3:动测|报警,4:动测&报警 5:命令触发, 6: 智能录像*/ + public byte reservedData; + + + } + + public static class NET_DVR_RECORDSCHEDWEEK extends Structure { + public NET_DVR_RECORDSCHED[] struRecordSched = new NET_DVR_RECORDSCHED[MAX_TIMESEGMENT_V30]; + + + } + + public static class NET_DVR_RECORD_V30 extends Structure { //通道录像参数配置(9000扩展) + public int dwSize; + public int dwRecord; /*是否录像 0-否 1-是*/ + public NET_DVR_RECORDDAY[] struRecAllDay = new NET_DVR_RECORDDAY[MAX_DAYS]; + public NET_DVR_RECORDSCHEDWEEK[] struRecordSched = new NET_DVR_RECORDSCHEDWEEK[MAX_DAYS]; + public int dwRecordTime; /* 录象延时长度 0-5秒, 1-20秒, 2-30秒, 3-1分钟, 4-2分钟, 5-5分钟, 6-10分钟*/ + public int dwPreRecordTime; /* 预录时间 0-不预录 1-5秒 2-10秒 3-15秒 4-20秒 5-25秒 6-30秒 7-0xffffffff(尽可能预录) */ + public int dwRecorderDuration; /* 录像保存的最长时间 */ + public byte byRedundancyRec; /*是否冗余录像,重要数据双备份:0/1*/ + public byte byAudioRec; /*录像时复合流编码时是否记录音频数据:国外有此法规*/ + public byte[] byReserve = new byte[10]; + + + } + + public static class NET_DVR_RECORD extends Structure { //通道录像参数配置 + public int dwSize; + public int dwRecord; /*是否录像 0-否 1-是*/ + public NET_DVR_RECORDDAY[] struRecAllDay = new NET_DVR_RECORDDAY[MAX_DAYS]; + public NET_DVR_RECORDSCHEDWEEK[] struRecordSched = new NET_DVR_RECORDSCHEDWEEK[MAX_DAYS]; + public int dwRecordTime; /* 录象时间长度 0-5秒, 1-20秒, 2-30秒, 3-1分钟, 4-2分钟, 5-5分钟, 6-10分钟*/ + public int dwPreRecordTime; /* 预录时间 0-不预录 1-5秒 2-10秒 3-15秒 4-20秒 5-25秒 6-30秒 7-0xffffffff(尽可能预录) */ + + + } + + public static class NET_DVR_STATFRAME extends Structure { //单帧统计参数 + public int dwRelativeTime; + public int dwAbsTime; /*统计绝对时标*/ + public byte[] byRes = new byte[92]; + + + } + + public static class NET_DVR_STATTIME extends Structure { //单帧统计参数 + public NET_DVR_TIME tmStart; //统计开始时间 + public NET_DVR_TIME tmEnd; //统计结束时间 + public byte[] byRes = new byte[92]; + + + } + + public static class UNION_PDC_STATPARAM extends Union { + // public byte[] byLen = new byte[140]; + public NET_DVR_STATFRAME struStatFrame; + public NET_DVR_STATTIME struStatTime; + + + } + + public static class NET_DVR_PDC_ALRAM_INFO extends Structure { //通道录像参数配置 + public int dwSize; + public byte byMode; /*0-单帧统计结果,1-最小时间段统计结果*/ + public byte byChannel; + public byte bySmart; //专业智能返回0,Smart 返回 1 + public byte byRes1; // 保留字节 + public NET_VCA_DEV_INFO struDevInfo = new NET_VCA_DEV_INFO(); //前端设备信息 + public UNION_PDC_STATPARAM uStatModeParam = new UNION_PDC_STATPARAM(); + public int dwLeaveNum; /* 离开人数 */ + public int dwEnterNum; /* 进入人数 */ + public byte byBrokenNetHttp; //断网续传标志位,0-不是重传数据,1-重传数据 + public byte byRes3; + public short wDevInfoIvmsChannelEx; //与NET_VCA_DEV_INFO里的byIvmsChannel含义相同,能表示更大的值。老客户端用byIvmsChannel能继续兼容,但是最大到255。新客户端版本请使用wDevInfoIvmsChannelEx + public int dwPassingNum; // 经过人数(进入区域后徘徊没有触发进入、离开的人数) + + + public byte[] byRes2 = new byte[32]; + + public void read() { + super.read(); + switch (byMode) { + case 0: + uStatModeParam.setType(NET_DVR_STATFRAME.class); + break; + case 1: + uStatModeParam.setType(NET_DVR_STATTIME.class); + break; + default: + break; + } + uStatModeParam.read(); + } + + public void write() { + super.write(); + uStatModeParam.write(); + } + + + } + + //云台协议表结构配置 + public static class NET_DVR_PTZ_PROTOCOL extends Structure { + public int dwType; /*解码器类型值,从1开始连续递增*/ + public byte[] byDescribe = new byte[DESC_LEN]; /*解码器的描述符,和8000中的一致*/ + + + } + + public static class NET_DVR_PTZCFG extends Structure { + public int dwSize; + public NET_DVR_PTZ_PROTOCOL[] struPtz = new NET_DVR_PTZ_PROTOCOL[PTZ_PROTOCOL_NUM];/*最大200中PTZ协议*/ + public int dwPtzNum; /*有效的ptz协议数目,从0开始(即计算时加1)*/ + public byte[] byRes = new byte[8]; + + + } + + /*************************** + * 云台类型(end) + ******************************/ + public static class NET_DVR_DECODERCFG_V30 extends Structure {//通道解码器(云台)参数配置(9000扩展) + public int dwSize; + public int dwBaudRate; //波特率(bps),0-50,1-75,2-110,3-150,4-300,5-600,6-1200,7-2400,8-4800,9-9600,10-19200, 11-38400,12-57600,13-76800,14-115.2k; + public byte byDataBit; // 数据有几位 0-5位,1-6位,2-7位,3-8位; + public byte byStopBit; // 停止位 0-1位,1-2位; + public byte byParity; // 校验 0-无校验,1-奇校验,2-偶校验; + public byte byFlowcontrol; // 0-无,1-软流控,2-硬流控 + public short wDecoderType; //解码器类型, 0-YouLi,1-LiLin-1016,2-LiLin-820,3-Pelco-p,4-DM DynaColor,5-HD600,6-JC-4116,7-Pelco-d WX,8-Pelco-d PICO + public short wDecoderAddress; /*解码器地址:0 - 255*/ + public byte[] bySetPreset = new byte[MAX_PRESET_V30]; /* 预置点是否设置,0-没有设置,1-设置*/ + public byte[] bySetCruise = new byte[MAX_CRUISE_V30]; /* 巡航是否设置: 0-没有设置,1-设置 */ + public byte[] bySetTrack = new byte[MAX_TRACK_V30]; /* 轨迹是否设置,0-没有设置,1-设置*/ + + + } + + public static class NET_DVR_DECODERCFG extends Structure {//通道解码器(云台)参数配置 + public int dwSize; + public int dwBaudRate; //波特率(bps),0-50,1-75,2-110,3-150,4-300,5-600,6-1200,7-2400,8-4800,9-9600,10-19200, 11-38400,12-57600,13-76800,14-115.2k; + public byte byDataBit; // 数据有几位 0-5位,1-6位,2-7位,3-8位; + public byte byStopBit; // 停止位 0-1位,1-2位; + public byte byParity; // 校验 0-无校验,1-奇校验,2-偶校验; + public byte byFlowcontrol; // 0-无,1-软流控,2-硬流控 + public short wDecoderType; //解码器类型, 0-YouLi,1-LiLin-1016,2-LiLin-820,3-Pelco-p,4-DM DynaColor,5-HD600,6-JC-4116,7-Pelco-d WX,8-Pelco-d PICO + public short wDecoderAddress; /*解码器地址:0 - 255*/ + public byte[] bySetPreset = new byte[MAX_PRESET]; /* 预置点是否设置,0-没有设置,1-设置*/ + public byte[] bySetCruise = new byte[MAX_CRUISE]; /* 巡航是否设置: 0-没有设置,1-设置 */ + public byte[] bySetTrack = new byte[MAX_TRACK]; /* 轨迹是否设置,0-没有设置,1-设置*/ + + + } + + public static class NET_DVR_PPPCFG_V30 extends Structure {//ppp参数配置(子结构) + public NET_DVR_IPADDR struRemoteIP; //远端IP地址 + public NET_DVR_IPADDR struLocalIP; //本地IP地址 + public byte[] sLocalIPMask = new byte[16]; //本地IP地址掩码 + public byte[] sUsername = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public byte byPPPMode; //PPP模式, 0-主动,1-被动 + public byte byRedial; //是否回拨 :0-否,1-是 + public byte byRedialMode; //回拨模式,0-由拨入者指定,1-预置回拨号码 + public byte byDataEncrypt; //数据加密,0-否,1-是 + public int dwMTU; //MTU + public byte[] sTelephoneNumber = new byte[PHONENUMBER_LEN]; //电话号码 + + + } + + public static class NET_DVR_PPPCFG extends Structure {//ppp参数配置(子结构) + public byte[] sRemoteIP = new byte[16]; //远端IP地址 + public byte[] sLocalIP = new byte[16]; //本地IP地址 + public byte[] sLocalIPMask = new byte[16]; //本地IP地址掩码 + public byte[] sUsername = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public byte byPPPMode; //PPP模式, 0-主动,1-被动 + public byte byRedial; //是否回拨 :0-否,1-是 + public byte byRedialMode; //回拨模式,0-由拨入者指定,1-预置回拨号码 + public byte byDataEncrypt; //数据加密,0-否,1-是 + public int dwMTU; //MTU + public byte[] sTelephoneNumber = new byte[PHONENUMBER_LEN]; //电话号码 + + + } + + + public static class NET_DVR_SINGLE_RS232 extends Structure {//RS232串口参数配置(9000扩展) + public int dwBaudRate; /*波特率(bps),0-50,1-75,2-110,3-150,4-300,5-600,6-1200,7-2400,8-4800,9-9600,10-19200, 11-38400,12-57600,13-76800,14-115.2k;*/ + public byte byDataBit; /* 数据有几位 0-5位,1-6位,2-7位,3-8位 */ + public byte byStopBit; /* 停止位 0-1位,1-2位 */ + public byte byParity; /* 校验 0-无校验,1-奇校验,2-偶校验 */ + public byte byFlowcontrol; /* 0-无,1-软流控,2-硬流控 */ + public int dwWorkMode; /* 工作模式,0-232串口用于PPP拨号,1-232串口用于参数控制,2-透明通道 */ + + + } + + public static class NET_DVR_RS232CFG_V30 extends Structure {//RS232串口参数配置(9000扩展) + public int dwSize; + public NET_DVR_SINGLE_RS232 struRs232;/*目前只有第一个串口设置有效,所有设备都只支持一个串口,其他七个保留*/ + public byte[] byRes = new byte[84]; + public NET_DVR_PPPCFG_V30 struPPPConfig;/*ppp参数*/ + + + } + + public static class NET_DVR_RS232CFG extends Structure {//RS232串口参数配置 + public int dwSize; + public int dwBaudRate;//波特率(bps),0-50,1-75,2-110,3-150,4-300,5-600,6-1200,7-2400,8-4800,9-9600,10-19200, 11-38400,12-57600,13-76800,14-115.2k; + public byte byDataBit;// 数据有几位 0-5位,1-6位,2-7位,3-8位; + public byte byStopBit;// 停止位 0-1位,1-2位; + public byte byParity;// 校验 0-无校验,1-奇校验,2-偶校验; + public byte byFlowcontrol;// 0-无,1-软流控,2-硬流控 + public int dwWorkMode;// 工作模式,0-窄带传输(232串口用于PPP拨号),1-控制台(232串口用于参数控制),2-透明通道 + public NET_DVR_PPPCFG struPPPConfig; + + + } + + public static class NET_DVR_ALARMINCFG_V30 extends Structure {//报警输入参数配置(9000扩展) + public int dwSize; + public byte[] sAlarmInName = new byte[NAME_LEN]; /* 名称 */ + public byte byAlarmType; //报警器类型,0:常开,1:常闭 + public byte byAlarmInHandle; /* 是否处理 0-不处理 1-处理*/ + public byte[] reservedData = new byte[2]; + public NET_DVR_HANDLEEXCEPTION_V30 struAlarmHandleType; /* 处理方式 */ + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS];//布防时间 + public byte[] byRelRecordChan = new byte[MAX_CHANNUM_V30]; //报警触发的录象通道,为1表示触发该通道 + public byte[] byEnablePreset = new byte[MAX_CHANNUM_V30]; /* 是否调用预置点 0-否,1-是*/ + public byte[] byPresetNo = new byte[MAX_CHANNUM_V30]; /* 调用的云台预置点序号,一个报警输入可以调用多个通道的云台预置点, 0xff表示不调用预置点。*/ + public byte[] byEnablePresetRevert = new byte[MAX_CHANNUM_V30]; /* 是否恢复到调用预置点前的位置(保留) */ + public short[] wPresetRevertDelay = new short[MAX_CHANNUM_V30]; /* 恢复预置点延时(保留) */ + public byte[] byEnableCruise = new byte[MAX_CHANNUM_V30]; /* 是否调用巡航 0-否,1-是*/ + public byte[] byCruiseNo = new byte[MAX_CHANNUM_V30]; /* 巡航 */ + public byte[] byEnablePtzTrack = new byte[MAX_CHANNUM_V30]; /* 是否调用轨迹 0-否,1-是*/ + public byte[] byPTZTrack = new byte[MAX_CHANNUM_V30]; /* 调用的云台的轨迹序号 */ + public byte[] byRes = new byte[16]; + + + } + + public static class NET_DVR_ALARMINCFG extends Structure {//报警输入参数配置 + public int dwSize; + public byte[] sAlarmInName = new byte[NAME_LEN]; /* 名称 */ + public byte byAlarmType; //报警器类型,0:常开,1:常闭 + public byte byAlarmInHandle; /* 是否处理 0-不处理 1-处理*/ + public NET_DVR_HANDLEEXCEPTION struAlarmHandleType; /* 处理方式 */ + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS];//布防时间 + public byte[] byRelRecordChan = new byte[MAX_CHANNUM]; //报警触发的录象通道,为1表示触发该通道 + public byte[] byEnablePreset = new byte[MAX_CHANNUM]; /* 是否调用预置点 0-否,1-是*/ + public byte[] byPresetNo = new byte[MAX_CHANNUM]; /* 调用的云台预置点序号,一个报警输入可以调用多个通道的云台预置点, 0xff表示不调用预置点。*/ + public byte[] byEnableCruise = new byte[MAX_CHANNUM]; /* 是否调用巡航 0-否,1-是*/ + public byte[] byCruiseNo = new byte[MAX_CHANNUM]; /* 巡航 */ + public byte[] byEnablePtzTrack = new byte[MAX_CHANNUM]; /* 是否调用轨迹 0-否,1-是*/ + public byte[] byPTZTrack = new byte[MAX_CHANNUM]; /* 调用的云台的轨迹序号 */ + + + } + + public static class NET_DVR_ADDIT_POSITION extends Structure {//车载GPS信息结构(2007-12-27) + public byte[] sDevName = new byte[32]; /* 设备名称 */ + public int dwSpeed; /*速度*/ + public int dwLongitude; /* 经度*/ + public int dwLatitude; /* 纬度*/ + public byte[] direction = new byte[2]; /* direction[0]:'E'or'W'(东经/西经), direction[1]:'N'or'S'(北纬/南纬) */ + public byte[] res = new byte[2]; /* 保留位 */ + + + } + + public static class struRecordingHost extends Structure { + public byte bySubAlarmType; + public byte[] byRes1 = new byte[3]; + public NET_DVR_TIME_EX struRecordEndTime = new NET_DVR_TIME_EX(); + } + + public static class struAlarmHardDisk extends Structure { + public int dwAlarmHardDiskNum; + + + } + + public static class struAlarmChannel extends Structure { + public int dwAlarmChanNum; + public int dwPicLen;//Jpeg图片长度 + public byte byPicURL; //图片数据采用URL方式 0-二进制图片数据,1-图片数据走URL方式 + public byte byTarget; /*0-不区分识别目标,1-识别目标为人,2-识别目标为车*/ + public byte[] byRes1 = new byte[2]; //保留 + public Pointer pDataBuff; //报警图片或者图片URL + } + + public static class struIOAlarm extends Structure { + public int dwAlarmInputNo; + public int dwTrigerAlarmOutNum; + public int dwTrigerRecordChanNum; + + + } + + public static class NET_DVR_TIME_EX extends Structure { + public short wYear; + public byte byMonth; + public byte byDay; + public byte byHour; + public byte byMinute; + public byte bySecond; + public byte byRes; + } + + public static class uStruAlarm extends Union { + public byte[] byUnionLen = new byte[116]; + public struIOAlarm struioAlarm = new struIOAlarm(); + public struAlarmHardDisk strualarmHardDisk = new struAlarmHardDisk(); + public struAlarmChannel strualarmChannel = new struAlarmChannel(); + public struRecordingHost strurecordingHost = new struRecordingHost(); + + + } + + public static class NET_DVR_ALRAM_FIXED_HEADER extends Structure { + public int dwAlarmType; + public NET_DVR_TIME_EX struAlarmTime = new NET_DVR_TIME_EX(); + public uStruAlarm ustruAlarm = new uStruAlarm(); + public Pointer pRes; + public byte byTimeDiffFlag; /*时差字段是否有效 0-时差无效, 1-时差有效 */ + public byte cTimeDifferenceH; /*与UTC的时差(小时),-12 ... +14, +表示东区,,byTimeDiffFlag为1时有效*/ + public byte cTimeDifferenceM; /*与UTC的时差(分钟),-30, 30, 45, +表示东区,byTimeDiffFlag为1时有效*/ + public byte byRes; //保留 + public short wDevInfoIvmsChannel; //增加后端透传前端时的通道号 + public byte[] byRes2 = new byte[2]; //保留 + } + + public static class NET_DVR_ALARMINFO_V40 extends Structure { + public NET_DVR_ALRAM_FIXED_HEADER struAlarmFixedHeader = new NET_DVR_ALRAM_FIXED_HEADER(); + public Pointer pAlarmData; + + + } + + public static class NET_DVR_ALARMINFO_V30 extends Structure {//上传报警信息(9000扩展) + public int dwAlarmType;/*0-信号量报警,1-硬盘满,2-信号丢失,3-移动侦测,4-硬盘未格式化,5-读写硬盘出错,6-遮挡报警,7-制式不匹配, 8-非法访问, 0xa-GPS定位信息(车载定制)*/ + public int dwAlarmInputNumber;/*报警输入端口*/ + public byte[] byAlarmOutputNumber = new byte[MAX_ALARMOUT_V30];/*触发的输出端口,为1表示对应输出*/ + public byte[] byAlarmRelateChannel = new byte[MAX_CHANNUM_V30];/*触发的录像通道,为1表示对应录像, dwAlarmRelateChannel[0]对应第1个通道*/ + public byte[] byChannel = new byte[MAX_CHANNUM_V30];/*dwAlarmType为2或3,6时,表示哪个通道,dwChannel[0]对应第1个通道*/ + public byte[] byDiskNumber = new byte[MAX_DISKNUM_V30];/*dwAlarmType为1,4,5时,表示哪个硬盘, dwDiskNumber[0]对应第1个硬盘*/ + + + } + + public static class NET_DVR_ALARMINFO extends Structure { + public int dwAlarmType;/*0-信号量报警,1-硬盘满,2-信号丢失,3-移动侦测,4-硬盘未格式化,5-读写硬盘出错,6-遮挡报警,7-制式不匹配, 8-非法访问, 9-串口状态, 0xa-GPS定位信息(车载定制)*/ + public int dwAlarmInputNumber;/*报警输入端口, 当报警类型为9时该变量表示串口状态0表示正常, -1表示错误*/ + public int[] dwAlarmOutputNumber = new int[MAX_ALARMOUT];/*触发的输出端口,为1表示对应哪一个输出*/ + public int[] dwAlarmRelateChannel = new int[MAX_CHANNUM];/*触发的录像通道,dwAlarmRelateChannel[0]为1表示第1个通道录像*/ + public int[] dwChannel = new int[MAX_CHANNUM];/*dwAlarmType为2或3,6时,表示哪个通道,dwChannel[0]位对应第1个通道*/ + public int[] dwDiskNumber = new int[MAX_DISKNUM];/*dwAlarmType为1,4,5时,表示哪个硬盘, dwDiskNumber[0]位对应第1个硬盘*/ + + + } + + public static class NET_DVR_ALARMINFO_EX extends Structure {//上传报警信息(杭州竞天定制 2006-07-28) + public int dwAlarmType;/*0-信号量报警,1-硬盘满,2-信号丢失,3-移动侦测,4-硬盘未格式化,5-读写硬盘出错,6-遮挡报警,7-制式不匹配, 8-非法访问*/ + public int dwAlarmInputNumber;/*报警输入端口*/ + public int[] dwAlarmOutputNumber = new int[MAX_ALARMOUT];/*报警输入端口对应的输出端口,哪一位为1表示对应哪一个输出*/ + public int[] dwAlarmRelateChannel = new int[MAX_CHANNUM];/*报警输入端口对应的录像通道,哪一位为1表示对应哪一路录像,dwAlarmRelateChannel[0]对应第1个通道*/ + public int[] dwChannel = new int[MAX_CHANNUM];/*dwAlarmType为2或3,6时,表示哪个通道,dwChannel[0]位对应第0个通道*/ + public int[] dwDiskNumber = new int[MAX_DISKNUM];/*dwAlarmType为1,4,5时,表示哪个硬盘*/ + public byte[] sSerialNumber = new byte[SERIALNO_LEN]; //序列号 + public byte[] sRemoteAlarmIP = new byte[16]; //远程报警IP地址; + + + } + + ////////////////////////////////////////////////////////////////////////////////////// +//IPC接入参数配置 + public static class NET_DVR_IPDEVINFO extends Structure {/* IP设备结构 */ + public int dwEnable; /* 该IP设备是否启用 */ + public byte[] sUserName = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public NET_DVR_IPADDR struIP = new NET_DVR_IPADDR(); /* IP地址 */ + public short wDVRPort; /* 端口号 */ + public byte[] byres = new byte[34]; /* 保留 */ + + + } + + public static class NET_DVR_IPCHANINFO extends Structure {/* IP通道匹配参数 */ + public byte byEnable; /* 该通道是否启用 */ + public byte byIPID; /* IP设备ID 取值1- MAX_IP_DEVICE */ + public byte byChannel; /* 通道号 */ + public byte[] byres = new byte[33]; /* 保留 */ + + + } + + public static class NET_DVR_IPPARACFG extends Structure {/* IP接入配置结构 */ + public int dwSize; /* 结构大小 */ + public NET_DVR_IPDEVINFO[] struIPDevInfo = new NET_DVR_IPDEVINFO[MAX_IP_DEVICE]; /* IP设备 */ + public byte[] byAnalogChanEnable = new byte[MAX_ANALOG_CHANNUM]; /* 模拟通道是否启用,从低到高表示1-32通道,0表示无效 1有效 */ + public NET_DVR_IPCHANINFO[] struIPChanInfo = new NET_DVR_IPCHANINFO[MAX_IP_CHANNEL]; /* IP通道 */ + + + } + + public class NET_DVR_IPDEVINFO_V31 extends Structure { + public byte byEnable;/* 该通道是否启用 */ + public byte byProType;//协议类型(默认为私有协议),0- 私有协议,1- 松下协议,2- 索尼,更多协议通过NET_DVR_GetIPCProtoList获取。 + public byte byEnableQuickAdd;//0-不支持快速添加;1-使用快速添加 + public byte byRes1;//保留,置为0 + public byte[] sUserName = new byte[HCNetSDK.NAME_LEN];//用户名 + public byte[] sPassword = new byte[HCNetSDK.PASSWD_LEN];//密码 + public byte[] byDomain = new byte[HCNetSDK.MAX_DOMAIN_NAME];//设备域名 + public NET_DVR_IPADDR struIP = new NET_DVR_IPADDR();//IP地址 + public short wDVRPort;//端口号 + public byte[] szDeviceID = new byte[32]; + public byte[] byRes2 = new byte[2];//保留,置为0 + + + } + + public class NET_DVR_STREAM_MODE extends Structure { + + public byte byGetStreamType;//取流方式:0- 直接从设备取流;1- 从流媒体取流;2- 通过IPServer获得IP地址后取流; + //3- 通过IPServer找到设备,再通过流媒体取设备的流; 4- 通过流媒体由URL去取流;5- 通过hiDDNS域名连接设备然后从设备取流 + public byte[] byRes = new byte[3];//保留,置为0 + public NET_DVR_GET_STREAM_UNION uGetStream = new NET_DVR_GET_STREAM_UNION();//不同取流方式联合体 + + public void read() { + super.read(); + switch (byGetStreamType) { + case 0: + uGetStream.setType(NET_DVR_IPCHANINFO.class); + break; + case 6: + uGetStream.setType(NET_DVR_IPCHANINFO_V40.class); + break; + default: + break; + } + } + + + } + + public class NET_DVR_IPSERVER_STREAM extends Structure { + public byte byEnable; + public byte[] byRes = new byte[3]; + public NET_DVR_IPADDR struIPServer = new NET_DVR_IPADDR(); + public short wPort; + public short wDvrNameLen; + public byte[] byDVRName = new byte[HCNetSDK.NAME_LEN]; + public short wDVRSerialLen; + public short[] byRes1 = new short[2]; + public byte[] byDVRSerialNumber = new byte[HCNetSDK.SERIALNO_LEN]; + public byte[] byUserName = new byte[HCNetSDK.NAME_LEN]; + public byte[] byPassWord = new byte[HCNetSDK.PASSWD_LEN]; + public byte byChannel; + public byte[] byRes2 = new byte[11]; + + + } + + public class NET_DVR_STREAM_MEDIA_SERVER_CFG extends Structure { + + public byte byValid;//是否启用流媒体服务器取流:0-不启用,非0-启用 + public byte[] byRes1 = new byte[3];//保留,置为0 + public NET_DVR_IPADDR struDevIP = new NET_DVR_IPADDR();//流媒体服务器的IP地址 + public short wDevPort;//流媒体服务器端口 + public byte byTransmitType;//传输协议类型:0-TCP,1-UDP + public byte[] byRes2 = new byte[69]; + + + } + + public class NET_DVR_DEV_CHAN_INFO extends Structure { + public NET_DVR_IPADDR struIP = new NET_DVR_IPADDR();//设备IP地址 + public short wDVRPort;//设备端口号 + public byte byChannel;//通道号,目前设备的模拟通道号是从1开始的,对于9000等设备的IPC接入,数字通道号从33开始 + public byte byTransProtocol;//传输协议类型:0-TCP,1-UDP,2-多播方式,3-RTP + public byte byTransMode;//传输码流模式:0-主码流,1-子码流 + public byte byFactoryType;//前端设备厂家类型, 通过接口NET_DVR_GetIPCProtoList获取 + public byte byDeviceType;//设备类型(视频综合平台使用):1- IPC,2- ENCODER + public byte byDispChan;// 显示通道号(智能配置使用),根据能力集决定使用解码通道还是显示通道 + public byte bySubDispChan;//显示通道子通道号(智能配置时使用) + public byte byResolution;//分辨率:1- CIF,2- 4CIF,3- 720P,4- 1080P,5- 500W,用于多屏控制器,多屏控制器会根据该参数分配解码资源 + public byte[] byRes = new byte[2];//保留,置为0 + public byte[] byDomain = new byte[HCNetSDK.MAX_DOMAIN_NAME];//设备域名 + public byte[] sUserName = new byte[HCNetSDK.NAME_LEN];//设备登陆帐号 + public byte[] sPassword = new byte[HCNetSDK.PASSWD_LEN];//设备密码 + } + + public class NET_DVR_PU_STREAM_CFG extends Structure { + public int dwSize;//结构体大小 + public NET_DVR_STREAM_MEDIA_SERVER_CFG struStreamMediaSvrCfg = new NET_DVR_STREAM_MEDIA_SERVER_CFG(); + public NET_DVR_DEV_CHAN_INFO struDevChanInfo = new NET_DVR_DEV_CHAN_INFO(); + } + + public class NET_DVR_PU_STREAM_CFG_V41 extends Structure { + public int dwSize; + public byte byStreamMode;/*取流模式,0-无效,1-通过IP或域名取流,2-通过URL取流,3-通过动态域名解析向设备取流*/ + public byte byStreamEncrypt; //是否进行码流加密处理,0-不支持,1-支持 + public byte[] byRes1 = new byte[2]; + public NET_DVR_DEC_STREAM_MODE uDecStreamMode;//取流信息 + public int dwDecDelayTime;//解码延时时间,单位:毫秒 + public byte[] sStreamPassword = new byte[STREAM_PASSWD_LEN]; //码流加密密码,需敏感信息加密 + public byte[] byRes2 = new byte[48]; + } + + + public class NET_DVR_DDNS_STREAM_CFG extends Structure { + public byte byEnable; + public byte[] byRes1 = new byte[3]; + public NET_DVR_IPADDR struStreamServer = new NET_DVR_IPADDR(); + public short wStreamServerPort; + public byte byStreamServerTransmitType; + public byte byRes2; + public NET_DVR_IPADDR struIPServer = new NET_DVR_IPADDR(); + public short wIPServerPort; + public byte[] byRes3 = new byte[2]; + public byte[] sDVRName = new byte[HCNetSDK.NAME_LEN]; + public short wDVRNameLen; + public short wDVRSerialLen; + public byte[] sDVRSerialNumber = new byte[HCNetSDK.SERIALNO_LEN]; + public byte[] sUserName = new byte[HCNetSDK.NAME_LEN]; + public byte[] sPassWord = new byte[HCNetSDK.PASSWD_LEN]; + public short wDVRPort; + public byte[] byRes4 = new byte[2]; + public byte byChannel; + public byte byTransProtocol; + public byte byTransMode; + public byte byFactoryType; + + + } + + public class NET_DVR_PU_STREAM_URL extends Structure { + public byte byEnable;//是否启用:0- 禁用,1- 启用 + public byte[] strURL = new byte[240];//取流URL路径 + public byte byTransPortocol;//传输协议类型:0-TCP,1-UDP + public short wIPID;//设备ID号,wIPID = iDevInfoIndex + iGroupNO*64 +1 + public byte byChannel;//设备通道号 + public byte[] byRes = new byte[7];//保留,置为0 + + + } + + public class NET_DVR_HKDDNS_STREAM extends Structure { + public byte byEnable;//是否启用 + public byte[] byRes = new byte[3];//保留 + public byte[] byDDNSDomain = new byte[64];//hiDDNS服务器地址 + public short wPort;//hiDDNS端口,默认:80 + public short wAliasLen;//别名长度 + public byte[] byAlias = new byte[HCNetSDK.NAME_LEN];//别名 + public short wDVRSerialLen;//序列号长度 + public byte[] byRes1 = new byte[2];//保留 + public byte[] byDVRSerialNumber = new byte[HCNetSDK.SERIALNO_LEN];//设备序列号 + public byte[] byUserName = new byte[HCNetSDK.NAME_LEN];//设备登录用户名 + public byte[] byPassWord = new byte[HCNetSDK.PASSWD_LEN];//设备登录密码 + public byte byChannel;//设备通道号 + public byte[] byRes2 = new byte[11];//保留 + + + } + + public class NET_DVR_IPCHANINFO_V40 extends Structure { + + public byte byEnable;//IP通道在线状态,是一个只读的属性; + //0表示HDVR或者NVR设备的数字通道连接对应的IP设备失败,该通道不在线;1表示连接成功,该通道在线 + public byte byRes1;//保留,置为0 + public short wIPID;//IP设备ID + public int dwChannel;//IP设备的通道号,例如设备A(HDVR或者NVR设备)的IP通道01,对应的是设备B(DVS)里的通道04,则byChannel=4,如果前端接的是IPC则byChannel=1。 + public byte byTransProtocol;//传输协议类型:0- TCP,1- UDP,2- 多播,0xff- auto(自动) + public byte byTransMode;//传输码流模式:0- 主码流,1- 子码流 + public byte byFactoryType;//前端设备厂家类型 + public byte[] byRes = new byte[241];//保留,置为0 + + + } + + + public static class NET_DVR_GET_STREAM_UNION extends Union { + public NET_DVR_IPCHANINFO struChanInfo = new NET_DVR_IPCHANINFO(); /*IP通道信息*/ + public NET_DVR_IPCHANINFO_V40 struIPChan = new NET_DVR_IPCHANINFO_V40(); //直接从设备取流(扩展) + public byte[] byUnionLen = new byte[492]; //直接从设备取流(扩展) + + + } + + public static class NET_DVR_IPPARACFG_V40 extends Structure {/* IP接入配置结构V40 */ + public int dwSize; /* 结构大小 */ + public int dwGroupNum;//设备支持的总组数(只读)。 + public int dwAChanNum;//最大模拟通道个数(只读) + public int dwDChanNum;//数字通道个数(只读) + public int dwStartDChan;//起始数字通道(只读) + public byte[] byAnalogChanEnable = new byte[MAX_CHANNUM_V30]; //模拟通道资源是否启用,从低到高表示1-64通道:0-禁用,1-启用。 + public NET_DVR_IPDEVINFO_V31[] struIPDevInfo = new NET_DVR_IPDEVINFO_V31[MAX_IP_DEVICE_V40];//IP设备信息,下标0对应设备IP ID为1 + public NET_DVR_STREAM_MODE[] struStreamMode = new NET_DVR_STREAM_MODE[MAX_CHANNUM_V30];//取流模式 + public byte[] byRes2 = new byte[20];//保留,置为0 + + + } + + public static class NET_DVR_IPALARMOUTINFO extends Structure {/* 报警输出参数 */ + public byte byIPID; /* IP设备ID取值1- MAX_IP_DEVICE */ + public byte byAlarmOut; /* 报警输出号 */ + public byte[] byRes = new byte[18]; /* 保留 */ + + + } + + public static class NET_DVR_IPALARMOUTCFG extends Structure {/* IP报警输出配置结构 */ + public int dwSize; /* 结构大小 */ + public NET_DVR_IPALARMOUTINFO[] struIPAlarmOutInfo = new NET_DVR_IPALARMOUTINFO[MAX_IP_ALARMOUT];/* IP报警输出 */ + + + } + + public static class NET_DVR_IPALARMININFO extends Structure {/* 报警输入参数 */ + public byte byIPID; /* IP设备ID取值1- MAX_IP_DEVICE */ + public byte byAlarmIn; /* 报警输入号 */ + public byte[] byRes = new byte[18]; /* 保留 */ + + + } + + public static class NET_DVR_IPALARMINCFG extends Structure {/* IP报警输入配置结构 */ + public int dwSize; /* 结构大小 */ + public NET_DVR_IPALARMININFO[] struIPAlarmInInfo = new NET_DVR_IPALARMININFO[MAX_IP_ALARMIN];/* IP报警输入 */ + + + } + + public static class NET_DVR_IPALARMINFO extends Structure {//ipc alarm info + public NET_DVR_IPDEVINFO[] struIPDevInfo = new NET_DVR_IPDEVINFO[MAX_IP_DEVICE]; /* IP设备 */ + public byte[] byAnalogChanEnable = new byte[MAX_ANALOG_CHANNUM]; /* 模拟通道是否启用,0-未启用 1-启用 */ + public NET_DVR_IPCHANINFO[] struIPChanInfo = new NET_DVR_IPCHANINFO[MAX_IP_CHANNEL]; /* IP通道 */ + public NET_DVR_IPALARMININFO[] struIPAlarmInInfo = new NET_DVR_IPALARMININFO[MAX_IP_ALARMIN]; /* IP报警输入 */ + public NET_DVR_IPALARMOUTINFO[] struIPAlarmOutInfo = new NET_DVR_IPALARMOUTINFO[MAX_IP_ALARMOUT]; /* IP报警输出 */ + + + } + + public static class NET_DVR_SINGLE_HD extends Structure {//本地硬盘信息配置 + public int dwHDNo; /*硬盘号, 取值0~MAX_DISKNUM_V30-1*/ + public int dwCapacity; /*硬盘容量(不可设置)*/ + public int dwFreeSpace; /*硬盘剩余空间(不可设置)*/ + public int dwHdStatus; /*硬盘状态(不可设置) 0-正常, 1-未格式化, 2-错误, 3-SMART状态, 4-不匹配, 5-休眠*/ + public byte byHDAttr; /*0-默认, 1-冗余; 2-只读*/ + public byte[] byRes1 = new byte[3]; + public int dwHdGroup; /*属于哪个盘组 1-MAX_HD_GROUP*/ + public byte[] byRes2 = new byte[120]; + } + + public static class NET_DVR_HDCFG extends Structure { + public int dwSize; + public int dwHDCount; /*硬盘数(不可设置)*/ + public NET_DVR_SINGLE_HD[] struHDInfo = new NET_DVR_SINGLE_HD[MAX_DISKNUM_V30];//硬盘相关操作都需要重启才能生效; + } + + public static class NET_DVR_SINGLE_HDGROUP extends Structure {//本地盘组信息配置 + public int dwHDGroupNo; /*盘组号(不可设置) 1-MAX_HD_GROUP*/ + public byte[] byHDGroupChans = new byte[64]; /*盘组对应的录像通道, 0-表示该通道不录象到该盘组,1-表示录象到该盘组*/ + public byte[] byRes = new byte[8]; + } + + public static class NET_DVR_HDGROUP_CFG extends Structure { + public int dwSize; + public int dwHDGroupCount; /*盘组总数(不可设置)*/ + public NET_DVR_SINGLE_HDGROUP[] struHDGroupAttr = new NET_DVR_SINGLE_HDGROUP[MAX_HD_GROUP];//硬盘相关操作都需要重启才能生效; + } + + public static class NET_DVR_SCALECFG extends Structure {//配置缩放参数的结构 + public int dwSize; + public int dwMajorScale; /* 主显示 0-不缩放,1-缩放*/ + public int dwMinorScale; /* 辅显示 0-不缩放,1-缩放*/ + public int[] dwRes = new int[2]; + } + + public static class NET_DVR_ALARMOUTCFG_V30 extends Structure {//DVR报警输出(9000扩展) + public int dwSize; + public byte[] sAlarmOutName = new byte[NAME_LEN]; /* 名称 */ + public int dwAlarmOutDelay; /* 输出保持时间(-1为无限,手动关闭) */ + //0-5秒,1-10秒,2-30秒,3-1分钟,4-2分钟,5-5分钟,6-10分钟,7-手动 + public NET_DVR_SCHEDTIMEWEEK[] struAlarmOutTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS];/* 报警输出激活时间段 */ + public byte[] byRes = new byte[16]; + } + + public static class NET_DVR_ALARMOUTCFG extends Structure {//DVR报警输出 + public int dwSize; + public byte[] sAlarmOutName = new byte[NAME_LEN]; /* 名称 */ + public int dwAlarmOutDelay; /* 输出保持时间(-1为无限,手动关闭) */ + //0-5秒,1-10秒,2-30秒,3-1分钟,4-2分钟,5-5分钟,6-10分钟,7-手动 + public NET_DVR_SCHEDTIMEWEEK[] struAlarmOutTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS];/* 报警输出激活时间段 */ + } + + public static class NET_DVR_PREVIEWCFG_V30 extends Structure {//DVR本地预览参数(9000扩展) + public int dwSize; + public byte byPreviewNumber;//预览数目,0-1画面,1-4画面,2-9画面,3-16画面, 4-6画面, 5-8画面, 0xff:最大画面 + public byte byEnableAudio;//是否声音预览,0-不预览,1-预览 + public short wSwitchTime;//切换时间,0-不切换,1-5s,2-10s,3-20s,4-30s,5-60s,6-120s,7-300s + public byte[][] bySwitchSeq = new byte[MAX_PREVIEW_MODE][MAX_WINDOW_V30];//切换顺序,如果lSwitchSeq[i]为 0xff表示不用 + public byte[] byRes = new byte[24]; + } + + public static class NET_DVR_PREVIEWCFG extends Structure {//DVR本地预览参数 + public int dwSize; + public byte byPreviewNumber;//预览数目,0-1画面,1-4画面,2-9画面,3-16画面,0xff:最大画面 + public byte byEnableAudio;//是否声音预览,0-不预览,1-预览 + public short wSwitchTime;//切换时间,0-不切换,1-5s,2-10s,3-20s,4-30s,5-60s,6-120s,7-300s + public byte[] bySwitchSeq = new byte[MAX_WINDOW];//切换顺序,如果lSwitchSeq[i]为 0xff表示不用 + } + + public static class NET_DVR_VGAPARA extends Structure {//DVR视频输出 + public short wResolution; /* 分辨率 */ + public short wFreq; /* 刷新频率 */ + public int dwBrightness; /* 亮度 */ + } + + /* + * MATRIX输出参数结构 + */ + public static class NET_DVR_MATRIXPARA_V30 extends Structure { + public short[] wOrder = new short[MAX_ANALOG_CHANNUM]; /* 预览顺序, 0xff表示相应的窗口不预览 */ + public short wSwitchTime; /* 预览切换时间 */ + public byte[] res = new byte[14]; + } + + public static class NET_DVR_MATRIXPARA extends Structure { + public short wDisplayLogo; /* 显示视频通道号(保留) */ + public short wDisplayOsd; /* 显示时间(保留) */ + } + + public static class NET_DVR_VOOUT extends Structure { + public byte byVideoFormat; /* 输出制式,0-PAL,1-NTSC */ + public byte byMenuAlphaValue; /* 菜单与背景图象对比度 */ + public short wScreenSaveTime; /* 屏幕保护时间 0-从不,1-1分钟,2-2分钟,3-5分钟,4-10分钟,5-20分钟,6-30分钟 */ + public short wVOffset; /* 视频输出偏移 */ + public short wBrightness; /* 视频输出亮度 */ + public byte byStartMode; /* 启动后视频输出模式(0:菜单,1:预览)*/ + public byte byEnableScaler; /* 是否启动缩放 (0-不启动, 1-启动)*/ + } + + public static class NET_DVR_VIDEOOUT_V30 extends Structure {//DVR视频输出(9000扩展) + public int dwSize; + public NET_DVR_VOOUT[] struVOOut = new NET_DVR_VOOUT[MAX_VIDEOOUT_V30]; + public NET_DVR_VGAPARA[] struVGAPara = new NET_DVR_VGAPARA[MAX_VGA_V30]; /* VGA参数 */ + public NET_DVR_MATRIXPARA_V30[] struMatrixPara = new NET_DVR_MATRIXPARA_V30[MAX_MATRIXOUT]; /* MATRIX参数 */ + public byte[] byRes = new byte[16]; + } + + public static class NET_DVR_VIDEOOUT extends Structure {//DVR视频输出 + public int dwSize; + public NET_DVR_VOOUT[] struVOOut = new NET_DVR_VOOUT[MAX_VIDEOOUT]; + public NET_DVR_VGAPARA[] struVGAPara = new NET_DVR_VGAPARA[MAX_VGA]; /* VGA参数 */ + public NET_DVR_MATRIXPARA struMatrixPara; /* MATRIX参数 */ + } + + public static class NET_DVR_USER_INFO_V30 extends Structure {//单用户参数(子结构)(9000扩展) + public byte[] sUserName = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public byte[] byLocalRight = new byte[MAX_RIGHT]; /* 本地权限 */ + /*数组0: 本地控制云台*/ + /*数组1: 本地手动录象*/ + /*数组2: 本地回放*/ + /*数组3: 本地设置参数*/ + /*数组4: 本地查看状态、日志*/ + /*数组5: 本地高级操作(升级,格式化,重启,关机)*/ + /*数组6: 本地查看参数 */ + /*数组7: 本地管理模拟和IP camera */ + /*数组8: 本地备份 */ + /*数组9: 本地关机/重启 */ + public byte[] byRemoteRight = new byte[MAX_RIGHT];/* 远程权限 */ + /*数组0: 远程控制云台*/ + /*数组1: 远程手动录象*/ + /*数组2: 远程回放 */ + /*数组3: 远程设置参数*/ + /*数组4: 远程查看状态、日志*/ + /*数组5: 远程高级操作(升级,格式化,重启,关机)*/ + /*数组6: 远程发起语音对讲*/ + /*数组7: 远程预览*/ + /*数组8: 远程请求报警上传、报警输出*/ + /*数组9: 远程控制,本地输出*/ + /*数组10: 远程控制串口*/ + /*数组11: 远程查看参数 */ + /*数组12: 远程管理模拟和IP camera */ + /*数组13: 远程关机/重启 */ + public byte[] byNetPreviewRight = new byte[MAX_CHANNUM_V30]; /* 远程可以预览的通道 0-有权限,1-无权限*/ + public byte[] byLocalPlaybackRight = new byte[MAX_CHANNUM_V30]; /* 本地可以回放的通道 0-有权限,1-无权限*/ + public byte[] byNetPlaybackRight = new byte[MAX_CHANNUM_V30]; /* 远程可以回放的通道 0-有权限,1-无权限*/ + public byte[] byLocalRecordRight = new byte[MAX_CHANNUM_V30]; /* 本地可以录像的通道 0-有权限,1-无权限*/ + public byte[] byNetRecordRight = new byte[MAX_CHANNUM_V30]; /* 远程可以录像的通道 0-有权限,1-无权限*/ + public byte[] byLocalPTZRight = new byte[MAX_CHANNUM_V30]; /* 本地可以PTZ的通道 0-有权限,1-无权限*/ + public byte[] byNetPTZRight = new byte[MAX_CHANNUM_V30]; /* 远程可以PTZ的通道 0-有权限,1-无权限*/ + public byte[] byLocalBackupRight = new byte[MAX_CHANNUM_V30]; /* 本地备份权限通道 0-有权限,1-无权限*/ + public NET_DVR_IPADDR struUserIP; /* 用户IP地址(为0时表示允许任何地址) */ + public byte[] byMACAddr = new byte[MACADDR_LEN]; /* 物理地址 */ + public byte byPriority; /* 优先级,0xff-无,0--低,1--中,2--高 */ + /* + 无……表示不支持优先级的设置 + 低……默认权限:包括本地和远程回放,本地和远程查看日志和状态,本地和远程关机/重启 + 中……包括本地和远程控制云台,本地和远程手动录像,本地和远程回放,语音对讲和远程预览 + 本地备份,本地/远程关机/重启 + 高……管理员 + */ + public byte[] byRes = new byte[17]; + } + + public static class NET_DVR_USER_INFO_EX extends Structure {//单用户参数(SDK_V15扩展)(子结构) + public byte[] sUserName = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public int[] dwLocalRight = new int[MAX_RIGHT]; /* 权限 */ + /*数组0: 本地控制云台*/ + /*数组1: 本地手动录象*/ + /*数组2: 本地回放*/ + /*数组3: 本地设置参数*/ + /*数组4: 本地查看状态、日志*/ + /*数组5: 本地高级操作(升级,格式化,重启,关机)*/ + public int dwLocalPlaybackRight; /* 本地可以回放的通道 bit0 -- channel 1*/ + public int[] dwRemoteRight = new int[MAX_RIGHT]; /* 权限 */ + /*数组0: 远程控制云台*/ + /*数组1: 远程手动录象*/ + /*数组2: 远程回放 */ + /*数组3: 远程设置参数*/ + /*数组4: 远程查看状态、日志*/ + /*数组5: 远程高级操作(升级,格式化,重启,关机)*/ + /*数组6: 远程发起语音对讲*/ + /*数组7: 远程预览*/ + /*数组8: 远程请求报警上传、报警输出*/ + /*数组9: 远程控制,本地输出*/ + /*数组10: 远程控制串口*/ + public int dwNetPreviewRight; /* 远程可以预览的通道 bit0 -- channel 1*/ + public int dwNetPlaybackRight; /* 远程可以回放的通道 bit0 -- channel 1*/ + public byte[] sUserIP = new byte[16]; /* 用户IP地址(为0时表示允许任何地址) */ + public byte[] byMACAddr = new byte[MACADDR_LEN]; /* 物理地址 */ + } + + public static class NET_DVR_USER_INFO extends Structure {//单用户参数(子结构) + public byte[] sUserName = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public int[] dwLocalRight = new int[MAX_RIGHT]; /* 权限 */ + /*数组0: 本地控制云台*/ + /*数组1: 本地手动录象*/ + /*数组2: 本地回放*/ + /*数组3: 本地设置参数*/ + /*数组4: 本地查看状态、日志*/ + /*数组5: 本地高级操作(升级,格式化,重启,关机)*/ + public int[] dwRemoteRight = new int[MAX_RIGHT]; /* 权限 */ + /*数组0: 远程控制云台*/ + /*数组1: 远程手动录象*/ + /*数组2: 远程回放 */ + /*数组3: 远程设置参数*/ + /*数组4: 远程查看状态、日志*/ + /*数组5: 远程高级操作(升级,格式化,重启,关机)*/ + /*数组6: 远程发起语音对讲*/ + /*数组7: 远程预览*/ + /*数组8: 远程请求报警上传、报警输出*/ + /*数组9: 远程控制,本地输出*/ + /*数组10: 远程控制串口*/ + public byte[] sUserIP = new byte[16]; /* 用户IP地址(为0时表示允许任何地址) */ + public byte[] byMACAddr = new byte[MACADDR_LEN]; /* 物理地址 */ + } + + public static class NET_DVR_USER_V30 extends Structure {//DVR用户参数(9000扩展) + public int dwSize; + public NET_DVR_USER_INFO_V30[] struUser = new NET_DVR_USER_INFO_V30[MAX_USERNUM_V30]; + } + + public static class NET_DVR_USER_EX extends Structure {//DVR用户参数(SDK_V15扩展) + public int dwSize; + public NET_DVR_USER_INFO_EX[] struUser = new NET_DVR_USER_INFO_EX[MAX_USERNUM]; + } + + public static class NET_DVR_USER extends Structure {//DVR用户参数 + public int dwSize; + public NET_DVR_USER_INFO[] struUser = new NET_DVR_USER_INFO[MAX_USERNUM]; + } + + public static class NET_DVR_EXCEPTION_V30 extends Structure {//DVR异常参数(9000扩展) + public int dwSize; + public NET_DVR_HANDLEEXCEPTION_V30[] struExceptionHandleType = new NET_DVR_HANDLEEXCEPTION_V30[MAX_EXCEPTIONNUM_V30]; + /*数组0-盘满,1- 硬盘出错,2-网线断,3-局域网内IP 地址冲突,4-非法访问, 5-输入/输出视频制式不匹配, 6-行车超速(车载专用), 7-视频信号异常(9000)*/ + } + + public static class NET_DVR_EXCEPTION extends Structure {//DVR异常参数 + public int dwSize; + public NET_DVR_HANDLEEXCEPTION[] struExceptionHandleType = new NET_DVR_HANDLEEXCEPTION[MAX_EXCEPTIONNUM]; + /*数组0-盘满,1- 硬盘出错,2-网线断,3-局域网内IP 地址冲突,4-非法访问, 5-输入/输出视频制式不匹配, 6-行车超速(车载专用)*/ + } + + public static class NET_DVR_CHANNELSTATE_V30 extends Structure {//通道状态(9000扩展) + public byte byRecordStatic; //通道是否在录像,0-不录像,1-录像 + public byte bySignalStatic; //连接的信号状态,0-正常,1-信号丢失 + public byte byHardwareStatic;//通道硬件状态,0-正常,1-异常,例如DSP死掉 + public byte byRes1; //保留 + public int dwBitRate;//实际码率 + public int dwLinkNum;//客户端连接的个数 + public NET_DVR_IPADDR[] struClientIP = new NET_DVR_IPADDR[MAX_LINK];//客户端的IP地址 + public int dwIPLinkNum;//如果该通道为IP接入,那么表示IP接入当前的连接数 + public byte byExceedMaxLink; // 是否超出了单路6路连接数 0 - 未超出, 1-超出 + public byte[] byRes = new byte[3]; // 保留字节 + public int dwAllBitRate; //所有实际码率之和 + public int dwChannelNo; //当前的通道号,0xffffffff表示无效 + } + + public static class NET_DVR_CHANNELSTATE extends Structure {//通道状态 + public byte byRecordStatic; //通道是否在录像,0-不录像,1-录像 + public byte bySignalStatic; //连接的信号状态,0-正常,1-信号丢失 + public byte byHardwareStatic;//通道硬件状态,0-正常,1-异常,例如DSP死掉 + public byte reservedData; //保留 + public int dwBitRate;//实际码率 + public int dwLinkNum;//客户端连接的个数 + public int[] dwClientIP = new int[MAX_LINK];//客户端的IP地址 + } + + public static class NET_DVR_DISKSTATE extends Structure {//硬盘状态 + public int dwVolume;//硬盘的容量 + public int dwFreeSpace;//硬盘的剩余空间 + public int dwHardDiskStatic; //硬盘的状态,按位:1-休眠,2-不正常,3-休眠硬盘出错 + } + + public static class NET_DVR_WORKSTATE_V30 extends Structure {//DVR工作状态(9000扩展) + public int dwDeviceStatic; //设备的状态,0-正常,1-CPU占用率太高,超过85%,2-硬件错误,例如串口死掉 + public NET_DVR_DISKSTATE[] struHardDiskStatic = new NET_DVR_DISKSTATE[MAX_DISKNUM_V30]; + public NET_DVR_CHANNELSTATE_V30[] struChanStatic = new NET_DVR_CHANNELSTATE_V30[MAX_CHANNUM_V30];//通道的状态 + public byte[] byAlarmInStatic = new byte[MAX_ALARMIN_V30]; //报警端口的状态,0-没有报警,1-有报警 + public byte[] byAlarmOutStatic = new byte[MAX_ALARMOUT_V30]; //报警输出端口的状态,0-没有输出,1-有报警输出 + public int dwLocalDisplay;//本地显示状态,0-正常,1-不正常 + public byte[] byAudioChanStatus = new byte[MAX_AUDIO_V30];//表示语音通道的状态 0-未使用,1-使用中, 0xff无效 + public byte[] byRes = new byte[10]; + } + + public static class NET_DVR_WORKSTATE extends Structure {//DVR工作状态 + public int dwDeviceStatic; //设备的状态,0-正常,1-CPU占用率太高,超过85%,2-硬件错误,例如串口死掉 + public NET_DVR_DISKSTATE[] struHardDiskStatic = new NET_DVR_DISKSTATE[MAX_DISKNUM]; + public NET_DVR_CHANNELSTATE[] struChanStatic = new NET_DVR_CHANNELSTATE[MAX_CHANNUM];//通道的状态 + public byte[] byAlarmInStatic = new byte[MAX_ALARMIN]; //报警端口的状态,0-没有报警,1-有报警 + public byte[] byAlarmOutStatic = new byte[MAX_ALARMOUT]; //报警输出端口的状态,0-没有输出,1-有报警输出 + public int dwLocalDisplay;//本地显示状态,0-正常,1-不正常 + } + + public static class NET_DVR_LOG_V30 extends Structure {//日志信息(9000扩展) + public NET_DVR_TIME strLogTime; + public int dwMajorType; //主类型 1-报警; 2-异常; 3-操作; 0xff-全部 + public int dwMinorType;//次类型 0-全部; + public byte[] sPanelUser = new byte[MAX_NAMELEN]; //操作面板的用户名 + public byte[] sNetUser = new byte[MAX_NAMELEN];//网络操作的用户名 + public NET_DVR_IPADDR struRemoteHostAddr;//??程主机地址 + public int dwParaType;//参数类型 + public int dwChannel;//通道号 + public int dwDiskNumber;//硬盘号 + public int dwAlarmInPort;//报警输入端口 + public int dwAlarmOutPort;//报警输出端口 + public int dwInfoLen; + public byte[] sInfo = new byte[LOG_INFO_LEN]; + } + + //日志信息 + public static class NET_DVR_LOG extends Structure { + public NET_DVR_TIME strLogTime; + public int dwMajorType; //主类型 1-报警; 2-异常; 3-操作; 0xff-全部 + public int dwMinorType;//次类型 0-全部; + public byte[] sPanelUser = new byte[MAX_NAMELEN]; //操作面板的用户名 + public byte[] sNetUser = new byte[MAX_NAMELEN];//网络操作的用户名 + public byte[] sRemoteHostAddr = new byte[16];//远程主机地址 + public int dwParaType;//参数类型 + public int dwChannel;//通道号 + public int dwDiskNumber;//硬盘号 + public int dwAlarmInPort;//报警输入端口 + public int dwAlarmOutPort;//报警输出端口 + } + + /************************ + * DVR日志 end + ***************************/ + public static class NET_DVR_ALARMOUTSTATUS_V30 extends Structure {//报警输出状态(9000扩展) + public byte[] Output = new byte[MAX_ALARMOUT_V30]; + } + + public static class NET_DVR_ALARMOUTSTATUS extends Structure {//报警输出状态 + public byte[] Output = new byte[MAX_ALARMOUT]; + } + + public static class NET_DVR_TRADEINFO extends Structure {//交易信息 + public short m_Year; + public short m_Month; + public short m_Day; + public short m_Hour; + public short m_Minute; + public short m_Second; + public byte[] DeviceName = new byte[24]; //设备名称 + public int dwChannelNumer; //通道号 + public byte[] CardNumber = new byte[32]; //卡号 + public byte[] cTradeType = new byte[12]; //交易类型 + public int dwCash; //交易金额 + } + + public static class NET_DVR_FRAMETYPECODE extends Structure {/*帧格式*/ + public byte[] code = new byte[12]; /* 代码 */ + } + + public static class NET_DVR_FRAMEFORMAT_V30 extends Structure {//ATM参数(9000扩展) + public int dwSize; + public NET_DVR_IPADDR struATMIP; /* ATM IP地址 */ + public int dwATMType; /* ATM类型 */ + public int dwInputMode; /* 输入方式 0-网络侦听 1-网络接收 2-串口直接输入 3-串口ATM命令输入*/ + public int dwFrameSignBeginPos; /* 报文标志位的起始位置*/ + public int dwFrameSignLength; /* 报文标志位的长度 */ + public byte[] byFrameSignContent = new byte[12]; /* 报文标志位的内容 */ + public int dwCardLengthInfoBeginPos; /* 卡号长度信息的起始位置 */ + public int dwCardLengthInfoLength; /* 卡号长度信息的长度 */ + public int dwCardNumberInfoBeginPos; /* 卡号信息的起始位置 */ + public int dwCardNumberInfoLength; /* 卡号信息的长度 */ + public int dwBusinessTypeBeginPos; /* 交易类型的起始位置 */ + public int dwBusinessTypeLength; /* 交易类型的长度 */ + public NET_DVR_FRAMETYPECODE[] frameTypeCode = new NET_DVR_FRAMETYPECODE[10]; /* 类型 */ + public short wATMPort; /* 卡号捕捉端口号(网络协议方式) (保留)0xffff表示该值无效*/ + public short wProtocolType; /* 网络协议类型(保留) 0xffff表示该值无效*/ + public byte[] byRes = new byte[24]; + } + + public static class NET_DVR_FRAMEFORMAT extends Structure {//ATM参数 + public int dwSize; + public byte[] sATMIP = new byte[16]; /* ATM IP地址 */ + public int dwATMType; /* ATM类型 */ + public int dwInputMode; /* 输入方式 0-网络侦听 1-网络接收 2-串口直接输入 3-串口ATM命令输入*/ + public int dwFrameSignBeginPos; /* 报文标志位的起始位置*/ + public int dwFrameSignLength; /* 报文标志位的长度 */ + public byte[] byFrameSignContent = new byte[12]; /* 报文标志位的内容 */ + public int dwCardLengthInfoBeginPos; /* 卡号长度信息的起始位置 */ + public int dwCardLengthInfoLength; /* 卡号长度信息的长度 */ + public int dwCardNumberInfoBeginPos; /* 卡号信息的起始位置 */ + public int dwCardNumberInfoLength; /* 卡号信息的长度 */ + public int dwBusinessTypeBeginPos; /* 交易类型的起始位置 */ + public int dwBusinessTypeLength; /* 交易类型的长度 */ + public NET_DVR_FRAMETYPECODE[] frameTypeCode = new NET_DVR_FRAMETYPECODE[10];/* 类型 */ + } + + public static class NET_DVR_FTPTYPECODE extends Structure { + public byte[] sFtpType = new byte[32]; /*客户定义的操作类型*/ + public byte[] sFtpCode = new byte[8]; /*客户定义的操作类型的对应的码*/ + } + + public static class NET_DVR_FRAMEFORMAT_EX extends Structure {//ATM参数添加FTP上传参数, 俄罗斯银行定制, 2006-11-17 + public int dwSize; + public byte[] sATMIP = new byte[16]; /* ATM IP地址 */ + public int dwATMType; /* ATM类型 */ + public int dwInputMode; /* 输入方式 0-网络侦听 1-网络接收 2-串口直接输入 3-串口ATM命令输入*/ + public int dwFrameSignBeginPos; /* 报文标志位的起始位置*/ + public int dwFrameSignLength; /* 报文标志位的长度 */ + public byte[] byFrameSignContent = new byte[12]; /* 报文标志位的内容 */ + public int dwCardLengthInfoBeginPos; /* 卡号长度信息的起始位置 */ + public int dwCardLengthInfoLength; /* 卡号长度信息的长度 */ + public int dwCardNumberInfoBeginPos; /* 卡号信息的起始位置 */ + public int dwCardNumberInfoLength; /* 卡号信息的长度 */ + public int dwBusinessTypeBeginPos; /* 交易类型的起始位置 */ + public int dwBusinessTypeLength; /* 交易类型的长度 */ + public NET_DVR_FRAMETYPECODE[] frameTypeCode = new NET_DVR_FRAMETYPECODE[10];/* 类型 */ + public byte[] sFTPIP = new byte[16]; /* FTP IP */ + public byte[] byFtpUsername = new byte[NAME_LEN]; /* 用户名 */ + public byte[] byFtpPasswd = new byte[PASSWD_LEN]; /* 密码 */ + public byte[] sDirName = new byte[NAME_LEN]; /*服务器目录名*/ + public int dwATMSrvType; /*ATM服务器类型,0--wincor ,1--diebold*/ + public int dwTimeSpace; /*取值为1.2.3.4.5.10*/ + public NET_DVR_FTPTYPECODE[] sFtpTypeCodeOp = new NET_DVR_FTPTYPECODE[300]; /*新加的*/ + public int dwADPlay; /* 1 表示在播放广告,0 表示没有播放广告*/ + public int dwNewPort; //端口 + } +/****************************ATM(end)***************************/ + + /***************************** + * DS-6001D/F(begin) + ***************************/ +//DS-6001D Decoder + public static class NET_DVR_DECODERINFO extends Structure { + public byte[] byEncoderIP = new byte[16]; //解码设备连接的服务器IP + public byte[] byEncoderUser = new byte[16]; //解码设备连接的服务器的用户名 + public byte[] byEncoderPasswd = new byte[16]; //解码设备连接的服务器的密码 + public byte bySendMode; //解码设备连接服务器的连接模式 + public byte byEncoderChannel; //解码设备连接的服务器的通道号 + public short wEncoderPort; //解码设备连接的服务器的端口号 + public byte[] reservedData = new byte[4]; //保留 + } + + public static class NET_DVR_DECODERSTATE extends Structure { + public byte[] byEncoderIP = new byte[16]; //解码设备连接的服务器IP + public byte[] byEncoderUser = new byte[16]; //解码设备连接的服务器的用户名 + public byte[] byEncoderPasswd = new byte[16]; //解码设备连接的服务器的密码 + public byte byEncoderChannel; //解码设备连接的服务器的通道号 + public byte bySendMode; //解码设备连接的服务器的连接模式 + public short wEncoderPort; //解码设备连接的服务器的端口号 + public int dwConnectState; //解码设备连接服务器的状态 + public byte[] reservedData = new byte[4]; //保留 + } + + public static class NET_DVR_DECCHANINFO extends Structure { + public byte[] sDVRIP = new byte[16]; /* DVR IP地址 */ + public short wDVRPort; /* 端口号 */ + public byte[] sUserName = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public byte byChannel; /* 通道号 */ + public byte byLinkMode; /* 连接模式 */ + public byte byLinkType; /* 连接类型 0-主码流 1-子码流 */ + } + + public static class NET_DVR_DECINFO extends Structure {/*每个解码通道的配置*/ + public byte byPoolChans; /*每路解码通道上的循环通道数量, 最多4通道 0表示没有解码*/ + public NET_DVR_DECCHANINFO[] struchanConInfo = new NET_DVR_DECCHANINFO[MAX_DECPOOLNUM]; + public byte byEnablePoll; /*是否轮巡 0-否 1-是*/ + public byte byPoolTime; /*轮巡时间 0-保留 1-10秒 2-15秒 3-20秒 4-30秒 5-45秒 6-1分钟 7-2分钟 8-5分钟 */ + } + + public static class NET_DVR_DECCFG extends Structure {/*整个设备解码配置*/ + public int dwSize; + public int dwDecChanNum; /*解码通道的数量*/ + public NET_DVR_DECINFO[] struDecInfo = new NET_DVR_DECINFO[MAX_DECNUM]; + } + + //2005-08-01 + public static class NET_DVR_PORTINFO extends Structure {/* 解码设备透明通道设置 */ + public int dwEnableTransPort; /* 是否启动透明通道 0-不启用 1-启用*/ + public byte[] sDecoderIP = new byte[16]; /* DVR IP地址 */ + public short wDecoderPort; /* 端口号 */ + public short wDVRTransPort; /* 配置前端DVR是从485/232输出,1表示232串口,2表示485串口 */ + public byte[] cReserve = new byte[4]; + } + + public static class NET_DVR_PORTCFG extends Structure { + public int dwSize; + public NET_DVR_PORTINFO[] struTransPortInfo = new NET_DVR_PORTINFO[MAX_TRANSPARENTNUM]; /* 数组0表示232 数组1表示485 */ + } + + /*https://jna.dev.java.net/javadoc/com/sun/jna/Union.html#setType(java.lang.Class) see how to use the JNA Union*/ + public static class NET_DVR_PLAYREMOTEFILE extends Structure {/* 控制网络文件回放 */ + public int dwSize; + public byte[] sDecoderIP = new byte[16]; /* DVR IP地址 */ + public short wDecoderPort; /* 端口号 */ + public short wLoadMode; /* 回放下载模式 1-按名字 2-按时间 */ + public byte[] byFile = new byte[100]; + + public static class mode_size extends Union { + public byte[] byFile = new byte[100]; // 回放的文件名 + + public static class bytime extends Structure { + public int dwChannel; + public byte[] sUserName = new byte[NAME_LEN]; //请求视频用户名 + public byte[] sPassword = new byte[PASSWD_LEN]; // 密码 + public NET_DVR_TIME struStartTime; //按时间回放的开始时间 + public NET_DVR_TIME struStopTime; // 按时间回放的结束时间 + } + } + } + + public static class NET_DVR_DECCHANSTATUS extends Structure {/*当前设备解码连接状态*/ + public int dwWorkType; /*工作方式:1:轮巡、2:动态连接解码、3:文件回放下载 4:按时间回放下载*/ + public byte[] sDVRIP = new byte[16]; /*连接的设备ip*/ + public short wDVRPort; /*连接端口号*/ + public byte byChannel; /* 通道号 */ + public byte byLinkMode; /* 连接模式 */ + public int dwLinkType; /*连接类型 0-主码流 1-子码流*/ + public byte[] sUserName = new byte[NAME_LEN]; /*请求视频用户名*/ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public byte[] cReserve = new byte[52]; + + public static class objectInfo extends Union { + public static class userInfo extends Structure { + public byte[] sUserName = new byte[NAME_LEN]; //请求视频用户名 + public byte[] sPassword = new byte[PASSWD_LEN]; // 密码 + public byte[] cReserve = new byte[52]; + } + + public static class fileInfo extends Structure { + public byte[] fileName = new byte[100]; + } + + public static class timeInfo extends Structure { + public int dwChannel; + public byte[] sUserName = new byte[NAME_LEN]; //请求视频用户名 + public byte[] sPassword = new byte[PASSWD_LEN]; // 密码 + public NET_DVR_TIME struStartTime; // 按时间回放的开始时间 + public NET_DVR_TIME struStopTime; //按时间回放的结束时间 + } + } + } + + public static class NET_DVR_DECSTATUS extends Structure { + public int dwSize; + public NET_DVR_DECCHANSTATUS[] struDecState = new NET_DVR_DECCHANSTATUS[MAX_DECNUM]; + } + + /***************************** + * DS-6001D/F(end) + ***************************/ + + public static class NET_DVR_SHOWSTRINGINFO extends Structure {//单字符参数(子结构) + public short wShowString; // 预览的图象上是否显示字符,0-不显示,1-显示 区域大小704*576,单个字符的大小为32*32 + public short wStringSize; /* 该行字符的长度,不能大于44个字符 */ + public short wShowStringTopLeftX; /* 字符显示位置的x坐标 */ + public short wShowStringTopLeftY; /* 字符名称显示位置的y坐标 */ + public byte[] sString = new byte[44]; /* 要显示的字符内容 */ + } + + //叠加字符(9000扩展) + public static class NET_DVR_SHOWSTRING_V30 extends Structure { + public int dwSize; + public NET_DVR_SHOWSTRINGINFO[] struStringInfo = new NET_DVR_SHOWSTRINGINFO[MAX_STRINGNUM_V30]; /* 要显示的字符内容 */ + } + + //叠加字符扩展(8条字符) + public static class NET_DVR_SHOWSTRING_EX extends Structure { + public int dwSize; + public NET_DVR_SHOWSTRINGINFO[] struStringInfo = new NET_DVR_SHOWSTRINGINFO[MAX_STRINGNUM_EX]; /* 要显示的字符内容 */ + } + + //叠加字符 + public static class NET_DVR_SHOWSTRING extends Structure { + public int dwSize; + public NET_DVR_SHOWSTRINGINFO[] struStringInfo = new NET_DVR_SHOWSTRINGINFO[MAX_STRINGNUM]; /* 要显示的字符内容 */ + } + + /**************************** + * DS9000新增结构(begin) + ******************************/ + +/* +EMAIL参数结构 +*/ + public static class NET_DVR_SENDER extends Structure { + public byte[] sName = new byte[NAME_LEN]; /* 发件人姓名 */ + public byte[] sAddress = new byte[MAX_EMAIL_ADDR_LEN]; /* 发件人地址 */ + } + + public static class NET_DVRRECEIVER extends Structure { + public byte[] sName = new byte[NAME_LEN]; /* 收件人姓名 */ + public byte[] sAddress = new byte[MAX_EMAIL_ADDR_LEN]; /* 收件人地址 */ + } + + public static class NET_DVR_EMAILCFG_V30 extends Structure { + public int dwSize; + public byte[] sAccount = new byte[NAME_LEN]; /* 账号*/ + public byte[] sPassword = new byte[MAX_EMAIL_PWD_LEN]; /*密码 */ + public NET_DVR_SENDER struSender; + public byte[] sSmtpServer = new byte[MAX_EMAIL_ADDR_LEN]; /* smtp服务器 */ + public byte[] sPop3Server = new byte[MAX_EMAIL_ADDR_LEN]; /* pop3服务器 */ + public NET_DVRRECEIVER[] struReceiver = new NET_DVRRECEIVER[3]; /* 最多可以设置3个收件人 */ + public byte byAttachment; /* 是否带附件 */ + public byte bySmtpServerVerify; /* 发送服务器要求身份验证 */ + public byte byMailInterval; /* mail interval */ + public byte[] res = new byte[77]; + } + + /* +DVR实现巡航数据结构 +*/ + public static class NET_DVR_CRUISE_PARA extends Structure { + public int dwSize; + public byte[] byPresetNo = new byte[CRUISE_MAX_PRESET_NUMS]; /* 预置点号 */ + public byte[] byCruiseSpeed = new byte[CRUISE_MAX_PRESET_NUMS]; /* 巡航速度 */ + public short[] wDwellTime = new short[CRUISE_MAX_PRESET_NUMS]; /* 停留时间 */ + public byte[] byEnableThisCruise; /* 是否启用 */ + public byte[] res = new byte[15]; + } + + /**************************** + * DS9000新增结构(end) + ******************************/ + +//时间点 + public static class NET_DVR_TIMEPOINT extends Structure { + public int dwMonth; //月 0-11表示1-12个月 + public int dwWeekNo; //第几周 0-第1周 1-第2周 2-第3周 3-第4周 4-最后一周 + public int dwWeekDate; //星期几 0-星期日 1-星期一 2-星期二 3-星期三 4-星期四 5-星期五 6-星期六 + public int dwHour; //小时 开始时间0-23 结束时间1-23 + public int dwMin; //分 0-59 + } + + //夏令时参数 + public static class NET_DVR_ZONEANDDST extends Structure { + public int dwSize; + public byte[] byRes1 = new byte[16]; //保留 + public int dwEnableDST; //是否启用夏时制 0-不启用 1-启用 + public byte byDSTBias; //夏令时偏移值,30min, 60min, 90min, 120min, 以分钟计,传递原始数值 + public byte[] byRes2 = new byte[3]; + public NET_DVR_TIMEPOINT struBeginPoint; //夏时制开始时间 + public NET_DVR_TIMEPOINT struEndPoint; //夏时制停止时间 + } + + //图片质量 + public static class NET_DVR_JPEGPARA extends Structure { + /*注意:当图像压缩分辨率为VGA时,支持0=CIF, 1=QCIF, 2=D1抓图, + 当分辨率为3=UXGA(1600x1200), 4=SVGA(800x600), 5=HD720p(1280x720),6=VGA,7=XVGA, 8=HD900p + 仅支持当前分辨率的抓图*/ + public short wPicSize; /* 0=CIF, 1=QCIF, 2=D1 3=UXGA(1600x1200), 4=SVGA(800x600), 5=HD720p(1280x720),6=VGA*/ + public short wPicQuality; /* 图片质量系数 0-最好 1-较好 2-一般 */ + } + + /* aux video out parameter */ +//辅助输出参数配置 + public static class NET_DVR_AUXOUTCFG extends Structure { + public int dwSize; + public int dwAlarmOutChan; /* 选择报警弹出大报警通道切换时间:1画面的输出通道: 0:主输出/1:辅1/2:辅2/3:辅3/4:辅4 */ + public int dwAlarmChanSwitchTime; /* :1秒 - 10:10秒 */ + public int[] dwAuxSwitchTime = new int[MAX_AUXOUT]; /* 辅助输出切换时间: 0-不切换,1-5s,2-10s,3-20s,4-30s,5-60s,6-120s,7-300s */ + public byte[][] byAuxOrder = new byte[MAX_AUXOUT][MAX_WINDOW]; /* 辅助输出预览顺序, 0xff表示相应的窗口不预览 */ + } + + //ntp + public static class NET_DVR_NTPPARA extends Structure { + public byte[] sNTPServer = new byte[64]; /* Domain Name or IP addr of NTP server */ + public short wInterval; /* adjust time interval(hours) */ + public byte byEnableNTP; /* enable NPT client 0-no,1-yes*/ + public byte cTimeDifferenceH; /* 与国际标准时间的 小时偏移-12 ... +13 */ + public byte cTimeDifferenceM;/* 与国际标准时间的 分钟偏移0, 30, 45*/ + public byte res1; + public short wNtpPort; /* ntp server port 9000新增 设备默认为123*/ + public byte[] res2 = new byte[8]; + } + + //ddns + public static class NET_DVR_DDNSPARA extends Structure { + public byte[] sUsername = new byte[NAME_LEN]; /* DDNS账号用户名/密码 */ + public byte[] sPassword = new byte[PASSWD_LEN]; + public byte[] sDomainName = new byte[64]; /* 域名 */ + public byte byEnableDDNS; /*是否应用 0-否,1-是*/ + public byte[] res = new byte[15]; + } + + public static class NET_DVR_DDNSPARA_EX extends Structure { + public byte byHostIndex; /* 0-Hikvision DNS 1-Dyndns 2-PeanutHull(花生壳), 3-希网3322*/ + public byte byEnableDDNS; /*是否应用DDNS 0-否,1-是*/ + public short wDDNSPort; /* DDNS端口号 */ + public byte[] sUsername = new byte[NAME_LEN]; /* DDNS用户名*/ + public byte[] sPassword = new byte[PASSWD_LEN]; /* DDNS密码 */ + public byte[] sDomainName = new byte[MAX_DOMAIN_NAME]; /* 设备配备的域名地址 */ + public byte[] sServerName = new byte[MAX_DOMAIN_NAME]; /* DDNS 对应的服务器地址,可以是IP地址或域名 */ + public byte[] byRes = new byte[16]; + } + + public static class NET_DVR_DDNS extends Structure { + public byte[] sUsername = new byte[NAME_LEN]; /* DDNS账号用户名*/ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public byte[] sDomainName = new byte[MAX_DOMAIN_NAME]; /* 设备配备的域名地址 */ + public byte[] sServerName = new byte[MAX_DOMAIN_NAME]; /* DDNS协议对应的服务器地址,可以是IP地址或域名 */ + public short wDDNSPort; /* 端口号 */ + public byte[] byRes = new byte[10]; + } + + //9000扩展 + public static class NET_DVR_DDNSPARA_V30 extends Structure { + public byte byEnableDDNS; + public byte byHostIndex;/* 0-Hikvision DNS(保留) 1-Dyndns 2-PeanutHull(花生壳) 3-希网3322 */ + public byte[] byRes1 = new byte[2]; + public NET_DVR_DDNS[] struDDNS = new NET_DVR_DDNS[MAX_DDNS_NUMS];//9000目前只支持前3个配置,其他配置保留 + public byte[] byRes2 = new byte[16]; + } + + //email + public static class NET_DVR_EMAILPARA extends Structure { + public byte[] sUsername = new byte[64]; /* 邮件账号/密码 */ + public byte[] sPassword = new byte[64]; + public byte[] sSmtpServer = new byte[64]; + public byte[] sPop3Server = new byte[64]; + public byte[] sMailAddr = new byte[64]; /* email */ + public byte[] sEventMailAddr1 = new byte[64]; /* 上传报警/异常等的email */ + public byte[] sEventMailAddr2 = new byte[64]; + public byte[] res = new byte[16]; + } + + public static class NET_DVR_NETAPPCFG extends Structure {//网络参数配置 + public int dwSize; + public byte[] sDNSIp = new byte[16]; /* DNS服务器地址 */ + public NET_DVR_NTPPARA struNtpClientParam; /* NTP参数 */ + public NET_DVR_DDNSPARA struDDNSClientParam; /* DDNS参数 */ + //NET_DVR_EMAILPARA struEmailParam; /* EMAIL参数 */ + public byte[] res = new byte[464]; /* 保留 */ + } + + public static class NET_DVR_SINGLE_NFS extends Structure {//nfs结构配置 + public byte[] sNfsHostIPAddr = new byte[16]; + public byte[] sNfsDirectory = new byte[PATHNAME_LEN]; // PATHNAME_LEN = 128 + } + + public static class NET_DVR_NFSCFG extends Structure { + public int dwSize; + public NET_DVR_SINGLE_NFS[] struNfsDiskParam = new NET_DVR_SINGLE_NFS[MAX_NFS_DISK]; + } + + //巡航点配置(HIK IP快球专用) + public static class NET_DVR_CRUISE_POINT extends Structure { + public byte PresetNum; //预置点 + public byte Dwell; //停留时间 + public byte Speed; //速度 + public byte Reserve; //保留 + } + + public static class NET_DVR_CRUISE_RET extends Structure { + public NET_DVR_CRUISE_POINT[] struCruisePoint = new NET_DVR_CRUISE_POINT[32]; //最大支持32个巡航点 + } + + /************************************ + * 多路解码器(begin) + ***************************************/ +//多路解码器扩展 added by zxy 2007-05-23 + public static class NET_DVR_NETCFG_OTHER extends Structure { + public int dwSize; + public byte[] sFirstDNSIP = new byte[16]; + public byte[] sSecondDNSIP = new byte[16]; + public byte[] sRes = new byte[32]; + } + + public static class NET_DVR_MATRIX_DECINFO extends Structure { + public byte[] sDVRIP = new byte[16]; /* DVR IP地址 */ + public short wDVRPort; /* 端口号 */ + public byte byChannel; /* 通道号 */ + public byte byTransProtocol; /* 传输协议类型 0-TCP 1-UDP */ + public byte byTransMode; /* 传输码流模式 0-主码流 1-子码流*/ + public byte[] byRes = new byte[3]; + public byte[] sUserName = new byte[NAME_LEN]; /* 监控主机登陆帐号 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 监控主机密码 */ + } + + public static class NET_DVR_MATRIX_DYNAMIC_DEC extends Structure {//启动/停止动态解码 + public int dwSize; + public NET_DVR_MATRIX_DECINFO struDecChanInfo; /* 动态解码通道信息 */ + } + + public static class NET_DVR_MATRIX_DEC_CHAN_STATUS extends Structure {//2007-12-13 modified by zxy 修改多路解码器的NET_DVR_MATRIX_DEC_CHAN_STATUS结构 + public int dwSize;//2008-1-16 modified by zxy dwIsLinked的状态由原来的0-未链接 1-连接修改成以下三种状态。 + public int dwIsLinked; /* 解码通道状态 0-休眠 1-正在连接 2-已连接 3-正在解码 */ + public int dwStreamCpRate; /* Stream copy rate, X kbits/second */ + public byte[] cRes = new byte[64]; /* 保留 */ + } +//end 2007-12-13 modified by zxy + + public static class NET_DVR_MATRIX_DEC_CHAN_INFO extends Structure { + public int dwSize; + public NET_DVR_MATRIX_DECINFO struDecChanInfo; /* 解码通道信息 */ + public int dwDecState; /* 0-动态解码 1-循环解码 2-按时间回放 3-按文件回放 */ + public NET_DVR_TIME StartTime; /* 按时间回放开始时间 */ + public NET_DVR_TIME StopTime; /* 按时间回放停止时间 */ + public byte[] sFileName = new byte[128]; /* 按文件回放文件名 */ + } + + //连接的通道配置 2007-11-05 + public static class NET_DVR_MATRIX_DECCHANINFO extends Structure { + public int dwEnable; /* 是否启用 0-否 1-启用*/ + public NET_DVR_MATRIX_DECINFO struDecChanInfo; /* 轮循解码通道信息 */ + } + + //2007-11-05 新增每个解码通道的配置 + public static class NET_DVR_MATRIX_LOOP_DECINFO extends Structure { + public int dwSize; + public int dwPoolTime; /*轮巡时间 */ + public NET_DVR_MATRIX_DECCHANINFO[] struchanConInfo = new NET_DVR_MATRIX_DECCHANINFO[MAX_CYCLE_CHAN]; + } + + //2007-05-25 多路解码器数字矩阵配置 +//矩阵行信息 2007-12-28 + public static class NET_DVR_MATRIX_ROW_ELEMENT extends Structure { + public byte[] sSurvChanName = new byte[128]; /* 监控通道名称,支持中文 */ + public int dwRowNum; /* 行号 */ + public NET_DVR_MATRIX_DECINFO struDecChanInfo; /* 矩阵行信息 */ + } + + public static class NET_DVR_MATRIX_ROW_INDEX extends Structure { + public byte[] sSurvChanName = new byte[128]; /* 监控通道名称,支持中文 */ + public int dwRowNum; /* 行号 */ + } + + //矩阵列信息 2007-12-28 + public static class NET_DVR_MATRIX_COLUMN_ELEMENT extends Structure { + public int dwLocalDispChanNum; /* 本地显示通道号 */ + public int dwGlobalDispChanNum; /* 全局显示通道号 */ + public int dwRes; /* 保留 */ + } + + public static class NET_DVR_MATRIX_GLOBAL_COLUMN_ELEMENT extends Structure { + public int dwConflictTag; /* 冲突标记,0:无冲突,1:冲突 */ + public int dwConflictGloDispChan; /* 与之冲突的全局通道号 */ + public NET_DVR_MATRIX_COLUMN_ELEMENT struColumnInfo;/* 矩阵列元素结构体 */ + } + + //手动查看 2007-12-28 + public static class NET_DVR_MATRIX_ROW_COLUMN_LINK extends Structure { + public int dwSize; + /* + * 以下三个参数只需要指定其中一个便可指定数字矩阵里的某一行 + * 所代表的远程监控通道。 + * 如果指定了多个域并有冲突,设备将按照域的先后顺序为准取最先定义者。 + */ + public int dwRowNum; /* -1代表无效域,大于0者方为有效的矩阵行号 */ + public byte[] sSurvChanName = new byte[128]; /* 监控通道名,是否无效按字符串的有效性判断 */ + public int dwSurvNum; /* 监控通道号,按矩阵行列表的顺序指定,一般情况下与行号一致 */ + /* + * 以下两项只需要指定其中一项便可,如果两项都有效默认选择第一项 + */ + public int dwGlobalDispChanNum; /* 电视墙上的电视机编号 */ + public int dwLocalDispChanNum; + /* + * 0代表播放即时码流, + * 1表示按时间回访远程监控设备的文件 + * 2表示按文件名回访 + */ + public int dwTimeSel; + public NET_DVR_TIME StartTime; + public NET_DVR_TIME StopTime; + public byte[] sFileName = new byte[128]; + } + + public static class NET_DVR_MATRIX_PREVIEW_DISP_CHAN extends Structure { + public int dwSize; + public int dwGlobalDispChanNum; /* 电视墙上的电视机编号 */ + public int dwLocalDispChanNum; /* 解码通道 */ + } + + public static class NET_DVR_MATRIX_LOOP_PLAY_SET extends Structure {//轮循功能 2007-12-28 + public int dwSize; + /* 任意指定一个,-1为无效,如果都指定则以LocalDispChanNum为准 */ + public int dwLocalDispChanNum; /* 解码通道 */ + public int dwGlobalDispChanNum; /* 电视墙上的电视机编号 */ + public int dwCycTimeInterval; /* 轮循时间间隔 */ + } + + public static class NET_DVR_MATRIX_LOCAL_HOST_INFO extends Structure {//矩阵中心配置 2007-12-28 + public int dwSize; + public int dwLocalHostProperty; /* 本地主机类型 0-服务器 1-客户端*/ + public int dwIsIsolated; /* 本地主机是否独立于系统,0:联网,1:独立 */ + public int dwLocalMatrixHostPort; /* 本地主机访问端口 */ + public byte[] byLocalMatrixHostUsrName = new byte[NAME_LEN]; /* 本地主机登录用户名 */ + public byte[] byLocalMatrixHostPasswd = new byte[PASSWD_LEN]; /* 本地主机登录密码 */ + public int dwLocalMatrixCtrlMedia; /* 控制方式 0x1串口键盘控制 0x2网络键盘控制 0x4矩阵中心控制 0x8PC客户端控制*/ + public byte[] sMatrixCenterIP = new byte[16]; /* 矩阵中心IP地址 */ + public int dwMatrixCenterPort; /* 矩阵中心端口号 */ + public byte[] byMatrixCenterUsrName = new byte[NAME_LEN]; /* 矩阵中心登录用户名 */ + public byte[] byMatrixCenterPasswd = new byte[PASSWD_LEN]; /* 矩阵中心登录密码 */ + } + + //2007-12-22 + public static class TTY_CONFIG extends Structure { + public byte baudrate; /* 波特率 */ + public byte databits; /* 数据位 */ + public byte stopbits; /* 停止位 */ + public byte parity; /* 奇偶校验位 */ + public byte flowcontrol; /* 流控 */ + public byte[] res = new byte[3]; + } + + public static class NET_DVR_MATRIX_TRAN_CHAN_INFO extends Structure { + public byte byTranChanEnable; /* 当前透明通道是否打开 0:关闭 1:打开 */ + /* + * 多路解码器本地有1个485串口,1个232串口都可以作为透明通道,设备号分配如下: + * 0 RS485 + * 1 RS232 Console + */ + public byte byLocalSerialDevice; /* Local serial device */ + /* + * 远程串口输出还是两个,一个RS232,一个RS485 + * 1表示232串口 + * 2表示485串口 + */ + public byte byRemoteSerialDevice; /* Remote output serial device */ + public byte res1; /* 保留 */ + public byte[] sRemoteDevIP = new byte[16]; /* Remote Device IP */ + public short wRemoteDevPort; /* Remote Net Communication Port */ + public byte[] res2 = new byte[2]; /* 保留 */ + public TTY_CONFIG RemoteSerialDevCfg; + } + + public static class NET_DVR_MATRIX_TRAN_CHAN_CONFIG extends Structure { + public int dwSize; + public byte by232IsDualChan; /* 设置哪路232透明通道是全双工的 取值1到MAX_SERIAL_NUM */ + public byte by485IsDualChan; /* 设置哪路485透明通道是全双工的 取值1到MAX_SERIAL_NUM */ + public byte[] res = new byte[2]; /* 保留 */ + public NET_DVR_MATRIX_TRAN_CHAN_INFO[] struTranInfo = new NET_DVR_MATRIX_TRAN_CHAN_INFO[MAX_SERIAL_NUM];/*同时支持建立MAX_SERIAL_NUM个透明通道*/ + } + + //2007-12-24 Merry Christmas Eve... + public static class NET_DVR_MATRIX_DEC_REMOTE_PLAY extends Structure { + public int dwSize; + public byte[] sDVRIP = new byte[16]; /* DVR IP地址 */ + public short wDVRPort; /* 端口号 */ + public byte byChannel; /* 通道号 */ + public byte byReserve; + public byte[] sUserName = new byte[NAME_LEN]; /* 用户名 */ + public byte[] sPassword = new byte[PASSWD_LEN]; /* 密码 */ + public int dwPlayMode; /* 0-按文件 1-按时间*/ + public NET_DVR_TIME StartTime; + public NET_DVR_TIME StopTime; + public byte[] sFileName = new byte[128]; + } + + + public static class NET_DVR_MATRIX_DEC_REMOTE_PLAY_CONTROL extends Structure { + public int dwSize; + public int dwPlayCmd; /* 播放命令 见文件播放命令*/ + public int dwCmdParam; /* 播放命令参数 */ + } + + public static class NET_DVR_MATRIX_DEC_REMOTE_PLAY_STATUS extends Structure { + public int dwSize; + public int dwCurMediaFileLen; /* 当前播放的媒体文件长度 */ + public int dwCurMediaFilePosition; /* 当前播放文件的播放位置 */ + public int dwCurMediaFileDuration; /* 当前播放文件的总时间 */ + public int dwCurPlayTime; /* ½“前已经播放的时间 */ + public int dwCurMediaFIleFrames; /* 当前播放文件的总帧数 */ + public int dwCurDataType; /* 当前传输的数据类型,19-文件头,20-流数据, 21-播放结束标志 */ + public byte[] res = new byte[72]; + } + + public static class NET_DVR_MATRIX_PASSIVEMODE extends Structure { + public short wTransProtol; //传输协议,0-TCP, 1-UDP, 2-MCAST + public short wPassivePort; //TCP,UDP时为TCP,UDP端口, MCAST时为MCAST端口 + public NET_DVR_IPADDR struMcastIP; //TCP,UDP时无效, MCAST时为多播地址 + public byte byStreamType; //数据播放模式:1- 实时流,2- 文件流 + public byte[] res = new byte[7]; + } +/************************************多路解码器(end)***************************************/ + + + /************************************ + * 拼控(Start) + ***************************************/ + + + public static final int NET_DVR_GET_SUBWND_DECODE_OSD = 9183; //获取子窗口解码OSD信息 + public static final int NET_DVR_GET_SUBWND_DECODE_OSD_ALL = 9184; //获取所有子窗口解码OSD信息 + public static final int NET_DVR_SET_SUBWND_DECODE_OSD = 9185; //设置子窗口解码OSD信息 + public static final int NET_DVR_GET_SUBWND_DECODE_OSD_CAP = 9186; //获取子窗口解码OSD信息能力集 + public static final int NET_DVR_GET_DECODE_CHANNEL_OSD = 9187; //获取解码通道OSD信息 + public static final int NET_DVR_SET_DECODE_CHANNEL_OSD = 9188; //设置解码通道OSD信息 + + public static final int MAX_PLAN_ACTION_NUM = 32; //预案动作个数 + public static final int DAYS_A_WEEK = 7; //一周7天 + public static final int MAX_PLAN_COUNT = 16; //预案个数 + public static final int MAX_LEN_OSD_CONTENT = 256; //OSD信息最大长度 + public static final int MAX_NUM_OSD_ONE_SUBWND = 8; //单个子窗口支持的最大OSD数量 + public static final int MAX_NUM_SPLIT_WND = 64; //单个窗口支持的最大分屏窗口数量(即子窗口数量) + public static final int MAX_NUM_OSD = 8; + public static final int MAX_CYCLE_CHAN_V30 = 64; //最大轮巡通道数(扩展) + public static final int STREAM_PASSWD_LEN = 12; //码流加密密钥最大长度 + + public static class NET_DVR_VIDEO_WALL_INFO extends Structure { + public int dwSize; + //窗口号:1字节墙号+1字节保留+2字节窗口号 + public int dwWindowNo; + public int dwSceneNo;//场景号 + public int dwDestWallNo; //目的墙号 + public int dwDestSceneNo;//目的场景号 + public byte[] byRes = new byte[12]; + } + + public static class NET_DVR_SCENE_CONTROL_INFO extends Structure { + public int dwSize; + public NET_DVR_VIDEO_WALL_INFO struVideoWallInfo; //电视墙信息 + public int dwCmd; //场景控制命令,1-场景模式切换(如果要切换的是当前场景,则不进行切换),2-初始化场景(将此场景的配置清空,如果是当前场景,则同时对当前场景进行清屏操作),3-强制切换(无论是否是当前场景,强制切换),4-保存当前模式到某场景 5-删除场景 ,6-场景复制 + public byte[] byRes = new byte[4]; + } + + public static class NET_DVR_BUF_INFO extends Structure { + public Pointer pBuf; + public int nLen; + } + + public static class NET_DVR_IN_PARAM extends Structure { + public NET_DVR_BUF_INFO struCondBuf; + public NET_DVR_BUF_INFO struInParamBuf; + public int dwRecvTimeout; //接收数据超时时间,单位:ms,置0采用接口默认超时 + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_OUT_PARAM extends Structure { + public NET_DVR_BUF_INFO struOutBuf; + public Pointer lpStatusList; + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_RECTCFG_EX extends Structure { + public int dwXCoordinate; /*矩形左上角起始点X坐标*/ + public int dwYCoordinate; /*矩形左上角Y坐标*/ + public int dwWidth; /*矩形宽度*/ + public int dwHeight; /*矩形高度*/ + public byte[] byRes = new byte[4]; + + } + + public static class NET_DVR_VIDEOWALLWINDOWPOSITION extends Structure { + public int dwSize; + public byte byEnable; //窗口使能,0-不使能,1-使能 + public byte byWndOperateMode; //窗口操作模式,0-统一坐标,1-分辨率坐标 + public byte[] byRes1 = new byte[6]; + public int dwWindowNo;//窗口号 + public int dwLayerIndex;//窗口相对应的图层号,图层号到最大即置顶,置顶操作 + public NET_DVR_RECTCFG_EX struRect; //目的窗口统一坐标(相对显示墙),获取或按统一坐标设置时有效 + public NET_DVR_RECTCFG_EX struResolution; //目的窗口分辨率坐标,获取或按分辨率坐标设置有效 + public int dwXCoordinate; //LED区域左上角X坐标(统一坐标),获取或按分辨率坐标设置有效 + public int dwYCoordinate; //LED区域左上角Y坐标(统一坐标),获取或按分辨率坐标设置有效 + public byte[] byRes2 = new byte[36]; + } + + public static class VIDEOWALLWINDOWPOSITION_ARRAY extends Structure { + public NET_DVR_VIDEOWALLWINDOWPOSITION[] strVideoWinPostion; + + public VIDEOWALLWINDOWPOSITION_ARRAY(int iLen) { + strVideoWinPostion = new NET_DVR_VIDEOWALLWINDOWPOSITION[iLen]; + } + + + } + + + public static class NET_DVR_WALLWINPARAM extends Structure { + public int dwSize; + public byte byTransparency; //使能透明度,0-关,非0-开 + public byte byWinMode;//窗口分屏模式,能力集获取 + public byte byEnableSpartan;//畅显使能,0-关,1-开 + public byte byDecResource; //为窗口分配的解码资源,1-D1,2-720P,3-1080P + public byte byWndShowMode; //窗口显示模式,0-此字段不用,1-子窗口模式,2-子窗口全屏模式 + public byte byEnabledFeature; //是否启用场景特写,0-不启用,!0-启用 + public byte byFeatureMode; //特写模式,启用场景特写时有效,0-无效,1-“1+5”模式 + public byte byRes1; + public int dwAmplifyingSubWndNo; //全屏子窗口号(1字节墙号+1字节子窗口号+2字节窗口号) + //当byWndShowMode为2时有效,表示当前全屏显示的子窗口 + public byte byWndTopKeep; //窗口置顶保持,0-不保持,1-保持 + public byte byWndOpenKeep; //窗口打开保持,0-不保持,1-保持 + public byte[] byRes = new byte[22]; + } + + public static class NET_DVR_PLAN_LIST extends Structure { + public int dwSize; + public int dwPlanNums; //设备输入信号源数量 + public Pointer pBuffer; //指向dwInputSignalNums个NET_DVR_PLAN_CFG结构大小的缓冲区 + public byte byWallNo; //墙号,从1开始 + public byte[] byRes1 = new byte[2]; + public int dwBufLen; //所分配缓冲区长度,输入参数(大于等于dwInputSignalNums个NET_DVR_PLAN_CFG结构大小) + public byte[] byRes2 = new byte[64]; + } + + /*预案项信息*/ + public static class NET_DVR_PLAN_INFO extends Structure { + public byte byValid; // 该项是否有效 + public byte byType; // 见定义NET_DVR_PLAN_OPERATE_TYPE + public short wLayoutNo; // 布局号 + public byte byScreenStyle; //屏幕型号,开关机所用,1是低亮,2是高亮 + public byte byBaseMapType; //底图类型,1-图片底图,2-超高清输入底图,底图切换时有效 + public byte[] byRes1 = new byte[2]; + public int dwDelayTime; // 一个项的运行时间, 单位秒 + public int dwSerialNo; //串口号,屏幕控制时使用 + public int dwBaseMapWndNo; //底图窗口号,底图切换时有效 + public int dwBaseMapNo; //底图号,底图切换时有效;底图类型为1时,此参数为图片序号,底图类型为2时此参数为超高清输入子系统输入号(1字节设备号+1字节子板号+2字节显示输入序号) + public byte[] byRes2 = new byte[20]; + } + + public static class NET_DVR_CYCLE_TIME extends Structure { + public byte byValid; + public byte[] byRes = new byte[3]; + public NET_DVR_TIME_EX struTime = new NET_DVR_TIME_EX(); + } + + /*预案管理*/ + public static class NET_DVR_PLAN_CFG extends Structure { + public int dwSize; + public byte byValid; // 该预案是否有效 + public byte byWorkMode; // 预案工作模式 1表示手动,2自动,3预案循环 + public byte byWallNo; //电视墙号,从1开始 + public byte byPlanNo; //预案号,获取预案列表时有效,0-无效或不支持 + public byte[] byPlanName = new byte[NAME_LEN/*32*/]; //预案名称 + public NET_DVR_TIME_EX struTime; // 工作模式为自动时使用 + public NET_DVR_CYCLE_TIME[] struTimeCycle = new NET_DVR_CYCLE_TIME[DAYS_A_WEEK/*7*/]; /*循环时间,周期为一个星期,年、月、日三个参数不使用。如:struTimeCycle[0]中的byValid的值是1,表示星期天执行该预案。星期取值区间为[0,6],其中0代表星期天,1代表星期一,以此类推*/ + public int dwWorkCount; // 预案内容执行次数 + public NET_DVR_PLAN_INFO[] strPlanEntry = new NET_DVR_PLAN_INFO[MAX_PLAN_ACTION_NUM/*32*/]; // 预案执行的内容 + public int dwPlanNo; //4字节预案号,客户端统一使用4字节的预案号,单字节的预案号不再使用 + public byte[] byRes2 = new byte[60]; + } + + public static class NET_DVR_WALLSCENECFG extends Structure { + public int dwSize; + public byte[] sSceneName = new byte[NAME_LEN]; //场景名称 + public byte byEnable; //场景是否有效,0-无效,1-有效 + public byte bySceneIndex; //场景号,只能获取。获取所有场景时使用该参数 + public byte[] byRes = new byte[78]; + } + + public static class NET_DVR_SUBWND_DECODE_OSD extends Structure { + public int dwSize = 0; + public int dwSubWndNo = 0; //子窗口号(4字节组合方式) + public int dwOSDNums = 0; //该子窗口配置的OSD信息的个数 + public NET_DVR_OSD_INFO[] struOSDList = new NET_DVR_OSD_INFO[MAX_NUM_OSD_ONE_SUBWND]; //OSD信息列表 + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_OSD_INFO extends Structure { + public byte byEnabled = 1; //是否使能,零-不使能,非零-使能 + public byte byEnabledFlash = 0; //是否闪烁,零-不闪烁,非零-闪烁 + public byte byFontSize = 1; //字体大小,1-大,2-中,3-小 + public byte byTransparent = 0; //透明度,取值范围0-100 + public NET_DVR_RGB_COLOR struColor = new NET_DVR_RGB_COLOR(); //字体颜色 + public short wCoordinateX = 0; //OSD左上角X坐标 + public short wCoordinateY = 0; //OSD左上角Y坐标 + public byte[] byContent = new byte[MAX_LEN_OSD_CONTENT]; //OSD信息 + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_DEV_CHAN_INFO_EX extends Structure { + public byte byChanType; //通道类型,0-普通通道,1-零通道,2-流ID,3-本地输入源,4-虚拟屏服务器通道,5-拼接通道,6-屏幕服务器,7-分布式网络源,8-多相机融合通道,9-网络输入源 + public byte[] byStreamId = new byte[STREAM_ID_LEN]; //流ID,当byChanType=2、9时,该字段用于指定流或者网络ipc的ID号 + public byte[] byRes1 = new byte[3]; + public int dwChannel; //通道号,通道类型为普通通道,零通道,本地输入源,虚拟屏服务器通道,拼接通道,屏幕服务器,分布式网络源时填此字段 + public byte[] byRes2 = new byte[24]; + public byte[] byAddress = new byte[MAX_DOMAIN_NAME]; //设备域名 + public short wDVRPort; //端口号 + public byte byChannel; //通道号,dwChannel不为0时此字段无效 + public byte byTransProtocol; //传输协议类型0-TCP,1-UDP + public byte byTransMode; //传输码流模式 0-主码流 1-子码流 + public byte byFactoryType; /*前端设备厂家类型,通过接口获取*/ + public byte byDeviceType; //设备类型(视频综合平台智能板使用),1-解码器(此时根据视频综合平台能力集中byVcaSupportChanMode字段来决定是使用解码通道还是显示通道),2-编码器 + public byte byDispChan;//显示通道号,智能配置使用 + public byte bySubDispChan;//显示通道子通道号,智能配置时使用 + public byte byResolution; //; 1-CIF 2-4CIF 3-720P 4-1080P 5-500w大屏控制器使用,大屏控制器会根据该参数分配解码资源 + public byte[] byRes = new byte[2]; + public byte[] sUserName = new byte[NAME_LEN]; //监控主机登陆帐号 + public byte[] sPassword = new byte[PASSWD_LEN]; //监控主机密码 + } + + public static class NET_DVR_STREAM_MEDIA_SERVER extends Structure { + public byte byValid; //是否启用,0-否,1-是 + public byte[] byRes1 = new byte[3]; + public byte[] byAddress = new byte[MAX_DOMAIN_NAME]; //IP或者域名 + public short wDevPort; /*流媒体服务器端口*/ + public byte byTransmitType; /*传输协议类型 0-TCP,1-UDP*/ + public byte[] byRes2 = new byte[5]; + } + + public static class NET_DVR_DEV_DDNS_INFO extends Structure { + public byte[] byDevAddress = new byte[MAX_DOMAIN_NAME]; //域名(IPServer或hiDDNS时可填序列号或者别名) + public byte byTransProtocol; //传输协议类型0-TCP,1-UDP, 2-MCAST + public byte byTransMode; //传输码流模式 0-主码流 1-子码流 + public byte byDdnsType; //域名服务器类型,0-IPServer 1-Dyndns 2-PeanutHull(花生壳),3- NO-IP, 4- hiDDNS + public byte byRes1; + public byte[] byDdnsAddress = new byte[MAX_DOMAIN_NAME]; //DDNS服务器地址 + public short wDdnsPort; //DDNS服务器端口号 + public byte byChanType; //0-普通通道,1-零通道,2-流ID + public byte byFactoryType; //前端设备厂家类型,通过接口获取 + public int dwChannel; //通道号 + public byte[] byStreamId = new byte[STREAM_ID_LEN]; //流ID + public byte[] sUserName = new byte[NAME_LEN]; //监控主机登陆帐号 + public byte[] sPassword = new byte[PASSWD_LEN]; //监控主机密码 + public short wDevPort; //前端设备通信端口 + public byte[] byRes2 = new byte[2]; + } + + public static class NET_DVR_DEC_STREAM_DEV_EX extends Structure { + public NET_DVR_STREAM_MEDIA_SERVER struStreamMediaSvrCfg = new NET_DVR_STREAM_MEDIA_SERVER(); + public NET_DVR_DEV_CHAN_INFO_EX struDevChanInfo = new NET_DVR_DEV_CHAN_INFO_EX(); + } + + //DDNS方式取流 + public static class NET_DVR_DEC_DDNS_DEV extends Structure { + public NET_DVR_DEV_DDNS_INFO struDdnsInfo; + public NET_DVR_STREAM_MEDIA_SERVER struMediaServer; + } + + public static class NET_DVR_DEC_STREAM_MODE extends Union { + public NET_DVR_DEC_STREAM_DEV_EX struDecStreamDev = new NET_DVR_DEC_STREAM_DEV_EX(); + public NET_DVR_PU_STREAM_URL struUrlInfo = new NET_DVR_PU_STREAM_URL(); + public NET_DVR_DEC_DDNS_DEV struDdnsDecInfo = new NET_DVR_DEC_DDNS_DEV(); + public byte[] byRes = new byte[300]; + } + + public static class NET_DVR_MATRIX_CHAN_INFO_V41 extends Structure { + public byte byEnable; //是否启用,0-否,1-是 + public byte byStreamMode;/*取流模式,0-无效,1-通过IP或域名取流,2-通过URL取流,3-通过动态域名解析向设备取流*/ + public byte[] byRes = new byte[2]; + public NET_DVR_DEC_STREAM_MODE uDecStreamMode = new NET_DVR_DEC_STREAM_MODE();//取流信息 + } + + public static class NET_DVR_MATRIX_LOOP_DECINFO_V41 extends Structure { + public int dwSize; + public int dwPoolTime; /*轮巡间隔*/ + public NET_DVR_MATRIX_CHAN_INFO_V41[] struchanConInfo = new NET_DVR_MATRIX_CHAN_INFO_V41[MAX_CYCLE_CHAN_V30]; + public byte byStreamEncrypt; //是否进行码流加密处理,0-不支持,1-支持 + public byte[] byRes = new byte[3]; + public byte[] sStreamPassword = new byte[STREAM_PASSWD_LEN]; //码流加密密码,需敏感信息加密 + } + + /************************************ + * 拼控(End) + ***************************************/ + + public static class NET_DVR_EMAILCFG extends Structure { /* 12 bytes */ + public int dwSize; + public byte[] sUserName = new byte[32]; + public byte[] sPassWord = new byte[32]; + public byte[] sFromName = new byte[32]; /* Sender *///字符串中的第一个字符和最后一个字符不能是"@",并且字符串中要有"@"字符 + public byte[] sFromAddr = new byte[48]; /* Sender address */ + public byte[] sToName1 = new byte[32]; /* Receiver1 */ + public byte[] sToName2 = new byte[32]; /* Receiver2 */ + public byte[] sToAddr1 = new byte[48]; /* Receiver address1 */ + public byte[] sToAddr2 = new byte[48]; /* Receiver address2 */ + public byte[] sEmailServer = new byte[32]; /* Email server address */ + public byte byServerType; /* Email server type: 0-SMTP, 1-POP, 2-IMTP…*/ + public byte byUseAuthen; /* Email server authentication method: 1-enable, 0-disable */ + public byte byAttachment; /* enable attachment */ + public byte byMailinterval; /* mail interval 0-2s, 1-3s, 2-4s. 3-5s*/ + } + + public static class NET_DVR_COMPRESSIONCFG_NEW extends Structure { + public int dwSize; + public NET_DVR_COMPRESSION_INFO_EX struLowCompression; //定šš时录像 + public NET_DVR_COMPRESSION_INFO_EX struEventCompression; //事件触发录像 + } + + //球机位置信息 + public static class NET_DVR_PTZPOS extends Structure { + public short wAction;//获取时该字段无效 + public short wPanPos;//水平参数 + public short wTiltPos;//垂直参数 + public short wZoomPos;//变倍参数 + } + + //球机范围信息 + public static class NET_DVR_PTZSCOPE extends Structure { + public short wPanPosMin;//水平参数min + public short wPanPosMax;//水平参数max + public short wTiltPosMin;//垂直参数min + public short wTiltPosMax;//垂直参数max + public short wZoomPosMin;//变倍参数min + public short wZoomPosMax;//变倍参数max + } + + public static class NET_DVR_PTZABSOLUTEEX_CFG extends Structure { + public int dwSize;//结构体大小 + public NET_PTZ_INFO struPTZCtrl = new NET_PTZ_INFO();//设备PTZF信息 + public int dwFocalLen;//焦距范围:0-100000MM + public float fHorizontalSpeed;//水平转动速度:0.01-1000.00度/S + public float fVerticalSpeed;//垂直转动速度:0.01-1000.00度/S + /*镜头变倍配置类型;absoluteZoom:通过变倍参数进行配置,选择为该类型时struPTZCtrl中的fZoom参数生效。focalLen:通过焦距参数进行配置,选择为该类型时,dwFocalLen参数生效。*/ + public byte byZoomType;// 镜头变倍配置类型0~ absoluteZoom,1~ focalLen + public byte[] byRes = new byte[123]; + } + + //rtsp配置 ipcamera专用 + public static class NET_DVR_RTSPCFG extends Structure { + public int dwSize; //长度 + public short wPort; //rtsp服务器侦听端口 + public byte[] byReserve = new byte[54]; //预留 + } + + /******************************** + * 接口参数结构(begin) + *********************************/ + +//NET_DVR_Login()参数结构 + public static class NET_DVR_DEVICEINFO extends Structure { + public byte[] sSerialNumber = new byte[SERIALNO_LEN]; //序列号 + public byte byAlarmInPortNum; //DVR报警输入个数 + public byte byAlarmOutPortNum; //DVR报警输出个数 + public byte byDiskNum; //DVR硬盘个数 + public byte byDVRType; //DVR类型, 1:DVR 2:ATM DVR 3:DVS ...... + public byte byChanNum; //DVR 通道个数 + public byte byStartChan; //起始通道号,例如DVS-1,DVR - 1 + } + + //NET_DVR_Login_V30()参数结构 + public static class NET_DVR_DEVICEINFO_V30 extends Structure { + public byte[] sSerialNumber = new byte[SERIALNO_LEN]; //序列号 + public byte byAlarmInPortNum; //报警输入个数 + public byte byAlarmOutPortNum; //报警输出个数 + public byte byDiskNum; //硬盘个数 + public byte byDVRType; //设备类型, 1:DVR 2:ATM DVR 3:DVS ...... + public byte byChanNum; //模拟通道个数 + public byte byStartChan; //起始通道号,例如DVS-1,DVR - 1 + public byte byAudioChanNum; //语音通道数 + public byte byIPChanNum; //最大数字通道个数,低位 + public byte byZeroChanNum; //零通道编码个数 //2010-01-16 + public byte byMainProto; //主码流传输协议类型 0-private, 1-rtsp,2-同时支持private和rtsp + public byte bySubProto; //子码流传输协议类型0-private, 1-rtsp,2-同时支持private和rtsp + public byte bySupport; //能力,位与结果为0表示不支持,1表示支持, + public byte bySupport1; // 能力集扩充,位与结果为0表示不支持,1表示支持 + public byte bySupport2; /*能力*/ + public short wDevType; //设备型号 + public byte bySupport3; //能力集扩展 + public byte byMultiStreamProto;//是否支持多码流,按位表示,0-不支持,1-支持,bit1-码流3,bit2-码流4,bit7-主码流,bit-8子码流 + public byte byStartDChan; //起始数字通道号,0表示无效 + public byte byStartDTalkChan; //起始数字对讲通道号,区别于模拟对讲通道号,0表示无效 + public byte byHighDChanNum; //数字通道个数,高位 + public byte bySupport4; //能力集扩展 + public byte byLanguageType;// 支持语种能力,按位表示,每一位0-不支持,1-支持 + // byLanguageType 等于0 表示 老设备 + // byLanguageType & 0x1表示支持中文 + // byLanguageType & 0x2表示支持英文 + public byte byVoiceInChanNum; //音频输入通道数 + public byte byStartVoiceInChanNo; //音频输入起始通道号 0表示无效 + public byte bySupport5; + public byte bySupport6; //能力 + public byte byMirrorChanNum; //镜像通道个数,<录播主机中用于表示导播通道> + public short wStartMirrorChanNo; //起始镜像通道号 + public byte bySupport7; //能力 + public byte byRes2; //保留 + } + + public static final int NET_DVR_DEV_ADDRESS_MAX_LEN = 129; + public static final int NET_DVR_LOGIN_USERNAME_MAX_LEN = 64; + public static final int NET_DVR_LOGIN_PASSWD_MAX_LEN = 64; + + public static interface FLoginResultCallBack extends Callback { + public int invoke(int lUserID, int dwResult, NET_DVR_DEVICEINFO_V30 lpDeviceinfo, Pointer pUser); + } + + //NET_DVR_Login_V40()参数 + public static class NET_DVR_USER_LOGIN_INFO extends Structure { + public byte[] sDeviceAddress = new byte[NET_DVR_DEV_ADDRESS_MAX_LEN]; + public byte byUseTransport; + public short wPort; + public byte[] sUserName = new byte[NET_DVR_LOGIN_USERNAME_MAX_LEN]; + public byte[] sPassword = new byte[NET_DVR_LOGIN_PASSWD_MAX_LEN]; + public FLoginResultCallBack cbLoginResult; + public Pointer pUser; + public boolean bUseAsynLogin; + public byte byProxyType; //0:不使用代理,1:使用标准代理,2:使用EHome代理 + public byte byUseUTCTime; //0-不进行转换,默认,1-接口上输入输出全部使用UTC时间,SDK完成UTC时间与设备时区的转换,2-接口上输入输出全部使用平台本地时间,SDK完成平台本地时间与设备时区的转换 + public byte byLoginMode; //0-Private 1-ISAPI 2-自适应 + public byte byHttps; //0-不适用tls,1-使用tls 2-自适应 + public int iProxyID; //代理服务器序号,添加代理服务器信息时,相对应的服务器数组下表值 + public byte byVerifyMode; //认证方式,0-不认证,1-双向认证,2-单向认证;认证仅在使用TLS的时候生效; + public byte[] byRes2 = new byte[119]; + } + + //NET_DVR_Login_V40()参数 + public static class NET_DVR_DEVICEINFO_V40 extends Structure { + public NET_DVR_DEVICEINFO_V30 struDeviceV30 = new NET_DVR_DEVICEINFO_V30(); + public byte bySupportLock; + public byte byRetryLoginTime; + public byte byPasswordLevel; + public byte byRes1; + public int dwSurplusLockTime; + public byte byCharEncodeType;//字符编码类型:0- 无字符编码信息(老设备),1- GB2312(简体中文),2- GBK,3- BIG5(繁体中文),4- Shift_JIS(日文),5- EUC-KR(韩文),6- UTF-8,7- ISO8859-1,8- ISO8859-2,9- ISO8859-3,…,依次类推,21- ISO8859-15(西欧) + public byte bySupportDev5; //支持v50版本的设备参数获取,设备名称和设备类型名称长度扩展为64字节 + public byte bySupport; //能力集扩展,位与结果:0- 不支持,1- 支持 + public byte byLoginMode; //登录模式 0-Private登录 1-ISAPI登录 + public int dwOEMCode; + public int iResidualValidity; //该用户密码剩余有效天数,单位:天,返回负值,表示密码已经超期使用,例如“-3表示密码已经超期使用3天” + public byte byResidualValidity; // iResidualValidity字段是否有效,0-无效,1-有效 + public byte bySingleStartDTalkChan; //独立音轨接入的设备,起始接入通道号,0-为保留字节,无实际含义,音轨通道号不能从0开始 + public byte bySingleDTalkChanNums; //独立音轨接入的设备的通道总数,0-表示不支持 + public byte byPassWordResetLevel; //0-无效,1-管理员创建一个非管理员用户为其设置密码,该非管理员用户正确登录设备后要提示“请修改初始登录密码”,未修改的情况下,用户每次登入都会进行提醒;2-当非管理员用户的密码被管理员修改,该非管理员用户再次正确登录设备后,需要提示“请重新设置登录密码”,未修改的情况下,用户每次登入都会进行提醒。 + public byte bySupportStreamEncrypt; //能力集扩展,位与结果:0- 不支持,1- 支持 bySupportStreamEncrypt & 0x1:表示是否支持RTP/TLS取流 bySupportStreamEncrypt & 0x2: 表示是否支持SRTP/UDP取流 bySupportStreamEncrypt & 0x4: 表示是否支持SRTP/MULTICAST取流 + public byte byMarketType;//0-无效(未知类型),1-经销型,2-行业型 + public byte[] byRes2 = new byte[238]; + } + + //sdk网络环境枚举变量,用于远程升级 + enum _SDK_NET_ENV { + LOCAL_AREA_NETWORK, + WIDE_AREA_NETWORK + } + + //显示模式 + enum DISPLAY_MODE { + NORMALMODE, + OVERLAYMODE + } + + //发送模式 + enum SEND_MODE { + PTOPTCPMODE, + PTOPUDPMODE, + MULTIMODE, + RTPMODE, + RESERVEDMODE + } + + ; + + //抓图模式 + enum CAPTURE_MODE { + BMP_MODE, //BMP模式 + JPEG_MODE //JPEG模式 + } + + ; + + //实时声音模式 + enum REALSOUND_MODE { + NONE, //SDK中无此模式,只是为了填补0这个位置 + MONOPOLIZE_MODE, //独占模式 1 + SHARE_MODE //共享模式 2 + } + + ; + + //软解码预览参数 +// public static class NET_DVR_CLIENTINFO extends Structure { +// public int lChannel; +// public int lLinkMode; +// public HWND hPlayWnd; +// public String sMultiCastIP; +// } + + //预览V40接口 +// public static class NET_DVR_PREVIEWINFO extends Structure { +// public int lChannel;//通道号 +// public int dwStreamType; // 码流类型,0-主码流,1-子码流,2-码流3,3-码流4, 4-码流5,5-码流6,7-码流7,8-码流8,9-码流9,10-码流10 +// public int dwLinkMode;// 0:TCP方式,1:UDP方式,2:多播方式,3 - RTP方式,4-RTP/RTSP,5-RSTP/HTTP ,6- HRUDP(可靠传输) ,7-RTSP/HTTPS +// public HWND hPlayWnd;//播放窗口的句柄,为NULL表示不播放图象 +// public int bBlocked; //0-非阻塞取流, 1-阻塞取流, 如果阻塞SDK内部connect失败将会有5s的超时才能够返回,不适合于轮询取流操作. +// public int bPassbackRecord; //0-不启用录像回传,1启用录像回传 +// public byte byPreviewMode;//预览模式,0-正常预览,1-延迟预览 +// public byte[] byStreamID = new byte[32];//流ID,lChannel为0xffffffff时启用此参数 +// public byte byProtoType; //应用层取流协议,0-私有协议,1-RTSP协议 +// public byte byRes1; +// public byte byVideoCodingType; //码流数据编解码类型 0-通用编码数据 1-热成像探测器产生的原始数据(温度数据的加密信息,通过去加密运算,将原始数据算出真实的温度值) +// public int dwDisplayBufNum; //播放库播放缓冲区最大缓冲帧数,范围1-50,置0时默认为1 +// public byte byNPQMode; //NPQ是直连模式,还是过流媒体 0-直连 1-过流媒体 +// public byte[] byRes = new byte[215]; +// } + + public static class NET_DVR_STREAM_INFO extends Structure { + public int dwSize; + public byte[] byID = new byte[32]; + public int dwChannel; + public byte[] byRes = new byte[32]; + } + + //配置条件 + public static class NET_DVR_CLOUDSTORAGE_COND extends Structure { + public int dwSize; + public int dwChannel; + public byte[] byRes1 = new byte[64]; + } + + public static class NET_DVR_STREAM_RECORD_STATUS extends Structure { + public int dwSize; + public byte byRecord; + public byte byOffLineRecord; + public byte[] byRes1 = new byte[2]; + public int dwRelatedHD; + public byte[] byRes2 = new byte[8]; + } + + //SDK状态信息(9000新增) + public static class NET_DVR_SDKSTATE extends Structure { + public int dwTotalLoginNum; //当前login用户数 + public int dwTotalRealPlayNum; //当前realplay路数 + public int dwTotalPlayBackNum; //当前回放或下载路数 + public int dwTotalAlarmChanNum; //当前建立报警通道路数 + public int dwTotalFormatNum; //当前硬盘格式化路数 + public int dwTotalFileSearchNum; //当前日志或文件搜索路数 + public int dwTotalLogSearchNum; //当前日志或文件搜索路数 + public int dwTotalSerialNum; //当前透明通道路数 + public int dwTotalUpgradeNum; //当前升级路数 + public int dwTotalVoiceComNum; //当前语音转发路数 + public int dwTotalBroadCastNum; //当前语音广播路数 + public int[] dwRes = new int[10]; + } + + //SDK功能支持信息(9000新增) + public static class NET_DVR_SDKABL extends Structure { + public int dwMaxLoginNum; //最大login用户数 MAX_LOGIN_USERS + public int dwMaxRealPlayNum; //最大realplay路数 WATCH_NUM + public int dwMaxPlayBackNum; //最大回放或下载路数 WATCH_NUM + public int dwMaxAlarmChanNum; //最大建立报警通道路数 ALARM_NUM + public int dwMaxFormatNum; //最大硬盘格式化路数 SERVER_NUM + public int dwMaxFileSearchNum; //最大文件搜索路数 SERVER_NUM + public int dwMaxLogSearchNum; //最大日志搜索路数 SERVER_NUM + public int dwMaxSerialNum; //最大透明通道路数 SERVER_NUM + public int dwMaxUpgradeNum; //最大升级路数 SERVER_NUM + public int dwMaxVoiceComNum; //最大语音转发路数 SERVER_NUM + public int dwMaxBroadCastNum; //最大语音广播路数 MAX_CASTNUM + public int[] dwRes = new int[10]; + } + + //报警设备信息 + public static class NET_DVR_ALARMER extends Structure { + public byte byUserIDValid; /* userid是否有效 0-无效,1-有效 */ + public byte bySerialValid; /* 序列号是否有效 0-无效,1-有效 */ + public byte byVersionValid; /* 版本号是否有效 0-无效,1-有效 */ + public byte byDeviceNameValid; /* 设备名字是否有效 0-无效,1-有效 */ + public byte byMacAddrValid; /* MAC地址是否有效 0-无效,1-有效 */ + public byte byLinkPortValid; /* login端口是否有效 0-无效,1-有效 */ + public byte byDeviceIPValid; /* 设备IP是否有效 0-无效,1-有效 */ + public byte bySocketIPValid; /* socket ip是否有效 0-无效,1-有效 */ + public int lUserID; /* NET_DVR_Login()返回值, 布防时有效 */ + public byte[] sSerialNumber = new byte[SERIALNO_LEN]; /* 序列号 */ + public int dwDeviceVersion; /* 版本信息 高16位表示主版本,低16位表示次版本*/ + public byte[] sDeviceName = new byte[NAME_LEN]; /* 设备名字 */ + public byte[] byMacAddr = new byte[MACADDR_LEN]; /* MAC地址 */ + public short wLinkPort; /* link port */ + public byte[] sDeviceIP = new byte[128]; /* IP地址 */ + public byte[] sSocketIP = new byte[128]; /* 报警主动上传时的socket IP地址 */ + public byte byIpProtocol; /* Ip协议 0-IPV4, 1-IPV6 */ + public byte[] byRes2 = new byte[11]; + + + } + + //硬解码显示区域参数(子结构) + public static class NET_DVR_DISPLAY_PARA extends Structure { + public int bToScreen; + public int bToVideoOut; + public int nLeft; + public int nTop; + public int nWidth; + public int nHeight; + public int nReserved; + } + + //硬解码预览参数 + public static class NET_DVR_CARDINFO extends Structure { + public int lChannel;//通道号 + public int lLinkMode; //最高位(31)为0表示主码流,为1表示子,0-30位表示码流连接方式:0:TCP方式,1:UDP方式,2:多播方式,3 - RTP方式,4-电话线,5-128k宽带,6-256k宽带,7-384k宽带,8-512k宽带; + public String sMultiCastIP; + public NET_DVR_DISPLAY_PARA struDisplayPara; + } + + //录象文件参数 + public static class NET_DVR_FIND_DATA extends Structure { + public byte[] sFileName = new byte[100];//文件名 + public NET_DVR_TIME struStartTime;//文件的开始时间 + public NET_DVR_TIME struStopTime;//文件的结束时间 + public int dwFileSize;//文件的大小 + } + + //录象文件参数(9000) + public static class NET_DVR_FINDDATA_V30 extends Structure { + public byte[] sFileName = new byte[100];//文件名 + public NET_DVR_TIME struStartTime;//文件的开始时间 + public NET_DVR_TIME struStopTime;//文件的结束时间 + public int dwFileSize;//文件的大小 + public byte[] sCardNum = new byte[32]; + public byte byLocked;//9000设备支持,1表示此文件已经被锁定,0表示正常的文件 + public byte[] byRes = new byte[3]; + } + + //录象文件参数(带卡号) + public static class NET_DVR_FINDDATA_CARD extends Structure { + public byte[] sFileName = new byte[100];//文件名 + public NET_DVR_TIME struStartTime;//文件的开始时间 + public NET_DVR_TIME struStopTime;//文件的结束时间 + public int dwFileSize;//文件的大小 + public byte[] sCardNum = new byte[32]; + } + + public static class NET_DVR_FILECOND_V40 extends Structure { + public int lChannel; + public int dwFileType; + public int dwIsLocked; + public int dwUseCardNo;//是否带ATM信息进行查询:0-不带ATM信息,1-按交易卡号查询,2-按交易类型查询,3-按交易金额查询,4-按卡号、交易类型及交易金额的组合查询 5-按课程名称查找,此时卡号表示课程名称 + public byte[] sCardNumber = new byte[CARDNUM_LEN_OUT]; + public NET_DVR_TIME struStartTime = new NET_DVR_TIME(); + public NET_DVR_TIME struStopTime = new NET_DVR_TIME(); + public byte byDrawFrame; //0:不抽帧,1:抽帧 + public byte byFindType; //0:查询普通卷,1:查询存档卷 + public byte byQuickSearch; //0:普通查询,1:快速(日历)查询 + public byte bySpecialFindInfoType; //专有查询条件类型 0-无效, 1-带ATM查询条件 + public int dwVolumeNum; //存档卷号 + public byte[] byWorkingDeviceGUID = new byte[GUID_LEN]; //工作机GUID,通过获取N+1得到 + public NET_DVR_SPECIAL_FINDINFO_UNION uSpecialFindInfo = new NET_DVR_SPECIAL_FINDINFO_UNION(); //专有查询条件 + public byte byStreamType; //0-同一个时间段只返回一种录像,优先级顺序为:主码流、子码流、三码流,1-子码流,2-三码流,3-主码流,254-双码流搜索(优先返回主码流录像,没有主码流录像时返回子码流录像) + public byte byAudioFile; //音频文件 0-非音频文件,1-音频文件 + public byte[] byRes2 = new byte[30]; //保留 + } + + public static class NET_DVR_SPECIAL_FINDINFO_UNION extends Union { + public byte[] byLenth = new byte[8]; + public NET_DVR_ATMFINDINFO struATMFindInfo = new NET_DVR_ATMFINDINFO(); //ATM查询 + } + + public static class NET_DVR_ATMFINDINFO extends Structure { + public byte byTransactionType; //交易类型 0-全部,1-查询, 2-取款, 3-存款, 4-修改密码,5-转账, 6-无卡查询 7-无卡存款, 8-吞钞 9-吞卡 10-自定义 + public byte[] byRes = new byte[3]; //保留 + public int dwTransationAmount; //交易金额 ; + } + + //录像文件查找条件结构V50 + public static class NET_DVR_FILECOND_V50 extends Structure { + public NET_DVR_STREAM_INFO struStreamID; //流ID或通道号 + public NET_DVR_TIME_SEARCH_COND struStartTime = new NET_DVR_TIME_SEARCH_COND(); //开始时间 + public NET_DVR_TIME_SEARCH_COND struStopTime = new NET_DVR_TIME_SEARCH_COND(); //结束时间 + public byte byFindType; //0-查询普通卷,1-查询存档卷 2-查询N+1录像文件 + public byte byDrawFrame; //是否抽帧 0-不抽帧 1-抽帧 + public byte byQuickSearch; //0-普通查询,1-快速(日历)查询 + public byte byStreamType; //0-主码流,1-子码流,2-3码流,0xff-全部 + public int dwFileType; // 文件类型 + public int dwVolumeNum; //存档卷号,byFindType为1时有效 + public byte byIsLocked; //是否锁定 0-正常文件,1-锁定文件, 0xff表示所有文件 + public byte byNeedCard; //是否需要查询卡,0-不需要 1-需要 + public byte byOnlyAudioFile; //音频文件 0-视频文件 1-音频文件 + public byte bySpecialFindInfoType; //0-无效, 1-带ATM查询条件 + public byte[] szCardNum = new byte[32]; //卡号,byNeedCard为1时有效 + public byte[] szWorkingDeviceGUID = new byte[16]; //工作机GUID,通过获取N+1得到,byFindType为2时有效 + public NET_DVR_SPECIAL_FINDINFO_UNION uSpecialFindInfo = new NET_DVR_SPECIAL_FINDINFO_UNION(); //专有查询条件联合体 + public int dwTimeout; //查找超时时间(指定NET_DVR_FindNextFile_V30/NET_DVR_FindNextFile_V40/NET_DVR_FindNextFile_V50接口的超时时间返回);单位:毫秒,不填写(默认为0时),接口行为跟以前一样 ;有效值:0, [5000 – 15000] + public byte[] byRes = new byte[252]; + } + + public static class NET_DVR_FINDDATA_V40 extends Structure { + public byte[] sFileName = new byte[100];//文件名 + public NET_DVR_TIME struStartTime = new NET_DVR_TIME();//文件的开始时间 + public NET_DVR_TIME struStopTime = new NET_DVR_TIME();//文件的结束时间 + public int dwFileSize;//文件的大小 + public byte[] sCardNum = new byte[32]; + public byte byLocked;//9000设备支持,1表示此文件已经被锁定,0表示正常的文件 + public byte byFileType; //文件类型:0-定时录像,1-移动侦测 ,2-报警触发, + //3-报警|移动侦测 4-报警&移动侦测 5-命令触发 6-手动录像,7-震动报警,8-环境报警,9-智能报警,10-PIR报警,11-无线报警,12-呼救报警,14-智能交通事件 + public byte byQuickSearch; //0:普通查询结果,1:快速(日历)查询结果 + public byte byRes; + public int dwFileIndex; //文件索引号 + public byte byStreamType; + public byte[] byRes1 = new byte[127]; + } + + public static class NET_DVR_TIME_SEARCH extends Structure { + public short wYear; //年,设备OSD时间 + public byte byMonth; //月,设备OSD时间 + public byte byDay; //日,设备OSD时间 + public byte byHour; //时,设备OSD时间 + public byte byMinute; //分,设备OSD时间 + public byte bySecond; //秒,设备OSD时间 + public byte cTimeDifferenceH; //与国际标准时间的时差(小时),-12 ... +14 + public byte cTimeDifferenceM; //与国际标准时间的时差(分钟),-30, 0, 30, 45 + public byte byLocalOrUTC; //0-时差无效,设备本地时间,即设备OSD时间 1-时差有效 + public short wMillisecond; //毫秒,精度不够,默认为0 + } + + public static class NET_DVR_ADDRESS extends Structure { + public NET_DVR_IPADDR struIP = new NET_DVR_IPADDR(); //IP地址 + public short wPort; //端口号 + public byte[] byRes = new byte[2]; + } + + public static class NET_DVR_FINDDATA_V50 extends Structure { + public byte[] sFileName = new byte[100]; + public NET_DVR_TIME_SEARCH struStartTime = new NET_DVR_TIME_SEARCH(); + public NET_DVR_TIME_SEARCH struStopTime = new NET_DVR_TIME_SEARCH(); + public NET_DVR_ADDRESS struAddr = new NET_DVR_ADDRESS(); //片段所在的地址信息,集群回放时用到 + public int dwFileSize; //文件大小 + public byte byLocked; //文件是否被锁定,1-文件已锁定;0-文件未锁定 + public byte byFileType; //文件类型,与V40相同 + public byte byQuickSearch; //0- 普通查询结果,1- 快速(日历)查询结果 + public byte byStreamType; //码流类型:0- 主码流,1- 子码流,2- 码流三 + public int dwFileIndex; //文件索引号 + public byte[] sCardNum = new byte[32]; //卡号 + public int dwTotalLenH; // 对于大文件搜索,时间段内数据总长度,高32字节 + public int dwTotalLenL; // 对于大文件搜索,时间段内数据总长度,低32字节 + public byte byBigFileType; // 0为普通片段搜索,1为大文件搜索 + public byte[] byRes = new byte[247]; + } + + public static class NET_DVR_FILECOND extends Structure //录象文件查找条件结构 + { + public int lChannel;//通道号 + public int dwFileType;//录象文件类型0xff-全部,0-定时录像,1-移动侦测 ,2-报警触发,3-报警|移动侦测 4-报警&移动侦测 5-命令触发 6-手动录像 + public int dwIsLocked;//是否锁定 0-正常文件,1-锁定文件, 0xff表示所有文件 + public int dwUseCardNo;//是否使用卡号 + public byte[] sCardNumber = new byte[32];//卡号 + public NET_DVR_TIME struStartTime;//开始时间 + public NET_DVR_TIME struStopTime;//结束时间 + } + + public static class NET_DVR_PLAYCOND extends Structure //回放或者下载信息结构体 + { + public int dwChannel;//通道号 + public NET_DVR_TIME struStartTime; + public NET_DVR_TIME struStopTime; + public byte byDrawFrame; //0:不抽帧,1:抽帧 + public byte byStreamType; //码流类型,0-主码流 1-子码流 2-码流三 + public byte[] byStreamID = new byte[STREAM_ID_LEN]; + public byte[] byRes = new byte[30];//保留 + } + +// public static class NET_DVR_VOD_PARA extends Structure //回放或者下载信息结构体 +// { +// public int dwSize; +// public NET_DVR_STREAM_INFO struIDInfo; +// public NET_DVR_TIME struBeginTime; +// public NET_DVR_TIME struEndTime; +// public HWND hWnd; +// public byte byDrawFrame; //0:不抽帧,1:抽帧 +// public byte byVolumeType; //0-普通录像卷 1-存档卷 +// public byte byVolumeNum; //卷号,目前指存档卷号 +// public byte byStreamType; //码流类型 0-主码流, 1-子码流,2-码流三 +// public int dwFileIndex; //存档卷上的录像文件索引,搜索存档卷录像时返回的值 +// public byte byAudioFile; //音频文件0-否,1-是 +// public byte byCourseFile; //课程文件0-否,1-是 +// public byte byDownload; //是否下载 0-否,1-是 +// public byte byOptimalStreamType; //是否按最优码流类型回放 0-否,1-是(对于双码流设备,某一段时间内的录像文件与指定码流类型不同,则返回实际码流类型的录像) +// public byte[] byRes2 = new byte[20]; +// } + + //图片查找条件 + public static class NET_DVR_FIND_PICTURE_PARAM extends Structure { + public int dwSize; // 结构体大小 + public int lChannel; // 通道号 + public byte byFileType; //图片查找类型 + public byte byNeedCard; // 是否需要卡号 + /* + 0-保留,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-皖,0xff-全部 + */ + public byte byProvince; //省份索引值 + public byte byEventType; // 事件类型:0保留,1-交通事件;2-违章取证;3-其他事件 + public byte[] sCardNum = new byte[CARDNUM_LEN_V30]; // 卡号 + public NET_DVR_TIME struStartTime = new NET_DVR_TIME();//查找图片的开始时间 + public NET_DVR_TIME struStopTime = new NET_DVR_TIME();// 查找图片的结束时间 + //ITC3.7 新增 + public int dwTrafficType; //图片检索生效项 参考 VCA_OPERATE _TYPE + public int dwVehicleType; //车辆类型 参考 VCA_VEHICLE_TYPE + //违规检测类型参考 VCA_ILLEGAL_TYPE 当前不支持复选 + public int dwIllegalType; + public byte byLaneNo; //车道号(1~99) + public byte bySubHvtType;//0-保留,1-机动车(机动车子类型中支持车牌检索,省份检索),2-非机动车,3-行人 + public byte[] byRes2 = new byte[2]; + public byte[] sLicense = new byte[MAX_LICENSE_LEN/*16*/]; //车牌号码 + public byte byRegion; // 区域索引值 0-保留,1-欧洲(Europe Region),2-俄语区域(Russian Region),3-欧洲&俄罗斯(EU&CIS), 4-中东(Middle East),0xff-所有 + public byte byCountry; // 国家索引值,参照:COUNTRY_INDEX + public byte byArea; //地区 + public byte byISO8601; //是否是8601的时间格式,即时差字段是否有效0-时差无效,年月日时分秒为设备本地时间 1-时差有效 + public byte cStartTimeDifferenceH; //开始时间与UTC的时差(小时),-12 ... +14, 正数表示东时区 + public byte cStartTimeDifferenceM; //开始时间与UTC的时差(分钟),-30, 0, 30, 45,正数表示东时区 + public byte cStopTimeDifferenceH; //结束时间与UTC的时差(小时),-12 ... +14,正数表示东时区 + public byte cStopTimeDifferenceM; //结束时间与UTC的时差(分钟),-30, 0, 30, 45,正数表示东时区 + } + + public static class NET_DVR_FIND_PICTURE extends Structure { + public byte[] sFileName = new byte[PICTURE_NAME_LEN];//图片名 + public NET_DVR_TIME struTime;//图片的时间 + public int dwFileSize;//图片的大小 + public byte[] sCardNum = new byte[CARDNUM_LEN_V30]; //卡号 + public byte byPlateColor;//参考结构 VCA_PLATE_COLOR + public byte byVehicleLogo;//参考结构 VLR_VEHICLE_CLASS + public byte byEventSearchStatus; //连续图片表示同一查找结果的时候,0-表示后面没有图片信息,1-表示后面还有图片信息。总共图片信息包括最后一张状态为0的图片。 + public byte byRecogResult;//识别结果参考结构VTR_RESULT + public byte[] sLicense = new byte[MAX_LICENSE_LEN/*16*/]; //车牌号码 + public byte[] byRes = new byte[12]; + } + + + public class NET_DVR_FIND_PICTURE_V50 extends Structure { + public byte[] sFileName = new byte[PICTURE_NAME_LEN];//图片名 + public NET_DVR_TIME struTime = new NET_DVR_TIME();//图片的时间 + public int dwFileSize;//图片的大小 + public byte[] sCardNum = new byte[CARDNUM_LEN_V30]; //卡号 + public byte byPlateColor;//参考结构 VCA_PLATE_COLOR + public byte byVehicleLogo;//参考结构 VLR_VEHICLE_CLASS + public byte byFileType; //文件类型, :0定时抓图1 移动侦测抓图 2 报警抓图3 报警 | 移动侦测抓图 4 报警 & 移动侦测抓图 6 手动抓图 ,9-智能图片,10- PIR报警,11- 无线报警,12- 呼救报警, 0xa 预览时截图,0xd 人脸侦测, 0xe 越界侦测,0xf 入侵区域侦测,0x10 场景变更侦测, 0x11-设备本地回放时截图, 0x12-智能侦测 + public byte byRecogResult;//识别结果参考结构VTR_RESULT + public byte[] sLicense = new byte[MAX_LICENSE_LEN/*16*/]; //车牌号码 + public byte byEventSearchStatus; //连续图片表示同一查找结果的时候,0-表示后面没有图片信息,1-表示后面还有图片信息。总共图片信息包括最后一张状态为0的图片。 + public NET_DVR_ADDRESS struAddr; //图片所在的地址信息,图片下载时用到 + public byte[] byRes = new byte[256]; // 保留字节 + public NET_DVR_PIC_EXTRA_INFO_UNION uPicExtraInfo; //图片附件信息 + } + + + public class NET_DVR_PIC_PARAM extends Structure { + public Pointer pDVRFileName; + public Pointer pSavedFileBuf; + public int dwBufLen; + public IntByReference lpdwRetLen; + public NET_DVR_ADDRESS struAddr; + public byte[] byRes = new byte[256]; + } + + + //查找结果结构体 + public static class NET_DVR_FIND_PICTURE_V40 extends Structure { + public byte[] sFileName = new byte[PICTURE_NAME_LEN];//图片名 + public NET_DVR_TIME struTime = new NET_DVR_TIME();//图片的时间 + public int dwFileSize;//图片的大小 + public byte[] sCardNum = new byte[CARDNUM_LEN_V30]; //卡号 + public byte byPlateColor;//参考结构 VCA_PLATE_COLOR + public byte byVehicleLogo;//参考结构 VLR_VEHICLE_CLASS + public byte byFileType; //文件类型, :0定时抓图1 移动侦测抓图 2 报警抓图3 报警 | 移动侦测抓图 4 报警 & 移动侦测抓图 6 手动抓图 ,9-智能图片,10- PIR报警,11- 无线报警,12- 呼救报警, 0xa 预览时截图,0xd 人脸侦测, 0xe 越界侦测,0xf 入侵区域侦测,0x10 场景变更侦测, 0x11-设备本地回放时截图, 0x12-智能侦测, 0x32-防区报警, 0x33-紧急求助, 0x34-业务咨询 + public byte byRecogResult;//识别结果参考结构VTR_RESULT + public byte[] sLicense = new byte[MAX_LICENSE_LEN/*16*/]; //车牌号码 + public byte byEventSearchStatus; //连续图片表示同一查找结果的时候,0-表示后面没有图片信息,1-表示后面还有图片信息。总共图片信息包括最后一张状态为0的图片。 + public byte[] byRes = new byte[75]; // 保留字节 + public NET_DVR_PIC_EXTRA_INFO_UNION uPicExtraInfo; //图片附件信息 + } + + public static class NET_DVR_FACE_EXTRA_INFO extends Union { + public NET_VCA_RECT[] struVcaRect = new NET_VCA_RECT[MAX_FACE_PIC_NUM]; //人脸子图坐标信息 + public byte[] byRes = new byte[64]; + } + + //图片附件信息联合体 + public static class NET_DVR_PIC_EXTRA_INFO_UNION extends Union { + public byte[] byUnionLen = new byte[544]; //联合体长度,无实际意义 + public NET_DVR_FACE_EXTRA_INFO struFaceExtraInfo; //人脸侦测信息 + } + + public static class NET_DVR_PACKET_INFO_EX extends Union { + public short wWidth; //width + public short wHeight; //height + public int dwTimeStamp; //lower time stamp + public int dwTimeStampHigh;//higher time stamp + public int dwYear; //year + public int dwMonth; //month + public int dwDay; //day + public int dwHour; //hour + public int dwMinute; //minute + public int dwSecond; //second + public int dwMillisecond; //millisecond + public int dwFrameNum; //frame num + public int dwFrameRate; //frame rate,当帧率小于0时,0x80000002:表示1/2帧率,同理可推0x80000010为1/16帧率 + public int dwFlag; //flag E帧标记 + public int dwFilePos; //file pos + public int dwPacketType; //Packet type:0 -file head,1 -video I frame,2- video B frame, 3- video P frame, 10- audio packet, 11- private packet + public int dwPacketSize; //packet size + public Pointer pPacketBuffer; //packet buffer + public byte[] byRes1 = new byte[4]; + public int dwPacketMode; //打包方式:0-保留,1-FU_A打包方式 + public byte[] byRes2 = new byte[16]; + public int[] dwReserved = new int[6]; //reserved[0] 表示私有数据类型 + } + + //云台区域选择放大缩小(HIK 快球专用) + public static class NET_DVR_POINT_FRAME extends Structure { + public int xTop; //方框起始点的x坐标 + public int yTop; //方框结束点的y坐标 + public int xBottom; //方框结束点的x坐标 + public int yBottom; //方框结束点的y坐标 + public int bCounter; //保留 + } + + //语音对讲参数 + public static class NET_DVR_COMPRESSION_AUDIO extends Structure { + public byte byAudioEncType; //音频编码类型 0-G722; 1-G711 + public byte[] byres = new byte[7];//这里保留音频的压缩参数 + } + + public static class NET_DVR_AUDIODEC_INFO extends Structure { + public int nchans; /* 声道数 */ + public int sample_rate; /* 采样率 */ + public int aacdec_profile; /* 编码用的框架 */ + public int[] reserved = new int[16]; /* 保留 */ + } + + //音频解码 + public static class NET_DVR_AUDIODEC_PROCESS_PARAM extends Structure { + public Pointer in_buf; /* 输入数据buf */ + public Pointer out_buf; /* 输出数据buf */ + public int in_data_size; /* 输入in_buf内数据byte数 */ + public int proc_data_size; /* 输出解码库处理in_buf中数据大小bytes */ + public int out_frame_size; /* 解码一帧后数据BYTE数 */ + public NET_DVR_AUDIODEC_INFO dec_info = new NET_DVR_AUDIODEC_INFO(); /* 输出解码信息 */ + public int g726dec_reset; /* 重置开关 */ + public int g711_type; /* g711编码类型,0 - U law, 1- A law */ + public int[] reserved = new int[16]; /* 保留 */ + } + + public static class NET_DVR_AUDIOENC_INFO extends Structure { + public int in_frame_size; /* 输入一帧数据大小(BYTES),由GetInfoParam函数返回 */ + public int[] reserved = new int[16]; /* 保留 */ + } + + //音频编码 + public static class NET_DVR_AUDIOENC_PROCESS_PARAM extends Structure { + public Pointer in_buf; /* 输入buf */ + public Pointer out_buf; /* 输出buf */ + public int out_frame_size; /* 编码一帧后的BYTE数 */ + public int g726enc_reset; /* 重置开关 */ + public int g711_type; /* g711编码类型,0 - U law, 1- A law */ + public int enc_mode; /* 音频编码模式,AMR编码配置 */ + public int[] reserved = new int[16]; /* 保留 */ + } + + //用于接收报警信息的缓存区 + public static class RECV_ALARM extends Structure { + public byte[] RecvBuffer = new byte[4000];//此处的400应不小于最大报警报文长度 + } + + //布防参数 + public static class NET_DVR_SETUPALARM_PARAM extends Structure { + public int dwSize; + public byte byLevel; //布防优先级,0-一等级(高),1-二等级(中),2-三等级(低) + public byte byAlarmInfoType; //上传报警信息类型(抓拍机支持),0-老报警信息(NET_DVR_PLATE_RESULT),1-新报警信息(NET_ITS_PLATE_RESULT)2012-9-28 + public byte byRetAlarmTypeV40; //0--返回NET_DVR_ALARMINFO_V30或NET_DVR_ALARMINFO, 1--设备支持NET_DVR_ALARMINFO_V40则返回NET_DVR_ALARMINFO_V40,不支持则返回NET_DVR_ALARMINFO_V30或NET_DVR_ALARMINFO + public byte byRetDevInfoVersion; //CVR上传报警信息回调结构体版本号 0-COMM_ALARM_DEVICE, 1-COMM_ALARM_DEVICE_V40 + public byte byRetVQDAlarmType; //VQD报警上传类型,0-上传报报警NET_DVR_VQD_DIAGNOSE_INFO,1-上传报警NET_DVR_VQD_ALARM + public byte byFaceAlarmDetection; + public byte bySupport; + public byte byBrokenNetHttp; + public short wTaskNo; //任务处理号 和 (上传数据NET_DVR_VEHICLE_RECOG_RESULT中的字段dwTaskNo对应 同时 下发任务结构 NET_DVR_VEHICLE_RECOG_COND中的字段dwTaskNo对应) + public byte byDeployType; //布防类型:0-客户端布防,1-实时布防 + public byte[] byRes1 = new byte[3]; + public byte byAlarmTypeURL;//bit0-表示人脸抓拍报警上传(INTER_FACESNAP_RESULT);0-表示二进制传输,1-表示URL传输(设备支持的情况下,设备支持能力根据具体报警能力集判断,同时设备需要支持URL的相关服务,当前是”云存储“) + public byte byCustomCtrl;//Bit0- 表示支持副驾驶人脸子图上传: 0-不上传,1-上传,(注:只在公司内部8600/8200等平台开放) + + + } + + public static class NET_DVR_SETUPALARM_PARAM_V50 extends Structure { + public int dwSize; + public byte byLevel; //布防优先级,0-一等级(高),1-二等级(中),2-三等级(低) + public byte byAlarmInfoType; //上传报警信息类型(抓拍机支持),0-老报警信息(NET_DVR_PLATE_RESULT),1-新报警信息(NET_ITS_PLATE_RESULT)2012-9-28 + public byte byRetAlarmTypeV40; //0--返回NET_DVR_ALARMINFO_V30或NET_DVR_ALARMINFO, 1--设备支持NET_DVR_ALARMINFO_V40则返回NET_DVR_ALARMINFO_V40,不支持则返回NET_DVR_ALARMINFO_V30或NET_DVR_ALARMINFO + public byte byRetDevInfoVersion; //CVR上传报警信息回调结构体版本号 0-COMM_ALARM_DEVICE, 1-COMM_ALARM_DEVICE_V40 + public byte byRetVQDAlarmType; //VQD报警上传类型,0-上传报报警NET_DVR_VQD_DIAGNOSE_INFO,1-上传报警NET_DVR_VQD_ALARM + //1-表示人脸侦测报警扩展(INTER_FACE_DETECTION),0-表示原先支持结构(INTER_FACESNAP_RESULT) + public byte byFaceAlarmDetection; + //Bit0- 表示二级布防是否上传图片: 0-上传,1-不上传 + //Bit1- 表示开启数据上传确认机制;0-不开启,1-开启 + //Bit6- 表示雷达检测报警(eventType:radarDetection)是否开启实时上传;0-不开启,1-开启(用于web插件实时显示雷达目标轨迹) + public byte bySupport; + //断网续传类型 + //bit0-车牌检测(IPC) (0-不续传,1-续传) + //bit1-客流统计(IPC) (0-不续传,1-续传) + //bit2-热度图统计(IPC) (0-不续传,1-续传) + //bit3-人脸抓拍(IPC) (0-不续传,1-续传) + //bit4-人脸对比(IPC) (0-不续传,1-续传) + //bit5-JSON报警透传(IPC) (0-不续传,1-续传) + //bit6-热度图按人员停留时间统计数据上传事件(0-不续传,1-续传) + //bit7-热度图按人数统计数据上传事件的确认机制(0-不续传,1-续传) + public byte byBrokenNetHttp; + public short wTaskNo; //任务处理号 和 (上传数据NET_DVR_VEHICLE_RECOG_RESULT中的字段dwTaskNo对应 同时 下发任务结构 NET_DVR_VEHICLE_RECOG_COND中的字段dwTaskNo对应) + public byte byDeployType; //布防类型:0-客户端布防,1-实时布防 + public byte bySubScription; //订阅,按位表示,未开启订阅不上报 //占位 + //Bit7-移动侦测人车分类是否传图;0-不传图(V30上报),1-传图(V40上报) + public byte[] byRes1 = new byte[2]; + public byte byAlarmTypeURL;//bit0-表示人脸抓拍报警上传(INTER_FACESNAP_RESULT);0-表示二进制传输,1-表示URL传输(设备支持的情况下,设备支持能力根据具体报警能力集判断,同时设备需要支持URL的相关服务,当前是”云存储“) + //bit1-表示EVENT_JSON中图片数据长传类型;0-表示二进制传输,1-表示URL传输(设备支持的情况下,设备支持能力根据具体报警能力集判断) + //bit2 - 人脸比对(报警类型为COMM_SNAP_MATCH_ALARM)中图片数据上传类型:0 - 二进制传输,1 - URL传输 + //bit3 - 行为分析(报警类型为COMM_ALARM_RULE)中图片数据上传类型:0 - 二进制传输,1 - URL传输,本字段设备是否支持,对应软硬件能力集中节点是否返回且为true + public byte byCustomCtrl;//Bit0- 表示支持副驾驶人脸子图上传: 0-不上传,1-上传 + public byte[] byRes4 = new byte[128]; + } + + + //区域框参数 + public static class NET_VCA_RECT extends Structure { + public float fX; + public float fY; + public float fWidth; + public float fHeight; + } + + //报警目标信息 + public static class NET_VCA_TARGET_INFO extends Structure { + public int dwID; + public NET_VCA_RECT struRect; + public byte[] byRes = new byte[4]; + } + + //前端设备信息 + public static class NET_VCA_DEV_INFO extends Structure { + public NET_DVR_IPADDR struDevIP; + public short wPort; + public byte byChannel; + public byte byIvmsChannel; + } + + //事件规则信息 + public static class NET_VCA_RULE_INFO extends Structure { + public byte byRuleID; + public byte byRes; + public short wEventTypeEx; + public byte[] byRuleName = new byte[NAME_LEN]; + public int dwEventType; + public NET_VCA_EVENT_UNION uEventParam; + + public void read() { + super.read(); + switch (wEventTypeEx) { + case 1: + uEventParam.setType(NET_VCA_TRAVERSE_PLANE.class); + break; + case 2: + case 3: + uEventParam.setType(NET_VCA_AREA.class); + break; + default: + break; + } + uEventParam.read(); + } + + public void write() { + super.write(); + uEventParam.write(); + } + + } + + //警戒规则参数联合体 + public static class NET_VCA_EVENT_UNION extends Union { + public int[] uLen = new int[23]; + public NET_VCA_TRAVERSE_PLANE struTraversePlane; + public NET_VCA_AREA struArea; + } + + //穿越警戒面参数 + public static class NET_VCA_TRAVERSE_PLANE extends Structure { + public NET_VCA_LINE struPlaneBottom; + public int dwCrossDirection; + public byte bySensitivity; + public byte byPlaneHeight; + public byte byDetectionTarget;/*检测目标:0- 所有目标,1- 人,2- 车 */ + public byte[] byRes2 = new byte[37]; + } + + public static class NET_DVR_HANDLEEXCEPTION_V40 extends Structure { + public int dwHandleType;/*处理方式,各种异常处理方式的"或"结果,异常处理方式: + 0x00: 无响应 0x01: 监视器上警告 0x02: 声音警告 0x04: 上传中心 + 0x08: 触发报警输出 0x10: Jpeg抓图并上传EMail + 0x20: 无线声光报警器联动 0x40: 联动电子地图(目前仅PCNVR支持) + 0x200:抓图并上传ftp 0x400: 虚焦侦测联动聚焦 + 0x800: PTZ联动跟踪(球机跟踪目标) + E.g. dwHandleType==0x01|0x04 表示配置报警发生时联动监视器上警告并且将报警信息上传中心。 */ + public int dwMaxRelAlarmOutChanNum;/*设备最大支持的触发报警输出通道数(只读) */ + public int dwRelAlarmOutChanNum;/*已配置的触发的报警输出通道个数,决定dwRelAlarmOut取前多少个数组下标 */ + public int[] dwRelAlarmOut = new int[MAX_CHANNUM_V30];/*触发报警输出通道,取数组前dwRelAlarmOutChanNum个值, + 其值表示报警输出通道号(从1开始),初始值是0xfffffffff(不关联通道)。 + 例如,dwRelAlarmOutChanNum=5,则可以配置触发报警输出通道dwRelAlarmOut[0]~dwRelAlarmOut[4]。 */ + public byte[] byRes = new byte[64]; /*保留,置为0 */ + } + + public static final int MAX_ALERTLINE_NUM = 8; + + public static class NET_VCA_TRAVERSE_PLANE_DETECTION extends Structure { + public int dwSize; + public byte byEnable;//使能 + public byte byEnableDualVca;// 启用支持智能后检索 0-不启用,1-启用 + public byte[] byRes1 = new byte[2]; + public NET_VCA_TRAVERSE_PLANE[] struAlertParam = new NET_VCA_TRAVERSE_PLANE[MAX_ALERTLINE_NUM]; //警戒线参数 + public NET_DVR_SCHEDTIMEWEEK[] struAlarmSched = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS]; + public NET_DVR_HANDLEEXCEPTION_V40 struHandleException; //异常处理方式 + public int dwMaxRelRecordChanNum; //报警触发的录象通道 数(只读)最大支持数量 + public int dwRelRecordChanNum; //报警触发的录象通道 数 实际支持的数量 + public int[] byRelRecordChan = new int[MAX_CHANNUM_V30];//触发录像的通道号 + public NET_DVR_SCHEDTIME[] struHolidayTime = new NET_DVR_SCHEDTIME[MAX_TIMESEGMENT_V30]; //假日布防时间 + public byte[] byRes2 = new byte[100]; + } + + public static class NET_VCA_INTRUSION extends Structure { + public NET_VCA_POLYGON struRegion;//区域范围 + public short wDuration; //行为事件触发时间阈值: 1-120秒,建议5秒,判断是有效报警的时间 在ATM系统中触发文件阈值为 1-1000秒 + public byte bySensitivity; //灵敏度参数,范围[1-100] + public byte byRate; //占比:区域内所有未报警目标尺寸目标占区域面积的比重,归一化为-; + /* + 检测目标,可支持多选,具体定义为: + 0~所有目标(表示不锁定检测目标,所有目标都将进行检测) + 0x01 ~ 人, + 0x02 ~ 车, + 0x04 ~ 其他 + */ + public byte byDetectionTarget; + public byte byPriority;//优先级,0~低,1~中,2~高 + public byte[] byRes = new byte[2]; //保留 + } + + + //快速移动参数 + public static class NET_VCA_RUN extends Structure { + public NET_VCA_POLYGON struRegion;//区域范围 + public float fRunDistance; //人快速移动最大距离, 范围: [0.1, 1.00] 像素模式 实际模式(1,20)m/s + public byte bySensitivity; //灵敏度参数,范围[1,5] + public byte byMode; // 0 像素模式 1 实际模式 + /* + 检测目标,可支持多选,具体定义为: + 0~所有目标(表示不锁定检测目标,所有目标都将进行检测) + 0x01 ~ 人, + 0x02 ~ 车,, + 0x04 ~ 其他, + 该字段支持多选,按位取值,例如3表示1+2. + */ + public byte byDetectionTarget; + public byte byRes; + } + + + //奔跑检测 + public static class NET_VCA_RUNNING extends Structure { + public NET_VCA_POLYGON struRegion; //区域范围 + public int dwSpeed; //奔跑速度,范围[1,10] + public short wDuration; // 触发报警时间阈值 + public byte byRunMode; //奔跑模式,0-保留,1:单人奔跑,2:多人奔跑 + public byte byRes; + } + + //倒地参数 + public static class NET_VCA_FALL_DOWN extends Structure { + public NET_VCA_POLYGON struRegion;//区域范围 + public short wDuration; /* 触发事件阈值 1-60s*/ + public short bySensitivity; /* 灵敏度参数,范围[1,5] */ + public short byHeightThreshold; //高度阈值,范围[0,250],默认90,单位:厘米 + public byte[] byRes = new byte[4]; + } + + public static final int MAX_INTRUSIONREGION_NUM = 8; //最大区域数数 + + public static class NET_VCA_FIELDDETECION extends Structure { + public int dwSize; + public byte byEnable; //使能,是否开启 + public byte byEnableDualVca;// 启用支持智能后检索 0-不启用,1-启用 + public byte byEnableHumanMisinfoFilter;// 启用人体去误报 0-不启用,1-启用 + public byte byEnableVehicleMisinfoFilter;// 启用车辆去误报 0-不启用,1-启用 + public NET_VCA_INTRUSION[] struIntrusion = new NET_VCA_INTRUSION[MAX_INTRUSIONREGION_NUM];//每个区域的参数设置 + public NET_DVR_SCHEDTIMEWEEK[] struAlarmSched = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS]; //布防时间 + public NET_DVR_HANDLEEXCEPTION_V40 struHandleException; //异常处理方式 + public int dwMaxRelRecordChanNum; //报警触发的录象通道 数(只读)最大支持数量 + public int dwRelRecordChanNum; //报警触发的录象通道 数 实际支持的数量 + public int[] byRelRecordChan = new int[MAX_CHANNUM_V30];//触发录像通道 + public NET_DVR_SCHEDTIME[] struHolidayTime = new NET_DVR_SCHEDTIME[MAX_TIMESEGMENT_V30]; //假日布防时间 + public byte[] byRes2 = new byte[100]; + } + + public static class NET_DVR_CHANNEL_GROUP extends Structure { + public int dwSize; + public int dwChannel; + public int dwGroup; + public byte byID; + public byte[] byRes1 = new byte[3]; + public int dwPositionNo; + public byte[] byRes = new byte[56]; + } + + //线结构参数 + public static class NET_VCA_LINE extends Structure { + public NET_VCA_POINT struStart; + public NET_VCA_POINT struEnd; + } + + //点坐标参数 + public static class NET_VCA_POINT extends Structure { + public float fX; + public float fY; + + + } + + //进入/离开区域参数 + public static class NET_VCA_AREA extends Structure { + public NET_VCA_POLYGON struRegion; + public byte[] byRes = new byte[8]; + } + + //多边形结构体 + public static class NET_VCA_POLYGON extends Structure { + public int dwPointNum; + public NET_VCA_POINT[] struPos = new NET_VCA_POINT[VCA_MAX_POLYGON_POINT_NUM]; + } + + public static class NET_VCA_SIZE_FILTER extends Structure { + public byte byActive; //是否激活尺寸过滤器 0-否 非0-是 + public byte byMode; //过滤器模式SIZE_FILTER_MODE + public byte[] byRes = new byte[2]; //保留,置0 + public NET_VCA_RECT struMiniRect; //最小目标框,全0表示不设置 + public NET_VCA_RECT struMaxRect; //最大目标框,全0表示不设置 + } + + + //尺寸过滤策略 + public static class NET_VCA_FILTER_STRATEGY extends Structure { + public byte byStrategy; //尺寸过滤策略 0 - 不启用 1-高度和宽度过滤,2-面积过滤 + public byte[] byRes = new byte[11]; //保留 + } + + //行为分析报警 + public static class NET_VCA_RULE_ALARM extends Structure { + public int dwSize; + public int dwRelativeTime; + public int dwAbsTime; + public NET_VCA_RULE_INFO struRuleInfo; + public NET_VCA_TARGET_INFO struTargetInfo; + public NET_VCA_DEV_INFO struDevInfo; + public int dwPicDataLen; + public byte byPicType; + public byte byRelAlarmPicNum; //关联通道报警图片数量 + public byte bySmart;//IDS设备返回0(默认值),Smart Functiom Return 1 + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public int dwAlarmID; //报警ID,用以标识通道间关联产生的组合报警,0表示无效 + public short wDevInfoIvmsChannelEx; //与NET_VCA_DEV_INFO里的byIvmsChannel含义相同,能表示更大的值。老客户端用byIvmsChannel能继续兼容,但是最大到255。新客户端版本请使用wDevInfoIvmsChannelEx。 + public byte byRelativeTimeFlag; //dwRelativeTime字段是否有效 0-无效, 1-有效,dwRelativeTime表示UTC时间 + public byte byAppendInfoUploadEnabled; //附加信息上传使能 0-不上传 1-上传 + public Pointer pAppendInfo; //指向附加信息NET_VCA_APPEND_INFO的指针,byAppendInfoUploadEnabled为1时或者byTimeDiffFlag为1时有效 + public Pointer pImage; + } + + public static class NET_DVR_SYSTEM_TIME extends Structure { + public short wYear; //年 + public short wMonth; //月 + public short wDay; //日 + public short wHour; //时 + public short wMinute; //分 + public short wSecond; //秒 + public short wMilliSec; //毫秒 + public byte[] byRes = new byte[2]; + } + + //设备支持AI开放平台接入,上传视频检测数据 + public static class NET_AIOP_VIDEO_HEAD extends Structure { + public int dwSize; //dwSize = sizeof(NET_AIOP_VIDEO_HEAD) + public int dwChannel; //设备分析通道的通道号; + public NET_DVR_SYSTEM_TIME struTime = new NET_DVR_SYSTEM_TIME(); //时间 + public byte[] szTaskID = new byte[64]; //视频任务ID,来自于视频任务派发 + public int dwAIOPDataSize; //对应AIOPDdata数据长度 + public int dwPictureSize; //对应分析图片长度 + public byte[] szMPID = new byte[64]; //检测模型包ID,用于匹配AIOP的检测数据解析;可以通过URI(GET /ISAPI/Intelligent/AIOpenPlatform/algorithmModel/management?format=json)获取当前设备加载的模型包的label description信息; + public Pointer pBufferAIOPData; //AIOPDdata数据 + public Pointer pBufferPicture;//对应分析图片数据 + public byte byPictureMode;//图片数据传输模式 0-二进制,1-武汉云云存储,当byPictureMode为0时pBufferPicture为二进制数据,当byPictureMode为1时pBufferPicture为武汉云URL + public byte[] byRes2 = new byte[3];//保留字节 + public int dwPresetIndex; //预置点序号 + public byte[] byRes = new byte[176]; + } + + //设备支持AI开放平台接入,上传图片检测数据 + public static class NET_AIOP_PICTURE_HEAD extends Structure { + public int dwSize; //dwSize = sizeof(NET_AIOP_PICTURE_HEAD) + public NET_DVR_SYSTEM_TIME struTime = new NET_DVR_SYSTEM_TIME(); //时间 + public byte[] szPID = new byte[64]; //透传下发的图片ID,来自于图片任务派发 + public int dwAIOPDataSize; //对应AIOPDdata数据长度 + public byte byStatus; //状态值:0-成功,1-图片大小错误 + public byte[] byRes1 = new byte[3]; + public byte[] szMPID = new byte[64]; //检测模型包ID,用于匹配AIOP的检测数据解析; + public Pointer pBufferAIOPData;//AIOPDdata数据 + public int dwPresetIndex; //预置点序号 + public byte[] byRes = new byte[180]; + } + + + public static class NET_DVR_AI_PICTUR_UPLOAD extends Structure { + public int dwSize; + public byte[] szTaskID = new byte[64]; //任务id,strlen.max = 64,业务平台统一维护管理 + public byte[] szPID = new byte[64]; //图片id,strlen.max = 64,业务平台统一维护管理 + public byte[] byRes = new byte[128]; + } + + // AI开放平台接入轮询视频检测报警结构体。 + public static class NET_AIOP_POLLING_SNAP_HEAD extends Structure { + public int dwSize; //dwSize = sizeof(NET_AIOP_POLLING_SNAP_HEAD) + public int dwChannel; //设备分析通道的通道号(走SDK协议); + public NET_DVR_SYSTEM_TIME struTime = new NET_DVR_SYSTEM_TIME(); //时间 + public byte[] szTaskID = new byte[64]; //轮询抓图任务ID,来自于轮询抓图任务派发 + public int dwAIOPDataSize; //对应AIOPDdata数据长度 + public int dwPictureSize; //对应分析图片长度 + public byte[] szMPID = new byte[64]; //检测模型包ID,用于匹配AIOP的检测数据解析; + public Pointer pBufferAIOPData;//AIOPDdata数据 + public Pointer pBufferPicture;//分析图片数据 + public byte byPictureMode;//图片数据传输模式 0-二进制,1-武汉云云存储,当byPictureMode为0时pBufferPicture为二进制数据,当byPictureMode为1时pBufferPicture为武汉云URL + public byte[] byRes2 = new byte[3];//保留字节 + public int dwPresetIndex; //预置点序号 + public byte[] byRes = new byte[176]; + } + + // AI开放平台接入轮询视频检测报警结构体。 + public static class NET_AIOP_POLLING_VIDEO_HEAD extends Structure { + public int dwSize; //dwSize = sizeof(NET_AIOP_POLLING_VIDEO_HEAD) + public int dwChannel; //设备分析通道的通道号(走SDK协议); + public NET_DVR_SYSTEM_TIME struTime; //时间 + public byte[] szTaskID = new byte[64]; //轮询抓图任务ID,来自于轮询抓图任务派发 + public int dwAIOPDataSize; //对应AIOPDdata数据长度 + public int dwPictureSize; //对应分析图片长度 + public byte[] szMPID = new byte[64]; //检测模型包ID,用于匹配AIOP的检测数据解析; + public Pointer pBufferAIOPData;//AIOPDdata数据 + public Pointer pBufferPicture;//对应分析图片数据 + public byte byPictureMode;//图片数据传输模式 0-二进制,1-武汉云云存储,当byPictureMode为0时pBufferPicture为二进制数据,当byPictureMode为1时pBufferPicture为武汉云URL + public byte[] byRes2 = new byte[3];//保留字节 + public int dwPresetIndex; //预置点序号 + public byte[] byRes = new byte[176]; + } + + //规则触发参数 + public static class NET_VCA_RULE_TRIGGER_PARAM extends Structure { + public byte byTriggerMode; //规则的触发方式,0- 不启用,1- 轨迹点 2- 目标面积 + public byte byTriggerPoint; //触发点,触发方式为轨迹点时有效 0- 中,1-上,2-下 + public byte[] byRes1 = new byte[2]; //保留 + public float fTriggerArea; //触发目标面积百分比 [0,100],触发方式为目标面积时有效 + public byte[] byRes2 = new byte[4]; //保留 + } + + public static class NET_VCA_ONE_RULE_V42 extends Structure { + public byte byActive; //是否激活规则, 0-否,非0-是 + public byte byEventPriority;//事件优先级 0-低,1-中,2-高 + public byte[] byRes1 = new byte[4]; //保留,设置为0字段 + public short wEventType; //行为事件类型,参考VCA_RULE_EVENT_TYPE_EX + public byte[] byRuleName = new byte[NAME_LEN/*32*/]; //规则名称 + public NET_VCA_EVENT_UNION uEventParam; //行为分析事件参数 + public NET_VCA_SIZE_FILTER struSizeFilter; //尺寸过滤器 + public NET_DVR_SCHEDTIMEWEEK[] struAlarmTime = new NET_DVR_SCHEDTIMEWEEK[MAX_DAYS];//布防时间 + public NET_DVR_HANDLEEXCEPTION_V40 struAlarmHandleType; /*处理方式*/ + //异常处理方式中报警输出号与组号绑定,即组号为0时,表示关联的报警输出号范围为1-64,当组号为1时,表示关联的报警输出号范围为65-128, 且是组内紧凑排列,如果遇到0xffffffff表示本组 当前的及组内后续的报警出号无效 + public int[] dwRelRecordChan = new int[MAX_CHANNUM_V30]; /* 报警触发的录象通道(四字节的通道号,初始值是 0xffffffff)*/ + //关联的录像通道号与组号绑定,即组号为0时,表示关联的通道号范围为1-64,当组号为1时,表示关联的通道号范围为65-128, 且是组内紧凑排列,如果遇到0xffffffff表示本组 当前的及组内后续的关联通道号无效 + public short wAlarmDelay; //智能报警延时,0-5s,1-10,2-30s,3-60s,4-120s,5-300s,6-600s + public byte[] byRes2 = new byte[2]; //保留 + public NET_VCA_FILTER_STRATEGY struFilterStrategy; //尺寸过滤策略 + public NET_VCA_RULE_TRIGGER_PARAM struTriggerParam; //规则触发参数 + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_PTZ_POSITION extends Structure { + // 是否启用场景,在设置场景行为规则的时候该字段无效,在设置球机本地配置场景位置信息时作为使能位 + public byte byEnable; + public byte[] byRes1 = new byte[3]; //保留 + public byte[] byPtzPositionName = new byte[NAME_LEN]; //场景位置名称 + public NET_DVR_PTZPOS struPtzPos; //ptz 坐标 + public byte[] byRes2 = new byte[40]; + } + + //行为分析配置结构体 + public static class NET_VCA_RULECFG_V42 extends Structure { + public int dwSize; //结构图大小 + public byte byPicProType; //报警时图片处理方式 0-不处理 1-上传 + public byte byUpLastAlarm; //是否先上传最近一次的报警,0-否,1-是 + public byte byPicRecordEnable; //是否启用图片存储, 0-不启用, 1-启用 + public byte byRes1; + public NET_DVR_JPEGPARA struPicParam; //图片规格结构 + public NET_VCA_ONE_RULE_V42[] struRule = new NET_VCA_ONE_RULE_V42[16]; /* 规则数组*/ + public short[] wRelSnapChan = new short[3]; //关联抓图通道,当主通道报警时,同时会上传关联通道的抓拍图片,0表示不关联,其他值为关联通道号 + public byte byTrackEnable; //是否启用跟踪 + public byte byRes2; + public NET_DVR_PTZ_POSITION struPTZPosition; //场景位置信息 + public short wTrackDuration; //跟踪持续时间,单位s + public short wIntervalTime; //单次报警间隔时间(秒)[1-7200](ˆ默认为600) + public short wHeightLimit;//目标检测高度下限(厘米)[0-250](默认为80cm),小于此高度的目标将不作为目标进行检测 + public byte[] byRes = new byte[58];//保留 + } + + public static final int CID_CODE_LEN = 4; + public static final int DEV_SERIAL_LEN = 9; + public static final int ACCOUNTNUM_LEN = 6; + public static final int ACCOUNTNUM_LEN_32 = 32; + + public static class NET_DVR_CID_ALARM extends Structure { + public int dwSize; + public byte[] sCIDCode = new byte[CID_CODE_LEN/*4*/]; //CID事件号 + public byte[] sCIDDescribe = new byte[NAME_LEN/*32*/]; //CID事件名 + public NET_DVR_TIME_EX struTriggerTime = new NET_DVR_TIME_EX(); //触发报警的时间点 + public NET_DVR_TIME_EX struUploadTime = new NET_DVR_TIME_EX(); //上传报警的时间点 + public byte[] sCenterAccount = new byte[ACCOUNTNUM_LEN/*6*/]; //中心帐号 + public byte byReportType; //见定义NET_DVR_ALARMHOST_REPORT_TYPE + public byte byUserType; //用户类型,0-网络用户 1-键盘用户,2-手机用户,3-系统用户 + public byte[] sUserName = new byte[NAME_LEN/*32*/]; //网络用户用户名 + public short wKeyUserNo; //键盘用户号 0xFFFF表示无效 + public byte byKeypadNo; //键盘号 0xFF表示无效 + public byte bySubSysNo; //子系统号 0xFF表示无效 + public short wDefenceNo; //防区号 0xFFFF表示无效 + public byte byVideoChanNo; //视频通道号 0xFF表示无效 + public byte byDiskNo; //硬盘号 0xFF表示无效 + public short wModuleAddr; //模块地址 0xFFFF表示无效 + public byte byCenterType; //0-无效, 1-中心账号(长度6),2-扩展的中心账号(长度9) + public byte byRes1; + public byte[] sCenterAccountV40 = new byte[ACCOUNTNUM_LEN_32/*32*/]; //中心账号V40,使用此字段时sCenterAccount无效 + public byte[] byDevSerialNo = new byte[DEV_SERIAL_LEN]; /*产品序列号*/ + public byte byRepeaterNo; //中继器号,为0无效 + public short wRemoteCtrllerUserNo; //遥控器用户号,为0无效 + public int dwIOTChannelNo; //IOT通道号 + public byte[] byRes2 = new byte[12]; + } + + public static class NET_DVR_SENSOR_ALARM extends Structure { + public int dwSize; // 结构体大小 + public int dwAbsTime; // 绝对时标信息 OSD显示信息 + public byte[] byName = new byte[NAME_LEN]; // sensor 名称 + public byte bySensorChannel; // 模拟量通道 + public byte byType; // 模拟量类型 + public byte byAlarmType; // 1-上4、2-上3、3-上2、4-上1、5-下1、6-下2、7-下3、8-下4 和当前模式有关 + // 例如当为1000时,有上1下1,2,3报警四种报警 + public byte byAlarmMode; //报警模式,五种,-HHHH、-HHHL、-HHLL、HLLL、-LLLL, 作为平台报警程度判断功能,即:1111(上上上上),1110(上上上下),1100(上上下下),1000(上下下下),0000(下下下下) + public float fValue; // 但前模拟量的值 + public float fOriginalValue; //原始电流电压值,保留小数点后三位,具体值表示电流还是电压根据NET_DVR_SENSOR_INFO的bySensorStandard类型 + public byte[] byRes2 = new byte[28]; // 保留字节 + } + + //开关量报警上传 + public static class NET_DVR_SWITCH_ALARM extends Structure { + public int dwSize; + public byte[] byName = new byte[NAME_LEN]; // switch 名称 + public short wSwitchChannel; // 开关量通道, 0-255 + public byte byAlarmType; // 报警类型 0--正常,1--短路,2--断路,3-异常 + public byte[] byRes = new byte[41]; // 保留字节 + } + + public static class NET_DVR_ALARMHOST_EXCEPTION_ALARM extends Structure { + public int dwSize; // 结构体大小 + // 异常参数 1-设备防拆报警 2-设备防拆后后恢复正常 3-主电源掉电报警 4-主电源掉电后恢复正常 5-内部通信故障报警 + // 6-内部通信故障后恢复正常 7-电话线断线 8-电话线断线恢复 9-自检失败报警 10-自检失败后恢复正常 + // 11蓄电池欠压 12蓄电池电压恢复正常,13-蓄电池故障;14-MBUS模块掉线;15-MBUS模块掉线恢复;16-键盘掉线; + //17-键盘掉线恢复;18-设备被移动;19-设备被移动复位 20-485外设线路断报警 21-485外设线路断后恢复正常 + //25-子板1插上,26-子板1拔出, 27-子板2插上,28-子板2拔出 + public int dwExceptionType; + public byte[] byRes = new byte[36]; // 保留 + } + + + public static class NET_DVR_ALARMHOST_POINT_VALUE extends Structure { + public byte byChanType; //接入类型,1-本地模拟量通道,2-本地开关量通道,3-485通道,4-网络通道 + public byte byPointType; //点类型,1-遥测(模拟量),2-遥信(开关量) + public byte[] byRes1 = new byte[2]; //保留 + public int dwChanNo; //485通道号,0xffffffff表示无效,通道类型为1时:表示本地模拟量通道号,通道类型为2时表示本地开关量通道号,通道类型为3时表示485通道号。 + public int dwSubChanNo; //槽位号, 0xffffffff表示无效,通道类型为3时使用 + public int dwVariableNo; //变量编号,0xffffffff表示无效 + public int dwPointNo; //104点号,0xffffffff表示无效 + public int iValue; //监测点的值,表示低32位 + public int iValueEx; //监测点的值,表示高32位 + public byte[] byRes = new byte[12]; + } + + public static class NET_DVR_ALARMHOST_DATA_UNION extends Structure { + public byte[] byLength = new byte[40]; + public NET_DVR_ALARMHOST_POINT_VALUE struPointValue; //监测点实时数据 + } + + public static class NET_DVR_ALARMHOST_DATA_UPLOAD extends Structure { + public int dwSize; + public byte byDataType; //数据类型,1-监测点实时数据上传 + public byte[] byRes1 = new byte[3]; + public NET_DVR_ALARMHOST_DATA_UNION struAlarmData; + public byte[] byRes2 = new byte[32]; + } + + //车牌识别结果子结构 + public static class NET_DVR_PLATE_INFO extends Structure { + public byte byPlateType; //车牌类型 + public byte byColor; //车牌颜色 + public byte byBright; //车牌亮度 + public byte byLicenseLen; //车牌字符个数 + public byte byEntireBelieve; //整个车牌的置信度,-100 + public byte byRegion; // 区域索引值 0-保留,1-欧洲(EU),2-俄语区域(ER),3-欧洲&俄罗斯(EU&CIS) ,4-中东(ME),0xff-所有 + public byte byCountry; // 国家索引值,参照枚举COUNTRY_INDEX(不支持"COUNTRY_ALL = 0xff, //ALL 全部") + public byte byArea; //区域(省份),各国家内部区域枚举,阿联酋参照 EMI_AREA + public byte byPlateSize; //车牌尺寸,0~未知,1~long, 2~short(中东车牌使用) + public byte byAddInfoFlag; + public short wCRIndex;//国家/地区索引,索引值参考_CR_ INDEX_ + public byte[] byRes = new byte[12]; //保留 + public byte[] sPlateCategory = new byte[8];//车牌附加信息, 即中东车牌中车牌号码旁边的小字信息,(目前只有中东地区支持) + public int dwXmlLen; //XML报警信息长度 + public Pointer pXmlBuf; // XML报警信息指针,报警类型为 COMM_ITS_PLATE_RESUL时有效,其XML对应到EventNotificationAlert XML Block + public NET_VCA_RECT struPlateRect = new NET_VCA_RECT(); //车牌位置 + public byte[] sLicense = new byte[MAX_LICENSE_LEN]; //车牌号码,注:中东车牌需求把小字也纳入车牌号码,小字和车牌号中间用空格分隔 + public byte[] byBelieve = new byte[MAX_LICENSE_LEN]; //各个识别字符的置信度,如检测到车牌"浙A12345", 置信度为,20,30,40,50,60,70,则表示"浙"字正确的可能性只有%,"A"字的正确的可能性是% + } + + public static class NET_DVR_VEHICLE_INFO extends Structure { + public int dwIndex; //车辆序号 + public byte byVehicleType; //车辆类型 0 表示其它车型,1 表示小型车,2 表示大型车 ,3表示行人触发 ,4表示二轮车触发 5表示三轮车触发(3.5Ver) + public byte byColorDepth; //车身颜色深浅 + public byte byColor; //车身颜色,参考VCR_CLR_CLASS + /*雷达异常状态: + 0~雷达正常, + 1~雷达故障 + 2~雷达一直发送某一个相同速度值 + 3~雷达送出数据为0 + 4~雷达送出数据过大或者过小 + */ + public byte byRadarState; + public short wSpeed; //单位km/h + public short wLength; //前一辆车的车身长度 + /*违规类型,0-正常,1-低速,2-超速,3-逆行,4-闯红灯,5-压车道线,6-不按导向,7-路口滞留, + 8-机占非,9-违法变道,10-不按车道 11-违反禁令,12-路口停车,13-绿灯停车, 14-未礼让行人(违法代码1357), + 15-违章停车,16-违章掉头,17-占用应急车道,18-禁右,19-禁左,20-压黄线,21-未系安全带,22-行人闯红灯,23-加塞,24-违法使用远光灯, + 25-驾驶时拨打接听手持电话,26-左转不让直行,27-右转不让左转,28-掉头不让直行,29-大弯小转, 30-闯绿灯,31-未带头盔, + 32-非机动车载人,33-非机动车占用机动车道,34-非机动车打伞棚, 35-黑烟车, 36-鸣笛*/ + public byte byIllegalType; + public byte byVehicleLogoRecog; //参考枚举类型 VLR_VEHICLE_CLASS + public byte byVehicleSubLogoRecog; //车辆品牌子类型识别;参考VSB_VOLKSWAGEN_CLASS等子类型枚举。 + public byte byVehicleModel; //车辆子品牌年款,0-未知,参考"车辆子品牌年款.xlsx" + public byte[] byCustomInfo = new byte[16]; //自定义信息 + public short wVehicleLogoRecog; //车辆主品牌,参考"车辆主品牌.xlsx" (该字段兼容byVehicleLogoRecog); + public byte byIsParking;//是否停车 0-无效,1-停车,2-未停车 + public byte byRes;//保留字节 + public int dwParkingTime; //停车时间,单位:s + public byte[] byRes3 = new byte[8]; + } + + //手动抓拍 + public static class NET_DVR_MANUALSNAP extends Structure { + public byte byOSDEnable;//0-不关闭(默认),1-关闭 + public byte byLaneNo;//车道号, 范围为1-6,默认为1(抓拍机内部测试使用) + public byte byChannel;//通道号 + public byte[] byRes = new byte[21]; //保留 + } + + //交通抓拍结果信息 + public static class NET_DVR_PLATE_RESULT extends Structure { + public int dwSize; + public byte byResultType; + public byte byChanIndex; + public short wAlarmRecordID; + public int dwRelativeTime; + public byte[] byAbsTime = new byte[32]; + public int dwPicLen; + public int dwPicPlateLen; + public int dwVideoLen; + public byte byTrafficLight; + public byte byPicNum; + public byte byDriveChan; + public byte byVehicleType; + public int dwBinPicLen; + public int dwCarPicLen; + public int dwFarCarPicLen; + public Pointer pBuffer3; + public Pointer pBuffer4; + public Pointer pBuffer5; + public byte[] byRes3 = new byte[8]; + public NET_DVR_PLATE_INFO struPlateInfo; + public NET_DVR_VEHICLE_INFO struVehicleInfo; + public Pointer pBuffer1; + public Pointer pBuffer2; + } + + public static class NET_DVR_TIME_V30 extends Structure { + public short wYear; + public byte byMonth; + public byte byDay; + public byte byHour; + public byte byMinute; + public byte bySecond; + public byte byRes; + public short wMilliSec; + public byte[] byRes1 = new byte[2]; + + + } + + public static class NET_ITS_PICTURE_INFO extends Structure { + public int dwDataLen; + public byte byType; + public byte byDataType; + public byte byCloseUpType; + public byte byPicRecogMode; + public int dwRedLightTime; + public byte[] byAbsTime = new byte[32]; + public NET_VCA_RECT struPlateRect = new NET_VCA_RECT(); + public NET_VCA_RECT struPlateRecgRect = new NET_VCA_RECT(); + public Pointer pBuffer; + public int dwUTCTime;//UTC时间 + public byte byCompatibleAblity;//兼容能力字段,按位表示,值:0- 无效,1- 有效 + public byte byTimeDiffFlag; /*时差字段是否有效 0-时差无效, 1-时差有效 */ + public byte cTimeDifferenceH; /*与UTC的时差(小时),-12 ... +14, +表示东区,,byTimeDiffFlag为1时有效*/ + public byte cTimeDifferenceM; /*与UTC的时差(分钟),-30, 30, 45, +表示东区,byTimeDiffFlag为1时有效*/ + public byte[] byRes2 = new byte[4]; + } + + public static class NET_ITS_PLATE_RESULT extends Structure { + public int dwSize; + public int dwMatchNo; + public byte byGroupNum; + public byte byPicNo; + public byte bySecondCam; + public byte byFeaturePicNo; + public byte byDriveChan; + public byte byVehicleType; + public byte byDetSceneID; + public byte byVehicleAttribute; + public short wIllegalType; + public byte[] byIllegalSubType = new byte[8]; + public byte byPostPicNo; + public byte byChanIndex; + public short wSpeedLimit; + public byte byChanIndexEx; //byChanIndexEx*256+byChanIndex表示真实通道号。 + public byte byRes2; + public NET_DVR_PLATE_INFO struPlateInfo = new NET_DVR_PLATE_INFO(); + public NET_DVR_VEHICLE_INFO struVehicleInfo = new NET_DVR_VEHICLE_INFO(); + public byte[] byMonitoringSiteID = new byte[48]; + public byte[] byDeviceID = new byte[48]; + public byte byDir; + public byte byDetectType; + public byte byRelaLaneDirectionType; + public byte byCarDirectionType; + public int dwCustomIllegalType; + public Pointer pIllegalInfoBuf; + public byte byIllegalFromatType; + public byte byPendant; + public byte byDataAnalysis; + public byte byYellowLabelCar; + public byte byDangerousVehicles; + public byte byPilotSafebelt; + public byte byCopilotSafebelt; + public byte byPilotSunVisor; + public byte byCopilotSunVisor; + public byte byPilotCall; + public byte byBarrierGateCtrlType; + public byte byAlarmDataType; + public NET_DVR_TIME_V30 struSnapFirstPicTime = new NET_DVR_TIME_V30(); + public int dwIllegalTime; + public int dwPicNum; + public NET_ITS_PICTURE_INFO[] struPicInfo = new NET_ITS_PICTURE_INFO[6]; + } + + public int MAX_PARKNO_LEN = 16; //车位编号长度 + public int MAX_ID_LEN = 48; //编号最大长度 + + //停车场数据上传 + public static class NET_ITS_PARK_VEHICLE extends Structure { + public int dwSize; //结构长度 + public byte byGroupNum; //图片组数量(单次轮询抓拍的图片数量) + public byte byPicNo; //连拍的图片组上传图片序号(接收到图片组数量后,表示接收完成 + //接收超时不足图片组数量时,根据需要保留或删除) + public byte byLocationNum; //单张图片所管理的车位数 + public byte byParkError; //停车异常,0-正常 1 异常 + public byte[] byParkingNo = new byte[MAX_PARKNO_LEN];//车位编号 + public byte byLocationStatus; //车位车辆状态,0-无车,1有车 + public byte bylogicalLaneNum;//逻辑车位号,0-3,一个相机最大能管4个车位 (0代表最左边,3代表最右边) + public short wUpLoadType;//第零位表示:0~轮训上传、1~变化上传 + public byte[] byRes1 = new byte[4]; //保留字节 + public int dwChanIndex; //通道号数字通道 + public NET_DVR_PLATE_INFO struPlateInfo; //车牌信息结构 + public NET_DVR_VEHICLE_INFO struVehicleInfo; //车辆信息 + public byte[] byMonitoringSiteID = new byte[MAX_ID_LEN]; //监测点编号 + public byte[] byDeviceID = new byte[MAX_ID_LEN]; //设备编号 + public int dwPicNum; //图片数量(与picGroupNum不同,代表本条信息附带的图片数量,图片信息由struVehicleInfoEx定义 + public NET_ITS_PICTURE_INFO[] struPicInfo = new NET_ITS_PICTURE_INFO[2]; //图片信息,单张回调,最多2张图,由序号区分 + public byte[] byRes2 = new byte[256]; + } + + public static class NET_DVR_SNAPCFG extends Structure { + + public int dwSize; + public byte byRelatedDriveWay;//触发IO关联的车道号 + public byte bySnapTimes; //线圈抓拍次数,0-不抓拍,非0-连拍次数,目前最大5次 + public short wSnapWaitTime; //抓拍等待时间,单位ms,取值范围[0,60000] + public short[] wIntervalTime = new short[MAX_INTERVAL_NUM];//连拍间隔时间,ms + public int dwSnapVehicleNum; //抓拍车辆序号。 + public NET_DVR_JPEGPARA struJpegPara;//抓拍图片参数 + public byte[] byRes2 = new byte[16]; + } + + // 道闸控制 + public static class NET_DVR_BARRIERGATE_CFG extends Structure { + public int dwSize; + public int dwChannel; //通道号 + public byte byLaneNo; //道闸号(0-表示无效值(设备需要做有效值判断),1-道闸1) + /* + 若老的平台不支持byUnlock字段,该字段将赋值为0,通过“0-关闭道闸,1-开启道闸,2-停止道闸”中的任何一种操作皆可进行解锁。 + 若新平台支持byUnlock字段,需byUnlock字段赋值为1,并结合4~解锁道闸来进行解锁。byUnlock字段赋值为1后,“0-关闭道闸,1-开启道闸,2-停止道闸”操作将不可用于解锁。 + */ + public byte byBarrierGateCtrl;//0-关闭道闸,1-开启道闸,2-停止道闸 3-锁定道闸,4~解锁道闸 + public byte byEntranceNo;//出入口编号 [1,8] + public byte byUnlock;//启用解锁使能,0~为不启用,1~启用 + public byte[] byRes = new byte[12]; + } + + + public static class NET_DVR_AGEGROUP_PARAM extends Structure { + public int dwTeenage;//少年(人数) + public int dwYouth;//青年(人数) + public int dwMidLife;//中年(人数) + public int dwElderly;//老年(人数) + public int dwChild;//儿童(人数) + public int dwAdolescent;//青少年(人数) + public int dwPrime;//壮年(人数) + public int dwMidage;//中老年(人数) + public byte[] byRes = new byte[48]; + } + + public static class NET_DVR_SEXGROUP_PARAM extends Structure { + public int dwMale;//男(人数) + public int dwFemale;//女(人数) + public byte[] byRes = new byte[64]; + } + + public static class NET_DVR_PROGRAM_INFO extends Structure { + public int dwProgramNo; //节目编号 + public byte[] sProgramName = new byte[NAME_LEN]; //节目名称 + public byte[] byRes = new byte[16]; + } + + public static class NET_DVR_FACECAPTURE_STATISTICS_RESULT extends Structure { + public int dwSize; + public NET_DVR_TIME_EX struStartTime;/*间隔开始时间*/ + public NET_DVR_TIME_EX struEndTime;/*间隔结束时间*/ + public byte byStatType;//数据类型统计:Bit0-年龄段有效,Bit1-性别有效,Bit2-人数有效 + public byte[] byRes = new byte[7]; + public int dwPeopleNum;//人数统计 + public NET_DVR_AGEGROUP_PARAM struAgeGroupParam;//年龄段人数统计 + public NET_DVR_SEXGROUP_PARAM struSexGroupParam;//性别人数统计 + public NET_DVR_PROGRAM_INFO struProgramInfo; //节目信息 + public byte[] byRes1 = new byte[76]; + } + + //获取交通数据条件结构 + public static class NET_DVR_TRAFFIC_DATA_QUERY_COND extends Structure { + public int dwSize; + /* + Bit0-通道有效 + Bit1-时间有效 + Bit2-车牌号有效 + Bit3-车牌类型有效 + Bit4-车牌颜色有效 + Bit5-车身颜色有效 + Bit6-车辆类型有效 + Bit7-车辆品牌有效 + Bit8-车道号有效 + Bit9-监测方向有效 + Bit10-最低速度有效 + Bit11-最高速度有效 + Bit12-数据类型有效 + Bit13-布控方式类型有效 + Bit14-违法取证有效 + Bit15-事件类型有效 + Bit16-取证类型有效 + */ + public int dwQueryCond;//查询条件 0表示无效,1表示有效 + public int dwChannel;//默认是1([1~32],bit0表示通道1,依次类推bit31表示通道32) + public NET_DVR_TIME_V30 struStartTime;//开始时间 + public NET_DVR_TIME_V30 struEndTime;//结束时间 + public byte[] sLicense = new byte[MAX_LICENSE_LEN/*16*/];//(设备支持模糊查询, GB2312编码) + /* + Bit0-未知(其他) + Bit1-标准民用车与军车 + Bit2-02式民用车牌 + Bit3-武警车 + Bit4-警车 + Bit5-民用车双行尾牌 + Bit6-使馆车牌 + Bit7-农用车 + Bit8-摩托车 + */ + public int dwPlateType;//车牌类型(支持按位表示,可以复选) + /* + Bit0-未知(其他) + Bit1-黄色 + Bit2-白色 + Bit3-黑色 + Bit4-绿色 + Bit5-蓝色 + */ + public int dwPlateColor;//车牌颜色(支持按位表示,可以复选) + /* + Bit0-未ª知(其他) + Bit1-白色 + Bit2-银色 + Bit3-灰色 + Bit4-黑色 + Bit5-红色 + Bit6-深蓝色 + Bit7-蓝色 + Bit8-黄色 + Bit9-绿色 + Bit10-棕色 + Bit11-粉色 + Bit12-紫色 + Bit13-深灰色 + */ + public int dwVehicleColor;//车身颜色(支持按位表示,可以复选) + /* + Bit0-未知(其他) + Bit1-客车 + Bit2-大货车 + Bit3-轿车 + Bit4-面包车 + Bit5-小货车 + Bit6-行人 + Bit7-二轮车 + Bit8-三轮车 + Bit9-SUV/MPV + Bit10-中型客车 + */ + public int dwVehicleType;//车辆类型(支持按位表示,可以复选) + /** + * Bit0-其他(保留) + * Bit1-低速 + * Bit2-超速 + * Bit3-逆行 + * Bit4-闯红灯 + * Bit5-压车道线 + * Bit6-不按导向 + * Bit7-路口滞留 + * Bit8-机占非 + * Bit9-违法变道 + * Bit10-不按车道 + * Bit11-违反禁令 + * Bit12-路口停车 + * Bit13-绿灯停车 + * Bit14-未礼让行人 + * Bit15-违章停车 + * Bit16-违章掉头 + * Bit17-占用应急车道 + * Bit18-未系安全带 + */ + public int dwIllegalType; + /** + * Bit0-其他(保留) + * Bit1-拥堵 + * Bit2-停车 + * Bit3-逆行 + * Bit4-行人 + * Bit5-抛洒物 + * Bit6-烟雾 + * Bit7-压线 + * Bit8-禁止名单 + * Bit9-超速 + * Bit10-变道 + * Bit11-掉头 + * Bit12-机占非 + * Bit13-加塞 + */ + public int dwEventType; + /** + * Bit0-其他(保留) + * Bit1-城市公路违法停车 + * Bit2-高速公路违法停车 + * Bit3-压线 + * Bit4-逆行 + * Bit5-违法变道 + * Bit6-机占非 + */ + public int dwForensiceType; + public short wVehicleLogoRecog; //车辆主品牌,参考"车辆主品牌.xlsx" (仅单选) + public byte byLaneNo;//车道号(0~255,0号车道 表示 车道号未知) + public byte byDirection;//监测方向,1-上行,2-下行,3-双向,4-由东向西,5-由南向北,6-由西向东,7-由北向南 + public short wMinSpeed;//最低速度(0~999)单位km/h + public short wMaxSpeed;//最高速度(0~999)单位km/h + public byte byDataType;//数据类型 0-卡口数据,1-违法数据,2-交通事件,3-取证数据 (仅单选) + public byte byExecuteCtrl;//布控 0-允许名单,1-禁止名单,0xff-其他 + public byte[] byRes = new byte[254]; + } + + public static final int MAX_TRAFFIC_PICTURE_NUM = 8; //交通图片数量 + + //交通数据结构体 + public static class NET_DVR_TRAFFIC_DATA_QUERY_RESULT extends Structure { + public int dwSize; + public int dwChannel;//默认是1([1~32]) + public byte[] sLicense = new byte[MAX_LICENSE_LEN/*16*/]; + /* + Bit0-未知(其他) + Bit1-标准民用车与军车 + Bit2-02式民用车牌 + Bit3-武警车 + Bit4-警车 + Bit5-民用车双行尾牌 + Bit6-使馆车牌 + Bit7-农用车 + Bit8-摩托车 + */ + public int dwPlateType;//车牌类型 + /* + Bit0-未知(其他) + Bit1-黄色 + Bit2-白色 + Bit3-黑色 + Bit4-绿色 + Bit5-蓝色 + */ + public int dwPlateColor;//车牌颜色 + /* + Bit0-未知(其他) + Bit1-白色 + Bit2-银色 + Bit3-灰色 + Bit4-黑色 + Bit5-红色 + Bit6-深蓝色 + Bit7-蓝色 + Bit8-黄色 + Bit9-绿色 + Bit10-棕色 + Bit11-粉色 + Bit12-紫色 + Bit13-深灰色 + */ + public int dwVehicleColor;//车身颜色 + /* + Bit0-未知(其他) + Bit1-客车 + Bit2-大货车 + Bit3-轿车 + Bit4-面包车 + Bit5-小货车 + Bit6-行人 + Bit7-二轮车 + Bit8-三轮车 + Bit9-SUV/MPV + Bit10-中型客车 + Bit11-机动车 + Bit12-非机动车 + Bit13-小型轿车 + Bit14-微型轿车 + Bit15-皮卡车 + Bit16-集装箱卡车 + Bit17-微卡,栏板卡 + Bit18-渣土车 + Bit19-吊车,工程车 + Bit20-油罐车 + Bit21-混凝土搅拌车 + Bit22-平板拖车 + Bit23-两厢轿车 + Bit24-三厢轿车 + Bit25-轿跑 + Bit26-小型客车 + */ + public int dwVehicleType;//车辆类型 + /** + * Bit0-其他(保留) + * Bit1-低速 + * Bit2-超速 + * Bit3-逆行 + * Bit4-闯红灯 + * Bit5-压车道线 + * Bit6-不按导向 + * Bit7-路口滞留 + * Bit8-机占非 + * Bit9-违法变道 + * Bit10-不按车道 + * Bit11-违反禁令 + * Bit12-路口停车 + * Bit13-绿灯停车 + * Bit14-未礼让行人 + * Bit15-违章停车 + * Bit16-违章掉头 + * Bit17-占用应急车道 + * Bit18-未系安全带 + */ + public int dwIllegalType; + /** + * Bit0-其他(保留) + * Bit1-拥堵 + * Bit2-停车 + * Bit3-逆行 + * Bit4-行人 + * Bit5-抛洒物 + * Bit6-烟雾 + * Bit7-压线 + * Bit8-禁止名单 + * Bit9-超速 + * Bit10-变道 + * Bit11-掉头 + * Bit12-机占非 + * Bit13-加塞 + */ + public int dwEventType; + /** + * Bit0-其他(保留) + * Bit1-城市公路违法停车 + * Bit2-高速公路违法停车 + * Bit3-压线 + * Bit4-逆行 + * Bit5-违法变道 + * Bit6-机占非 + */ + public int dwForensiceType; + public short wVehicleLogoRecog; //车辆主品牌,参考"车辆主品牌.xlsx" + public byte byLaneNo;//车道号(0~255,0号车道 表示 车道号未知) + public byte byDirection;//监测方向,1-上行,2-下行,3-双向,4-由东向西,5-由南向北,6-由西向东,7-由北向南 + public short wSpeed;//速度(0~999)单位km/h + public byte byDataType;//数据类型: 0-卡口 1-违法 2-事件 3-取证 + public byte[] byRes = new byte[253]; + public NET_DVR_TRAFFIC_PICTURE_PARAM[] struTrafficPic = new NET_DVR_TRAFFIC_PICTURE_PARAM[MAX_TRAFFIC_PICTURE_NUM/*8*/]; + } + + //交通图片参数子结构 + public static final int PICTURE_NAME_LEN = 64; + + public static class NET_DVR_TRAFFIC_PICTURE_PARAM extends Structure { + public NET_DVR_TIME_V30 struRelativeTime = new NET_DVR_TIME_V30(); //抓拍相对时标 + public NET_DVR_TIME_V30 struAbsTime = new NET_DVR_TIME_V30(); //抓拍绝对时标 + public byte[] szPicName = new byte[PICTURE_NAME_LEN/*64*/]; + public byte byPicType;//图片类型 0-车牌图,1-抓拍原图,2-合成图,3-特写图 + public byte[] byRes = new byte[63]; + } + + public static class NET_DVR_VEHICLE_CONTROL_COND extends Structure { + public int dwChannel; + public int dwOperateType; + public byte[] sLicense = new byte[MAX_LICENSE_LEN]; + public byte[] sCardNo = new byte[48]; + public byte byListType; + public byte[] byRes1 = new byte[3]; + public int dwDataIndex; + public byte[] byRes = new byte[116]; + } + + public static class NET_DVR_VEHICLE_CONTROL_LIST_INFO extends Structure { + public int dwSize; + public int dwChannel; + public int dwDataIndex; + public byte[] sLicense = new byte[16]; + public byte byListType; + public byte byPlateType; + public byte byPlateColor; + public byte[] byRes = new byte[21]; + public byte[] sCardNo = new byte[48]; + public NET_DVR_TIME_V30 struStartTime = new NET_DVR_TIME_V30(); + public NET_DVR_TIME_V30 struStopTime = new NET_DVR_TIME_V30(); + public byte[] sOperateIndex = new byte[32]; + public byte[] byRes1 = new byte[224]; + } + + //车辆报警 + public static class NET_DVR_VEHICLE_CONTROL_ALARM extends Structure { + public int dwSize; + public byte byListType; //名单属性:0-允许名单,1-禁止名单,2-临时名单 + public byte byPlateType; //车牌类型 + public byte byPlateColor; //车牌颜色 + public byte byRes1; + public byte[] sLicense = new byte[MAX_LICENSE_LEN];//车牌号码 + public byte[] sCardNo = new byte[MAX_CARDNO_LEN]; // 卡号 + public NET_DVR_TIME_V30 struAlarmTime = new NET_DVR_TIME_V30(); //报警时间 + public int dwChannel; //设备通道号,如果直连的是IPC,则为ipc通道号;如果连的DVR\nvr,则为DVR\NVR的通道号 + public int dwPicDataLen; //图片数据大小,0表示无图片,不为0是表示后面带图片数据 + public byte byPicType; //图片类型,0-JPEG + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public byte[] byRes3 = new byte[2]; + public Pointer pPicData; + public byte[] byRes2 = new byte[48]; + } + + public int MAX_LED_INFO_LEN = 512; + public int MAX_VOICE_INFO_LEN = 128; + + //LED屏幕显示参数 + public static class NET_DVR_LEDDISPLAY_CFG extends Structure { + public int dwSize;//结构体大小 + public byte[] sDisplayInfo = new byte[MAX_LED_INFO_LEN/*512*/]; // LED显示内容 + public byte byDisplayMode;//显示方式:0~左移,1~右移,2~立即显示 + public byte bySpeedType;//速度类型:0~快,1~中,2~慢 + public byte byShowPlateEnable;//显示车牌使能,0~关闭,1~启用 + public byte byRes1; + public int dwShowTime;//显示时长,1~60秒 + public byte[] byRes = new byte[128]; + } + + //语音播报控制参数 + public static class NET_DVR_VOICEBROADCAST_CFG extends Structure { + public int dwSize;//结构体大小 + public byte[] sInfo = new byte[MAX_VOICE_INFO_LEN/*128*/]; //语音播报内容 + public byte byBroadcastNum;// 语音播报次数, 1~10次 + public byte byIntervalTime;// 语音播报间隔时间,1~5s + public byte[] byRes = new byte[126]; + } + + //缴费金额信息 + public static class NET_DVR_CHARGEACCOUNT_CFG extends Structure { + public int dwSize;//结构体大小 + public float fAccount;//实际收费金额 + public byte[] byRes = new byte[128]; + } + + public static final int DOOR_NAME_LEN = 32; //门名称 + public static final int STRESS_PASSWORD_LEN = 8; //胁迫密码长度 + public static final int SUPER_PASSWORD_LEN = 8; //胁迫密码长度 + public static final int UNLOCK_PASSWORD_LEN = 8; // 解除密码长度 + + public static class NET_DVR_DOOR_CFG extends Structure { + public int dwSize; + public byte[] byDoorName = new byte[DOOR_NAME_LEN]; //门名称 + public byte byMagneticType; //门磁类型,0-常闭,1-常开 + public byte byOpenButtonType; //开门按钮类型,0-常闭,1-常开 + public byte byOpenDuration; //开门持续时间,1-255s(楼层继电器动作时间) + public byte byDisabledOpenDuration; //残障人士卡开门持续时间,1-255s + public byte byMagneticAlarmTimeout; //门磁检测超时报警时间,0-255s,0表示不报警 + public byte byEnableDoorLock; //是否启用闭门回锁,0-否,1-是 + public byte byEnableLeaderCard; //是否启用首卡常开功能,0-否,1-是 + public byte byLeaderCardMode; //首卡模式,0-不启用首卡功能,1-首卡常开模式,2-首卡授权模式(使用了此字段,则byEnableLeaderCard无效) + public int dwLeaderCardOpenDuration; //首卡常开持续时间,1-1440min + public byte[] byStressPassword = new byte[STRESS_PASSWORD_LEN]; //胁迫密码 + public byte[] bySuperPassword = new byte[SUPER_PASSWORD_LEN]; //超级密码 + public byte[] byUnlockPassword = new byte[UNLOCK_PASSWORD_LEN]; //解除码NET_DVR_LOCAL_CONTROLLER_STATUS + public byte byUseLocalController; //只读,是否连接在就地控制器上,0-否,1-是 + public byte byRes1; + public short wLocalControllerID; //只读,就地控制器序号,1-64,0代表未注册 + public short wLocalControllerDoorNumber; //只读,就地控制器的门编号,1-4,0代表未注册 + public short wLocalControllerStatus; //只读,就地控制器在线状态:0-离线,1-网络在线,2-环路1上的RS485串口1,3-环路1上的RS485串口2,4-环路2上的RS485串口1,5-环路2上的RS485串口2,6-环路3上的RS485串口1,7-环路3上的RS485串口2,8-环路4上的RS485串口1,9-环路4上的RS485串口2(只读) + public byte byLockInputCheck; //是否启用门锁输入检测(1字节,0不启用,1启用,默认不启用) + public byte byLockInputType; //门锁输入类型(1字节,0常闭,1常开,默认常闭) + public byte byDoorTerminalMode; //门相关端子工作模式(1字节,0防剪防短,1普通,默认防剪防短) + public byte byOpenButton; //是否启用开门按钮(1字节,0是,1否,默认是) + public byte byLadderControlDelayTime; //梯控访客延迟时间,1-255min + public byte[] byRes2 = new byte[43]; + } + + public static class NET_DVR_DOOR_STATUS_PLAN extends Structure { + public int dwSize; + public int dwTemplateNo; //计划模板编号,为0表示取消关联,恢复默认状态(普通状态) + public byte[] byRes = new byte[64]; + } + + + public static class NET_DVR_EVENT_CARD_LINKAGE_COND extends Structure { + public int dwSize; + public int dwEventID; //事件ID + public short wLocalControllerID; //就地控制器序号[1,64] + public byte[] byRes = new byte[106]; + } + + public static final int MAX_ALARMHOST_ALARMIN_NUM = 512;//网络报警主机最大报警输入口数 + public static final int MAX_ALARMHOST_ALARMOUT_NUM = 512;//网络报警主机最大报警输出口数 + + public static class NET_DVR_EVENT_CARD_LINKAGE_CFG_V50 extends Structure { + public int dwSize; //结构体大小 + public byte byProMode; //联动方式,0-事件,1-卡号, 2-MAC地址 + public byte[] byRes1 = new byte[3]; + public int dwEventSourceID; //事件源ID,当主类型为设备事件时无效, 当主类型是门事件时为门编号;当主类型为读卡器事件时,为读卡器ID;当为报警输入事件时为防区报警输入ID或事件报警输入ID。0xffffffff表示联动全部 + public NET_DVR_EVETN_CARD_LINKAGE_UNION uLinkageInfo = new NET_DVR_EVETN_CARD_LINKAGE_UNION(); //联动方式参数 + public byte[] byAlarmout = new byte[MAX_ALARMHOST_ALARMOUT_NUM]; //关联的报警输出号,按位表示,为0表示不关联,为1表示关联 + public byte[] byRes2 = new byte[32]; //保留 + public byte[] byOpenDoor = new byte[MAX_DOOR_NUM_256]; //按位表示,是否联动开门,0-不联动,1-联动 + public byte[] byCloseDoor = new byte[MAX_DOOR_NUM_256]; //按位表示,是否联动关门,0-不联动,1-联动 + public byte[] byNormalOpen = new byte[MAX_DOOR_NUM_256]; //按位表示,是否联动常开,0-不联动,1-联动 + public byte[] byNormalClose = new byte[MAX_DOOR_NUM_256]; //按位表示,是否联动常关,0-不联动,1-联动 + public byte byMainDevBuzzer; //主机蜂鸣器 0-不联动,1-联动输出 + public byte byCapturePic; //是否联动抓拍,0-不联动抓拍,1-联动抓拍 + public byte byRecordVideo; //是否联动录像,0-不联动录像,1-联动录像 + public byte[] byRes3 = new byte[29]; //保留 + public byte[] byReaderBuzzer = new byte[MAX_CARD_READER_NUM_512]; //联动读卡器蜂鸣器,按位表示,0-不联动,1-联动 + public byte[] byAlarmOutClose = new byte[MAX_ALARMHOST_ALARMOUT_NUM]; //关联报警输出关闭,按字节表示,为0表示不关联,为1表示关联 + public byte[] byAlarmInSetup = new byte[MAX_ALARMHOST_ALARMIN_NUM]; //关联防区布防,按字节表示,为0表示不关联,为1表示关联 + public byte[] byAlarmInClose = new byte[MAX_ALARMHOST_ALARMIN_NUM]; //关联防区撤防,按字节表示,为0表示不关联,为1表示关联 + public byte[] byRes = new byte[500]; //保留 + } + + public static class NET_DVR_EVENT_LINKAGE_INFO extends Structure { + public short wMainEventType; //事件主类型,0-设备事件,1-报警输入事件,2-门事件,3-读卡器事件 + public short wSubEventType; //事件次类型 + public byte[] byRes = new byte[28]; + } + + public static class NET_DVR_EVETN_CARD_LINKAGE_UNION extends Union { + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //卡号 + public NET_DVR_EVENT_LINKAGE_INFO struEventLinkage; //事件联动时参数 + public byte[] byMACAddr = new byte[MACADDR_LEN]; //物理MAC地址 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + } + + //卡参数配置条件 + public static class NET_DVR_CARD_CFG_COND extends Structure { + public int dwSize; + public int dwCardNum; + public byte byCheckCardNo; + public byte[] ibyRes = new byte[31]; + } + + //获取卡参数的发送数据 + public static class NET_DVR_CARD_CFG_SEND_DATA extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[32]; + public byte[] byRes = new byte[16]; + } + + public static class CARDRIGHTPLAN extends Structure { + public byte[] byRightPlan = new byte[4]; + } + + //卡参数 + public static class NET_DVR_CARD_CFG extends Structure { + public int dwSize; + public int dwModifyParamType; + public byte[] byCardNo = new byte[32]; + public byte byCardValid; + public byte byCardType; + public byte byLeaderCard; + public byte byRes1; + public int dwDoorRight; + public NET_DVR_VALID_PERIOD_CFG struValid; + public int dwBelongGroup; + public byte[] byCardPassword = new byte[8]; + public CARDRIGHTPLAN[] byCardRightPlan = new CARDRIGHTPLAN[32]; + public int dwMaxSwipeTime; + public int dwSwipeTime; + public short wRoomNumber; + public short wFloorNumber; + public byte[] byRes2 = new byte[20]; + } + + public int ACS_CARD_NO_LEN = 32; //门禁卡号长度 + public int MAX_GROUP_NUM_128 = 128; //最大群组数 + public int MAX_DOOR_NUM_256 = 256; //最大门数 + public int CARD_PASSWORD_LEN = 8; //卡密码长度 + public int MAX_CARD_READER_NUM = 64; //最大读卡器数 + public int MAX_DOOR_CODE_LEN = 8; //房间代码长度 + public int MAX_LOCK_CODE_LEN = 8; //锁代码长度 + public int MAX_CARD_RIGHT_PLAN_NUM = 4; //卡权限最大计划个数 + public int MAX_CASE_SENSOR_NUM = 8; //最大case sensor触发器数 + + public static class CARDRIGHTPLAN_WORD extends Structure { + public short[] wRightPlan = new short[MAX_CARD_RIGHT_PLAN_NUM]; + } + + public static class NET_DVR_CARD_CFG_V50 extends Structure { + public int dwSize; + public int dwModifyParamType;//需要修改的卡参数,设置卡参数时有效,按位表示,每位代表一种参数,1为需要修改,0为不修改 + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //卡号 + public byte byCardValid; //卡是否有效,0-无效,1-有效(用于删除卡,设置时置为0进行删除,获取时此字段始终为1) + public byte byCardType; //卡类型,1-普通卡,2-残障人士卡,3-禁止名单卡,4-巡更卡,5-胁迫卡,6-超级卡,7-来宾卡,8-解除卡,9-员工卡,10-应急卡,11-应急管理卡,默认普通卡 + public byte byLeaderCard; //是否为首卡,1-是,0-否 + public byte byRes1; + public byte[] byDoorRight = new byte[MAX_DOOR_NUM_256]; //门权限(楼层权限),按位表示,1为有权限,0为无权限,从低位到高位表示对门1-N是否有权限 + public NET_DVR_VALID_PERIOD_CFG struValid; //有效期参数 + public byte[] byBelongGroup = new byte[MAX_GROUP_NUM_128]; //所属群组,按字节表示,1-属于,0-不属于 + public byte[] byCardPassword = new byte[CARD_PASSWORD_LEN]; //卡密码 + public CARDRIGHTPLAN_WORD[] wCardRightPlan = new CARDRIGHTPLAN_WORD[MAX_DOOR_NUM_256]; //卡权限计划,取值为计划模板编号,同个门不同计划模板采用权限或的方式处理 + public int dwMaxSwipeTime; //最大刷卡次数,0为无次数限制(开锁次数) + public int dwSwipeTime; //已刷卡次数 + public short wRoomNumber; //房间号 + public short wFloorNumber; //层号 + public int dwEmployeeNo; //工号 + public byte[] byName = new byte[NAME_LEN]; //姓名 + public short wDepartmentNo; //部门编号 + public short wSchedulePlanNo; //排班计划编号 + public byte bySchedulePlanType; //排班计划类型:0-无意义、1-个人、2-部门 + public byte byRightType; //下发权限类型:0-普通发卡权限、1-二维码权限、2-蓝牙权限(可视对讲设备二维码权限配置项:房间号、卡号(虚拟卡号)、最大刷卡次数(开锁次数)、有效期参数;蓝牙权限:卡号(萤石APP账号)、其他参数配置与普通发卡权限一致) + public byte[] byRes2 = new byte[2]; + public int dwLockID; //锁ID + public byte[] byLockCode = new byte[MAX_LOCK_CODE_LEN]; //锁代码 + public byte[] byRoomCode = new byte[MAX_DOOR_CODE_LEN]; //房间代码 + public int dwCardRight; //卡权限 + public int dwPlanTemplate; //计划模板(每天)各时间段是否启用,按位表示,0--不启用,1-启用 + public int dwCardUserId; //持卡人ID + public byte byCardModelType; //0-空,1- MIFARE S50,2- MIFARE S70,3- FM1208 CPU卡,4- FM1216 CPU卡,5-国密CPU卡,6-身份证,7- NFC + public byte[] byRes3 = new byte[83]; + } + + //有效期参数结构体 + public static class NET_DVR_VALID_PERIOD_CFG extends Structure { + public byte byEnable; + public byte[] byRes1 = new byte[3]; + public NET_DVR_TIME_EX struBeginTime; + public NET_DVR_TIME_EX struEndTime; + public byte byTimeType; //时间类型 + public byte[] byRes2 = new byte[31]; + } + + //扩展结构体信息 + public static class NET_DVR_ID_CARD_INFO_EXTEND extends Structure { + public byte byRemoteCheck; //是否需要远程核验(0-无效,1-不需要(默认),2-需要) + public byte byThermometryUnit; //测温单位(0-摄氏度(默认),1-华氏度,2-开尔文) + public byte byIsAbnomalTemperature; //人脸抓拍测温是否温度异常:1-是,0-否 + public byte byRes2; + public float fCurrTemperature; //人脸温度(精确到小数点后一位) + public NET_VCA_POINT struRegionCoordinates = new NET_VCA_POINT(); //人脸温度坐标 + public int dwQRCodeInfoLen; //二维码信息长度,不为0是表示后面带数据 + public int dwVisibleLightDataLen; //热成像相机可见光图片长度,不为0是表示后面带数据 + public int dwThermalDataLen; //热成像图片长度,不为0是表示后面带数据 + public Pointer pQRCodeInfo; //二维码信息指针 + public Pointer pVisibleLightData; //热成像相机可见光图片指针 + public Pointer pThermalData; //热成像图片指针 + public byte[] byRes = new byte[1024]; + } + + //身份证信息报警 + public static class NET_DVR_ID_CARD_INFO_ALARM extends Structure { + public int dwSize; //结构长度 + public NET_DVR_ID_CARD_INFO struIDCardCfg = new NET_DVR_ID_CARD_INFO();//身份证信息 + public int dwMajor; //报警主类型,参考宏定义 + public int dwMinor; //报警次类型,参考宏定义 + public NET_DVR_TIME_V30 struSwipeTime = new NET_DVR_TIME_V30(); //时间 + public byte[] byNetUser = new byte[MAX_NAMELEN];//网络操作的用户名 + public NET_DVR_IPADDR struRemoteHostAddr = new NET_DVR_IPADDR();//远程主机地址 + public int dwCardReaderNo; //读卡器编号,为0无效 + public int dwDoorNo; //门编号,为0无效 + public int dwPicDataLen; //图片数据大小,不为0是表示后面带数据 + public Pointer pPicData; + public byte byCardType; //卡类型,1-普通卡,2-残障人士卡,3-禁止名单卡,4-巡更卡,5-胁迫卡,6-超级卡,7-来宾卡,8-解除卡,为0无效 + public byte byDeviceNo; // 设备编号,为0时无效(有效范围1-255) + public byte byMask; //是否带口罩:0-保留,1-未知,2-不戴口罩,3-戴口罩 + public byte byCurrentEvent; //是否为实时事件:0-无效,1-是(实时事件),2-否(离线事件) + public int dwFingerPrintDataLen; // 指纹数据大小,不为0是表示后面带数据 + public Pointer pFingerPrintData; + public int dwCapturePicDataLen; // 抓拍图片数据大小,不为0是表示后面带数据 + public Pointer pCapturePicData; + public int dwCertificatePicDataLen; //证件抓拍图片数据大小,不为0是表示后面带数据 + public Pointer pCertificatePicData; + public byte byCardReaderKind; //读卡器属于哪一类,0-无效,1-IC读卡器,2-身份证读卡器,3-二维码读卡器,4-指纹头 + public byte[] byRes3 = new byte[2]; + public byte byIDCardInfoExtend; //pIDCardInfoExtend是否有效:0-无效,1-有效 + public Pointer pIDCardInfoExtend; //byIDCardInfoExtend为1时,表示指向一个NET_DVR_ID_CARD_INFO_EXTEND结构体 + public int dwSerialNo; //事件流水号,为0无效 + public byte[] byRes = new byte[168]; + } + + public static final int CARD_READER_DESCRIPTION = 32; //读卡器描述 + + public static class NET_DVR_CARD_READER_CFG_V50 extends Structure { + public int dwSize; + public byte byEnable; //是否使能,1-使能,0-不使能 + public byte byCardReaderType; //读卡器类型,1-DS-K110XM/MK/C/CK,2-DS-K192AM/AMP,3-DS-K192BM/BMP,4-DS-K182AM/AMP,5-DS-K182BM/BMP,6-DS-K182AMF/ACF,7-韦根或485不在线,8- DS-K1101M/MK,9- DS-K1101C/CK,10- DS-K1102M/MK/M-A,11- DS-K1102C/CK,12- DS-K1103M/MK,13- DS-K1103C/CK,14- DS-K1104M/MK,15- DS-K1104C/CK,16- DS-K1102S/SK/S-A,17- DS-K1102G/GK,18- DS-K1100S-B,19- DS-K1102EM/EMK,20- DS-K1102E/EK,21- DS-K1200EF,22- DS-K1200MF,23- DS-K1200CF,24- DS-K1300EF,25- DS-K1300MF,26- DS-K1300CF,27- DS-K1105E,28- DS-K1105M,29- DS-K1105C,30- DS-K182AMF,31- DS-K196AMF,32-DS-K194AMP,33-DS-K1T200EF/EF-C/MF/MF-C/CF/CF-C,34-DS-K1T300EF/EF-C/MF/MF-C/CF/CF-C,35-DS-K1T105E/E-C/M/M-C/C/C-C,36-DS-K1T803F/F-M/F-S/F-E,37-DS-K1A801F/F-M/F-S/F-E,38-DS-K1107M/MK,39-DS-K1107E/EK,40-DS-K1107S/SK,41-DS-K1108M/MK,42-DS-K1108E/EK,43-DS-K1108S/SK,44-DS-K1200F,45-DS-K1S110-I,46-DS-K1T200M-PG/PGC,47-DS-K1T200M-PZ/PZC,48-DS-K1109H + public byte byOkLedPolarity; //OK LED极性,0-阴极,1-阳极 + public byte byErrorLedPolarity; //Error LED极性,0-阴极,1-阳极 + public byte byBuzzerPolarity; //蜂鸣器极性,0-阴极,1-阳极 + public byte bySwipeInterval; //重复刷卡间隔时间,单位:秒 + public byte byPressTimeout; //按键超时时间,单位:秒 + public byte byEnableFailAlarm; //是否启用读卡失败超次报警,0-不启用,1-启用 + public byte byMaxReadCardFailNum; //最大读卡失败次数 + public byte byEnableTamperCheck; //是否支持防拆检测,0-disable ,1-enable + public byte byOfflineCheckTime; //掉线检测时间 单位秒 + public byte byFingerPrintCheckLevel; //指纹识别等级,1-1/10误认率,2-1/100误认率,3-1/1000误认率,4-1/10000误认率,5-1/100000误认率,6-1/1000000误认率,7-1/10000000误认率,8-1/100000000误认率,9-3/100误认率,10-3/1000误认率,11-3/10000误认率,12-3/100000误认率,13-3/1000000误认率,14-3/10000000误认率,15-3/100000000误认率,16-Automatic Normal,17-Automatic Secure,18-Automatic More Secure(目前门禁不支持) + public byte byUseLocalController; //只读,是否连接在就地控制器上,0-否,1-是 + public byte byRes1; + public short wLocalControllerID; //只读,就地控制器序号, byUseLocalController=1时有效,1-64,0代表未注册 + public short wLocalControllerReaderID; //只读,就地控制器的读卡器ID,byUseLocalController=1时有效,0代表未注册 + public short wCardReaderChannel; //只读,读卡器通信通道号,byUseLocalController=1时有效,0韦根或离线,1-RS485A,2-RS485B + public byte byFingerPrintImageQuality; //指纹图像质量,0-无效,1-低质量(V1),2-中等质量(V1),3-高质量(V1),4-最高质量(V1),5-低质量(V2),6-中等质量(V2),7-高质量(V2),8-最高质量(V2) + public byte byFingerPrintContrastTimeOut; //指纹对比超时时间,0-无效,范围1-20代表:1s-20s,0xff-无限大 + public byte byFingerPrintRecogizeInterval; //指纹连续识别间隔,0-无效,范围1-10代表:1s-10s,0xff-无延迟 + public byte byFingerPrintMatchFastMode; //指纹匹配快速模式,0-无效,范围1-5代表:快速模式1-快速模式5,0xff-自动 + public byte byFingerPrintModuleSensitive; //指纹模组灵敏度,0-无效,范围1-8代表:灵敏度级别1-灵敏度级别8 + public byte byFingerPrintModuleLightCondition; //指纹模组光线条件,0-无效,1-室外,2-室内 + public byte byFaceMatchThresholdN; //人脸比对阀值,范围0-100 + public byte byFaceQuality; //人脸质量,范围0-100 + public byte byFaceRecogizeTimeOut; //人脸识别超时时间,范围1-20代表:1s-20s,0xff-无限大 + public byte byFaceRecogizeInterval; //人脸连续识别间隔,0-无效,范围1-10代表:1s-10s,0xff-无延迟 + public short wCardReaderFunction; //只读,读卡器种类,按位表示:第1位-指纹,第二位-人脸,第三位-指静脉 + public byte[] byCardReaderDescription = new byte[CARD_READER_DESCRIPTION]; //读卡器描述 + public short wFaceImageSensitometry; //只读,人脸图像曝光度,范围0-65535 + public byte byLivingBodyDetect; //真人检测,0-无效,1-不启用,2-启用 + public byte byFaceMatchThreshold1; //人脸1:1匹配阀值,范围0-100 + public short wBuzzerTime; //蜂鸣时间,范围0s-5999s(0-代表长鸣) + public byte byFaceMatch1SecurityLevel; //人脸1:1识别安全等级,0-无效,1-一般,2-较强,3-极强 + public byte byFaceMatchNSecurityLevel; //人脸1:N识别安全等级,0-无效,1-一般,2-较强,3-极强 + public byte byEnvirMode;//人脸识别环境模式,0-无效,1-室内,2-其他; + public byte byLiveDetLevelSet;//活体检测阈值等级设置,0-无效,1-低,2-中,3-高; + public byte byLiveDetAntiAttackCntLimit;//活体检测防攻击次数, 0-无效,1-255次(客户端、设备统一次数限制,根据能力级限制); + public byte byEnableLiveDetAntiAttack;//活体检测防攻击使能,0-无效,1-不启用,2-启用 + public byte bySupportDelFPByID;//只读,读卡器是否支持按手指ID删除指纹,0-无效,1-不支持,2-支持 + public byte byFaceContrastMotionDetLevel;//人脸比对时移动侦测级别,0-无效,1-低,2-中,3-高,0xff-禁用 + public byte byDayFaceMatchThresholdN; //白天人脸1:N匹配阀值,范围0-100 + public byte byNightFaceMatchThresholdN; //夜晚人脸1:N匹配阀值,范围0-100 + public byte byFaceRecogizeEnable; //人脸识别使能:0-无效,1-开启,2-关闭 + public byte byBlockListMatchThreshold; //禁止名单匹配阀值,范围0-100 + public byte byRes3; + public byte byDefaultVerifyMode; //只读,读卡器默认验证方式(出厂默认),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-刷卡或指纹或密码 + public int dwFingerPrintCapacity;//只读,指纹容量 + public int dwFingerPrintNum;//只读,已存在指纹数量 + public byte byEnableFingerPrintNum;//只读,指纹容量使能:0-不使能,1-使能(只有当该字段为1-使能时,dwFingerPrintCapacity和dwFingerPrintNum才有效) + public byte[] byRes = new byte[231]; + } + + /**************** + * 优化接口结构体定义开始 + *************/ + + public static final int NET_SDK_CONFIG_STATUS_SUCCESS = 1000; + public static final int NET_SDK_CONFIG_STATUS_NEED_WAIT = 1001; + public static final int NET_SDK_CONFIG_STATUS_FINISH = 1002; + public static final int NET_SDK_CONFIG_STATUS_FAILED = 1003; + public static final int NET_SDK_CONFIG_STATUS_EXCEPTION = 1004; + + public static final int NET_SDK_GET_NEXT_STATUS_SUCCESS = 1000; + public static final int NET_SDK_GET_NEXT_STATUS_NEED_WAIT = 1001; + public static final int NET_SDK_NEXT_STATUS__FINISH = 1002; + public static final int NET_SDK_GET_NEXT_STATUS_FAILED = 1003; + + public static class NET_DVR_CARD_COND extends Structure { + public int dwSize; + public int dwCardNum; //设置或获取卡数量,获取时置为0xffffffff表示获取所有卡信息 + public byte[] byRes = new byte[64]; + } + + public static class NET_DVR_CARD_SEND_DATA extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //卡号 + public byte[] byRes = new byte[16]; + } + + public static class NET_DVR_CARD_RECORD extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; + public byte byCardType; + public byte byLeaderCard; + public byte byUserType; + public byte byRes1; + public byte[] byDoorRight = new byte[MAX_DOOR_NUM_256]; + public NET_DVR_VALID_PERIOD_CFG struValid = new NET_DVR_VALID_PERIOD_CFG(); + public byte[] byBelongGroup = new byte[MAX_GROUP_NUM_128]; + public byte[] byCardPassword = new byte[CARD_PASSWORD_LEN]; + public short[] wCardRightPlan = new short[MAX_DOOR_NUM_256]; + public int dwMaxSwipeTimes; + public int dwSwipeTimes; + public int dwEmployeeNo; + public byte[] byName = new byte[NAME_LEN]; + //按位表示,0-无权限,1-有权限 + //第0位表示:弱电报警 + //第1位表示:开门提示音 + //第2位表示:限制客卡 + //第3位表示:通道 + //第4位表示:反锁开门 + //第5位表示:巡更功能 + public int dwCardRight; + public byte[] byRes = new byte[256]; + } + + public static class NET_DVR_CARD_STATUS extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; + public int dwErrorCode; + public byte byStatus; // 状态:0-失败,1-成功 + public byte[] byRes = new byte[23]; + } + + + public static class NET_DVR_FACE_COND extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; + public int dwFaceNum; + public int dwEnableReaderNo; + public byte[] byRes = new byte[124]; + } + + public static class NET_DVR_FACE_RECORD extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; + public int dwFaceLen; + public Pointer pFaceBuffer; + public byte[] byRes = new byte[128]; + } + + public static class NET_DVR_FACE_STATUS extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; + public byte[] byErrorMsg = new byte[ERROR_MSG_LEN]; + public int dwReaderNo; + public byte byRecvStatus; + public byte[] byRes = new byte[131]; + } + + public static class NET_DVR_FINGERPRINT_COND extends Structure { + public int dwSize; + public int dwFingerprintNum; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; + public int dwEnableReaderNo; + public byte byFingerPrintID; + public byte[] byRes = new byte[131]; + } + + public static class NET_DVR_FINGERPRINT_RECORD extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; + public int dwFingerPrintLen; //指纹数据长度 + public int dwEnableReaderNo; //需要下发指纹的读卡器编号 + public byte byFingerPrintID; //手指编号,有效值范围为1-10 + public byte byFingerType; //指纹类型 0-普通指纹,1-胁迫指纹 + public byte[] byRes1 = new byte[30]; + public byte[] byFingerData = new byte[MAX_FINGER_PRINT_LEN]; //指纹数据内容 + public byte[] byRes = new byte[96]; + } + + public static class NET_DVR_FINGERPRINT_STATUS extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //指纹关联的卡号 + public byte byCardReaderRecvStatus; //指纹读卡器状态,按字节表示,0-失败,1-成功,2-该指纹模组不在线,3-重试或指纹质量差,4-内存已满,5-已存在该指纹,6-已存在该指纹ID,7-非法指纹ID,8-该指纹模组无需配置 + public byte byFingerPrintID; //手指编号,有效值范围为1-10 + public byte byFingerType; //指纹类型 0-普通指纹,1-胁迫指纹 + public byte byRecvStatus; //主机错误状态:0-成功,1-手指编号错误,2-指纹类型错误,3-卡号错误(卡号规格不符合设备要求),4-指纹未关联工号或卡号(工号或卡号字段为空),5-工号不存在,6-指纹数据长度为0,7-读卡器编号错误,8-工号错误 + public byte[] byErrorMsg = new byte[ERROR_MSG_LEN]; //下发错误信息,当byCardReaderRecvStatus为5时,表示已存在指纹对应的卡号 + public int dwCardReaderNo; //当byCardReaderRecvStatus为5时,表示已存在指纹对应的指纹读卡器编号,可用于下发错误返回。0时表示无错误信息 + public byte[] byRes = new byte[20]; + } + + public static class NET_DVR_CAPTURE_FINGERPRINT_COND extends Structure { + public int dwSize; + public byte byFingerPrintPicType; //图片类型:0-无意义 + public byte byFingerNo; //手指编号,范围1-10 + public byte[] byRes = new byte[126]; + } + + // + public static class NET_DVR_CAPTURE_FINGERPRINT_CFG extends Structure { + public int dwSize; + public int dwFingerPrintDataSize; //指纹数据大小 + public byte[] byFingerData = new byte[MAX_FINGER_PRINT_LEN]; //图片类型:0-无意义 + public int dwFingerPrintPicSize; //指纹图片大小,等于0时,代表无指纹图片数据 + public Pointer pFingerPrintPicBuffer; //指纹图片缓存 + public byte byFingerNo; //手指编号,范围1-10 + public byte byFingerPrintQuality; //指纹质量,范围1-100 + public byte[] byRes = new byte[62]; + } + + public static class NET_DVR_FINGER_PRINT_INFO_CTRL_V50 extends Structure { + public int dwSize; + public byte byMode; //删除方式,0-按卡号(人员ID)方式删除,1-按读卡器删除 + public byte[] byRes1 = new byte[3]; //保留 + public NET_DVR_DEL_FINGER_PRINT_MODE_V50 struProcessMode; //处理方式 + public byte[] byRes = new byte[64]; //保留 + } + + public static class NET_DVR_DEL_FINGER_PRINT_MODE_V50 extends Union { + public byte[] uLen = new byte[588]; //联合体长度 + public NET_DVR_FINGER_PRINT_BYCARD_V50 struByCard; //按卡号(人员ID)的方式删除 + public NET_DVR_FINGER_PRINT_BYREADER_V50 struByReader; //按读卡器的方式删除 + } + + public static class NET_DVR_FINGER_PRINT_BYREADER_V50 extends Structure { + public int dwCardReaderNo; //按值表示,指纹读卡器编号 + public byte byClearAllCard; //是否删除所有卡的指纹信息,0-按卡号(人员ID)删除指纹信息,1-删除所有卡(人员ID)的指纹信息 + public byte[] byRes1 = new byte[3]; //保留 + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //指纹关联的卡号 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + public byte[] byRes = new byte[516]; //保留 + } + + public static class NET_DVR_FINGER_PRINT_BYCARD_V50 extends Structure { + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //指纹关联的卡号 + public byte[] byEnableCardReader = new byte[MAX_CARD_READER_NUM_512]; //指纹的读卡器信息,按位表示 + public byte[] byFingerPrintID = new byte[10]; //需要删除的手指编号,按数组下标,值表示0-不删除,1-删除该指纹 + public byte[] byRes1 = new byte[2]; + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + } + + //人脸删除控制参数结构体 + public static class NET_DVR_FACE_PARAM_CTRL extends Structure { + public int dwSize; + public byte byMode; //删除方式,0-按卡号方式删除,1-按读卡器删除 + public byte[] byRes1 = new byte[3]; //保留 + public NET_DVR_DEL_FACE_PARAM_MODE struProcessMode = new NET_DVR_DEL_FACE_PARAM_MODE(); //处理方式 + public byte[] byRes = new byte[64]; //保留 + + public void read() { + super.read(); + switch (byMode) { + case 0: + struProcessMode.setType(NET_DVR_FACE_PARAM_BYCARD.class); + break; + case 1: + struProcessMode.setType(NET_DVR_FACE_PARAM_BYREADER.class); + break; + default: + break; + } + struProcessMode.read(); + } + + public void write() { + super.write(); + struProcessMode.write(); + } + } + + //指纹删除控制参数结构体 + public static class NET_DVR_FINGER_PRINT_INFO_CTRL extends Structure { + public int dwSize; + public byte byMode; //删除方式,0-按卡号方式删除,1-按读卡器删除 + public byte[] byRes1 = new byte[3]; //保留 + public NET_DVR_DEL_FINGER_PRINT_MODE struProcessMode = new NET_DVR_DEL_FINGER_PRINT_MODE(); //处理方式 + public byte[] byRes = new byte[64]; //保留 + + public void read() { + super.read(); + switch (byMode) { + case 0: + struProcessMode.setType(NET_DVR_FINGER_PRINT_BYCARD.class); + break; + case 1: + struProcessMode.setType(NET_DVR_FINGER_PRINT_BYREADER.class); + break; + default: + break; + } + struProcessMode.read(); + } + + public void write() { + super.write(); + struProcessMode.write(); + } + } + + public static class NET_DVR_DEL_FINGER_PRINT_MODE extends Union { + // public byte[] uLen = new byte[588]; //联合体长度 + public NET_DVR_FINGER_PRINT_BYCARD struByCard; //按卡号的方式删除 + public NET_DVR_FINGER_PRINT_BYREADER struByReader; //按读卡器的方式删除 + } + + public static class NET_DVR_FINGER_PRINT_BYCARD extends Structure { + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //人脸关联的卡号 + public byte[] byEnableCardReader = new byte[MAX_CARD_READER_NUM_512]; //人脸的读卡器信息,按数组表示 + public byte[] byFaceID = new byte[MAX_FACE_NUM]; //需要删除的人脸编号,按数组下标,值表示0-不删除,1-删除该人脸 + public byte[] byRes1 = new byte[34]; //保留 + } + + public static class NET_DVR_FINGER_PRINT_BYREADER extends Structure { + public int dwCardReaderNo; //按值表示,人脸读卡器编号 + public byte byClearAllCard; //是否删除所有卡的人脸信息,0-按卡号删除人脸信息,1-删除所有卡的人脸信息 + public byte[] byRes1 = new byte[3]; //保留 + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //人脸关联的卡号 + public byte[] byRes = new byte[548]; //保留 + } + + //门禁主机参数 + public static class NET_DVR_ACS_CFG extends Structure { + public int dwSize; //结构体大小 + public byte byRS485Backup; //是否启用下行RS485通信备份功能,0-不启用,1-启用 + public byte byShowCapPic; //是否显示抓拍图片, 0-不显示,1-显示 + public byte byShowCardNo; //是否显示卡号,0-不显示,1-显示 + public byte byShowUserInfo; //是否显示用户信息,0-不显示,1-显示 + public byte byOverlayUserInfo;//是否叠加用户信息,0-不叠加,1-叠加 + public byte byVoicePrompt; //是否启用语音提示,0-不启用,1-启用 + public byte byUploadCapPic; //联动抓拍是否上传图片,0-不上传,1-上传 + public byte bySaveCapPic; //是否保存抓拍图片,0-不保存,1-保存 + public byte byInputCardNo; //是否是否允许按键输入卡号,0-不允许,1-允许 + public byte byEnableWifiDetect; //是否启动wifi探针,0-不启动,1-启动 + public byte byEnable3G4G; //3G4G使能,0-不使能,1-使能 + public byte byProtocol;//读卡器通信协议类型,0-私有协议(默认),1-OSDP协议 + public byte[] byRes = new byte[500]; + } + + /************** + * 优化接口结构体定义结束 + ***************************/ + public static class NET_DVR_UPLOAD_ID_BLOCKLIST_COND extends Structure { + public int dwSize; + public int dwBlockListNum; //禁止名单数量 + public byte[] byRes = new byte[128]; + } + + public static class NET_DVR_UPLOAD_ID_BLOCKLIST_CFG extends Structure { + public int dwSize; + public NET_DVR_ID_CARD_INFO struIDCardCfg; //身份证信息(该结构体中姓名和身份证号码为必填项,其他字段为选填项) + public byte byBlockListValid; //身份证禁止名单是否有效:0-无效,1-有效(用于按身份证号码删除身份证禁止名单,该字段为0时代表删除) + public byte[] byRes = new byte[127]; //预留 + } + + public static class NET_DVR_UPLOAD_ID_BLOCKLIST_STATUS extends Structure { + public int dwSize; + public byte[] byIDNum = new byte[MAX_ID_NUM_LEN]; //身份证号码 + public byte byStatus; //状态:0-无效,1-处理中,2-上传失败,3-成功 + public byte[] byRes = new byte[63]; + } + + public static class REMOTECONFIGSTATUS extends Structure { + public byte[] byStatus = new byte[4]; + public byte[] byErrorCode = new byte[4]; + } + + + //开锁记录 + public static class NET_DVR_UNLOCK_RECORD_INFO extends Structure { + public byte byUnlockType; //开锁方式,参考UNLOCK_TYPE_ENUM + public byte[] byRes1 = new byte[3]; //保留 + public byte[] byControlSrc = new byte[NAME_LEN]; //操作发起源信息,刷卡开锁时为卡号,蓝牙开锁时为萤石的APP账号,二维码开锁时为访客的手机号,其余情况下为设备编号 + public int dwPicDataLen; //图片数据长度 + public Pointer pImage; //图片指针 + public int dwCardUserID; //持卡人ID + public short nFloorNumber;//刷卡开锁时有效,为楼层号 + public short wRoomNumber; //操作发起源附加信息,刷卡开锁时有效,为房间号, + public short wLockID; //(对于门口机,0-表示本机控制器上接的锁、1-表示外接控制器上接的锁) + public byte[] byRes2 = new byte[2]; + public byte[] byLockName = new byte[LOCK_NAME_LEN]; //刷卡开锁时有效,锁名称,对应门参数配置中门名称 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + public byte[] byRes = new byte[136]; //保留 + } + + //公告信息阅读回执 + public static class NET_DVR_NOTICEDATA_RECEIPT_INFO extends Structure { + public byte[] byNoticeNumber = new byte[MAX_NOTICE_NUMBER_LEN]; //公告编号 + public byte[] byRes = new byte[224]; //保留 + } + + //认证记录(设备未实现) + public static class NET_DVR_AUTH_INFO extends Structure { + public byte byAuthResult; //认证结果:0-无效,1-认证成功,2-认证失败 + public byte byAuthType; //认证方式:0-无效,1-指纹,2-人脸 + public byte[] byRes1 = new byte[2]; //保留 + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN/*32*/]; //卡号 + public int dwPicDataLen; //图片数据长度(当认证方式byAuthType为人脸时有效) + public Pointer pImage; //图片指针(当认证方式byAuthType为人脸时有效) + public byte[] byRes = new byte[212]; //保留 + } + + //车牌信息上传 + public static class NET_DVR_UPLOAD_PLATE_INFO extends Structure { + public byte[] sLicense = new byte[MAX_LICENSE_LEN]; //车牌号码 + public byte byColor; //车牌颜色,参考结构VCA_PLATE_COLOR + public byte[] byRes = new byte[239]; //保留 + } + + public static class NET_DVR_SEND_CARD_INFO extends Structure { + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN/*32*/]; //卡号 + public byte[] byRes = new byte[224]; //保留 + } + + //可视对讲事件记录信息联合体 + public static class NET_DVR_VIDEO_INTERCOM_EVENT_INFO_UINON extends Union { + public byte[] byLen = new byte[256]; //联合体大小 + public NET_DVR_UNLOCK_RECORD_INFO struUnlockRecord = new NET_DVR_UNLOCK_RECORD_INFO(); //开锁记录 + public NET_DVR_NOTICEDATA_RECEIPT_INFO struNoticedataReceipt = new NET_DVR_NOTICEDATA_RECEIPT_INFO(); //公告信息阅读回执 + public NET_DVR_AUTH_INFO struAuthInfo = new NET_DVR_AUTH_INFO(); //认证记录(设备未实现) + public NET_DVR_UPLOAD_PLATE_INFO struUploadPlateInfo = new NET_DVR_UPLOAD_PLATE_INFO(); //车牌信息上传 + public NET_DVR_SEND_CARD_INFO struSendCardInfo = new NET_DVR_SEND_CARD_INFO(); //门口机发卡,对应设备处于发卡状态,刷卡时上传该事件 + } + + //可视对讲事件记录 + public static class NET_DVR_VIDEO_INTERCOM_EVENT extends Structure { + public int dwSize; //结构体大小 + public NET_DVR_TIME_EX struTime = new NET_DVR_TIME_EX(); //时间 + public byte[] byDevNumber = new byte[MAX_DEV_NUMBER_LEN]; //设备编号 + public byte byEventType; //事件信息类型,1-开锁记录,2-公告信息阅读回执,3-认证记录,4-车牌信息上传,5非法卡刷卡事件,6-门口机发卡记录(需要启动门口机发卡功能,刷卡时才会上传该事件) + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public byte[] byRes1 = new byte[2]; //保留 + public NET_DVR_VIDEO_INTERCOM_EVENT_INFO_UINON uEventInfo = new NET_DVR_VIDEO_INTERCOM_EVENT_INFO_UINON(); //事件信息,具体内容参考byEventType取值 + public int dwIOTChannelNo; //IOT通道号 + public byte[] byRes2 = new byte[252]; //保留 + } + + public static class NET_DVR_CONTROL_GATEWAY extends Structure { + public int dwSize; //结构体大小 + public int dwGatewayIndex; //门禁序号,从1开始 + public byte byCommand; //操作命令,0-关闭,1-打开,2-常开(通道状态),3-恢复(普通状态) + public byte byLockType; //锁类型,0-普通(以前默认都为0),1-智能锁 + public short wLockID; //锁ID,从1开始(远程开门口机锁时,0表示门口机本机控制器上接的锁、1表示外接控制器上接的锁) + public byte[] byControlSrc = new byte[NAME_LEN]; //操作发起源信息 + public byte byControlType; //开锁类型,1-监视,2-通话 + public byte[] byRes3 = new byte[3]; + public byte[] byPassword = new byte[PASSWD_LEN]; //锁密码,当byLockType为智能锁时有效 + public byte[] byRes2 = new byte[108]; //保留 + } + + + //公告图片信息结构体 + public static class NET_DVR_NOTICE_PIC extends Structure { + public Pointer pPicData; //图片指针 + public int dwPicDataLen; //图片数据长度 + public byte[] byRes = new byte[32]; //保留 + } + + //公告数据 + public static class NET_DVR_NOTICE_DATA extends Structure { + public int dwSize; //结构体大小 + public NET_DVR_TIME_EX struTime = new NET_DVR_TIME_EX(); //公告时间 + public byte[] byNoticeNumber = new byte[MAX_NOTICE_NUMBER_LEN]; //公告编号 + public byte[] byNoticeTheme = new byte[MAX_NOTICE_THEME_LEN];//公告主题 + public byte[] byNoticeDetail = new byte[MAX_NOTICE_DETAIL_LEN]; //公告详情 + public byte byLevel; //公告等级,1-广告类信息;2-物业信息;3-报警类信息;4-通知类信息 + public byte byPicNum; //公告图片数量 + public byte[] byRes1 = new byte[2]; //保留 + public NET_DVR_NOTICE_PIC[] struNoticePic = new NET_DVR_NOTICE_PIC[MAX_NOTICE_PIC_NUM]; //公告图片 + public byte[] byRes2 = new byte[128]; //保留 + } + + public static class NET_DVR_DATE extends Structure { + public short wYear; //年 + public byte byMonth; //月 + public byte byDay; //日 + } + + //身份证信息 + public static class NET_DVR_ID_CARD_INFO extends Structure { + public int dwSize; //结构长度 + public byte[] byName = new byte[MAX_ID_NAME_LEN]; //姓名 + public NET_DVR_DATE struBirth; //出生日期 + public byte[] byAddr = new byte[MAX_ID_ADDR_LEN]; //住址 + public byte[] byIDNum = new byte[MAX_ID_NUM_LEN]; //身份证号码 + public byte[] byIssuingAuthority = new byte[MAX_ID_ISSUING_AUTHORITY_LEN]; //签发机关 + public NET_DVR_DATE struStartDate; //有效开始日期 + public NET_DVR_DATE struEndDate; //有效截止日期 + public byte byTermOfValidity; //是否长期有效, 0-否,1-是(有效截止日期无效) + public byte bySex; //性别,1-男,2-女 + public byte byNation; //民族 + public byte[] byRes = new byte[101]; + } + + public static class NET_DVR_ACS_EVENT_INFO_EXTEND_V20 extends Structure { + public byte byRemoteCheck; //是否需要远程核验(0-无效,1-不需要(默认),2-需要) + public byte byThermometryUnit; //测温单位(0-摄氏度(默认),1-华氏度,2-开尔文) + public byte byIsAbnomalTemperature; //人脸抓拍测温是否温度异常:1-是,0-否 + public byte byRes2; + public float fCurrTemperature; //人脸温度(精确到小数点后一位) + public NET_VCA_POINT struRegionCoordinates = new NET_VCA_POINT(); //人脸温度坐标 + public int dwQRCodeInfoLen; //二维码信息长度,不为0是表示后面带数据 + public int dwVisibleLightDataLen; //热成像相机可见光图片长度,不为0是表示后面带数据 + public int dwThermalDataLen; //热成像图片长度,不为0是表示后面带数据 + public Pointer pQRCodeInfo; //二维码信息指针 + public Pointer pVisibleLightData; //热成像相机可见光图片指针 + public Pointer pThermalData; //热成像图片指针 + public byte[] byRes = new byte[1024]; + + + } + + //门禁主机报警信息结构体 + public static class NET_DVR_ACS_ALARM_INFO extends Structure { + public int dwSize; + public int dwMajor; //报警主类型,参考宏定义 + public int dwMinor; //报警次类型,参考宏定义 + public NET_DVR_TIME struTime = new NET_DVR_TIME(); //时间 + public byte[] sNetUser = new byte[MAX_NAMELEN];//网络操作的用户名 + public NET_DVR_IPADDR struRemoteHostAddr = new NET_DVR_IPADDR();//远程主机地址 + public NET_DVR_ACS_EVENT_INFO struAcsEventInfo = new NET_DVR_ACS_EVENT_INFO(); //详细参数 + public int dwPicDataLen; //图片数据大小,不为0是表示后面带数据 + public Pointer pPicData; + public short wInductiveEventType; //归纳事件类型,0-无效,客户端判断该值为非0值后,报警类型通过归纳事件类型区分,否则通过原有报警主次类型(dwMajor、dwMinor)区分 + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public byte byRes1; //保留字节 + public int dwIOTChannelNo; //IOT通道号 + public Pointer pAcsEventInfoExtend; //byAcsEventInfoExtend为1时,表示指向一个NET_DVR_ACS_EVENT_INFO_EXTEND结构体 + public byte byAcsEventInfoExtend; //pAcsEventInfoExtend是否有效:0-无效,1-有效 + public byte byTimeType; //时间类型:0-设备本地时间,1-UTC时间(struTime的时间) + public byte byRes2; //保留字节 + public byte byAcsEventInfoExtendV20; //pAcsEventInfoExtendV20是否有效:0-无效,1-有效 + public Pointer pAcsEventInfoExtendV20; //byAcsEventInfoExtendV20为1时,表示指向一个NET_DVR_ACS_EVENT_INFO_EXTEND_V20结构体 + public byte[] byRes = new byte[4]; + } + + //门禁主机事件信息 + public static class NET_DVR_ACS_EVENT_INFO extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[32]; + public byte byCardType; + public byte byAllowListNo; + public byte byReportChannel; + public byte byCardReaderKind; + public int dwCardReaderNo; + public int dwDoorNo; + public int dwVerifyNo; + public int dwAlarmInNo; + public int dwAlarmOutNo; + public int dwCaseSensorNo; + public int dwRs485No; + public int dwMultiCardGroupNo; + public short wAccessChannel; + public byte byDeviceNo; + public byte byDistractControlNo; + public int dwEmployeeNo; + public short wLocalControllerID; + public byte byInternetAccess; + public byte byType; + public byte[] byMACAddr = new byte[MACADDR_LEN]; //物理地址,为0无效 + public byte bySwipeCardType;//刷卡类型,0-无效,1-二维码 + public byte byMask; //是否带口罩:0-保留,1-未知,2-不戴口罩,3-戴口罩 + public int dwSerialNo; //事件流水号,为0无效 + public byte byChannelControllerID; //通道控制器ID,为0无效,1-主通道控制器,2-从通道控制器 + public byte byChannelControllerLampID; //通道控制器灯板ID,为0无效(有效范围1-255) + public byte byChannelControllerIRAdaptorID; //通道控制器红外转接板ID,为0无效(有效范围1-255) + public byte byChannelControllerIREmitterID; //通道控制器红外对射ID,为0无效(有效范围1-255) + public byte byHelmet;//可选,是否戴安全帽:0-保留,1-未知,2-不戴安全, 3-戴安全帽 + public byte[] byRes = new byte[3]; + } + + public static final int NET_DEV_NAME_LEN = 64; + + public static class NET_DVR_ACS_EVENT_INFO_EXTEND extends Structure { + public int dwFrontSerialNo; //事件流水号,为0无效(若该字段为0,平台根据dwSerialNo判断是否丢失事件;若该字段不为0,平台根据该字段和dwSerialNo字段共同判断是否丢失事件)(主要用于解决报警订阅后导致dwSerialNo不连续的情况) + public byte byUserType; //人员类型:0-无效,1-普通人(主人),2-来宾(访客),3-禁止名单人,4-管理员 + public byte byCurrentVerifyMode; //读卡器当前验证方式:0-无效,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-刷卡或指纹或密码 + public byte byCurrentEvent; //是否为实时事件:0-无效,1-是(实时事件),2-否(离线事件) + public byte byPurePwdVerifyEnable; //设备是否支持纯密码认证, 0-不支持,1-支持 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID)(对于设备来说,如果使用了工号(人员ID)字段,byEmployeeNo一定要传递,如果byEmployeeNo可转换为dwEmployeeNo,那么该字段也要传递;对于上层平台或客户端来说,优先解析byEmployeeNo字段,如该字段为空,再考虑解析dwEmployeeNo字段) + public byte byAttendanceStatus; //考勤状态:0-未定义,1-上班,2-下班,3-开始休息,4-结束休息,5-开始加班,6-结束加班 + public byte byStatusValue; //考勤状态值 + public byte[] byRes2 = new byte[2]; + public byte[] byUUID = new byte[NET_SDK_UUID_LEN/*36*/]; //UUID(该字段仅在对接萤石平台过程中才会使用) + public byte[] byDeviceName = new byte[NET_DEV_NAME_LEN/*64*/]; //设备序列号 + public byte[] byRes = new byte[24]; + + } + + /* + 门禁主机报警事件细节结构体 + */ + public static class NET_DVR_ACS_EVENT_DETAIL extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //卡号(mac地址),为0无效 + public byte byCardType; //卡类型,1-普通卡,2-残障人士卡,3-禁止名单卡,4-巡更卡,5-胁迫卡,6-超级卡,7-来宾卡,8-解除卡,为0无效 + public byte byAllowListNo; //允许名单单号,1-8,为0无效 + public byte byReportChannel; //报告上传通道,1-布防上传,2-中心组1上传,3-中心组2上传,为0无效 + public byte byCardReaderKind; //读卡器属于哪一类,0-无效,1-IC读卡器,2-身份证读卡器,3-二维码读卡器,4-指纹头 + public int dwCardReaderNo; //读卡器编号,为0无效 + public int dwDoorNo; //门编号(楼层编号),为0无效 + public int dwVerifyNo; //多重卡认证序号,为0无效 + public int dwAlarmInNo; //报警输入号,为0无效 + public int dwAlarmOutNo; //报警输出号,为0无效 + public int dwCaseSensorNo; //事件触发器编号 + public int dwRs485No; //RS485通道号,为0无效 + public int dwMultiCardGroupNo; //群组编号 + public short wAccessChannel; //人员通道号 + public byte byDeviceNo; //设备编号,为0无效(有效范围1-255) + public byte byDistractControlNo;//分控器编号,为0无效 + public int dwEmployeeNo; //工号,为0无效 + public short wLocalControllerID; //就地控制器编号,0-门禁主机,1-64代表就地控制器 + public byte byInternetAccess; //网口ID:(1-上行网口1,2-上行网口2,3-下行网口1) + public byte byType; //防区类型,0:即时防区,1-24小时防区,2-延时防区 ,3-内部防区,4-钥匙防区 5-火警防区 6-周界防区 7-24小时无声防区 8-24小时辅助防区,9-24小时震动防区,10-门禁紧急开门防区,11-门禁紧急关门防区 0xff-无 + public byte[] byMACAddr = new byte[MACADDR_LEN]; //物理地址,为0无效 + public byte bySwipeCardType;//刷卡类型,0-无效,1-二维码 + public byte byEventAttribute; //事件属性:0-未定义,1-合法认证,2-其它 + public int dwSerialNo; //事件流水号,为0无效 + public byte byChannelControllerID; //通道控制器ID,为0无效,1-主通道控制器,2-从通道控制器 + public byte byChannelControllerLampID; //通道控制器灯板ID,为0无效(有效范围1-255) + public byte byChannelControllerIRAdaptorID; //通道控制器红外转接板ID,为0无效(有效范围1-255) + public byte byChannelControllerIREmitterID; //通道控制器红外对射ID,为0无效(有效范围1-255) + public int dwRecordChannelNum; //录像通道数目 + public Pointer pRecordChannelData;//录像通道,大小为sizeof(DWORD)* dwRecordChannelNum + public byte byUserType; //人员类型:0-无效,1-普通人(主人),2-来宾(访客),3-禁止名单人,4-管理员 + public byte byCurrentVerifyMode; //读卡器当前验证方式:0-无效,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-刷卡或指纹或密码 + public byte byAttendanceStatus; //考勤状态:0-未定义,1-上班,2-下班,3-开始休息,4-结束休息,5-开始加班,6-结束加班 + public byte byStatusValue; //考勤状态值 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID)(对于设备来说,如果使用了工号(人员ID)字段,byEmployeeNo一定要传递,如果byEmployeeNo可转换为dwEmployeeNo,那么该字段也要传递;对于上层平台或客户端来说,优先解析byEmployeeNo字段,如该字段为空,再考虑解析dwEmployeeNo字段) + public byte byRes1; //保留 + public byte byMask; //是否带口罩:0-保留,1-未知,2-不戴口罩,3-戴口罩 + public byte byThermometryUnit; //测温单位(0-摄氏度(默认),1-华氏度,2-开尔文) + public byte byIsAbnomalTemperature; //人脸抓拍测温是否温度异常:1-是,0-否 + public float fCurrTemperature; //人脸温度(精确到小数点后一位) + public NET_VCA_POINT struRegionCoordinates; //人脸温度坐标 + public byte[] byRes = new byte[48]; + } + + /* + 门禁主机报警事件配置结构体 + */ + public static class NET_DVR_ACS_EVENT_CFG extends Structure { + public int dwSize; + public int dwMajor; //报警主类型,参考宏定义 + public int dwMinor; //报警次类型,参考宏定义 + public NET_DVR_TIME struTime = new NET_DVR_TIME(); //时间 + public byte[] sNetUser = new byte[MAX_NAMELEN];//网络操作的用户名 + public NET_DVR_IPADDR struRemoteHostAddr;//远程主机地址 + public NET_DVR_ACS_EVENT_DETAIL struAcsEventInfo; //详细参数 + public int dwPicDataLen; //图片数据大小,不为0是表示后面带数据 + public Pointer pPicData; + public short wInductiveEventType; //归纳事件类型,0-无效,其他值参见2.2章节,客户端判断该值为非0值后,报警类型通过归纳事件类型区分,否则通过原有报警主次类型(dwMajor、dwMinor)区分 + public byte byTimeType; //时间类型:0-设备本地时间(默认),1-UTC时间(struTime的时间) + public byte byRes1; + public int dwQRCodeInfoLen; //二维码信息长度,不为0是表示后面带数据 + public int dwVisibleLightDataLen; //热成像相机可见光图片长度,不为0是表示后面带数据 + public int dwThermalDataLen; //热成像图片长度,不为0是表示后面带数据 + public Pointer pQRCodeInfo; //二维码信息指针 + public Pointer pVisibleLightData; //热成像相机可见光图片指针 + public Pointer pThermalData; //热成像图片指针 + public byte[] byRes = new byte[36]; + } + + public static final int NET_SDK_MONITOR_ID_LEN = 64; + + public static class NET_DVR_ACS_EVENT_COND extends Structure { + public int dwSize; + public int dwMajor; //报警主类型,参考事件上传宏定义,0-全部 + public int dwMinor; //报警次类型,参考事件上传宏定义,0-全部 + public NET_DVR_TIME struStartTime; //开始时间 + public NET_DVR_TIME struEndTime; //结束时间 + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //卡号 + public byte[] byName = new byte[NAME_LEN]; //持卡人姓名 + public byte byPicEnable; //是否带图片,0-不带图片,1-带图片 + public byte byTimeType; //时间类型:0-设备本地时间(默认),1-UTC时间(struStartTime和struEndTime的时间) + public byte[] byRes2 = new byte[2]; //保留 + public int dwBeginSerialNo; //起始流水号(为0时默认全部) + public int dwEndSerialNo; //结束流水号(为0时默认全部) + public int dwIOTChannelNo; //IOT通道号,0-无效 + public short wInductiveEventType; //归纳事件类型,0-无效,其他值参见2.2章节,客户端判断该值为非0值后,报警类型通过归纳事件类型区分,否则通过原有报警主次类型(dwMajor、dwMinor)区分 + public byte bySearchType; //搜索方式:0-保留,1-按事件源搜索(此时通道号为非视频通道号),2-按监控点ID搜索 + public byte byEventAttribute; //事件属性:0-未定义,1-合法事件,2-其它 + public byte[] szMonitorID = new byte[NET_SDK_MONITOR_ID_LEN/*64*/]; //监控点ID(由设备序列号、通道类型、编号组成,例如门禁点:设备序列号+“DOOR”+门编号) + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + public byte[] byRes = new byte[140]; //保留 + } + + public static class NET_DVR_ACS_WORK_STATUS_V50 extends Structure { + public int dwSize; + public byte[] byDoorLockStatus = new byte[MAX_DOOR_NUM_256]; //门锁状态(继电器开合状态),0-正常关,1-正常开,2-短路报警,3-断路报警,4-异常报警 + public byte[] byDoorStatus = new byte[MAX_DOOR_NUM_256]; //门状态(楼层状态),1-休眠,2-常开状态(自由),3-常闭状态(禁用),4-普通状态(受控) + public byte[] byMagneticStatus = new byte[MAX_DOOR_NUM_256]; //门磁状态,0-正常关,1-正常开,2-短路报警,3-断路报警,4-异常报警 + public byte[] byCaseStatus = new byte[MAX_CASE_SENSOR_NUM]; //事件触发器状态,0-无输入,1-有输入 + public short wBatteryVoltage; //蓄电池电压值,实际值乘10,单位:伏特 + public byte byBatteryLowVoltage; //蓄电池是否处于低压状态,0-否,1-是 + public byte byPowerSupplyStatus; //设备供电状态,1-交流电供电,2-蓄电池供电 + public byte byMultiDoorInterlockStatus; //多门互锁状态,0-关闭,1-开启 + public byte byAntiSneakStatus; //反潜回状态,0-关闭,1-开启 + public byte byHostAntiDismantleStatus; //主机防拆状态,0-关闭,1-开启 + public byte byIndicatorLightStatus; //指示灯状态,0-掉线,1-在线 + public byte[] byCardReaderOnlineStatus = new byte[MAX_CARD_READER_NUM_512]; //读卡器在线状态,0-不在线,1-在线 + public byte[] byCardReaderAntiDismantleStatus = new byte[MAX_CARD_READER_NUM_512]; //读卡器防拆状态,0-关闭,1-开启 + public byte[] byCardReaderVerifyMode = new byte[MAX_CARD_READER_NUM_512]; //读卡器当前验证方式,1-休眠,2-刷卡+密码,3-刷卡,4-刷卡或密码 + public byte[] bySetupAlarmStatus = new byte[MAX_ALARMHOST_ALARMIN_NUM];//报警输入口布防状态,0-对应报警输入口处于撤防状态,1-对应报警输入口处于布防状态 + public byte[] byAlarmInStatus = new byte[MAX_ALARMHOST_ALARMIN_NUM]; //按位表示报警输入口报警状态,0-对应报警输入口当前无报警,1-对应报警输入口当前有报警 + public byte[] byAlarmOutStatus = new byte[MAX_ALARMHOST_ALARMOUT_NUM]; //按位表示报警输出口状态,0-对应报警输出口无报警,1-对应报警输出口有报警 + public int dwCardNum; //已添加的卡数量 + public byte byFireAlarmStatus; //消防报警状态显示:0-正常、1-短路报警、2-断开报警 + public byte byBatteryChargeStatus; //电池充电状态:0-无效;1-充电中;2-未充电 + public byte byMasterChannelControllerStatus; //主通道控制器在线状态:0-无效;1-不在线;2-在线 + public byte bySlaveChannelControllerStatus; //从通道控制器在线状态:0-无效;1-不在线;2-在线 + public byte byAntiSneakServerStatus; //反潜回服务器状态:0-无效,1-未启用,2-正常,3-断开 + public byte[] byRes3 = new byte[3]; + public int dwAllowFaceNum; //已添加的允许名单人脸数量(通过能力集判断) + public int dwBlockFaceNum; //已添加的禁止名单人脸数量(通过能力集判断) + public byte[] byRes2 = new byte[108]; + } + + public static final int ACS_PARAM_DOOR_STATUS_WEEK_PLAN = 0x00000001;//门状态周计划参数 + public static final int ACS_PARAM_VERIFY_WEEK_PALN = 0x00000002; //读卡器周计划参数 + public static final int ACS_PARAM_CARD_RIGHT_WEEK_PLAN = 0x00000004; //卡权限周计划参数 + public static final int ACS_PARAM_DOOR_STATUS_HOLIDAY_PLAN = 0x00000008; //门状态假日计划参数 + public static final int ACS_PARAM_VERIFY_HOLIDAY_PALN = 0x00000010; //读卡器假日计划参数 + public static final int ACS_PARAM_CARD_RIGHT_HOLIDAY_PLAN = 0x00000020; //卡权限假日计划参数 + public static final int ACS_PARAM_DOOR_STATUS_HOLIDAY_GROUP = 0x00000040; //门状态假日组参数 + public static final int ACS_PARAM_VERIFY_HOLIDAY_GROUP = 0x00000080;//读卡器验证方式假日组参数 + public static final int ACS_PARAM_CARD_RIGHT_HOLIDAY_GROUP = 0x00000100; //卡权限假日组参数 + public static final int ACS_PARAM_DOOR_STATUS_PLAN_TEMPLATE = 0x00000200;//门状态计划模板参数 + public static final int ACS_PARAM_VERIFY_PALN_TEMPLATE = 0x00000400; //读卡器验证方式计划模板参数 + public static final int ACS_PARAM_CARD_RIGHT_PALN_TEMPLATE = 0x00000800; //卡权限计划模板参数 + public static final int ACS_PARAM_CARD = 0x00001000; //卡参数 + public static final int ACS_PARAM_GROUP = 0x00002000; //群组参数 + public static final int ACS_PARAM_ANTI_SNEAK_CFG = 0x00004000; //反潜回参数 + public static final int ACS_PAPAM_EVENT_CARD_LINKAGE = 0x00008000; //事件及卡号联动参数 + public static final int ACS_PAPAM_CARD_PASSWD_CFG = 0x00010000; //密码开门使能参数 + public static final int ACS_PARAM_PERSON_STATISTICS_CFG = 0x00020000; //人数统计参数 + public static final int ACS_PARAM_BLOCKLIST_PICTURE = 0x00040000; //禁止名单图片参数 + public static final int ACS_PARAM_ID_BLOCKLIST = 0x00080000; //身份证禁止名单参数 + public static final int ACS_PARAM_EXAM_INFO = 0x00100000; //考试信息参数 + public static final int ACS_PARAM_EXAMINEE_INFO = 0x00200000; //考生信息参数 + public static final int ACS_PARAM_FAILED_FACE_INFO = 0x00400000; //升级设备人脸建模失败记录 + + public static class NET_DVR_ACS_PARAM_TYPE extends Structure { + public int dwSize; + public int dwParamType; //参数类型,按位表示 + + public short wLocalControllerID; //就地控制器序号[1,64],0代表门禁主机 + public byte[] byRes = new byte[30]; + } + + + public static class NET_DVR_FACE_PARAM_COND extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //人脸关联的卡号 + public byte[] byEnableCardReader = new byte[MAX_CARD_READER_NUM_512]; //人脸的读卡器是否有效,0-无效,1-有效 + public int dwFaceNum; //设置或获取人脸数量,获取时置为0xffffffff表示获取所有人脸信息 + public byte byFaceID; //人脸编号,有效值范围为1-2 0xff表示该卡所有人脸 + public byte[] byRes = new byte[127]; //保留 + } + + public static class NET_DVR_FACE_PARAM_CFG extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //人脸关联的卡号 + public int dwFaceLen; //人脸数据长度,设备端返回的即加密后的数据 + public Pointer pFaceBuffer; //人脸数据指针 + public byte[] byEnableCardReader = new byte[MAX_CARD_READER_NUM_512]; //需要下发人脸的读卡器,按数组表示,从低位到高位表示,0-不下发该读卡器,1-下发到该读卡器 + public byte byFaceID; //人脸编号,有效值范围为1-2 + public byte byFaceDataType; //人脸数据类型:0-模板(默认),1-图片 + public byte[] byRes = new byte[126]; + } + + public static class NET_DVR_FACE_PARAM_STATUS extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //人脸关联的卡号 + public byte[] byCardReaderRecvStatus = new byte[MAX_CARD_READER_NUM_512]; //人脸读卡器状态,按字节表示,0-失败,1-成功,2-重试或人脸质量差,3-内存已满,4-已存在该人脸,5-非法人脸ID + public byte[] byErrorMsg = new byte[ERROR_MSG_LEN]; //下发错误信息,当byCardReaderRecvStatus为4时,表示已存在人脸对应的卡号 + public int dwCardReaderNo; //纹读卡器编号,可用于下发错误返回 + public byte byTotalStatus; //下发总的状态,0-当前人脸未下完所有读卡器,1-已下完所有读卡器(这里的所有指的是门禁主机往所有的读卡器下发了,不管成功与否) + public byte byFaceID; //人脸编号,有效值范围为1-2 + public byte[] byRes = new byte[130]; + } + + public static class NET_DVR_FACE_PARAM_BYCARD extends Structure { + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //人脸关联的卡号 + public byte[] byEnableCardReader = new byte[MAX_CARD_READER_NUM_512]; //人脸的读卡器信息,按数组表示 + public byte[] byFaceID = new byte[MAX_FACE_NUM]; //需要删除的人脸编号,按数组下标,值表示0-不删除,1-删除该人脸 + public byte[] byRes1 = new byte[42]; //保留 + } + + public static class NET_DVR_FACE_PARAM_BYREADER extends Structure { + public int dwCardReaderNo; //按值表示,人脸读卡器编号 + public byte byClearAllCard; //是否删除所有卡的人脸信息,0-按卡号删除人脸信息,1-删除所有卡的人脸信息 + public byte[] byRes1 = new byte[3]; //保留 + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //人脸关联的卡号 + public byte[] byRes = new byte[548]; //保留 + } + + public static class NET_DVR_DEL_FACE_PARAM_MODE extends Union { + public byte[] uLen = new byte[588]; //联合体长度 + public NET_DVR_FACE_PARAM_BYCARD struByCard; //按卡号的方式删除 + public NET_DVR_FACE_PARAM_BYREADER struByReader; //按读卡器的方式删除 + } + + public static class NET_DVR_CHECK_FACE_PICTURE_COND extends Structure { + public int dwSize; + public int dwPictureNum; //图片数量 + public byte byCheckTemplate; //0-校验图片是否合法(默认),1-校验图片和建模数据是否匹配 + public byte[] byRes = new byte[127]; + } + + public static class NET_DVR_CHECK_FACE_PICTURE_CFG extends Structure { + public int dwSize; + public int dwPictureNo; //图片编号 + public int dwPictureLen; //图片长度(图片大小不超过200k) + public Pointer pPictureBuffer; //图片指针 + public int dwFaceTemplateLen; //人脸建模数据长度 + public Pointer pFaceTemplateBuffer; //人脸建模数据指针 + public byte[] byRes = new byte[248]; + } + + public static class NET_DVR_CHECK_FACE_PICTURE_STATUS extends Structure { + public int dwSize; + public int dwPictureNo; //图片编号 + public byte byCheckStatus; //校验结果:0-无效,1-建模成功,2-建模失败,3-人脸模块通讯异常,4-图像无人脸,5-人脸朝上,6-人脸朝下,7-人脸偏左,8-人脸偏右,9-人脸顺时旋转, + //10 - 人脸逆时旋转,11-人眼间距小,12-人脸和模板匹配,13-人脸和模板不匹配,14-传输数据有误 + public byte[] byRes = new byte[127]; + } + + public static class NET_DVR_FINGER_PRINT_CFG_V50 extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //指纹关联的卡号 + public int dwFingerPrintLen; //指纹数据长度 + public byte[] byEnableCardReader = new byte[MAX_CARD_READER_NUM_512]; //需要下发指纹的读卡器,按数组表示,从低位到高位表示,0-不下发该读卡器,1-下发到该读卡器 + public byte byFingerPrintID; //手指编号,有效值范围为1-10 + public byte byFingerType; //指纹类型 0-普通指纹,1-胁迫指纹,2-巡更指纹,3-超级指纹,4-解除指纹 + public byte[] byRes1 = new byte[30]; + public byte[] byFingerData = new byte[MAX_FINGER_PRINT_LEN]; //指纹数据内容 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + public byte[] byLeaderFP = new byte[MAX_DOOR_NUM_256]; //对门是否有首次认证功能(按字节表示):0-无首次认证功能,1-有首次认证功能 + public byte[] byRes = new byte[128]; + } + + public static class NET_DVR_FINGER_PRINT_STATUS_V50 extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //指纹关联的卡号 + public byte[] byCardReaderRecvStatus = new byte[MAX_CARD_READER_NUM_512]; //指纹读卡器状态,按字节表示,0-失败,1-成功,2-该指纹模组不在线,3-重试或指纹质量差,4-内存已满,5-已存在该指纹,6-已存在该指纹ID,7-非法指纹ID,8-该指纹模组无需配置,10-指纹读卡器版本过低(无法支持工号) + public byte byFingerPrintID; //手指编号,有效值范围为1-10 + public byte byFingerType; //指纹类型 0-普通指纹,1-胁迫指纹,2-巡更指纹,3-超级指纹,4-解除指纹 + public byte byTotalStatus; //下发总的状态,0-当前指纹未下完所有读卡器,1-已下完所有读卡器(这里的所有指的是门禁主机往所有的读卡器下发了,不管成功与否) + public byte byRecvStatus; //主机错误状态:0-成功,1-手指编号错误,2-指纹类型错误,3-卡号错误(卡号规格不符合设备要求),4-指纹未关联工号或卡号(工号或卡号字段为空),5-工号不存在,6-指纹数据长度为0,7-读卡器编号错误,8-工号错误 + public byte[] byErrorMsg = new byte[ERROR_MSG_LEN]; //下发错误信息,当byCardReaderRecvStatus为5时,表示已存在指纹对应的卡号 + public int dwCardReaderNo; //当byCardReaderRecvStatus为5时,表示已存在指纹对应的指纹读卡器编号,可用于下发错误返回。0时表示无错误信息 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + public byte[] byErrorEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //下发错误信息,当byCardReaderRecvStatus为5时,表示已存在指纹对应的工号(人员ID) + public byte[] byRes = new byte[128]; + } + + public static class NET_DVR_FINGER_PRINT_INFO_COND_V50 extends Structure { + public int dwSize; + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //指纹关联的卡号(该字段获取时有效,设置时无效) + public byte[] byEnableCardReader = new byte[MAX_CARD_READER_NUM_512]; //指纹的读卡器是否有效,0-无效,1-有效 + public int dwFingerPrintNum; //设置或获指纹数量,获取时置为0xffffffff表示获取所有指纹信息 + public byte byFingerPrintID; //手指编号,有效值范围为1-10 0xff表示该卡所有指纹 + public byte byCallBackMode; //设备回调方式,0-设备所有读卡器下完了返回,1-在时间段内下了部分也返回 + public byte[] byRes2 = new byte[2]; //保留 + public byte[] byEmployeeNo = new byte[NET_SDK_EMPLOYEE_NO_LEN]; //工号(人员ID) + public byte[] byRes1 = new byte[128]; //保留 + } + + public static class NET_DVR_GROUP_CFG extends Structure { + public int dwSize; + public byte byEnable; //是否启用,0-不启用,1-启用 + public byte[] byRes1 = new byte[3]; + public NET_DVR_VALID_PERIOD_CFG struValidPeriodCfg = new NET_DVR_VALID_PERIOD_CFG(); //群组有效期参数 + public byte[] byGroupName = new byte[32]; //群组名称 + public byte[] byRes2 = new byte[32]; + } + + public static class NET_DVR_MULTI_CARD_CFG_V50 extends Structure { + public int dwSize; + public byte byEnable; + public byte bySwipeIntervalTimeout; + public byte[] byRes1 = new byte[2]; + public NET_DVR_MULTI_CARD_GROUP_CFG_V50[] struGroupCfg = (NET_DVR_MULTI_CARD_GROUP_CFG_V50[]) new NET_DVR_MULTI_CARD_GROUP_CFG_V50().toArray(20); + public byte[] byRes2 = new byte[32]; + } + + public static class NET_DVR_MULTI_CARD_GROUP_CFG_V50 extends Structure { + public byte byEnable; + public byte byEnableOfflineVerifyMode; + public byte[] byRes1 = new byte[2]; + public int dwTemplateNo; + public NET_DVR_GROUP_COMBINATION_INFO_V50[] struGroupCombination = (NET_DVR_GROUP_COMBINATION_INFO_V50[]) new NET_DVR_GROUP_COMBINATION_INFO_V50().toArray(8); + } + + public static class NET_DVR_GROUP_COMBINATION_INFO_V50 extends Structure { + public byte byEnable; + public byte byMemberNum; + public byte bySequenceNo; + public byte byRes; + public int dwGroupNo; + } + + + //自定义结构体,用于二维数组转换 + public static class NET_DVR_SINGLE_PLAN_SEGMENT_WEEK extends Structure { + public NET_DVR_SINGLE_PLAN_SEGMENT[] struPlanCfgDay = new NET_DVR_SINGLE_PLAN_SEGMENT[MAX_TIMESEGMENT_V30]; //一天的计划参数 + } + + public static class NET_DVR_WEEK_PLAN_CFG extends Structure { + public int dwSize; + public byte byEnable; //是否使能,1-使能,0-不使能 + public byte[] byRes1 = new byte[3]; + public NET_DVR_SINGLE_PLAN_SEGMENT_WEEK[] struPlanCfg = new NET_DVR_SINGLE_PLAN_SEGMENT_WEEK[MAX_DAYS]; //周计划参数 + public byte[] byRes2 = new byte[16]; + } + + public static class NET_DVR_SINGLE_PLAN_SEGMENT extends Structure { + public byte byEnable; //是否使能,1-使能,0-不使能 + public byte byDoorStatus; //门状态模式(梯控模式),0-无效,1-常开状态(自由),2-常闭状态(禁用),3-普通状态(门状态计划使用) + public byte byVerifyMode; //验证方式,0-无效,1-刷卡,2-刷卡+密码(读卡器验证方式计划使用),3-刷卡,4-刷卡或密码(读卡器验证方式计划使用), 5-指纹,6-指纹+密码,7-指纹或刷卡,8-指纹+刷卡,9-指纹+刷卡+密码(无先后顺序),10-人脸或指纹或刷卡或密码,11-人脸+指纹,12-人脸+密码, + //13-人脸+刷卡,14-人脸,15-工号+密码,16-指纹或密码,17-工号+指纹,18-工号+指纹+密码,19-人脸+指纹+刷卡,20-人脸+密码+指纹,21-工号+人脸,22-人脸或人脸+刷卡 + public byte[] byRes = new byte[5]; + public NET_DVR_TIME_SEGMENT struTimeSegment; //时间段参数 + } + + + public static class NET_DVR_TIME_SEGMENT extends Structure { + public NET_DVR_SIMPLE_DAYTIME struBeginTime; //开始时间点 + public NET_DVR_SIMPLE_DAYTIME struEndTime; //结束时间点 + } + + public static class NET_DVR_SIMPLE_DAYTIME extends Structure { + public byte byHour; //时 + public byte byMinute; //分 + public byte bySecond; //秒 + public byte byRes; + } + + public static class NET_DVR_WEEK_PLAN_COND extends Structure { + public int dwSize; + public int dwWeekPlanNumber; //周计划编号 + public short wLocalControllerID; //就地控制器序号[1,64] + public byte[] byRes = new byte[106]; + } + + public static final int TEMPLATE_NAME_LEN = 32; //计划模板名称长度 + public static final int MAX_HOLIDAY_GROUP_NUM = 16; //计划模板最大假日组数 + + public static class NET_DVR_PLAN_TEMPLATE extends Structure { + public int dwSize; + public byte byEnable; //是否启用,1-启用,0-不启用 + public byte[] byRes1 = new byte[3]; + public byte[] byTemplateName = new byte[TEMPLATE_NAME_LEN]; //模板名称 + public int dwWeekPlanNo; //周计划编号,0为无效 + public int[] dwHolidayGroupNo = new int[MAX_HOLIDAY_GROUP_NUM]; //假日组编号,就前填充,遇0无效 + public byte[] byRes2 = new byte[32]; + } + + public static class NET_DVR_PLAN_TEMPLATE_COND extends Structure { + public int dwSize; + public int dwPlanTemplateNumber; //计划模板编号,从1开始,最大值从门禁能力集获取 + public short wLocalControllerID; //就地控制器序号[1,64],0无效 + public byte[] byRes = new byte[106]; + } + + public static class NET_DVR_CAPTURE_FACE_COND extends Structure { + public int dwSize; + public byte[] byRes = new byte[128]; + } + + public static class NET_DVR_FACE_FEATURE extends Structure { + public NET_VCA_RECT struFace; //人脸子图区域 + public NET_VCA_POINT struLeftEye; // 左眼坐标 + public NET_VCA_POINT struRightEye; // 右眼坐标 + public NET_VCA_POINT struLeftMouth; // 嘴左边坐标 + public NET_VCA_POINT struRightMouth; // 嘴右边坐标 + public NET_VCA_POINT struNoseTip; // 鼻子坐标 + } + + public static class NET_DVR_CAPTURE_FACE_CFG extends Structure { + public int dwSize; + public int dwFaceTemplate1Size; //人脸模板1数据大小,等于0时,代表无人脸模板1数据 + public Pointer pFaceTemplate1Buffer; //人脸模板1数据缓存(不大于2.5k) + public int dwFaceTemplate2Size; //人脸模板2数据大小,等于0时,代表无人脸模板2数据 + public Pointer pFaceTemplate2Buffer; //人脸模板2数据缓存(不大于2.5K) + public int dwFacePicSize; //人脸图片数据大小,等于0时,代表无人脸图片数据 + public Pointer pFacePicBuffer; //人脸图片数据缓存 + public byte byFaceQuality1; //人脸质量,范围1-100 + public byte byFaceQuality2; //人脸质量,范围1-100 + public byte byCaptureProgress; //采集进度,目前只有两种进度值:0-未采集到人脸,100-采集到人脸(只有在进度为100时,才解析人脸信息) + public byte byFacePicQuality; //人脸图片中人脸质量 + public int dwInfraredFacePicSize; //红外人脸图片数据大小,等于0时,代表无人脸图片数据 + public Pointer pInfraredFacePicBuffer; //红外人脸图片数据缓存 + public byte byInfraredFacePicQuality; //红外人脸图片中人脸质量 + public byte[] byRes1 = new byte[3]; + public NET_DVR_FACE_FEATURE struFeature = new NET_DVR_FACE_FEATURE(); //人脸抠图特征信息 + public byte[] byRes = new byte[56]; + } + + public static class NET_DVR_XML_CONFIG_INPUT extends Structure { + public int dwSize; + public Pointer lpRequestUrl; + public int dwRequestUrlLen; + public Pointer lpInBuffer; + public int dwInBufferSize; + public int dwRecvTimeOut; + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_STRING_POINTER extends Structure { + public byte[] byString; + + public NET_DVR_STRING_POINTER(int iLen) { + byString = new byte[iLen]; + } + } + + public static class NET_DVR_XML_CONFIG_OUTPUT extends Structure { + public int dwSize; + public Pointer lpOutBuffer; + public int dwOutBufferSize; + public int dwReturnedXMLSize; + public Pointer lpStatusBuffer; + public int dwStatusSize; + public byte[] byRes = new byte[32]; + } + + //报警场景信息 + public static class NET_DVR_SCENE_INFO extends Structure { + public int dwSceneID; //场景ID, 0 - 表示该场景无效 + public byte[] bySceneName = new byte[NAME_LEN]; //场景名称 + public byte byDirection; //监测方向 1-上行,2-下行,3-双向,4-由东向西,5-由南向北,6-由西向东,7-由北向南,8-其它 + public byte[] byRes1 = new byte[3]; //保留 + public NET_DVR_PTZPOS struPtzPos; //Ptz 坐标 + public byte[] byRes2 = new byte[64]; //保留 + } + + // 方向结构体 + public static class NET_DVR_DIRECTION extends Structure { + public NET_VCA_POINT struStartPoint = new NET_VCA_POINT(); // 方向起始点 + public NET_VCA_POINT struEndPoint = new NET_VCA_POINT(); // 方向结束点 + } + + // 交通事件信息 + public static class NET_DVR_AID_INFO extends Structure { + public byte byRuleID; // 规则序号,为规则配置结构下标,0-16 + public byte[] byRes1 = new byte[3]; + public byte[] byRuleName = new byte[NAME_LEN]; // 规则名称 + public int dwAIDType; // 报警事件类型 + public NET_DVR_DIRECTION struDirect = new NET_DVR_DIRECTION(); // 报警指向区域 + public byte bySpeedLimit; //限速值,单位km/h[0,255] + public byte byCurrentSpeed; //当前速度值,单位km/h[0,255] + public byte byVehicleEnterState; //车辆出入状态:0- 无效,1- 驶入,2- 驶出 + public byte byState; //0-变化上传,1-轮巡上传 + public byte[] byParkingID = new byte[16]; //停车位编号 + public int dwAIDTypeEx; // 报警事件类型扩展,参考TRAFFIC_AID_TYPE_EX + public byte[] byRes2 = new byte[16]; // 保留字节 + } + + public int ILLEGAL_LEN = 32; //违法代码长度 + public int MONITORSITE_ID_LEN = 48;//监测点编号长度 + public int DEVICE_ID_LEN = 48; + + //交通取证报警 + public static class NET_DVR_TFS_ALARM extends Structure { + public int dwSize; //结构体大小 + public int dwRelativeTime; //相对时标 + public int dwAbsTime; //绝对时标 + public int dwIllegalType; //违章类型,采用国标定义,当dwIllegalType值为0xffffffff时使用byIllegalCode + public int dwIllegalDuration; //违法持续时间(单位:秒) = 抓拍最后一张图片的时间 - 抓拍第一张图片的时间 + public byte[] byMonitoringSiteID = new byte[MONITORSITE_ID_LEN];//监测点编号(路口编号、内部编号) + public byte[] byDeviceID = new byte[DEVICE_ID_LEN]; //设备编号 + public NET_VCA_DEV_INFO struDevInfo = new NET_VCA_DEV_INFO(); //前端设备信息 + public NET_DVR_SCENE_INFO struSceneInfo = new NET_DVR_SCENE_INFO(); //场景信息 + public NET_DVR_TIME_EX struBeginRecTime = new NET_DVR_TIME_EX(); //录像开始时间 + public NET_DVR_TIME_EX struEndRecTime = new NET_DVR_TIME_EX(); //录像结束时间 + public NET_DVR_AID_INFO struAIDInfo = new NET_DVR_AID_INFO(); //交通事件信息 + public NET_DVR_PLATE_INFO struPlateInfo = new NET_DVR_PLATE_INFO(); //车牌信息 + public NET_DVR_VEHICLE_INFO struVehicleInfo = new NET_DVR_VEHICLE_INFO(); //车辆信息 + public int dwPicNum; //图片数量 + public NET_ITS_PICTURE_INFO[] struPicInfo = new NET_ITS_PICTURE_INFO[8]; //图片信息,最多8张 + public byte bySpecificVehicleType; //具体车辆种类 参考识别结果类型VTR_RESULT + public byte byLaneNo; //关联车道号 + public byte[] byRes1 = new byte[2]; //保留 + public NET_DVR_TIME_V30 struTime = new NET_DVR_TIME_V30();//手动跟踪定位,当前时间。 + public int dwSerialNo;//序号; + public byte byVehicleAttribute;//车辆属性,按位表示,0- 无附加属性(普通车),bit1- 黄标车(类似年检的标志),bit2- 危险品车辆,值:0- 否,1- 是 + public byte byPilotSafebelt;//0-表示未知,1-系安全带,2-不系安全带 + public byte byCopilotSafebelt;//0-表示未知,1-系安全带,2-不系安全带 + public byte byPilotSunVisor;//0-表示未知,1-不打开遮阳板,2-打开遮阳板 + public byte byCopilotSunVisor;//0-表示未知, 1-不打开遮阳板,2-打开遮阳板 + public byte byPilotCall;// 0-表示未知, 1-不打电话,2-打电话 + public byte[] byRes2 = new byte[2]; //保留 + public byte[] byIllegalCode = new byte[ILLEGAL_LEN/*32*/];//违法代码扩展,当dwIllegalType值为0xffffffff;使用这个值 + public short wCountry; // 国家索引值,参照枚举COUNTRY_INDEX + public byte byRegion; //区域索引值,0-保留,1-欧洲(Europe Region),2-俄语区域(Russian Region),3-欧洲&俄罗斯(EU&CIS) , 4-中东(Middle East),0xff-所有 + public byte byCrossLine;//是否压线停车(侧方停车),0-表示未知,1-不压线,2-压线 + public byte[] byParkingSerialNO = new byte[16];//泊车位编号 + public byte byCrossSpaces;//是否跨泊车位停车(侧方停车),0-表示未知,1-未跨泊车位停车,2-跨泊车位停车 + public byte byAngledParking;//是否倾斜停车(侧方停车), 0-表示未知,1-未倾斜停车,2-倾斜停车 + public byte byAlarmValidity;//报警置信度,可以输出驶入驶出的置信度,范围0-100;置信度越高,事件真实性越高 + public byte byDoorsStatus;//车门状态 0-车门关闭 1-车门开启 + public int dwXmlLen;//XML报警信息长度 + public Pointer pXmlBuf; // XML报警信息指针,其XML对应到EventNotificationAlert XML Block + public byte byVehicleHeadTailStatus;//车头车尾状态 0-保留 1-车头 2-车尾 + public byte byBrokenNetHttp; //断网续传标志位,0-不重传数据,1-重传数据 + public byte[] byRes = new byte[30]; //保留 + } + + public static class NET_ITS_OVERLAPCFG_COND extends Structure { + public int dwSize; + public int dwChannel; + public int dwConfigMode; //配置模式,0-终端,1-前端(直连前端或终端接前端) + public byte byPicModeType;//0-表示小图(独立图),1-表示大图(合成图) + /* + 0表示关联 抓拍MPR模式(多帧触发抓拍 IPC使用) + 1 表示关联 抓拍 HVT 模式(混卡IPC使用) + */ + public byte byRelateType; + public byte[] byRes = new byte[14]; + + } + + //字符叠加每一条信息结构体 + public static class NET_ITS_OVERLAP_SINGLE_ITEM_PARAM_V50 extends Structure { + public byte[] byRes1 = new byte[2]; // 保留 + public byte byItemType; //类型,详见OVERLAP_ITEM_TYPE + public byte byChangeLineNum; //叠加项后的换行数[0-10](默认0) + public byte bySpaceNum; //叠加项后的空格数[0-255](默认0) + public byte[] byRes2 = new byte[2]; + public byte byEnablePos; //是否启用坐标显示 + public short wStartPosTop; //起始上坐标,只对图片内部叠加有效[0~2448](默认0) + public short wStartPosLeft; //起始左坐标,只对图片内部叠加有效[0~2448](默认0) + //自定义类型;与byItemType参数对应。可将byItemType参数类型自定义名称。若自定义内容为空,便默认以byItemType参数中的类型命名。 + public byte[] byItemTypeCustom = new byte[32]; + public byte[] byRes = new byte[8]; + + } + + public int MAX_OVERLAP_ITEM_NUM = 50; //最大字符叠加种数 + + public static class NET_ITS_OVERLAP_ITEM_PARAM_V50 extends Structure { + public NET_ITS_OVERLAP_SINGLE_ITEM_PARAM_V50[] struSingleItem = new NET_ITS_OVERLAP_SINGLE_ITEM_PARAM_V50[MAX_OVERLAP_ITEM_NUM]; //单条字符参数 + public int dwLinePercent; //叠加行百分比(0-100),(默认100) + public int dwItemsStlye; //叠加方式:0-横排,1-竖排(默认横排) + public short wStartPosTop; //起始上坐标,只对图片内部叠加有效[0~2448](默认0) + public short wStartPosLeft; //起始左坐标,只对图片内部叠加有效[0~2448](默认0) + public short wCharStyle; //字体类型,0-宋体1-魏体(默认) + public short wCharSize; //字符大小,0--16x16,1--32x32,2-48x48,3--64x64 (默认),8x128(Ver3.7) + public short wCharInterval; //字符间距,[0~16],可设单位:像素(默认) + public byte[] byRes1 = new byte[2]; + public int dwForeClorRGB; //前景色的RGB值bit0-1:(B) bit2-3:(G) bit4-5:(G) (默认x00FFFFFF-白) + public int dwBackClorRGB; //背景色的RGB值,只对图片外叠加有效bit0-1:(B) bit2-3:(G) bit4-5:(G) (默认x00000000-黑) + public byte byColorAdapt; //颜色是否自适应0-否1-是 + //(Ver3.7 新增) + // 参数补零使能 0-补零, 1-不补零(详细注释)速度,限速值 不足3位补0 + public byte byParamFillZeroEnble; + public byte byPlateLeftCornerEnable;// 车牌小图叠加左上角使能 0-不叠加, 1-叠加 + public byte byRes2; + public short wStartSPicPosTop; //起始上坐标,只对图片内部叠加有效[0~2448](默认0) + public short wStartSPicPosLeft; //起始左坐标,只对图片内部叠加有效[0~2448](默认0) + //OSD叠加位置 0-图片内,1-图片上边缘,2-图片下边缘(合成图专用的是上边缘外)(V3.7) + public byte byOsdLocate; + public byte[] byRes = new byte[63]; + + } + + //叠加项具体信息 + public static class NET_ITS_OVERLAP_INFO_PARAM extends Structure { + public byte[] bySite = new byte[128]; //地点描述 + public byte[] byRoadNum = new byte[32]; //路口编号 + public byte[] byInstrumentNum = new byte[32]; //设备编号 + public byte[] byDirection = new byte[32]; //方向编号 + public byte[] byDirectionDesc = new byte[32]; //方向描述 + public byte[] byLaneDes = new byte[32]; //车道描述 + public byte[] byRes1 = new byte[32]; //保留 + public byte[] byMonitoringSite1 = new byte[44]; //监测点1信息 + public byte[] byMonitoringSite2 = new byte[32]; //监测点2信息 + public byte[] byRes = new byte[64]; //保留 + } + + public static class NET_ITS_OVERLAP_CFG_V50 extends Structure { + public int dwSize; + public byte byEnable; //是否启用,0-不启用,1-启用 + public byte[] byRes1 = new byte[3]; + public NET_ITS_OVERLAP_ITEM_PARAM_V50 struOverLapItemV50 = new NET_ITS_OVERLAP_ITEM_PARAM_V50(); //字符串参数 + public NET_ITS_OVERLAP_INFO_PARAM struOverLapInfo = new NET_ITS_OVERLAP_INFO_PARAM(); //字符串内容信息 + public byte[] byRes = new byte[120]; + + } + + //人体特征识别结果结构体 + public static class NET_VCA_HUMAN_FEATURE extends Structure { + public byte byAgeGroup; //年龄段,参见 HUMAN_AGE_GROUP_ENUM + public byte bySex; //性别, 0-表示“未知”(算法不支持),1 – 男 , 2 – 女, 0xff-算法支持,但是没有识别出来 + public byte byEyeGlass; //是否戴眼镜 0-表示“未知”(算法不支持),1 – 不戴, 2 – 戴,0xff-算法支持,但是没有识别出来 + //抓拍图片人脸年龄的使用方式,如byAge为15,byAgeDeviation为1,表示,实际人脸图片年龄的为14-16之间 + public byte byAge;//年龄 0-表示“未知”(算法不支持),0xff-算法支持,但是没有识别出来 + public byte byAgeDeviation;//年龄误差值 + public byte byRes0; //字段预留 + public byte byMask; //是否戴口罩 0-表示“未知”(算法不支持),1 – 不戴, 2 – 戴, 0xff-算法支持,但是没有识别出来 + public byte bySmile; //是否微笑 0-表示“未知”(算法不支持),1 – 不微笑, 2 – 微笑, 0xff-算法支持,但是没有识别出来 + public byte byFaceExpression; /* 表情,参见FACE_EXPRESSION_GROUP_ENUM*/ + public byte byRes1; + public byte byRes2; + public byte byHat; // 帽子, 0-不支持,1-不戴帽子,2-戴帽子,0xff-unknow表示未知,算法支持未检出 + public byte[] byRes = new byte[4]; //保留 + } + + //人脸抓拍附加信息结构体 + public static class NET_VCA_FACESNAP_ADDINFO extends Structure { + //人脸矩形框,该坐标为人脸小图(头肩照)中人脸的坐标 + public NET_VCA_RECT struFacePicRect = new NET_VCA_RECT(); + public int iSwingAngle;//旋转角, -90~90度 + public int iTiltAngle;//俯仰角, -90~90度 + public int dwPupilDistance;//瞳距,范围为:最小值为10像素,最大值为当前分辨率宽度/1.6 + public byte byBlockingState;//目标遮挡状态, 0-表示“未知”(算法不支持),1~无遮挡,2~瞬时轻度遮挡,3~持续轻度遮挡,4~严重遮挡 + public byte byFaceSnapThermometryEnabled;//人脸抓拍测温使能 1-开启 0-关闭 + public byte byIsAbnomalTemperature;//人脸抓拍测温是否温度异常 1-是 0-否 + public byte byThermometryUnit;//测温单位: 0-摄氏度(℃),1-华氏度(℉),2-开尔文(K) + public NET_DVR_TIME_EX struEnterTime = new NET_DVR_TIME_EX(); // 最佳抓拍下进入时间 + public NET_DVR_TIME_EX struExitTime = new NET_DVR_TIME_EX(); // 最佳抓拍下离开时间 + public float fFaceTemperature; // 人脸温度( - 20.0℃~150.0℃,精确到小数点后1位) + public float fAlarmTemperature;// 测温报警警阈值(精确到小数点后1位) + public byte[] byRes = new byte[472];// 保留字节 + } + + //人脸抓拍结果 + public static class NET_VCA_FACESNAP_RESULT extends Structure { + public int dwSize; // 结构大小 + public int dwRelativeTime; // 相对时标 + public int dwAbsTime; // 绝对时标 + public int dwFacePicID; //人脸图ID + public int dwFaceScore; //人脸评分,0-100 + public NET_VCA_TARGET_INFO struTargetInfo = new NET_VCA_TARGET_INFO();//报警目标信息 + public NET_VCA_RECT struRect = new NET_VCA_RECT(); //人脸子图区域 + public NET_VCA_DEV_INFO struDevInfo = new NET_VCA_DEV_INFO(); //前端设备信息 + public int dwFacePicLen; //人脸子图的长度,为0表示没有图片,大于0表示有图片 + public int dwBackgroundPicLen; //背景图的长度,为0表示没有图片,大于0表示有图片(保留) + public byte bySmart; //IDS设备返回0(默认值),Smart Functiom Return 1 + public byte byAlarmEndMark;//报警结束标记0-保留,1-结束标记(该字段结合人脸ID字段使用,表示该ID对应的下报警结束,主要提供给NVR使用,用于判断报警结束,提取识别图片数据中,清晰度最高的图片) + public byte byRepeatTimes; //重复报警次数,0-无意义 + public byte byUploadEventDataType;//人脸图片数据长传方式:0-二进制数据,1-URL + public NET_VCA_HUMAN_FEATURE struFeature = new NET_VCA_HUMAN_FEATURE(); //人体属性 + public float fStayDuration; //停留画面中时间(单位: 秒) + public byte[] sStorageIP = new byte[16]; //存储服务IP地址 + public short wStoragePort; //存储服务端口号 + public short wDevInfoIvmsChannelEx; //与NET_VCA_DEV_INFO里的byIvmsChannel含义相同,能表示更大的值。老客户端用byIvmsChannel能继续兼容,但是最大到255。新客户端版本请使用wDevInfoIvmsChannelEx。 + public byte byFacePicQuality; + public byte byUIDLen; // 上传报警的标识长度 + public byte byLivenessDetectionStatus;// 活体检测状态:0-保留,1-未知(检测失败),2-非真人人脸,3-真人人脸,4-未开启活体检测 + /*附加信息标识位(即是否有NET_VCA_FACESNAP_ADDINFO结构体),0-无附加信息, 1-有附加信息。*/ + public byte byAddInfo; + public Pointer pUIDBuffer; //标识指针 + //附加信息指针,指向NET_VCA_FACESNAP_ADDINFO结构体 + public Pointer pAddInfoBuffer; + public byte byTimeDiffFlag; /*时差字段是否有效 0-时差无效, 1-时差有效 */ + public byte cTimeDifferenceH; /*与UTC的时差(小时),-12 ... +14, +表示东区,,byTimeDiffFlag为1时有效*/ + public byte cTimeDifferenceM; /*与UTC的时差(分钟),-30, 30, 45, +表示东区,byTimeDiffFlag为1时有效*/ + public byte byBrokenNetHttp; //断网续传标志位,0-不是重传数据,1-重传数据 + public Pointer pBuffer1; //人脸子图的图片数据 + public Pointer pBuffer2; //背景图的图片数据(保留,通过查找背景图接口可以获取背景图) + } + + //人脸抓拍信息 + public static class NET_VCA_FACESNAP_INFO_ALARM extends Structure { + public int dwRelativeTime; // 相对时标 + public int dwAbsTime; // 绝对时标 + public int dwSnapFacePicID; //抓拍人脸图ID + public int dwSnapFacePicLen; //抓拍人脸子图的长度,为0表示没有图片,大于0表示有图片 + public NET_VCA_DEV_INFO struDevInfo = new NET_VCA_DEV_INFO(); //前端设备信息 + public byte byFaceScore; //人脸评分,指人脸子图的质量的评分,0-100 + public byte bySex;//性别,0-未知,1-男,2-女 + public byte byGlasses;//是否带眼镜,0-未知,1-是,2-否 + //抓拍图片人脸年龄的使用方式,如byAge为15,byAgeDeviation为1,表示,实际人脸图片年龄的为14-16之间 + public byte byAge;//年龄 + public byte byAgeDeviation;//年龄误差值 + public byte byAgeGroup;//年龄段,详见HUMAN_AGE_GROUP_ENUM,若传入0xff表示未知 + public byte byFacePicQuality; + public byte byRes1; // 保留字节 + public int dwUIDLen; // 上传报警的标识长度 + public Pointer pUIDBuffer; //标识指针 + public float fStayDuration; //停留画面中时间(单位: 秒) + public Pointer pBuffer1; //抓拍人脸子图的图片数据 + } + + //籍贯参数 + public static class NET_DVR_AREAINFOCFG extends Structure { + public short wNationalityID; //国籍 + public short wProvinceID; //省 + public short wCityID; //市 + public short wCountyID; //县 + public int dwCode; //国家标准的省份、城市、县级代码,当这个字段不为0的时候,使用这个值,新设备上传这个值表示籍贯参数,老设备这个值为0 + } + + //人员信息 + public int MAX_HUMAN_BIRTHDATE_LEN = 10; + + public static class NET_VCA_HUMAN_ATTRIBUTE extends Structure { + public byte bySex; //性别:0-男,1-女 + public byte byCertificateType; //证件类型:0-身份证,1-警官证 + public byte[] byBirthDate = new byte[MAX_HUMAN_BIRTHDATE_LEN]; //出生年月,如:201106 + public byte[] byName = new byte[NAME_LEN]; //姓名 + public NET_DVR_AREAINFOCFG struNativePlace = new NET_DVR_AREAINFOCFG(); //籍贯参数 + public byte[] byCertificateNumber = new byte[NAME_LEN]; //证件号 + public int dwPersonInfoExtendLen;// 人员标签信息扩展长度 + public Pointer pPersonInfoExtend; //人员标签信息扩展信息 + public byte byAgeGroup;//年龄段,详见HUMAN_AGE_GROUP_ENUM,如传入0xff表示未知 + public byte[] byRes2 = new byte[11]; + } + + + //黑名单报警信息 + public static class NET_VCA_BLOCKLIST_INFO_ALARM extends Structure { + public NET_VCA_BLOCKLIST_INFO struBlockListInfo = new NET_VCA_BLOCKLIST_INFO(); //黑名单基本信息 + public int dwBlockListPicLen; //黑名单人脸子图的长度,为0表示没有图片,大于0表示有图片 + public int dwFDIDLen;// 人脸库ID长度 + public Pointer pFDID; //人脸库Id指针 + public int dwPIDLen;// 人脸库图片ID长度 + public Pointer pPID; //人脸库图片ID指针 + public short wThresholdValue; //人脸库阈值[0,100] + public byte[] byRes = new byte[2]; // 保留字节 + public Pointer pBuffer1; //黑名单人脸子图的图片数据 + } + + //黑名单信息 + public static class NET_VCA_BLOCKLIST_INFO extends Structure { + public int dwSize; //结构大小 + public int dwRegisterID; //名单注册ID号(只读) + public int dwGroupNo; //分组号 + public byte byType; //黑白名单标志:0-全部,1-白名单,2-黑名单 + public byte byLevel; //黑名单等级,0-全部,1-低,2-中,3-高 + public byte[] byRes1 = new byte[2]; //保留 + public NET_VCA_HUMAN_ATTRIBUTE struAttribute = new NET_VCA_HUMAN_ATTRIBUTE(); //人员信息 + public byte[] byRemark = new byte[NAME_LEN]; //备注信息 + public int dwFDDescriptionLen;//人脸库描述数据长度 + public Pointer pFDDescriptionBuffer;//人脸库描述数据指针 + public int dwFCAdditionInfoLen;//抓拍库附加信息长度 + public Pointer pFCAdditionInfoBuffer;//抓拍库附加信息数据指针(FCAdditionInfo中包含相机PTZ坐标) + public byte[] byRes2 = new byte[4]; + } + + + //禁止名单比对结果报警上传 + public static class NET_VCA_FACESNAP_MATCH_ALARM extends Structure { + public int dwSize; // 结构大小 + public float fSimilarity; //相似度,[0.001,1] + public NET_VCA_FACESNAP_INFO_ALARM struSnapInfo = new NET_VCA_FACESNAP_INFO_ALARM(); //抓拍信息 + public NET_VCA_BLOCKLIST_INFO_ALARM struBlockListInfo = new NET_VCA_BLOCKLIST_INFO_ALARM(); //禁止名单信息 + public byte[] sStorageIP = new byte[16]; //存储服务IP地址 + public short wStoragePort; //存储服务端口号 + public byte byMatchPicNum; //匹配图片的数量,0-保留(老设备这个值默认0,新设备这个值为0时表示后续没有匹配的图片信息) + public byte byPicTransType;//图片数据传输方式: 0-二进制;1-url + public int dwSnapPicLen;//设备识别抓拍图片长度 + public Pointer pSnapPicBuffer;//设备识别抓拍图片指针 + public NET_VCA_RECT struRegion = new NET_VCA_RECT();//目标边界框,设备识别抓拍图片中,人脸子图坐标 + public int dwModelDataLen;//建模数据长度 + public Pointer pModelDataBuffer;// 建模数据指针 + public byte byModelingStatus;// 建模状态 + public byte byLivenessDetectionStatus;//活体检测状态:0-保留,1-未知(检测失败),2-非真人人脸,3-真人人脸,4-未开启活体检测 + public byte cTimeDifferenceH; /*与UTC的时差(小时),-12 ... +14, +表示东区,0xff无效*/ + public byte cTimeDifferenceM; /*与UTC的时差(分钟),-30, 30, 45, +表示东区,0xff无效*/ + public byte byMask; //抓拍图是否戴口罩,0-保留,1-未知,2-不戴口罩,3-戴口罩 + public byte bySmile; //抓拍图是否微笑,0-保留,1-未知,2-不微笑,3-微笑 + public byte byContrastStatus; //比对结果,0-保留,1-比对成功,2-比对失败 + public byte byBrokenNetHttp; //断网续传标志位,0-不是重传数据,1-重传数据 + } + + //交通事件报警(扩展) + public static class NET_DVR_AID_ALARM_V41 extends Structure { + public int dwSize; //结构长度 + public int dwRelativeTime; //相对时标 + public int dwAbsTime; //绝对时标 + public NET_VCA_DEV_INFO struDevInfo = new NET_VCA_DEV_INFO(); //前端设备信息 + public NET_DVR_AID_INFO struAIDInfo = new NET_DVR_AID_INFO(); //交通事件信息 + public NET_DVR_SCENE_INFO struSceneInfo = new NET_DVR_SCENE_INFO(); //场景信息 + public int dwPicDataLen; //图片长度 + public Pointer pImage; //指向图片的指针 + // 0-数据直接上传; 1-云存储服务器URL(3.7Ver)原先的图片数据变成URL数据,图片长度变成URL长度 + public byte byDataType; + public byte byLaneNo; //关联车道号 + public short wMilliSecond; //时标毫秒 + //监测点编号(路口编号、内部编号) + public byte[] byMonitoringSiteID = new byte[MONITORSITE_ID_LEN/*48*/]; + public byte[] byDeviceID = new byte[DEVICE_ID_LEN/*48*/];//设备编号 + public int dwXmlLen;//XML报警信息长度 + public Pointer pXmlBuf;// XML报警信息指针,其XML对应到EventNotificationAlert XML Block + public byte byTargetType;// 检测的目标类型,0~未知,1~行人、2~二轮车、3~三轮车(行人检测中返回) + public byte byRuleID;//规则ID,1-4,当congestion事件配置了规则区域时返回 + public short wDevInfoIvmsChannelEx; //与NET_VCA_DEV_INFO里的byIvmsChannel含义相同,能表示更大的值。老客户端用byIvmsChannel能继续兼容,但是最大到255。新客户端版本请使用wDevInfoIvmsChannelEx。 + public byte byBrokenNetHttp; // 断网续传标志位,0-不重传数据,1-重传数据 + public byte[] byRes = new byte[3]; // 保留字节 + public int dwPlateSmallPicDataLen; //车牌小图图片长度 + public Pointer pPlateSmallImage; // //指向车牌小图的指针 + } + + + //交通统计信息报警(扩展) + public static class NET_DVR_TPS_ALARM_V41 extends Structure { + public int dwSize; // 结构体大小 + public int dwRelativeTime; // 相对时标 + public int dwAbsTime; // 绝对时标 + public NET_VCA_DEV_INFO struDevInfo; // 前端设备信息 + public NET_DVR_TPS_INFO_V41 struTPSInfo; // 交通参数统计信息 + //监测点编号(路口编号、内部编号) + public byte[] byMonitoringSiteID = new byte[MONITORSITE_ID_LEN/*48*/]; + public byte[] byDeviceID = new byte[DEVICE_ID_LEN/*48*/];//设备编号 + public int dwStartTime; // 开始统计时间 + public int dwStopTime; // 结束统计时间 + public byte[] byRes = new byte[24]; // 保留 + } + + public static class NET_DVR_LANE_PARAM_V41 extends Structure { + public byte[] byRuleName = new byte[NAME_LEN]; // 车道规则名称 + public byte byRuleID; // 规则序号,为规则配置结构下标,0-7 + public byte byLaneType; // 车道上行或下行 + public byte byTrafficState; // 车道的交通状态,0-无效,1-畅通,2-拥挤,3-堵塞 + public byte byLaneNo; //车道号 + public int dwVaryType; // 车道交通参数变化类型参照 TRAFFIC_DATA_VARY_TYPE_EX_ENUM,按位区分 + public int dwTpsType; // 数据变化类型标志,表示当前上传的统计参数中,哪些数据有效,参照ITS_TPS_TYPE,按位区分 + public int dwLaneVolume; // 车道流量,统计有多少车子通过 + public int dwLaneVelocity; // 车道速度,公里计算 + public int dwTimeHeadway; // 车头时距,以秒计算 + public int dwSpaceHeadway; // 车头间距,以米来计算 + public float fSpaceOccupyRation; // 车道占有率,百分比计算(空间上) + public float fTimeOccupyRation; // 时间占有率,百分比计算 + public int dwLightVehicle; // 小型车数量 + public int dwMidVehicle; // 中型车数量 + public int dwHeavyVehicle; // 重型车数量 + public NET_DVR_LANE_QUEUE struLaneQueue; // 车道队列长度 + public NET_VCA_POINT struRuleLocation; // 规则位置虚拟线圈的中心 + public int dwOversizeVehicle; // 大型车数量 + public byte[] byRes2 = new byte[60]; // 保留 + } + + public int MAX_TPS_RULE = 8; // 最大参数规则数目 + + public static class NET_DVR_TPS_INFO_V41 extends Structure { + public int dwLanNum; // 交通参数的车道数目 + public NET_DVR_LANE_PARAM_V41[] struLaneParam = new NET_DVR_LANE_PARAM_V41[MAX_TPS_RULE]; + public int dwSceneID;//场景ID + public byte[] byRes = new byte[28]; //保留 + } + + // 车道队列结构体 + public static class NET_DVR_LANE_QUEUE extends Structure { + public NET_VCA_POINT struHead; //队列头 + public NET_VCA_POINT struTail; //队列尾 + public int dwLength; //实际队列长度 单位为米 [0-500] + } + + //TPS统计过车数据上传 + public static class NET_DVR_TPS_STATISTICS_INFO extends Structure { + public int dwSize; // 结构体大小 + public int dwChan;//通道号 + public NET_DVR_TPS_STATISTICS_PARAM struTPSStatisticsInfo;// 交通参数统计信息 + public byte[] byRes = new byte[128]; // 保留 + } + + + // 交通参数统计信息 + public static class NET_DVR_TPS_STATISTICS_PARAM extends Structure { + public byte byStart; // 开始码 + public byte byCMD; // 命令号, 08-定时成组数据指令 + public byte[] byRes = new byte[2]; // 预留字节 + public short wDeviceID; // 设备ID + public short wDataLen; // 数据长度 + public byte byTotalLaneNum; // 有效车道总数 + public byte[] byRes1 = new byte[15]; + public NET_DVR_TIME_V30 struStartTime; //统计开始时间 + public int dwSamplePeriod; //统计时间,单位秒 + public NET_DVR_TPS_LANE_PARAM[] struLaneParam = new NET_DVR_TPS_LANE_PARAM[8]; + } + + //统计信息 + public static class NET_DVR_TPS_LANE_PARAM extends Structure { + public byte byLane; // 对应车道号 + public byte bySpeed; // 车道过车平均速度 + public byte[] byRes = new byte[2]; // 保留 + public int dwLightVehicle; // 小型车数量 + public int dwMidVehicle; // 中型车数量 + public int dwHeavyVehicle; // 重型车数量 + public int dwTimeHeadway; // 车头时距,以秒计算 + public int dwSpaceHeadway; // 车头间距,以米来计算 + public float fSpaceOccupyRation; // 空间占有率,百分比计算,浮点数*1000 + public float fTimeOccupyRation; // 时间占有率,百分比计算,浮点数*1000 + public byte[] byRes1 = new byte[16]; // 保留 + } + + //TPS实时过车数据上传 + public static class NET_DVR_TPS_REAL_TIME_INFO extends Structure { + public int dwSize; // 结构体大小 + public int dwChan;//通道号 + public NET_DVR_TIME_V30 struTime; //检测时间 + public NET_DVR_TPS_PARAM struTPSRealTimeInfo;// 交通参数统计信息 + public Pointer pAddInfoBuffer; + /*附加信息标识(即是否有NET_DVR_TPS_ADDINFO结构体),0-无附加信息, 1-有附加信息。*/ + public byte byAddInfoFlag; + public byte[] byRes1 = new byte[3]; // 保留 + public int dwDeviceIDEx; // 设备ID扩展 + public byte[] byRes = new byte[8]; // 保留 + } + + //实时信息 + public static class NET_DVR_TPS_PARAM extends Structure { + public byte byStart; // 开始码 + public byte byCMD; // 命令号,01-进入指令,02-离开指令,03-拥堵状态指令(为03时,只有byLaneState和byQueueLen有效),04-多线圈状态(为04时,wLoopState和wStateMask有效,表示byLane车道上多个线圈的过车状态) + public short wSpaceHeadway; //车头间距,以米来计算 + public short wDeviceID; // 设备ID + public short wDataLen; // 数据长度 + public byte byLane; // 对应车道号 + public byte bySpeed; // 对应车速(KM/H) + public byte byLaneState; // 车道状态;0-无状态,1-畅通,2-拥挤,3-堵塞 + public byte byQueueLen; // 堵塞状态下排队长度(比如50米) + public short wLoopState; //线圈状态,第几位表示几号线圈状态。状态1-到达,0-离开,线圈编号从镜头由近到远依次增大,用户在解析时优先解析车道号,再解析线圈号,单个车道的线圈号是唯一的。 + public short wStateMask; //线圈状态掩码,掩码位为1对应wLoopState状态位有效,为0表示无效 + public int dwDownwardFlow; //当前车道 从上到下车流量 + public int dwUpwardFlow; //当前车道 从下到上车流量 + public byte byJamLevel; //拥堵等级,当byLaneState为3时有效,1-轻度,2-中度,3-重度 + public byte byVehicleDirection; //0-未知,1-由上而下,2-由下而上 + public byte byJamFlow; //拥堵新增流量,每新增一辆车就上报一次累计车辆的信息 + public byte byChannelizationLane; //渠化车道号(渠化表示,车道数量变化的情况,一般为路口车道的数目) + public byte byVehicleType; //车型识别:0- 未知,1- 客车(大型),2- 货车(大型),3- 轿车(小型),4- 非机动车 + public byte[] byRes1 = new byte[5]; //保留 + public short wTimeHeadway; // 车头时距,以秒计算 + } + + public static class NET_DVR_TIME_SEARCH_COND extends Structure { + public short wYear; //年 + public byte byMonth; //月 + public byte byDay; //日 + public byte byHour; //时 + public byte byMinute; //分 + public byte bySecond; //秒 + public byte byLocalOrUTC; //0-时差无效,设备本地时间,即设备OSD时间 1-时差有效 + public short wMillisecond; //毫秒,精度不够,默认为0 + public byte cTimeDifferenceH; //与UTC的时差(小时),-12 ... +14,+表示东区,byLocalOrUTC为1时有效 + public byte cTimeDifferenceM; //与UTC的时差(分钟),-30, 0, 30, 45,+表示东区,byLocalOrUTC为1时有效 + } + + //事件搜索条件 + public static class NET_DVR_SEARCH_EVENT_PARAM extends Structure { + public short wMajorType; //0-移动侦测,1-报警输入, 2-智能事件 5-pos录像 7-门禁事件, 8-非视频联动事件 + public short wMinorType; //搜索次类型- 根据主类型变化,0xffff表示全部 + public NET_DVR_TIME struStartTime = new NET_DVR_TIME(); //搜索的开始时间,停止时间: 同时为(0, 0) 表示从最早的时间开始,到最后,最前面的4000个事件 + public NET_DVR_TIME struEndTime = new NET_DVR_TIME(); //搜索的结束时间 + public byte byLockType; // 0xff-全部,0-未锁,1-锁定 + public byte byValue; //0-按位表示,1-按值表示 + public byte[] byRes = new byte[130]; // 保留 + public UNION_EVENT_PARAM uSeniorParam = new UNION_EVENT_PARAM(); + } + + public static class UNION_EVENT_PARAM extends Union { + public byte[] byLen = new byte[SEARCH_EVENT_INFO_LEN]; + public EVENT_INQUESTPARAM struInquestParam = new EVENT_INQUESTPARAM(); + } + + //审讯事件搜索条件 + public static class EVENT_INQUESTPARAM extends Structure { + public byte byRoomIndex; //审讯室编号,按值表示,从1开始 + public byte[] byRes1 = new byte[3]; + public byte[] sInquestInfo = new byte[INQUEST_CASE_LEN]; + public byte[] byRes2 = new byte[232]; //保留 + } + + //事件搜索条件 + public static class NET_DVR_SEARCH_EVENT_PARAM_V50 extends Structure { + public short wMajorType; //0-移动侦测,1-报警输入, 2-智能事件 5-pos录像 7-门禁事件, 8-非视频联动事件 + public short wMinorType; //搜索次类型- 根据主类型变化,0xffff表示全部 + public NET_DVR_TIME_SEARCH_COND struStartTime = new NET_DVR_TIME_SEARCH_COND(); //搜索的开始时间,停止时间: 同时为(0, 0) 表示从最早的时间开始,到最后,最前面的4000个事件 + public NET_DVR_TIME_SEARCH_COND struEndTime = new NET_DVR_TIME_SEARCH_COND(); //搜索的结束时间 + public byte byLockType; // 0xff-全部,0-未锁,1-锁定 + public byte byQuickSearch; // 是否启用快速查询,0-不启用,1-启用(快速查询不会返回文件大小,仅对设备数据库进行查询,避免频繁唤醒硬盘) + public byte[] byRes = new byte[254]; // 保留 + public UNION_EVENT_PARAM_V50 uSeniorParam = new UNION_EVENT_PARAM_V50(); + } + + public static class UNION_EVENT_PARAM_V50 extends Union { + public byte[] byLen = new byte[SEARCH_EVENT_INFO_LEN_V40/*800*/]; + public EVENT_ALARMPARAM_V50 struAlarmParam = new EVENT_ALARMPARAM_V50(); + public EVENT_MOTIONPARAM_V50 struMotionParam = new EVENT_MOTIONPARAM_V50(); + public EVENT_VCAPARAM_V50 struVcaParam = new EVENT_VCAPARAM_V50(); + public EVENT_INQUESTPARAM_V50 struInquestParam = new EVENT_INQUESTPARAM_V50(); + public EVENT_VCADETECTPARAM_V50 struVCADetect = new EVENT_VCADETECTPARAM_V50(); + public EVENT_STREAMIDPARAM_V50 struStreamIDParam = new EVENT_STREAMIDPARAM_V50(); + public EVENT_POSPARAM_V50 struPosAlarm = new EVENT_POSPARAM_V50(); + public EVENT_TRIALPARAM_V50 struTrialParam = new EVENT_TRIALPARAM_V50(); + public EVENT_ACSPARAM_V50 struACSAlarm = new EVENT_ACSPARAM_V50(); + public EVENT_IOTPARAM_V50 struIOTAlarm = new EVENT_IOTPARAM_V50(); + } + + public static class EVENT_ALARMPARAM_V50 extends Structure { + /*报警输入号,按值表示,采用紧凑型排列,0xffff表示后续无效*/ + public short[] wAlarmInNo = new short[128]; + public byte[] byRes = new byte[544]; //保留 + } + + //移动侦测 + public static class EVENT_MOTIONPARAM_V50 extends Structure { + /* 移动侦测通道,按值表示 ,采用紧凑型排列,0xffff表示后续无效*/ + public short[] wMotDetChanNo = new short[MAX_CHANNUM_V30]; + public byte[] byRes = new byte[672]; /*保留*/ + } + + //行为分析 + public static class EVENT_VCAPARAM_V50 extends Structure { + //行为分析对应的通道,按值表示,采用紧凑型排列,0xffff表示后续无效 + public short[] wChanNo = new short[MAX_CHANNUM_V30]; + public byte byRuleID; //行为分析类型,规则0xff表示全部,从0开始 + public byte byDriverBehaviortType; //司机驾驶行为类型:0-保留、1-抽烟、2-接打电话、3-疲劳驾驶、4-分神提醒、5-驾驶员异常、6-未系安全带、7-红外阻断墨镜 + public byte byADASType; //高级辅助驾驶类型:0-保留、1-前向碰撞、2-车道偏离、3-盲区检测、4-车距检测、5-行人防撞、6-急加速、7-急减速、8-急左转弯、9-急右转弯、10-车辆翻车、11-未礼让行人 + public byte byGSensorType; // G-Sensor事件:0-保留、1-急加速、2-急减速、3-急左转弯、4-急右转弯、5-车辆翻车、6-车辆碰撞 + public byte bySensorInType; // Sensor-In行为:0-保留、1-刹车、2-左转、3-右转、4-倒车 + public byte[] byRes = new byte[667]; /*保留*/ + } + + //审讯事件搜索条件 + public static class EVENT_INQUESTPARAM_V50 extends Structure { + public byte byRoomIndex; //审讯室编号,从1开始 + public byte[] byRes = new byte[799]; //保留 + } + + //智能侦测查找条件 ,通道号按值表示 + public static class EVENT_VCADETECTPARAM_V50 extends Structure { + public byte byAll; //查找全部通道,0-否,此时dwChanNo参数有效, + //1-查找全部通道,此时dwChanNo参数无效。 + public byte[] byRes1 = new byte[3]; + public short[] wChanNo = new short[MAX_CHANNUM_V30];// 触发通道号,按值表示,0xffff无效,且后续数据也表示无效值 + public byte[] byRes = new byte[668]; + } + + public static class EVENT_STREAMIDPARAM_V50 extends Structure { + public NET_DVR_STREAM_INFO struIDInfo = new NET_DVR_STREAM_INFO(); // 流id信息,72字节长 + public int dwCmdType; // 外部触发类型,NVR接入云存储使用 + public byte byBackupVolumeNum; //存档卷号,CVR使用 + public byte[] byRes1 = new byte[3]; + public byte[] byArchiveLabel = new byte[64]; //存档标签,CVR使用 + public byte[] byRes = new byte[656]; + } + + //pos录像 + public static class EVENT_POSPARAM_V50 extends Structure { + public short[] wChannel = new short[MAX_CHANNUM_V30]; //通道,按值表示,紧凑型排列,遇到0xffff时表示数组后续值无效 + public byte byAllChan; //是否查找全部通道,0-否,此时wChannel有效,1-全部通道,此时wChannel无效 + public byte byCaseSensitive; //0-不区分大小写, 1-区分大小写 + public byte byCombinateMode; //关键字组合方式,0-或,1-与 + public byte byRes1; //保留 + public byte[] sKeyWord = new byte[MAX_POS_KEYWORDS_NUM * MAX_POS_KEYWORD_LEN]; + //关键字查找时的条件 + public byte[] byRes = new byte[284]; //保留 + } + + public static class EVENT_TRIALPARAM_V50 extends Structure { + public byte[] byCaseNo = new byte[SEARCH_CASE_NO_LEN]; + public byte[] byCaseName = new byte[SEARCH_CASE_NAME_LEN]; + public byte[] byLitigant1 = new byte[SEARCH_LITIGANT_LEN]; + public byte[] byLitigant2 = new byte[SEARCH_LITIGANT_LEN]; + public byte[] byChiefJudge = new byte[SEARCH_CHIEF_JUDGE_LEN]; + public byte byCaseType; + public byte[] byRes = new byte[547]; + } + + //门禁事件搜索条件 + public static class EVENT_ACSPARAM_V50 extends Structure { + public int dwMajor; //报警主类型(与事件上传主类型一致,0代表全部) + public int dwMinor; //报警次类型(与事件上传主类型一致,0代表全部) + public byte[] byCardNo = new byte[ACS_CARD_NO_LEN]; //卡号 + public byte[] byName = new byte[NAME_LEN/*32*/]; //姓名 + public byte[] byMACAddr = new byte[MACADDR_LEN]; //物理MAC地址 + public byte[] byRes = new byte[722]; + } + + //非视频联动事件搜索条件 + public static class EVENT_IOTPARAM_V50 extends Structure { + public short wDeviceType; //设备类型,0-海康门禁主机,1-海康可视对讲设备, 2-海康报警主机(预留) 3-GJD报警主机 4-Luminite报警主机, 5-OPTEX报警主机,6-cameraDetector模拟相机传感器设备 + public short wEventType; //搜索次类型- 根据主类型变化,0xffff表示全部 + public short[] wChannel = new short[MAX_CHANNUM_V30/*64*/]; //通道号,按值表示,紧凑型排列,遇到0xffff时表示数组后续值无效 + public byte byAllChan; //是否查找全部通道,0-否,此时wChannel有效,1-全部通道,此时wChannel无效 + public byte byCaseSensitive; //0-不区分大小写, 1-区分大小写 + public byte byCombinateMode; //关键字组合方式,0-或,1-与 + public byte bySearchType; //搜索方式:0-按视频源搜索(此时通道号为视频通道号) + public byte[] sKeyWord = new byte[MAX_POS_KEYWORDS_NUM * MAX_POS_KEYWORD_LEN];//关键字查找时的条件 + public short wZoneNo; //防区号,仅当设备类型为海康报警主机,次类型为防区(wEventType为1)时有效 + public byte[] byRes = new byte[278]; //保留 + } + + //查找返回结果 + public static class NET_DVR_SEARCH_EVENT_RET extends Structure { + public short wMajorType; //主类型 + public short wMinorType; //次类型 + public NET_DVR_TIME struStartTime = new NET_DVR_TIME(); //事件开始的时间 + public NET_DVR_TIME struEndTime = new NET_DVR_TIME(); //事件停止的时间 + public byte[] byChan = new byte[MAX_CHANNUM_V30]; + public byte[] byChanEx = new byte[32]; //关联通道,按位表示,使用该字段后byChan可以不使用 + public byte[] byRes = new byte[4]; + public UNION_EVENT_RET uSeniorRet = new UNION_EVENT_RET(); + } + + public static class UNION_EVENT_RET extends Union { + public byte[] byLen = new byte[304]; + public EVENT_ALARMSTRET struAlarmRet = new EVENT_ALARMSTRET(); + public EVENT_INQUESTRET struInquestRet = new EVENT_INQUESTRET(); + } + + //报警输入结果 + public static class EVENT_ALARMSTRET extends Structure { + + public int dwAlarmInNo; //报警输入号 + public byte[] byRes = new byte[SEARCH_EVENT_INFO_LEN]; + } + + //审讯事件 + public static class EVENT_INQUESTRET extends Structure { + public byte byRoomIndex; //审讯室编号,从1开始 + public byte byDriveIndex; //刻录机编号,从1开始 + public byte[] byRes1 = new byte[6]; //保留 + public int dwSegmentNo; //本片断在本次审讯中的序号,从1开始 + public short wSegmetSize; //本片断的大小, 单位M + public short wSegmentState; //本片断状态 0 刻录正常,1 刻录异常,2 不刻录审讯 + public byte[] byRes2 = new byte[288]; //保留 + + @Override + protected List getFieldOrder() { + // TODO Auto-generated method stub + return Arrays.asList("byRoomIndex", "byDriveIndex", "byRes1", "dwSegmentNo", "wSegmetSize", "wSegmentState", "byRes2"); + } + } + + //查找返回结果 + public static class NET_DVR_SEARCH_EVENT_RET_V50 extends Structure { + public short wMajorType; //主类型 + public short wMinorType; //次类型 + public NET_DVR_TIME_SEARCH struStartTime = new NET_DVR_TIME_SEARCH(); //事件开始的时间 + public NET_DVR_TIME_SEARCH struEndTime = new NET_DVR_TIME_SEARCH(); //事件停止的时间,脉冲事件时和开始时间一样 + public NET_DVR_ADDRESS struAddr = new NET_DVR_ADDRESS(); //片段所在的地址信息,集群回放时用到 + public short[] wChan = new short[MAX_CHANNUM_V40/*512*/]; //触发的通道号,0xffff表示后续无效 + public byte[] byRes = new byte[256]; + public UNION_EVENT_RET_V50 uSeniorRet = new UNION_EVENT_RET_V50(); + } + + public static class UNION_EVENT_RET_V50 extends Union { + public byte[] byLen = new byte[800]; + public EVENT_ALARMRET_V50 struAlarmRet = new EVENT_ALARMRET_V50(); + public EVENT_MOTIONRET_V50 struMotionRet = new EVENT_MOTIONRET_V50(); + public EVENT_VCARET_V50 struVcaRet = new EVENT_VCARET_V50(); + public EVENT_INQUESTRET_V50 struInquestRet = new EVENT_INQUESTRET_V50(); + public EVENT_STREAMIDRET_V50 struStreamIDRet = new EVENT_STREAMIDRET_V50(); + public EVENT_POSRET_V50 struPosRet = new EVENT_POSRET_V50(); + public EVENT_TRIALRET_V50 struTrialRet = new EVENT_TRIALRET_V50(); + public EVENT_IOTRET_V50 struIOTRet = new EVENT_IOTRET_V50(); + } + + //报警输入结果 + public static class EVENT_ALARMRET_V50 extends Structure { + public int dwAlarmInNo; //报警输入号 + public byte[] byRes = new byte[796]; + } + + //移动侦测结果 + public static class EVENT_MOTIONRET_V50 extends Structure { + public int dwMotDetNo; //移动侦测通道 + public byte[] byRes = new byte[796]; + } + + //行为分析结果 + public static class EVENT_VCARET_V50 extends Structure { + public int dwChanNo; //触发事件的通道号 + public byte byRuleID; //规则ID + public byte[] byRes1 = new byte[3]; //保留 + public byte[] byRuleName = new byte[NAME_LEN]; //规则名称 + public NET_VCA_EVENT_UNION uEvent = new NET_VCA_EVENT_UNION(); //行为事件参数 + public byte[] byRes = new byte[668]; //保留 + } + + //审讯事件 + public static class EVENT_INQUESTRET_V50 extends Structure { + public byte byRoomIndex; //审讯室编号,从1开始 + public byte byDriveIndex; //刻录机编号,从1开始 + public byte[] byRes1 = new byte[6]; //保留 + public int dwSegmentNo; //本片断在本次审讯中的序号,从1开始 + public short wSegmetSize; //本片断的大小, 单位M + public short wSegmentState; //本片断状态 0 刻录正常,1 刻录异常,2 不刻录审讯 + public byte[] byRes2 = new byte[784]; //保留 + } + + //流id录像查询结果 + public static class EVENT_STREAMIDRET_V50 extends Structure { + public int dwRecordType; //录像类型 0-定时录像 1-移动侦测 2-报警录像 3-报警|移动侦测 4-报警&移动侦测 5-命令触发 6-手动录像 7-震动报警 8-环境触发 9-智能报警 10-回传录像 + public int dwRecordLength; //录像大小 + public byte byLockFlag; // 锁定标志 0:没锁定 1:锁定 + public byte byDrawFrameType; // 0:非抽帧录像 1:抽帧录像 + public byte byPosition;// 文件所在存储位置:0-阵列上,1-带库机位上,可以直接下载,2-磁带库内,需要把磁盘切换到机位上,3-不在磁带库中,需要把磁盘插到磁带库中 + public byte byRes1; + public byte[] byFileName = new byte[NAME_LEN]; //文件名 + public int dwFileIndex; // 存档卷上的文件索引 + public byte[] byTapeIndex = new byte[NET_SDK_MAX_TAPE_INDEX_LEN]; //文件所在磁带编号 + public byte[] byFileNameEx = new byte[NET_SDK_MAX_FILE_LEN/*256*/]; //文件名扩展 + public byte[] byRes = new byte[464]; + } + + //POS录像查询结果 + public static class EVENT_POSRET_V50 extends Structure { + public int dwChanNo; //触发产生pos事件的通道 + public byte[] byRes = new byte[796]; + } + + public static class EVENT_TRIALRET_V50 extends Structure { + public byte byRoomIndex; //审讯室编号,从1开始 + public byte byDriveIndex; //刻录机编号,从1开始 + public short wSegmetSize; //本片断的大小, 单位M + public int dwSegmentNo; //本片断在本次审讯中的序号,从1开始 + public byte bySegmentState; //本片断状态,0-刻录正常,1-刻录异常,2-不刻录审讯 + public byte byCaseType; //案件类型;0-全部、1-刑事案件、2-民事案件 + public byte[] byRes = new byte[2]; + public byte[] byCaseNo = new byte[CASE_NO_RET_LEN]; //案件编号 + public byte[] byCaseName = new byte[CASE_NAME_RET_LEN]; //案件名称; + public byte[] byLitigant1 = new byte[LITIGANT_RET_LEN]; //当事人1; + public byte[] byLitigant2 = new byte[LITIGANT_RET_LEN]; //当事人2; + public byte[] byChiefJudge = new byte[CHIEF_JUDGE_RET_LEN];//审判长 + public byte[] byRes1 = new byte[600]; + } + + //非视频通道查询结果 + public static class EVENT_IOTRET_V50 extends Structure { + public int dwChanNo; //触发产生事件的通道号(事件源通道) + public byte[] byRes = new byte[796]; + } + + public static class NET_DVR_INQUEST_RESUME_SEGMENT extends Structure { + public NET_DVR_TIME struStartTime = new NET_DVR_TIME(); //事件起始时间 + public NET_DVR_TIME struStopTime = new NET_DVR_TIME(); //事件终止时间 + public byte byRoomIndex; //审讯室编号,从1开始 + public byte byDriveIndex; //刻录机编号,从1开始 + public short wSegmetSize; //本片断的大小, 单位M + public int dwSegmentNo; //本片断在本次审讯中的序号,从1开始 + public byte[] byRes = new byte[24]; //保留 + } + + public static class NET_DVR_INQUEST_RESUME_EVENT extends Structure { + public int dwResumeNum; //需恢复的事件个数 + public NET_DVR_INQUEST_RESUME_SEGMENT[] struResumeSegment = new NET_DVR_INQUEST_RESUME_SEGMENT[MAX_RESUME_SEGMENT]; + public byte byResumeMode; //恢复模式,0-单光盘恢复,1-双光盘恢复 + public byte[] byRes = new byte[199]; //保留 + } + + //报警信息查询条件结构体 + public static class NET_DVR_ALARM_SEARCH_COND extends Structure { + public int dwSize; + public NET_DVR_TIME_SEARCH_COND strStartTime; //开始时间,时间为空则代表不通过时间筛选。 + public NET_DVR_TIME_SEARCH_COND strStopTime; //结束时间, 时间为空则代表不通过时间筛选。 + /* + 报警命令,该字段值与报警布防类型相同,目前支持: + COMM_VCA_ALARM 0x4993 智能检测报警 + COMM_UPLOAD_FACESNAP_RESULT 0x1112 人脸识别结果上传 + COMM_SNAP_MATCH_ALAR 0x2902 人脸比对结果上传 + */ + public int dwAlarmComm; //若该命令为空这代表不进行报警命令过滤。 + public byte[] sAlarmUID = new byte[64]; //UID标识(上传报警时设备返回的UID标识,64字节的长度,可以使用时间(精确到毫秒)加上随即数的方式组成),为空则代表不区分UID + public byte[] byRes = new byte[128]; + } + + //报警信息查询结果结构体 + public static class NET_DVR_ALARM_SEARCH_RESULT extends Structure { + public int dwSize; + /* + 报警命令,该字段值与报警布防类型相同,目前支持: + COMM_VCA_ALARM 0x4993 智能检测报警 + COMM_UPLOAD_FACESNAP_RESULT 0x1112 人脸识别结果上传 + COMM_SNAP_MATCH_ALARM 0x2902 人脸比对结果上传 + */ + public int dwAlarmComm; + /* + 报警信息,该字段值与报警信息相同,目前支持: + 当COMM_VCA_ALARM时,该报警信息为JSON报文 + 当COMM_UPLOAD_FACESNAP_RESULT时,该报警信息为NET_VCA_FACESNAP_RESULT + 当COMM_SNAP_MATCH_ALARM—¶,该报警信息为NET_VCA_FACESNAP_MATCH_ALARM + */ + public int dwAlarmLen;//报警信息,即pAlarmInfo指针指向的数据长度 + public Pointer pAlarmInfo; + public NET_DVR_ALARMER struAlarmer = new NET_DVR_ALARMER(); + public byte[] byRes = new byte[128]; + } + + public static class NET_DVR_ALARM_ISAPI_INFO extends Structure { + public Pointer pAlarmData; // 报警数据(参见下表) + public int dwAlarmDataLen; // 报警数据长度 + public byte byDataType; // 0-invalid,1-xml,2-json + public byte byPicturesNumber; // 图片数量 + public byte[] byRes = new byte[2]; + public Pointer pPicPackData; // 图片变长部分 + //(byPicturesNumber个{NET_DVR_ALARM_ISAPI_PICDATA};) + public byte[] byRes1 = new byte[32]; + } + + public static class NET_DVR_LOCAL_GENERAL_CFG extends Structure { + public byte byExceptionCbDirectly; //0-通过线程池异常回调,1-直接异常回调给上层 + public byte byNotSplitRecordFile; //回放和预览中保存到本地录像文件不切片 0-默认切片,1-不切片 + public byte byResumeUpgradeEnable; //断网续传升级使能,0-关闭(默认),1-开启 + public byte byAlarmJsonPictureSeparate; //控制JSON透传报警数据和图片是否分离,0-不分离,1-分离(分离后走COMM_ISAPI_ALARM回调返回) + public byte[] byRes = new byte[4]; //保留 + public long i64FileSize; //单位:Byte + public int dwResumeUpgradeTimeout; //断网续传重连超时时间,单位毫秒 + public byte[] byRes1 = new byte[236]; //预留 + + } + + public static class NET_DVR_LOCAL_TCP_PORT_BIND_CFG extends Structure { + public short wLocalBindTcpMinPort; //本地绑定Tcp最小端口 + public short wLocalBindTcpMaxPort; //本地绑定Tcp最大端口 + public byte[] byRes = new byte[60]; //保留 + } + + + public static class NET_DVR_LOCAL_CHECK_DEV extends Structure { + public int dwCheckOnlineTimeout; //巡检时间间隔,单位ms 最小值为30s,最大值120s。为0时,表示用默认值(120s) + public int dwCheckOnlineNetFailMax; //由于网络原因失败的最大累加次数;超过该值SDK才回调用户异常,为0时,表示使用默认值1 + public byte[] byRes = new byte[256]; + } + + public static final int MAX_FILE_PATH_LEN = 256; //文件路径长度 + + public static class NET_DVR_ALARM_ISAPI_PICDATA extends Structure { + public int dwPicLen; + public byte byPicType; //图片格式: 1- jpg + public byte[] byRes = new byte[3]; + public byte[] szFilename = new byte[MAX_FILE_PATH_LEN]; + public Pointer pPicData; // 图片数据 + } + + public static class NET_DVR_FOCUSMODE_CFG extends Structure { + public int dwSize; + public byte byFocusMode; /* 聚焦模式,0-自动,1-手动,2-半自动 */ + public byte byAutoFocusMode; /* 自动聚焦模式,0-关,1-模式A,2-模式B,3-模式AB,4-模式C 自动聚焦模式,需要在聚焦模式为自动时才显示*/ + public short wMinFocusDistance; /* 最小聚焦距离,单位CM, 0-自动,0xffff-无穷远 */ + public byte byZoomSpeedLevel; /* 变倍速度,为实际取值,1-3 */ + public byte byFocusSpeedLevel; /* 聚焦速度,为实际取值,1-3 */ + public byte byOpticalZoom; /* 光学变倍,0-255 */ + public byte byDigtitalZoom; /* 数字变倍,0-255 */ + public float fOpticalZoomLevel; /* 光学变倍(倍率值) [1,32], 最小间隔0.5 ,内部设备交互的时候*1000 */ + public int dwFocusPos;/* dwFocusPos 是focus值(聚焦值),范围为[0x1000,0xC000],这个值是sony坐标值,使用这个值是为了对外统一,保证不同的镜头对外focus值都转换在这个范围内 (手动聚焦模式下下应用)*/ + public byte byFocusDefinitionDisplay;// 聚焦清晰度显示,0~不显示,1~显示, 开启会在码流上显示当前镜头目标的清晰度值,用于帮助客户调焦使相机抓拍能够达到最清晰的效果,该清晰度越大代表着越清晰,清晰度范围为:0~100.0000 + public byte byFocusSensitivity; //聚焦灵敏度,范围[0,2],聚焦模式为自动、半自动时生效 + public byte[] byRes1 = new byte[2]; + public int dwRelativeFocusPos;//相对focus值,其低16位表示聚焦值,0~4000;高16位代表当前聚焦值获取时的温度值 + public byte[] byRes = new byte[48]; + } + + public static class NET_DVR_SERIALSTART_V40 extends Structure { + public int dwSize; //结构体大小 + public int dwSerialType; //串口号(1-232串口,2-485串口) + public byte bySerialNum; //串口编号 + public byte[] byRes = new byte[255]; + + + } + + public static class NET_DVR_PRESET_NAME extends Structure { + public int dwSize; + public short wPresetNum; //预置点编号 + public byte[] byRes1 = new byte[2]; //字节对齐 + public byte[] byName = new byte[NAME_LEN]; + public short wPanPos; //水平参数 如果获取到的数据大于360默认减去360 + public short wTiltPos; //垂直参数 如果获取到的数据大于360默认减去360 + public short wZoomPos; //变倍参数如果获取到的数据大于360默认减去360 + public byte[] byRes = new byte[58]; + } + + //Sensor信息 + public static class NET_DVR_SENSOR_PARAM extends Structure { + public byte bySensorType;//SensorType:0-CCD,1-CMOS + public byte[] byRes = new byte[31]; + public float fHorWidth;//水平宽度 精确到小数点后两位 *10000 + public float fVerWidth;//垂直宽度 精确到小数点后两位 *10000 + public float fFold;//zoom=1没变时的焦距 精确到小数点后两位 *100 + } + + //球机位置信息 + public static class NET_DVR_PTZPOS_PARAM extends Structure { + public float fPanPos;//水平参数,精确到小数点后1位 + public float fTiltPos;//垂直参数,精确到小数点后1位 + public float fZoomPos;//变倍参数,精确到小数点后1位 + public byte[] byRes = new byte[16]; + } + + public static class NET_DVR_LLI_PARAM extends Structure { + public float fSec;//秒[0.000000,60.000000] + public byte byDegree;//度:纬度[0,90] 经度[0,180] + public byte byMinute;//分[0,59] + public byte[] byRes = new byte[6]; + } + + //GIS信息上传 + public static class NET_DVR_GIS_UPLOADINFO extends Structure { + public int dwSize;//结构体大小 + public int dwRelativeTime; //相对时标 + public int dwAbsTime; //绝对时标 + public NET_VCA_DEV_INFO struDevInfo = new NET_VCA_DEV_INFO();//前端设备 + public float fAzimuth;//电子罗盘的方位信息;方位角[0.00°,360.00°) + public byte byLatitudeType;//纬度类型,0-北纬,1-南纬 + public byte byLongitudeType;// 经度类型,0-东度,1-西度 + public byte[] byRes1 = new byte[2]; + public NET_DVR_LLI_PARAM struLatitude = new NET_DVR_LLI_PARAM(); /*纬度*/ + public NET_DVR_LLI_PARAM struLongitude = new NET_DVR_LLI_PARAM(); /*经度*/ + public float fHorizontalValue;//水平视场角,精确到小数点后面两位 + public float fVerticalValue;//垂直视场角,精确到小数点后面两位 + public float fVisibleRadius;//当前可视半径,精确到小数点后面两位 + public float fMaxViewRadius;//最大可视半径,精确到小数点后面0位(预留处理) + public NET_DVR_SENSOR_PARAM struSensorParam;//Sensor信息 + public NET_DVR_PTZPOS_PARAM struPtzPos; //ptz坐标 + public byte[] byRes = new byte[256]; + } + + public static class NET_DVR_DAYTIME extends Structure { + public byte byHour;//0~24 + public byte byMinute;//0~60 + public byte bySecond;//0~60 + public byte byRes; + public short wMilliSecond; //0~1000 + public byte[] byRes1 = new byte[2]; + } + + public static class NET_DVR_SCHEDULE_DAYTIME extends Structure { + public NET_DVR_DAYTIME struStartTime; //开始时间 + public NET_DVR_DAYTIME struStopTime; //结束时间 + } + + public static class NET_DVR_BUILTIN_SUPPLEMENTLIGHT extends Structure { + public int dwSize;//结构体大小 + public byte byMode;//补光灯模式 0-定时,1-开启,2-关闭,3-自动(非光敏,算法画面识别) + public byte byBrightnessLimit;//亮度限制[0,100] + public byte bySupplementLightMode;//补光灯类型,0~白光模式,1~混合模式 + public byte byMixedLightRegulatMode;//混合补光灯亮度调节模式,0~自动,1~手动,当bySupplementLightMode = 1时生效 + public byte byLrLightBrightness;//红外亮度控制[0,100],当byMixedLightRegulatMode = 1时生效。 + public byte byHighLrLightBrightness;// 远光红外光亮度配置[0,100],当byMixedLightRegulatMode = 1时生效 + public byte byHighBrightnessLimit;// 远光白光亮度配置[0,100],当byMixedLightRegulatMode = 1时生效 + public byte byLowLrLightBrightness;// 近光红外光亮度配置[0,100],当byMixedLightRegulatMode = 1时生效 + public NET_DVR_SCHEDULE_DAYTIME struSchedTime;//定时时间段 + public byte byLowBrightnessLimit;//近光白光亮度配置[0,100],当byMixedLightRegulatMode = 1时生效 + public byte byWhiteLightBrightness;// 白光灯亮度 + public byte[] byRes1 = new byte[254]; + } + + public static class NET_DVR_HANDLEEXCEPTION_V41 extends Structure { + public int dwHandleType; //异常处理,异常处理方式的"或"结果 + /*0x00: 无响应*/ + /*0x01: 监视器上警告*/ + /*0x02: 声音警告*/ + /*0x04: 上传中心*/ + /*0x08: 触发报警输出*/ + /*0x10: 触发JPRG抓图并上传Email*/ + /*0x20: 无线声光报警器联动*/ + /*0x40: 联动电子地图(目前只有PCNVR支持)*/ + /*0x200: 抓图并上传FTP*/ + /*0x400: 虚交侦测 联动 聚焦模式(提供可配置项,原先设备自动完成)IPC5.1.0*/ + /*0x800: PTZ联动跟踪(球机跟踪目标)*/ + /*0x4000:白光灯报警*/ + /*0x10000:短信报警*/ + public int dwMaxRelAlarmOutChanNum; //触发的报警输出通道数(只读)最大支持数 + public int[] dwRelAlarmOut = new int[MAX_ALARMOUT_V40]; //触发报警通道 + public byte[] byRes = new byte[64]; //保留 + } + + public static class NET_DVR_PRESETCHAN_INFO extends Structure { + public int dwEnablePresetChan; /*启用预置点的通道, 0xfffffff表示不调用预置点*/ + public int dwPresetPointNo; /*调用预置点通道对应的预置点序号, 0xfffffff表示不调用预置点。*/ + } + + public static class NET_DVR_CRUISECHAN_INFO extends Structure { + public int dwEnableCruiseChan; /*启用巡航的通道*/ + public int dwCruiseNo; /*巡航通道对应的巡航编号, 0xfffffff表示无效*/ + } + + public static class NET_DVR_PTZTRACKCHAN_INFO extends Structure { + public int dwEnablePtzTrackChan; /*启用云台轨迹的通道*/ + public int dwPtzTrackNo; /*云台轨迹通道对应的编号, 0xfffffff表示无效*/ + } + + public static class NET_DVR_EVENT_TRIGGER extends Structure { + public int dwSize;//结构体大小 + public NET_DVR_HANDLEEXCEPTION_V41 struHandleException; //异常处理方式 + public int[] dwRelRecordChan = new int[MAX_CHANNUM_V40]; //实际触发录像通道,按值表示,采用紧凑型排列,从下标0开始顺序读取,中间遇到0xffffffff则后续无效。 + public NET_DVR_PRESETCHAN_INFO[] struPresetChanInfo = new NET_DVR_PRESETCHAN_INFO[MAX_CHANNUM_V40]; //启用的预置点信息 + public NET_DVR_CRUISECHAN_INFO[] struCruiseChanInfo = new NET_DVR_CRUISECHAN_INFO[MAX_CHANNUM_V40]; //启用巡航功能通道的信息 + public NET_DVR_PTZTRACKCHAN_INFO[] struPtzTrackInfo = new NET_DVR_PTZTRACKCHAN_INFO[MAX_CHANNUM_V40]; //调用云台轨迹的通道信息 + public byte byDirection;//触发方向:0-保留;1-全部;2-正向;3-反向 + public byte[] byRes2 = new byte[255]; + } + + public static class NET_DVR_FACELIB_GUARD_COND extends Structure { + public int dwSize; + public int dwChannel; //通道号 + public byte[] szFDID = new byte[68];//人脸库的ID + public byte[] byRes = new byte[128]; + } + + //导入人脸数据条件 + public static class NET_DVR_FACELIB_COND extends Structure { + public int dwSize; + public byte[] szFDID = new byte[NET_SDK_MAX_FDID_LEN/*256*/];//人脸库ID + public byte byConcurrent;//设备并发处理 0-不开启,1-开始 + public byte byCover;//是否覆盖式导入 0-否,1-是 + public byte byCustomFaceLibID;//FDID是否是自定义,0-不是,1-是; + public byte byPictureSaveMode;//上传原图保存模式,0-保存,1-不保存; + public byte[] byIdentityKey = new byte[NET_SDK_MAX_INDENTITY_KEY_LEN/*64*/];//交互操作口令 + public byte[] byRes = new byte[60]; + } + + public static class NET_DVR_SEND_PARAM_IN extends Structure { + public Pointer pSendData; //发送的缓冲区,PicURL == 1 的时候,内存中存储的是 URL 字符串,byUploadModeling == 1 的时候,内存中存储的是 建模base64加密数据 + public int dwSendDataLen; //发送数据长度,PicURL == 1 的时候,表示的 URL 字符串的长度,byUploadModeling == 1 的时候,表示为建模数据base64后的加密长度 + public NET_DVR_TIME_V30 struTime = new NET_DVR_TIME_V30(); //图片时间 + public byte byPicType; //图片格式,1-jpg,2-bmp,3-png,4-SWF,5-GIF + public byte byPicURL; //图片数据采用URL方式 0-二进制图片数据,1-图片数据走URL方式 + /*是否上传建模数据; + 0- 二进制图片数据方式(pSendData指向二进制图片数据, dwPicDataLen为图片二进制数据长度), + 1- 直接上传建模数据(pSendData指向建模base64加密数据, dwPicDataLen为建模数据base64后的加密长度)。 + 注:建模数据采用base64加密方式,选择为建模数据上传后,byPicURL 无需。 + 当”/ISAPI/Intelligent/channels//faceContrast/capabilities”能力中返回isSupportUploadModeling能力节点时,支持上传建模数据. */ + public byte byUploadModeling; + public byte byRes1; + public int dwPicMangeNo; //图片管理号 + public byte[] sPicName = new byte[NAME_LEN]; //图片名称 + public int dwPicDisplayTime; //图片播放时长,单位秒 + public Pointer pSendAppendData; //发送图片的附加信息缓冲区,对应FaceAppendData 的XML描述; + public int dwSendAppendDataLen; //发送图片的附加信息数据长度 FaceAppendData XML的长度; + public byte[] byRes = new byte[192]; + } + + public static class NET_DVR_INQUEST_ROOM extends Structure { + public byte byRoomIndex; //审讯室编号 + public byte byFileType; //0-审讯文件,1-开庭上传文件 + public byte[] byRes = new byte[22]; //保留 + } + + public static class NET_DVR_INQUEST_CDRW_CFG extends Structure { + public int dwSize; + public int dwNum; //刻录机的数量 + public int[] dwRwSelectPara = new int[MAX_CHANNUM_V30];// 是否选中该光驱 + public int dwModeSelect; //0表示循环刻录模式 1表示并行刻录模式(默认模式) + public byte[] byRes = new byte[24]; //保留 + public int dwStartCDRW; //DVR 本地已经开始刻录 + public int dwHdExcp; //硬盘有异 常 + public int dwInterval; //时间间隔,10分钟(0)、20分钟(1)、30分钟(2) + public byte[] sLable = new byte[64]; //光盘名称 + } + + public static class NET_DVR_INQUEST_CDRW_STATUS extends Structure { + /*运行状态:0-审讯开始, + 1-审讯过程中刻录,2-审讯停止, + 3-刻录审讯文件, + 4-备份(事后备份和本地备份) + 5-空闲 + 6-初始化硬盘 + 7-恢复审讯*/ + public int dwType; + public NET_DVR_INQUEST_CDRW[] strCDRWNum = new NET_DVR_INQUEST_CDRW[MAX_INQUEST_CDRW_NUM]; //数组0表示刻录机1 + public NET_DVR_TIME_EX struInquestStartTime = new NET_DVR_TIME_EX(); //审讯开始的时间点 + public byte[] byRes = new byte[16]; //保留 + } + + public static class NET_DVR_INQUEST_CDRW extends Structure { + public int dwEnable; //刻录机状态是否有效,0-无效,1-有效 + public int dwStatus; /*当dwType=0时, 0-光盘正常,1-无光盘或光盘异常, + 当dwType=1或2时,0-刻录正常,1-无光盘或光盘异常,2-光盘已封盘(81不支持),3-光盘空间不足, 4-异常导致审讯终止(81不支持) + 当dwType=3时, 0-刻录正常,1-无光盘或光盘异常,2-光盘已封盘(81不支持),3-光盘空间不足 + 当dwType=4时,0-刻录正常,1-无光盘或光盘异常,2-光盘已封盘(81不支持),3-光盘空间不足 + 当dwType=5时,0-光盘正常, 1-无光盘或光盘异常,2-光盘已封盘(81不支持) + 当dwType=6或7时, 0-刻录正常, 1-无光盘或光盘异常, 2-光盘已封盘(81不支持), 3-光盘空间不足*/ + public int dwVolumn; //光盘容量,单位M + public int dwFreeSpace; //光盘剩余容量,单位M + public int dwTimeLeft; // 光盘剩余时间,单位秒 + public byte byCDType; // 光盘类型 + public byte[] byRes = new byte[3]; //保留字节 + } + + //实时温度检测条件参数 + public static class NET_DVR_REALTIME_THERMOMETRY_COND extends Structure { + public int dwSize; /*结构体大小*/ + public int dwChan; /*通道号,从1开始,0xffffffff代表获取全部通道*/ + public byte byRuleID;/*规则ID,0代表获取全部规则,具体规则ID从1开始*/ + public byte byMode; //长连接模式:0- 保留(兼容不支持该功能的老设备),1- 定时模式,2- 温差模式 + public short wInterval; //上传间隔(仅温差模式支持),取值范围:1-3600 秒,填0则默认3600S上传一次 + public byte[] byRes2 = new byte[60]; + } + + //点测温实时信息 + public static class NET_DVR_POINT_THERM_CFG extends Structure { + public float fTemperature; + public NET_VCA_POINT struPoint; + public byte[] byRes = new byte[120]; + } + + //框/线测温实时信息 + public static class NET_DVR_LINEPOLYGON_THERM_CFG extends Structure { + public float fMaxTemperature; + public float fMinTemperature; + public float fAverageTemperature; + public float fTemperatureDiff; + public NET_VCA_POLYGON struRegion; + public byte[] byRes = new byte[32]; + } + + //实时温度信息 + public static class NET_DVR_THERMOMETRY_UPLOAD extends Structure { + public int dwSize; /* 结构体大小 */ + public int dwRelativeTime; + public int dwAbsTime; + public byte[] szRuleName = new byte[NAME_LEN]; + public byte byRuleID;/* 规则ID,0代表获取全部规则,具体规则ID从1开始 */ + public byte byRuleCalibType; + public short wPresetNo; + public NET_DVR_POINT_THERM_CFG struPointThermCfg; + public NET_DVR_LINEPOLYGON_THERM_CFG struLinePolygonThermCfg; + public byte byThermometryUnit; + public byte byDataType; + public byte byRes1; + public byte bySpecialPointThermType; + public float fCenterPointTemperature; + public float fHighestPointTemperature; + public float fLowestPointTemperature; + public NET_VCA_POINT struHighestPoint; + public NET_VCA_POINT struLowestPoint; + public byte byIsFreezedata; + public byte[] byRes = new byte[95]; + } + + public static class NET_PTZ_INFO extends Structure { + public float fPan; + public float fTilt; + public float fZoom; + public int dwFocus;// 聚焦参数,聚焦范围:归一化0-100000 + public byte[] byRes = new byte[4]; + } + + //测温模式配置 + public static class NET_DVR_THERMOMETRY_MODE extends Structure { + public int dwSize;//结构体大小 + public byte byMode;//测温模式,0~普通模式,1~专家模式 + public byte byThermometryROIEnabled; //测温ROI使能 0-保留 1-不开启 2-开启(基于互斥兼容考虑) + public byte[] byRes = new byte[62]; + } + + public static class NET_DVR_THERMOMETRY_COND extends Structure { + public int dwSize;//结构体大小 + public int dwChannel; + public short wPresetNo;//0-保留 + public byte[] byRes = new byte[62]; + } + + public static class NET_DVR_THERMOMETRY_PRESETINFO_PARAM extends Structure { + public byte byEnabled; //是否使能:0- 否,1- 是 + public byte byRuleID;//规则ID 0-表示无效,从1开始 (list内部判断数据有效性) + public short wDistance;//距离(m)[0, 10000] + public float fEmissivity;//发射率(发射率 精确到小数点后两位)[0.01, 1.00](即:物体向外辐射能量的本领) + public byte byDistanceUnit;//距离单位: 0-米(m),1-英尺(feet),2-厘米(centimeter) + public byte[] byRes = new byte[2]; + public byte byReflectiveEnabled;//反射温度使能:0- 否,1- 是 + public float fReflectiveTemperature;//反射温度 精确到小数后2位 + public byte[] szRuleName = new byte[NAME_LEN/*32*/];//规则名称 + public byte byemissivityMode; //发射率配置类型 1-粗糙,2-较粗糙,3-较光滑, 4-光滑, 0xff-自定义 + public byte[] byRes1 = new byte[62]; + public byte byRuleCalibType;//规则标定类型 0-点,1-框,2-线 + public NET_VCA_POINT struPoint = new NET_VCA_POINT();//点测温坐标(当规则标定类型为"点"的时候生效) + public NET_VCA_POLYGON struRegion = new NET_VCA_POLYGON();//区域、线(当规则标定类型为"框"或者"线"的时候生效) + } + + public static class NET_DVR_THERMOMETRY_PRESETINFO extends Structure { + public int dwSize;//结构体大小 + public short wPresetNo;//0-保留 + public byte[] byRes = new byte[2]; + public NET_DVR_THERMOMETRY_PRESETINFO_PARAM[] struPresetInfo = new NET_DVR_THERMOMETRY_PRESETINFO_PARAM[40]; + } + + //温度报警(检测温度和配置温度比较报警) + public static class NET_DVR_THERMOMETRY_ALARM extends Structure { + public int dwSize; + public int dwChannel;//通道号 + public byte byRuleID;//规则ID + public byte byThermometryUnit;//测温单位: 0-摄氏度(℃),1-华氏度(℉),2-开尔文(K) + public short wPresetNo; //预置点号 + public NET_PTZ_INFO struPtzInfo = new NET_PTZ_INFO();//ptz坐标信息 + public byte byAlarmLevel;//0-预警 1-报警 + public byte byAlarmType;/*报警类型 0-最高温度 1-最低温度 2-平均温度 3-温差 4-温度突升 5-温度突降*/ + public byte byAlarmRule;//0-大于,1-小于 + public byte byRuleCalibType;//规则标定类型 0-点,1-框,2线 + public NET_VCA_POINT struPoint = new NET_VCA_POINT();//点测温坐标(当规则标定类型为点的时候生效) + public NET_VCA_POLYGON struRegion = new NET_VCA_POLYGON();//区域(当规则标定类型为框的时候生效) + public float fRuleTemperature;/*配置规则温度,精确到小数点后一位(-40-1000),(浮点数+100) */ + public float fCurrTemperature;/*当前温度,精确到小数点后一位(-40-1000),(浮点数+100) */ + public int dwPicLen;//可见光图片长度 + public int dwThermalPicLen;//热成像图片长度 + public int dwThermalInfoLen;//热成像附加信息长度 + public Pointer pPicBuff; ///可见光图片指针 + public Pointer pThermalPicBuff;// 热成像图片指针 + public Pointer pThermalInfoBuff; //热成像附加信息指针 + public NET_VCA_POINT struHighestPoint = new NET_VCA_POINT();//线、框测温最高温度位置坐标(当规则标定类型为线、框的时候生效) + public float fToleranceTemperature;/* 容差温度,精确到小数点后一位(-40-1000),(浮点数+100) */ + public int dwAlertFilteringTime;//温度预警等待时间 单位秒 范围为0-200秒,默认为0秒 + public int dwAlarmFilteringTime;//温度报警等待时间 单位秒 范围为0-200秒,默认为0秒 + public int dwTemperatureSuddenChangeCycle;//温度突变记录周期,单位秒 + public float fTemperatureSuddenChangeValue;//温度突变值,精确到小数点后一位(大于0) + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public byte[] byRes = new byte[39]; + } + + //温差报警 + public static class NET_DVR_THERMOMETRY_DIFF_ALARM extends Structure { + public int dwSize; + public int dwChannel;//通道号 + public byte byAlarmID1;//规则AlarmID1 + public byte byAlarmID2;//规则AlarmID2 + public short wPresetNo; //预置点号 + public byte byAlarmLevel;//0-预警 1-报警 + public byte byAlarmType;/*报警类型 0-最高温度 1-最低温度 2-平均温度*/ + public byte byAlarmRule;//0-大于,1-小于 + public byte byRuleCalibType;//规则标定类型 0-点,1-框,2线 + public NET_VCA_POINT[] struPoint = (NET_VCA_POINT[]) new NET_VCA_POINT().toArray(2);//点测温坐标(当规则标定类型为点的时候生效)数组下标0代表着AlarmID1,数组下标1代表着AlarmID2. + public NET_VCA_POLYGON[] struRegion = (NET_VCA_POLYGON[]) new NET_VCA_POLYGON().toArray(2);//区域(当规则标定类型为框的时候生效)数组下标0代表着AlarmID1,数组下标1代表着AlarmID2. + float fRuleTemperatureDiff;/*配置规则温差,精确到小数点后一位(-40-1000))*/ + float fCurTemperatureDiff;/*当前温差,精确到小数点后一位(-40-1000),(浮点数+100) */ + NET_PTZ_INFO struPtzInfo;//ptz坐标信息 + public int dwPicLen;//可见光图片长度 + public int dwThermalPicLen;//热成像图片长度 + public int dwThermalInfoLen;//热成像附加信息长度 + public Pointer pPicBuff; ///可见光图片指针 + public Pointer pThermalPicBuff;// 热成像图片指针 + public Pointer pThermalInfoBuff; //热成像附加信息指针 + public byte byThermometryUnit;//测温单位: 0-摄氏度(℃),1-华氏度(℉),2-开尔文(K) + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public byte[] byRes1 = new byte[2]; + float fToleranceTemperature;/*容差温度,精确到小数点后一位(-40-1000),(浮点数+100) */ + public int dwAlarmFilteringTime;//温度报警等待时间 单位秒 范围为0-200秒,默认为0秒 + public int dwVisibleChannel; //可见光通道通道号 + public byte[] byRes = new byte[48]; + } + + //船只检测报警上传 + public static class NET_DVR_SHIPSDETECTION_ALARM extends Structure { + public int dwSize; + public NET_VCA_DEV_INFO struDevInfo; //设备信息 + public int dwRelativeTime; //相对时标 + public int dwAbsTime; //绝对时标 + public byte byShipsNum; //船只数;(正跨越检测线的船只数) + public byte byShipsNumHead;//船只数;(船头检测船只数) + public byte byShipsNumEnd; //船只数;(船尾检测船只数) + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public NET_DVR_SHIPSINFO[] struShipInfo = (NET_DVR_SHIPSINFO[]) new NET_DVR_SHIPSINFO().toArray(MAX_SHIPS_NUM); /*20*///船只信息;最大支持20艘 + public int dwPicLen;//可见光图片长度 + public int dwThermalPicLen;//热成像图片长度 + public Pointer pPicBuffer; //可见光图片数据指针 + public Pointer pThermalPicBuffer; //热成像图片数据指针 + public short wDevInfoIvmsChannelEx; //与NET_VCA_DEV_INFO里的byIvmsChannel含义相同,能表示更大的值。老客户端用byIvmsChannel能继续兼容,但是最大到255。新客户端版本请使用wDevInfoIvmsChannelEx。 + public byte byTimeDiffFlag; /*时差字段是否有效 0-时差无效, 1-时差有效 */ + public byte cTimeDifferenceH; /*与UTC的时差(小时),-12 ... +14, +表示东区,,byTimeDiffFlag为1时有效*/ + public byte cTimeDifferenceM; /*与UTC的时差(分钟),-30, 30, 45, +表示东区,byTimeDiffFlag为1时有效*/ + public byte bySID;//场景ID + public byte[] byRes1 = new byte[2]; + public byte[] szSceneName = new byte[NAME_LEN];//场景名称,不超过32字符 + public byte[] byRes = new byte[216]; + } + + public static final int MAX_SHIPS_NUM = 20; //船只检测最大船只数 + + //船只信息 + public static class NET_DVR_SHIPSINFO extends Structure { + public float fShipsLength; //船只长度;1~1000.0m,精确到小数点后一位 + public float fShipsHeight; //船只高度;1~1000.0m,精确到小数点后一位 + public float fShipsWidth; //船只宽度;1~1000.0m,精确到小数点后一位 + public float fShipsSpeed; //船只速度;1~1000.0m/s,精确到小数点后一位 + public byte byShipsDirection;//船只方向;0~up,1~down,2~left,3~right + public byte byShipsDetState;//船只检测状态;0~正跨越检测线,1~船头检测,2~船尾检测 + public byte byTriggerLineID;//检测线ID + public byte[] byRes = new byte[61]; + public NET_VCA_POLYGON struShipsRect; //船只区域,归一化值,相对于大图(可见光图、热成像图)的分辨率 + } + + public static class NET_DVR_ARRAY_LIST extends Structure { + public int dwSize; // 结构体大小 + public int dwCount; // 阵列个数 + public NET_DVR_ARRAY_INFO[] struArrayInfo = new NET_DVR_ARRAY_INFO[SUPPORT_ARRAY_NUM]; + } + + public static class NET_DVR_BGA_INFO extends Structure { + public byte byBga; // 后台任务及类型 + public byte byBgaState; /*函数返回值--后台任务状态*/ + public short wBgaPercentage; /*函数返回值--后台任务执行百分比*/ + public byte[] byRes = new byte[4]; // 保留字节 + } + + // 阵列信息 + public static class NET_DVR_ARRAY_INFO extends Structure { + public short wArrayID; // 阵列ID + public byte byRaidMode; // raid模式 参照RAID_MODE + public byte byStatus; // 0-在线 1-磁盘丢失 2-下线 3-降级 4-异常 5-次正常 6-外来盘 7-已删除 8-SMART状态异常 0xff-不存在 + public int dwHCapacity; // 阵列容量高32位 + public int dwLCapacity; // 阵列容量低32位 + public int dwHFreeSpace; // 阵列剩余空间高32位 + public int dwLFreeSpace; // 阵列剩余空间高32位 + public byte[] byArrayName = new byte[MAX_NAMELEN]; // 阵列名称 + public byte byPDCount; // 物理磁盘数目 + public byte bySpareCount; // 热备数目 + public byte[] byRes1 = new byte[2]; + public short[] wPDSlots = new short[SUPPORT_PD_NUM]; // 物理磁盘索引 + public short[] wSparePDSlots = new short[SUPPORT_PD_NUM]; // 热备磁盘索引 + public NET_DVR_BGA_INFO struBgaInfo; // 后台任务运行状态 + public short[] wPDSlotsPartTwo = new short[SUPPORT_PD_NUM_PARTTWO]; //物理磁盘索引扩展,0表示无效 + public short[] wSparePDSlotsPartTwo = new short[SUPPORT_PD_NUM_PARTTWO]; // 热备磁盘索引扩展,0表示无效 + public byte[] byRes2 = new byte[48]; // 保留字节 + } + + //物理磁盘 + public static class NET_DVR_PHY_DISK_INFO extends Structure { + public short wPhySlot; // 硬盘槽位 + public byte byType; // 硬盘信息;0 普通,1全局热备,2-阵列热备 3-阵列盘 + public byte byStatus; // 硬盘状态; 0-正常 1-降级 2-已删除 3-磁盘丢失 4-下线 5-次正常 6-外来 7-异常 8-SMART状态异常 9-休眠 10-有坏块 0xff-不存在 + public byte[] byMode = new byte[40]; // 硬盘类型 字符串 + public int dwHCapacity; // 磁盘总量高32位 单位kb + public int dwLCapacity; // 磁盘总量低32位 + public byte[] byArrrayName = new byte[MAX_NAMELEN]; + public short wArrayID; // 所属阵列ID + public byte byArrayInformation; // 是否含有阵列信息:0 否,1是 + public byte[] byRes = new byte[101]; // 保留字节 + } + + public static class NET_DVR_WORKSTATE_V40 extends Structure { + public int dwSize; //结构体大小 + public int dwDeviceStatic; //设备的状态,0-正常,1-CPU占用率太高,超过85%,2-硬件错误,例如串口死掉 + public NET_DVR_DISKSTATE[] struHardDiskStatic = new NET_DVR_DISKSTATE[MAX_DISKNUM_V30]; //硬盘状态,一次最多只能获取33个硬盘信息 + public NET_DVR_CHANNELSTATE_V30[] struChanStatic = new NET_DVR_CHANNELSTATE_V30[MAX_CHANNUM_V40/*512*/];//通道的状态,从前往后顺序排列 + public int[] dwHasAlarmInStatic = new int[MAX_ALARMIN_V40]; //有报警的报警输入口,按值表示,按下标值顺序排列,值为0xffffffff时当前及后续值无效 + public int[] dwHasAlarmOutStatic = new int[MAX_ALARMOUT_V40]; //有报警输出的报警输出口,按值表示,按下标值顺序排列,值为0xffffffff时当前及后续值无效 + public int dwLocalDisplay; //本地显示状态,0-正常,1-不正常 + public byte[] byAudioInChanStatus = new byte[MAX_AUDIO_V30/*2*/]; //按位表示语音通道的状态 0-未使用,1-使用中,第0位表示第1个语音通道 + public byte[] byRes1 = new byte[2]; + public float fHumidity; //传感器获知的湿度,范围:0.0 ~100.0 + public float fTemperature; //传感器获知的温度,范围:-20.0 ~ 90.0 + public byte[] byRes = new byte[116]; //保留 + } + + public static class NET_DVR_GETWORKSTATE_COND extends Structure { + public int dwSize; //结构体长度 + public byte byFindHardByCond; /*0-查找全部磁盘(但一次最多只能查找33个),此时dwFindHardStatusNum无效*/ + public byte byFindChanByCond; /*0-查找全部通道,此时dwFindChanNum无效*/ + public byte[] byRes1 = new byte[2];//保留 + public int[] dwFindHardStatus = new int[MAX_DISKNUM_V30/*33*/]; /*要查找的硬盘号,按值表示,该值采用顺序排列, 遇到0xffffffff则认为后续无效 */ + public int[] dwFindChanNo = new int[MAX_CHANNUM_V40/*512*/]; /*要查找的通道号,按值表示,该值采用顺序排列, 遇到0xffffffff则认为后续无效 */ + public byte[] byRes = new byte[64]; //保留 + } + + //多边型结构体 + public static class NET_ITC_POLYGON extends Structure { + public int dwPointNum; //有效点 大于等于3,若是3点在一条线上认为是无效区域,线交叉认为是无效区域 + public NET_VCA_POINT[] struPos = new NET_VCA_POINT[ITC_MAX_POLYGON_POINT_NUM]; //多边形边界点,最多20个 + } + + public static class CUSTOM_uRegion extends Union { + public NET_VCA_RECT struRect = new NET_VCA_RECT(); + public NET_ITC_POLYGON struPolygon = new NET_ITC_POLYGON(); + } + + public static class NET_ITC_PLATE_RECOG_REGION_PARAM extends Structure { + public byte byMode; //区域类型,0-矩形,1-多边形 + public byte[] byRes1 = new byte[3]; + public CUSTOM_uRegion uRegion = new CUSTOM_uRegion(); + public byte[] byRes = new byte[16]; //保留 + } + + //单组IO测速参数 + public static class NET_ITC_SINGLE_IOSPEED_PARAM extends Structure { + public byte byEnable; //是否启用,0-不启用,1-启用 + public byte byTrigCoil1; //第一线圈关联IO,0-IO1,1-IO2,2-IO3,3-IO4,4-IO5,5-IO6 + public byte byCoil1IOStatus;//第一线圈IO输入口状态,0-下降沿(默认),1-上升沿,2-上升沿和下降沿,3-高电平,4-低电平 + public byte byTrigCoil2; //第二线圈关联IO,0-IO1,1-IO2,2-IO3,3-IO4,4-IO5,5-IO6 + public byte byCoil2IOStatus;//第二线圈IO输入口状态,0-下降沿(默认),1-上升沿,2-上升沿和下降沿,3-高电平,4-低电平 + public byte byRelatedDriveWay;//关联的车道号 + public byte byTimeOut;//超时时间(默认10),单位s + public byte byRelatedIOOutEx;//第0位表示IO输出口1,以此类推,0-不关联,1-关联 支持关联到8个(兼容byRelatedIOOut字段) + public int dwDistance;//线圈距离(默认1000),单位:厘米 + public byte byCapSpeed;//起拍速度(默认30),单位km/h + public byte bySpeedLimit;//限速值(默认60),单位km/h + public byte bySpeedCapEn; //是否启用超速抓拍,0-否,1-是 + public byte bySnapTimes1; //线圈1抓拍次数(默认不抓拍),0-不抓拍,非0-连拍次数,最大5次 + public byte bySnapTimes2; //线圈2抓拍次数(默认1),0-不抓拍,非0-连拍次数,最大5次 + public byte byBigCarSpeedLimit; //大车车速限制值 + public byte byBigCarSignSpeed;//标志限速(大车),单位km/h(3.7Ver) + public byte byIntervalType; //间隔类型(默认按时间),0-时间起效,1-距离起效 + public short[] wInterval1 = new short[MAX_INTERVAL_NUM];//线圈1连拍间隔时间(单位ms)或连拍间隔距离(单位分米),当byIntervalType为0时,表示间隔时间,当byIntervalType为1时,表示距离 + public short[] wInterval2 = new short[MAX_INTERVAL_NUM];//线圈2连拍间隔时间(单位ms)或连拍间隔距离(单位分米),当byIntervalType为0时,表示间隔时间,当byIntervalType为1时,表示距离 + public byte[] byRelatedIOOut = new byte[MAX_IOOUT_NUM]; //关联的IO输出口(可以同时关联多个),数组0表示IO输出口1,数组1表示IO输出口2,以此类推,0-不关联,1-关联 + public byte byFlashMode; //闪光灯闪烁模式,0-同时闪,1-轮流闪 + public byte byLaneType; //车道类型,0-未配置、1-高速公路、2-城市快速路、0xff-其他道路 + public byte byCarSignSpeed;//标志限速,单位km/h(3.7Ver) + public byte byUseageType; //车道用途类型,详见ITC_LANE_USEAGE_TYPE + public NET_ITC_PLATE_RECOG_REGION_PARAM[] struPlateRecog = new NET_ITC_PLATE_RECOG_REGION_PARAM[MAX_LANEAREA_NUM]; //牌识参数(可用牌识区域1个,保留一个) + //关联车道方向类型,参考ITC_RELA_LANE_DIRECTION_TYPE + //该参数为车道方向参数,与关联车道号对应,确保车道唯一性。 + public byte byRelaLaneDirectionType; + public byte byLowSpeedLimit; //小车限底速值,单位km/h + public byte byBigCarLowSpeedLimit; //大车限底速值,单位km/h + public byte byLowSpeedCapEn; //是否启用低速抓拍,0-否,1-是 + public byte byEmergencyCapEn; //是否启用应急车道抓拍,0-否,1-是 + public byte[] byRes = new byte[27]; + } + + //牌识参数 + public static class NET_ITC_PLATE_RECOG_PARAM extends Structure { + public byte[] byDefaultCHN = new byte[MAX_CHJC_NUM]; /*设备运行省份的汉字简写*/ + public byte byEnable; //是否启用该区域牌识,0-否,1-是 + public int dwRecogMode; + /*识别的类型, + bit0-背向识别:0-正向车牌识别,1-背向识别(尾牌识别) ; + bit1-大车牌识别或小车牌识别:0-小车牌识别,1-大车牌识别 ; + bit2-车身颜色识别:0-不采用车身颜色识别,在背向识别或小车牌识别时禁止启用,1-车身颜色识别; + bit3-农用车识别:0-不采用农用车识别,1-农用车识别; + bit4-模糊识别:0-不采用模糊识别,1-模糊识别; + bit5-帧定位或场定位:0-帧定位,1-场定位; + bit6-帧识别或场识别:0-帧识别,1-场识别; + bit7-晚上或白天:0-白天,1-晚上 + bit8-摩托车识别:0-不采用摩托车识别,1-摩托车识别; + bit9-场景模式:0-电警/多帧,1-卡口; + bit10-微小车牌:0-不启用,1-启用微小车牌识别(像素60~80) + bit11-安全带检测:0-不启用,1-启用安全带检测 + bit12-民航车牌识别: 0-不启用,1-开启民航车牌识别 + bit13-车牌过渡倾斜处理: 0-不启用,1-开启过渡倾斜处理(PRS) + bit14-超大车牌识别: 0-不启用,1-开启超大车牌识别(PRS) + bit15-遮阳板检测:0-不启用,1-启用遮阳板检测 + bit16-黄标车检测:0-不启用,1-启用黄标车检测 + bit17-危险品车辆检测:0-不启用,1-启用危险品车辆检测 + bit18-使馆车牌识别:0-不启用,1-启用使馆车牌识别 + bit19-车辆子品牌识别:0-不启用,1-启用车辆子品牌识别 + bit20-打电话识别:0-不启用,1-启用 + bit21-车窗悬挂物识别:0-不启用,1-启用 + */ + public byte byVehicleLogoRecog;//车标识别 0-不启用,1-启用 + /* + 0-保留,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-皖,0xff-全部 + */ + public byte byProvince;//省份索引值 + public byte byRegion;// 区域索引值 0-保留,1-欧洲,2-俄语区域, 3-欧洲&俄罗斯(EU&CIS),4-中东(Middle East) + public byte byCountry;//国家索引,参照枚举COUNTRY_INDEX(不支持“COUNTRY_ALL = 0xff,//ALL 全部”) + public short wPlatePixelWidthMin;//车牌像素识别宽度最小值(单位是像素)当前推荐范围[130,500] + public short wPlatePixelWidthMax;//车牌像素识别宽度最大值(单位是像素)当前推荐范围[130,500] + public byte[] byRes = new byte[24]; + } + + //卡口IO测速参数 + public static class NET_ITC_POST_IOSPEED_PARAM extends Structure { + public NET_ITC_PLATE_RECOG_PARAM struPlateRecog; //牌识参数 + public NET_ITC_SINGLE_IOSPEED_PARAM[] struSingleIOSpeed = new NET_ITC_SINGLE_IOSPEED_PARAM[MAX_IOSPEED_GROUP_NUM]; //单个IO测速组参数 + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_GEOGLOCATION extends Structure { + public int[] iRes = new int[2]; /*保留*/ + public int dwCity; /*城市,详见PROVINCE_CITY_IDX */ + } + + public static class NET_ITC_INTERVAL_PARAM extends Structure { + public byte byIntervalType; //间隔类型(默认按时间),0-时间起效,1-距离起效 + public byte[] byRes1 = new byte[3]; + public short[] wInterval = new short[MAX_INTERVAL_NUM];//连拍间隔时间(单位ms)或连拍间隔距离(单位分米),当byIntervalType为0时,表示间隔时间,当byIntervalType为1时,表示距离 + public byte[] byRes = new byte[8]; + } + + public static class NET_ITC_VTLANE_PARAM extends Structure { + public byte byRelatedDriveWay;//关联的车道号 + public byte bySpeedCapEn; //是否启用超速抓拍,0-否,1-是 + public byte bySignSpeed;//标志限速,单位km/h + public byte bySpeedLimit;//限速值,单位km/h + public byte bySnapTimes; //抓拍次数(默认1),0-不抓拍,非0-连拍次数,最大5 + public byte byBigCarSignSpeed;///*大车标志限速,单位km/h*/ + public byte byBigCarSpeedLimit;/*大车限速值,单位km/h*/ + public byte byRelatedIOOutEx;//第0位表示IO输出口1,以此类推,0-不关联,1-关联 支持关联到8个(兼容byRelatedIOOut字段) + public NET_ITC_INTERVAL_PARAM struInterval = new NET_ITC_INTERVAL_PARAM(); //抓拍间隔参数 + public byte[] byRelatedIOOut = new byte[MAX_IOOUT_NUM]; //关联的IO输出口,可以同时关联多个 + public byte byFlashMode; //闪光灯闪烁模式,0-同时闪,1-轮流闪 + public byte byLowSpeedLimit;/*限低速,单位km/h*/ + public byte byBigCarLowSpeedLimit; /*大车限低速,单位km/h*/ + //关联车道方向类型,参考ITC_RELA_LANE_DIRECTION_TYPE + //该参数为车道方向参数,与关联车道号对应,确保车道唯一性。 + public byte byRelaLaneDirectionType; + public NET_ITC_PLATE_RECOG_REGION_PARAM[] struPlateRecog = new NET_ITC_PLATE_RECOG_REGION_PARAM[MAX_LANEAREA_NUM]; //车道牌识参数 + public NET_VCA_LINE struLine = new NET_VCA_LINE(); //车道线 + } + + public static class NET_ITC_VTCOIL_INFO extends Structure { + public NET_VCA_RECT struLaneRect = new NET_VCA_RECT(); /*虚拟线圈区域*/ + public byte byTrigFlag; //触发标志,0-车头触发;1-车尾触发;2-车头/车尾都触发 + public byte byTrigSensitive; //触发灵敏度,1-100 + public byte[] byRelatedIOOut = new byte[MAX_IOOUT_NUM]; //关联的IO输出口(可以同时关联多个),数组0表示IO输出口1,数组1表示IO输出口2,以此类推,0-不关联,1-关联 + public byte byFlashMode; //闪光灯闪烁模式,0-同时闪,1-轮流闪 + public byte byLaneType; //车道类型,0-未配置、1-高速公路、2-城市快速路、0xff-其他道路 + public byte byEnableRadar; //是否启用雷达测速,0-否,1-是 + public NET_ITC_VTLANE_PARAM struLane = new NET_ITC_VTLANE_PARAM(); //关联的车道参数 + //车道用途类型,详见ITC_LANE_USEAGE_TYPE,使用1和8两种类型(3.7Ver) + public byte byUseageType; + //车辆行驶方向,详见ITC_LANE_CAR_DRIVE_DIRECT(3.7Ver) + public byte byCarDriveDirect; + public byte[] byRes = new byte[30]; + } + + public static class NET_ITC_RADAR_PARAM extends Structure { + public byte byRadarType; //雷达类型,0-无雷达,1-安道雷雷达,2-奥利维亚,3-川速微波4,雷达接IO扩展盒(此参数在卡口虚拟线圈、混行卡口界面中使用,卡口RS485雷达不使用),0xff-其它类型 + public byte byLevelAngle; //与水平线所成角度,默认为25°(0到90度) + public short wRadarSensitivity; //雷达灵敏度 + public short wRadarSpeedValidTime;//雷达速度有效时间(0~2000] ,0表示不支持 + public byte[] byRes1 = new byte[2]; + public float fLineCorrectParam;//线性矫正参数[0.0~2.0] + public int iConstCorrectParam;//常量矫正参数[-100~100] + public byte[] byRes2 = new byte[8]; + } + + //卡口虚拟线圈触发参数 + public static class NET_ITC_POST_VTCOIL_PARAM extends Structure { + public byte byRelatedLaneNum;//关联的车道个数 + public byte byIsDisplay; //视频中是否显示虚拟线圈,0-不显示,1-显示 + public byte byLoopPos; //晚间触发线圈的偏向(默认10) + public byte byPolarLenType; /*偏振镜类型,0:不加偏振镜;1:加施耐德偏振镜。*/ + public byte byDayAuxLightMode; /*白天辅助照明模式,0:无辅助照明;1:LED灯照明;2:闪光灯照明*/ + public byte byVideoLaneNO; //视频参考亮度的参考车道号 + public byte byVideoLowTh; /*视†频参考亮度低阈值初始化值(默认40)*/ + public byte byVideoHighTh; /*视频参考亮度高阈值初始化值(默认55)*/ + public byte byRecordMode; //录像标志:0-不录像,1-录像 + public byte bySnapMode;//抓拍模式:0-频闪模式;1-爆闪模式 + /*测速方式:0-不测速,0x1-雷达测速,0x2-视频测速*/ + public byte bySpeedDetector; + public byte byRes2; + public short wResolutionX;/* 设备当前分辨率宽*/ + public short wResolutionY;/* 设备当前分辨率高*/ + public int dwDayInitExp; /*视频白天曝光时间的初始值2000*/ + public int dwDayMaxExp; /*视频白天曝光时间的最大值20000*/ + public int dwNightExp; /*晚间视频曝光时间的设置值3000*/ + public int dwSnapExp; /*抓拍曝光时间*/ + public byte byDayInitGain; /*视频白天增益的初始值200*/ + public byte byDayMaxGain; /*视频白天增益的最大值400*/ + public byte byNightGain; /*晚间视频增益*/ + public byte bySnapGain; /*抓拍增益*/ + public int dwSceneMode; //场景模式, 详见SCENE_MODE + public NET_DVR_GEOGLOCATION struGeogLocation = new NET_DVR_GEOGLOCATION(); //地址位置(默认浙江) + public NET_ITC_PLATE_RECOG_PARAM struPlateRecog = new NET_ITC_PLATE_RECOG_PARAM(); //牌识参数 + public NET_ITC_VTCOIL_INFO[] struVtCoil = new NET_ITC_VTCOIL_INFO[MAX_VL_NUM]; //虚拟线圈参数 + public NET_ITC_RADAR_PARAM struRadar = new NET_ITC_RADAR_PARAM(); //雷达参数 + public NET_VCA_LINE struLine = new NET_VCA_LINE(); //右车道线 + //违规检测类型,按位表示,详见ITC_VIOLATION_DETECT_TYPE,0-不启用,1-启用(3.7Ver) + public int dwVioDetectType; + public byte byDebugMode; /*调试模式,0-不启用,1-启用*/ + public byte[] byRes = new byte[11]; + } + + //车道属性参数结构 + public static class NET_ITC_LANE_LOGIC_PARAM extends Structure { + public byte byUseageType; //车道用途类型,详见ITC_LANE_USEAGE_TYPE + public byte byDirectionType; //车道方向类型,详见ITC_LANE_DIRECTION_TYPE + public byte byCarDriveDirect; //车辆行驶方向,详见ITC_LANE_CAR_DRIVE_DIRECT + public byte[] byRes = new byte[33]; //保留 + } + + //视频电警线结构 + public static class NET_ITC_LINE extends Structure { + public NET_VCA_LINE struLine = new NET_VCA_LINE(); //线参数 + public byte byLineType; //线类型,详见ITC_LINE_TYPE + public byte[] byRes = new byte[7]; + } + + public static class NET_ITC_SNAPMODE_PARAM extends Structure { + public byte byVehicleCapMode;//机动车抓拍模式,0-频闪模式;1-爆闪模式 + public byte byNoVehicleCapMode;//非机动车抓拍模式,0-频闪模式;1-爆闪模式 + public byte byPasserCapMode;//行人抓拍模式,0-频闪模式;1-爆闪模式 + public byte[] byRes = new byte[29]; + } + + //size = 128 + public static class NET_ITC_HVT_EC_PARAM extends Structure { + public int dwCapShutter; //抓拍快门0~65535 + public short wCapGain; //抓拍增益0~100 + public byte[] byRes = new byte[2]; + public int dwDayTimeVideoShutter; //白天曝光时间最大值 + public short wDayTimeVideoGain; //白天增益最大值 + public short wNightVideoGain; //晚上增益最大值 + public short wNightVideoShutter; //晚上曝光时间最大值 + public byte[] byRes1 = new byte[108]; + } + + public static class NET_ITC_LANE_HVT_PARAM extends Structure { + public byte byLaneNO; //关联的车道号 1~255(用于叠加和上传) + public byte bySignSpeed; //标志限速,单位km/h 0~255 70 + public byte bySpeedLimit; //限速值,单位km/h 0~255 80 实际起效 + public byte byBigCarSignSpeed;///*大车标志限速,单位km/h*/ + public byte byBigCarSpeedLimit;/*大车限速值,单位km/h*/ + public byte bySpeedCapEn; //是否启用超速抓拍,0-否,1-是 + public byte byCaptureCount;//抓拍张数1~5(正常) + public byte byRelatedIOOut; /*关联的IO输出口(可以同时关联多个),按位表示IO输出口,第0位表示IO输出口1,以此类推,0-不关联,1-关联*/ + public byte byFlashMode; /*闪光灯闪烁模式,0-同时闪,1-轮流闪*/ + public byte byEnableRadar; //是否启用雷达测速,0-否,1-是 + public byte byChangeLaneEnable; //违章变道抓拍使能,0-关闭,1-开启 + public byte byChangeLaneCapNo; //违章变道抓拍张数2-3 + public int dwCapTarget; //抓拍类型 bit0 表示机动车 bit1 表示非机动车 bit2 表示行人 0~表示不选择 1~表示选择 + public NET_ITC_INTERVAL_PARAM struInterval; //抓拍间隔参数 + public byte[] byRes3 = new byte[24]; + public NET_ITC_LANE_LOGIC_PARAM struLane; //车道属性,用byUseageType和byCarDriveDirect + public NET_ITC_LINE struLeftLaneLine; //左车道线,线类型为虚线、实线、单黄线和双黄线 + public NET_ITC_LINE struRightLaneLine; //右车道线,线类型为虚线、实线、单黄线和双黄线 + public NET_ITC_POLYGON struPlateRecog; //牌识区域参数 + public NET_ITC_POLYGON struTraceArea; //视频触发焦点区域 + public NET_VCA_LINE struForwardTrigLine; //正向触发线:一条线段,关心端点位置,目前只支持水平配置,接口按线段的两个端点保存。(一般配置为正向车辆的最佳触发位置) + public NET_VCA_LINE struBackwardTrigLine; //背向触发线:一条线段,关心端点位置,目前只支持水平配置,接口按线段的两个端点保存(一般配置为背向车辆的最佳触发位置) + public NET_VCA_LINE struLeftTrigLine; //左边触发线:一条线段,关心端点位置,目前只支持垂直配置,接口按线段的两个端点保存(一般配置为从左边进入车辆的最佳触发位置) + public NET_VCA_LINE struRightTrigLine; //右边触发线:一条线段,关心端点位置,目前只支持垂直配置,接口按线段的两个端点保存(一般配置为从右边进入车辆的最佳触发位置) + public byte[] byRes4 = new byte[60]; + } + + public static class NET_ITC_POST_HVT_PARAM extends Structure { + public byte byLaneNum;//识别的车道个数,1-6 + public byte bySceneMode;//0-未知1-城区道路;2-小区出入口 + public byte byRoadExpBright;//路面期望亮度(视频曝光参数调整的依据之一。在无机动车时,依据此亮度期望值,调整视频曝光参数) + public byte byPlateExpBright;//车牌期望亮度(视频曝光参数调整的依据之一。在有机动车通过并识别到车牌时,依据此亮度期望值,对视频曝光参数调整) + public NET_ITC_POLYGON struDetectArea; //视频检测区域 + public NET_ITC_SNAPMODE_PARAM struCapMode = new NET_ITC_SNAPMODE_PARAM();//抓拍模式 + public NET_ITC_HVT_EC_PARAM struEcParam = new NET_ITC_HVT_EC_PARAM(); //曝光控制参数 + public NET_ITC_LANE_HVT_PARAM[] struLaneParam = new NET_ITC_LANE_HVT_PARAM[MAX_ITC_LANE_NUM]; //单车道属性 + public NET_ITC_PLATE_RECOG_PARAM struPlateRecog = new NET_ITC_PLATE_RECOG_PARAM(); //牌识参数 + public NET_DVR_GEOGLOCATION struGeogLocation = new NET_DVR_GEOGLOCATION(); //地址位置(默认浙江) + public byte[] byRes = new byte[324]; + } + + //抓拍机4.0新增 + public static class NET_ITC_LANE_HVT_PARAM_V50 extends Structure { + public byte byLaneNO; //关联的车道号1~255(用于叠加和上传) + public byte byFlashMode; //闪光灯闪烁模式,0-同时闪,1-轮流闪 + public byte bySignSpeed; //小车标志限高速,单位km/h + public byte bySpeedLimit; //小车限高速值,单位km/h + public byte bySignLowSpeed; //小车标志限底速,单位km/h + public byte byLowSpeedLimit; //小车限底速值,单位km/h + public byte byBigCarSignSpeed; //大车标志限高速,单位km/h(新交规) + public byte byBigCarSpeedLimit; //大车限高速值,单位km/h(新交规) + public byte byBigCarSignLowSpeed; //大车标志限底速,单位km/h + public byte byBigCarLowSpeedLimit; //大车限底速值,单位km/h + public byte bySnapTimes; //卡口抓拍张数,1~3 + public byte byDriveLineSnapTime;// 压线抓拍张数 1~3 + public byte byHighSpeedSnapTime;// 超高速抓拍张数1~3 + public byte byLowSpeedSnapTime;// 超低速抓拍张数1~3 + public byte byBanSnapTime;// 违反禁令抓拍张数 1~3 + public byte byReverseSnapTime;//逆行抓拍张数 1~3 + public byte byRelatedDriveWay; //关联车道号,用于匹配车检器 + public byte byLaneType; //车道类型,0-未配置、1-高速公路、2-城市快速路、0xff-其他道路 + //关联车道方向类型,参考ITC_RELA_LANE_DIRECTION_TYPE + //该参数为车道方向参数,与关联车道号byRelatedDriveWay对应,确保车道唯一性。 + public byte byRelaLaneDirectionType; + public byte[] byRes1 = new byte[27]; + public byte byChangeLaneEnable; //违章变道抓拍使能,0-关闭,1-开启 + public byte byChangeLaneCapNo; //违章变道抓拍张数2-3 + //目前仅使用第一个车道的,以后可能会扩展为多车道分别配置 + //类型, 按位表示,0-不启用,1-启用参考 ITC_VIOLATION_DETECT_TYPE + public int dwVioDetectType; + public int dwRelatedIOOut; //关联的IO输出口(可以同时关联多个),按位表示IO输出口,第0位表示IO输出口1,以此类推,0-不关联,1-关联 + public NET_ITC_LINE struTrigLine; //触发线,目前仅使用第一个车道的,以后可能会扩展为多车道分别配置 + public NET_ITC_LINE struLineLeft; //左车道线 + public NET_ITC_POLYGON struPlateRecog; //牌识区域 + public NET_ITC_LANE_LOGIC_PARAM struLane; //车道属性,用byUseageType和byCarDriveDirect + public NET_ITC_INTERVAL_PARAM struInterval;//抓拍间隔参数(20byte) + public byte[] byRes2 = new byte[280]; + } + + public static class NET_ITC_POST_HVT_PARAM_V50 extends Structure { + public byte byLaneNum; //识别的车道个数,1-6 + public byte byCapType; //抓拍类型,0-机、非、人(默认),1-机动车 + public byte byCapMode; //抓拍方式,0-视频抽帧,1-打断抓拍,2-混合模式, + public byte bySecneMode; //场景模式,0-城区道路(默认),1-小区出入口,2-高速公路 + public byte bySpeedMode; //测速模式,0-无测速,1-雷达测速,2-视频测速 + public byte byLineRuleEffect; //触发规则线有效性,每一位代表一条触发线,0-无效;1-有效。bit0-左触发线;bit1-右触发线;bit2-视频检测区域 + public byte[] byRes1 = new byte[78]; + public NET_ITC_LINE struLeftTrigLine; //左触发线(一条垂直线) + public NET_ITC_LINE struRigtTrigLine; //右触发线(一条垂直线) + public NET_ITC_LINE struLaneBoundaryLine; //车道边界线(最右边车道的右车道线) + public NET_ITC_POLYGON struDetectArea; //视频检测区域 + public NET_DVR_GEOGLOCATION struGeogLocation; //地理位置(默认浙江省)计算时区 + public NET_ITC_LANE_HVT_PARAM_V50[] struLaneParam = new NET_ITC_LANE_HVT_PARAM_V50[MAX_ITC_LANE_NUM/*6*/]; //单车道属性 + public NET_ITC_PLATE_RECOG_PARAM struPlateRecog; //牌识参数 + public byte[] byRes2 = new byte[260]; + } + + + public static class NET_ITC_LANE_PARAM extends Structure { + public byte byEnable; //是否启用该车道,0-不启用,1-启用 + public byte byRelatedDriveWay;//关联的车道号 + public short wDistance; //线圈距离,计算速度 + public short wTrigDelayTime; //触发延迟时间(默认200),单位:毫秒 + public byte byTrigDelayDistance; //触发延迟距离(默认0),单位:分米 + public byte bySpeedCapEn; //是否启用超速抓拍,0-否,1-是 + public byte bySignSpeed;//标志限速,单位km/h + public byte bySpeedLimit;//限速值,单位km/h + public byte bySnapTimes; //抓拍次数(默认1),0-不抓拍,非0-连拍次数,最大5 + public byte byOverlayDriveWay; //OSD叠加的车道号 + public NET_ITC_INTERVAL_PARAM struInterval; //抓拍间隔参数 + public byte[] byRelatedIOOut = new byte[MAX_IOOUT_NUM]; //关联的IO输出口,可以同时关联多个 + public byte byFlashMode; //闪光灯闪烁模式,0-同时闪,1-轮流闪 + public byte byCartSignSpeed;//标志限速(大车),单位km/h + public byte byCartSpeedLimit;//限速值(大车),单位km/h + public byte byRelatedIOOutEx;//第0位表示IO输出口1,以此类推,0-不关联,1-关联 支持关联到8个(兼容byRelatedIOOut字段) + public NET_ITC_PLATE_RECOG_REGION_PARAM[] struPlateRecog = new NET_ITC_PLATE_RECOG_REGION_PARAM[MAX_LANEAREA_NUM]; //车道牌识参数 + public byte byLaneType; //车道类型,0-未配置、1-高速公路、2-城市快速路、0xff-其他道路 + public byte byUseageType; //车道用途类型,详见ITC_LANE_USEAGE_TYPE + //关联车道方向类型,参考ITC_RELA_LANE_DIRECTION_TYPE + //该参数为车道方向参数,与关联车道号对应,确保车道唯一性。 + public byte byRelaLaneDirectionType; + public byte byLowSpeedLimit; //小车限底速值,单位km/h + public byte byBigCarLowSpeedLimit; //大车限底速值,单位km/h + public byte byLowSpeedCapEn; //是否启用低速抓拍,0-否,1-是 + public byte byEmergencyCapEn; //是否启用应急车道抓拍,0-否,1-是 + public byte[] byRes = new byte[9]; + } + + //卡口RS485车检器触发参数 + public static class NET_ITC_POST_RS485_PARAM extends Structure { + public byte byRelatedLaneNum;//关联的车道个数 + public byte byTriggerSpareMode; //触发备用模式,0-默认,1-卡口虚拟线圈模式,2-卡口混合车道模式 + public byte byFaultToleranceTime;//容错时间(单位:分钟),用于检测车检器是否正常的最大时间 + public byte byRes1; + public NET_ITC_PLATE_RECOG_PARAM struPlateRecog = new NET_ITC_PLATE_RECOG_PARAM(); //牌识参数 + public NET_ITC_LANE_PARAM[] struLane = new NET_ITC_LANE_PARAM[MAX_ITC_LANE_NUM]; //关联的车道参数 + public byte[] byRes = new byte[32]; + } + + //卡口RS485雷达触发参数 + public static class NET_ITC_POST_RS485_RADAR_PARAM extends Structure { + public byte byRelatedLaneNum;//关联的车道个数 + public byte[] byRes1 = new byte[3]; + public NET_ITC_PLATE_RECOG_PARAM struPlateRecog = new NET_ITC_PLATE_RECOG_PARAM(); //牌识参数 + public NET_ITC_LANE_PARAM[] struLane = new NET_ITC_LANE_PARAM[MAX_ITC_LANE_NUM]; //关联的车道参数 + public NET_ITC_RADAR_PARAM struRadar = new NET_ITC_RADAR_PARAM(); //雷达参数 + public byte[] byRes = new byte[32]; + } + + public static class NET_ITC_TRIGGER_PARAM_UNION extends Union { + public int[] uLen = new int[1070]; //参数 + public NET_ITC_POST_IOSPEED_PARAM struIOSpeed = new NET_ITC_POST_IOSPEED_PARAM(); //(卡口)IO测速参数 + // public NET_ITC_POST_SINGLEIO_PARAM struSingleIO = new NET_ITC_POST_SINGLEIO_PARAM(); //(卡口)单IO参数 + public NET_ITC_POST_RS485_PARAM struPostRs485 = new NET_ITC_POST_RS485_PARAM(); //(卡口)RS485车检器参数 + public NET_ITC_POST_RS485_RADAR_PARAM struPostRadar = new NET_ITC_POST_RS485_RADAR_PARAM(); //(卡口)RS485雷达参数 + public NET_ITC_POST_VTCOIL_PARAM struVtCoil = new NET_ITC_POST_VTCOIL_PARAM(); //(卡口)虚拟线圈参数 + public NET_ITC_POST_HVT_PARAM struHvt = new NET_ITC_POST_HVT_PARAM(); //(卡口)混行卡口参数 + // public NET_ITC_EPOLICE_IOTL_PARAM struIOTL = new NET_ITC_EPOLICE_IOTL_PARAM(); //(电警)IO红绿灯参数 +// public NET_ITC_EPOLICE_RS485_PARAM struEpoliceRs485 = new NET_ITC_EPOLICE_RS485_PARAM(); //(电警)RS485车检器触发参数 +// public NET_ITC_EPOLICE_RS485_PARAM struPERs485 = new NET_ITC_EPOLICE_RS485_PARAM(); //(卡式电警)RS485车检器触发参数 +// public NET_ITC_POST_MPR_PARAM struPostMpr = new NET_ITC_POST_MPR_PARAM(); //多帧检测触发(MPR) +// public NET_DVR_VIA_VTCOIL_PARAM struViaVtCoil = new NET_DVR_VIA_VTCOIL_PARAM(); //(VIA)视频检测参数 +// public NET_ITC_POST_IMT_PARAM struPostImt = new NET_ITC_POST_IMT_PARAM();//智慧监控触发 +// public NET_ITC_POST_PRS_PARAM struPostPrs = new NET_ITC_POST_PRS_PARAM();//视频检测触发 +// public NET_IPC_POST_HVT_PARAM struIpcHvt = new NET_IPC_POST_HVT_PARAM();//(IPC) 混行卡口参数 + public NET_ITC_POST_HVT_PARAM_V50 struHvtV50 = new NET_ITC_POST_HVT_PARAM_V50(); /*(卡口)混行卡口参数V50*/ +// public NET_ITC_POST_MOBILE_PARAM struPostMobile = new NET_ITC_POST_MOBILE_PARAM();// 移动交通触发模式 +// public NET_ITC_NOCOMITY_PEDESTRIAN_PARAM struNoComityPed = new NET_ITC_NOCOMITY_PEDESTRIAN_PARAM();//不礼让行人参数 +// public NET_ITC_REDLIGHT_PEDESTRIAN_PARAM struRedLightPed = new NET_ITC_REDLIGHT_PEDESTRIAN_PARAM();//行人闯红灯参数 + } + + //单个触发参数结构 + public static class NET_ITC_SINGLE_TRIGGERCFG extends Structure { + public byte byEnable; //是否启用该触发模式,0-否,1-是 + public byte[] byRes1 = new byte[3]; + public int dwTriggerType; //触发类型,详见ITC_TRIGGERMODE_TYPE + public NET_ITC_TRIGGER_PARAM_UNION uTriggerParam = new NET_ITC_TRIGGER_PARAM_UNION(); //触发参数 + public byte[] byRes = new byte[64]; + } + + //触发参数结构 + public static class NET_ITC_TRIGGERCFG extends Structure { + public int dwSize; //结构长度 + public NET_ITC_SINGLE_TRIGGERCFG struTriggerParam; //单个触发参数 + public byte[] byRes = new byte[32]; + } + + //单个IO接入信号灯参数 + public static class NET_ITC_SINGLE_IO_LIGHT_PARAM extends Structure { + public byte byLightType; //交通灯导向类型,0-左转灯,1-直行灯,2-右转灯 + public byte byRelatedIO; //关联的IO口号 + public byte byRedLightState; //红灯电平状态,0-高电平红灯,1-低电平红灯 + public byte[] byRes = new byte[17]; + } + + //IO接入信号灯参数 + public static class NET_ITC_IO_LIGHT_PARAM extends Structure { + public NET_ITC_SINGLE_IO_LIGHT_PARAM[] struIOLight = new NET_ITC_SINGLE_IO_LIGHT_PARAM[MAX_LIGHT_NUM]; //单个IO接入信号灯参数 + public byte[] byRes = new byte[8]; + } + + //单个485接入信号灯参数 + public static class NET_ITC_SINGLE_RS485_LIGHT_PARAM extends Structure { + public byte byLightType; //交通灯导向类型,0-左转灯,1-直行灯,2-右转灯 + public byte byRelatedLightChan; //关联的红绿灯检测器通道号 + public byte byInputLight; //接入的信号灯类型,0-接红灯,1-接绿灯 + public byte byRelatedYLightChan; //关联的黄灯检测器通道号 + public byte[] byRes = new byte[16]; + } + + //485接入信号灯参数 + public static class NET_ITC_RS485_LIGHT_PARAM extends Structure { + public NET_ITC_SINGLE_RS485_LIGHT_PARAM[] struRS485Light = new NET_ITC_SINGLE_RS485_LIGHT_PARAM[MAX_LIGHT_NUM]; //单个485接入信号灯参数 + public byte[] byRes = new byte[8]; + } + + public static class NET_POS_PARAM extends Structure { + public short wLeft; + public short wTop; + public short wRight; + public short wBottom; + } + + //单组视频检测交通信号灯参数结构 + public static class NET_ITC_SINGLE_VIDEO_DETECT_LIGHT_PARAM extends Structure { + public byte byLightNum; //交通灯个数 + public byte byStraightLight; //是否有直行标志灯,0-否 ,1-是 + public byte byLeftLight; //是否有左转标志灯,0-否,1-是 + public byte byRightLight; //是否有右转标志灯,0-否,1-是 + public byte byRedLight;//是否有红灯,0-否,1-是 + public byte byGreenLight; //是否有绿灯,0-否,1-是 + public byte byYellowLight; //是否有黄灯,0-否,1-是 + public byte byYellowLightTime;//取值范围(0~10s)(ITC3.7Ver) + public NET_POS_PARAM struLightRect; //交通灯区域 + public byte[] byRes = new byte[24]; + } + + //视频检测交通信号灯参数结构(最大可有12个区域检测,488字节) + public static class NET_ITC_VIDEO_DETECT_LIGHT_PARAM extends Structure { + public NET_ITC_SINGLE_VIDEO_DETECT_LIGHT_PARAM[] struTrafficLight = new NET_ITC_SINGLE_VIDEO_DETECT_LIGHT_PARAM[MAX_VIDEO_DETECT_LIGHT_NUM]; //单个视频检测信号灯参数 + public byte[] byRes = new byte[8]; + } + + //交通信号灯接入参数 + public static class NET_ITC_LIGHT_ACCESSPARAM_UNION extends Union { + public int[] uLen = new int[122]; + public NET_ITC_IO_LIGHT_PARAM struIOLight; //IO接入信号灯参数 + public NET_ITC_RS485_LIGHT_PARAM struRS485Light; //485接入信号灯参数 + public NET_ITC_VIDEO_DETECT_LIGHT_PARAM struVideoDelectLight; //视频检测信号灯参数 + } + + //交通信号灯参数结构 + public static class NET_ITC_TRAFFIC_LIGHT_PARAM extends Structure { + public byte bySource; //交通信号灯接入源,0-IO接入,1-RS485接入 + public byte[] byRes1 = new byte[3]; + public NET_ITC_LIGHT_ACCESSPARAM_UNION struLightAccess = new NET_ITC_LIGHT_ACCESSPARAM_UNION();//信号灯接入参数 + public byte[] byRes = new byte[32]; + } + + //违规检测参数结构 + public static class NET_ITC_VIOLATION_DETECT_PARAM extends Structure { + public int dwVioDetectType; //违规检测类型, 按位表示, 详见ITC_VIOLATION_DETECT_TYPE ,0-不启用,1-启用 + public byte byDriveLineSnapTimes; //压车道线抓拍张数,2-3 + public byte byReverseSnapTimes; //逆行抓拍,2-3 + public short wStayTime; //机占非停留时间(该时间后抓拍),单位s + public byte byNonDriveSnapTimes;//机占非抓拍张数2-3 + public byte byChangeLaneTimes;//违法变道抓拍张数 2-3 + public byte bybanTimes;//违法禁令抓拍张数2-3 + public byte byDriveLineSnapSen;// 压线灵敏度(0~100)(3.7Ver) + public short wSnapPosFixPixel; //第2,3张抓拍位置最小偏移(违反信号灯时起效)(单位:像素) 命名需改进 + public byte bySpeedTimes;//违法超速抓拍张数2-3(3.8Ver) + public byte byTurnAroundEnable;//违章掉头使能 0~关闭 1~开启 + public byte byThirdPlateRecogTime;//第三张牌识时间 0~180s + public byte byPostSnapTimes;//卡口抓拍张数,1-2张 + public byte[] byRes1 = new byte[18]; + public short wStopLineDis; //电警第2张违规图片与停止线的最短距离,[0,300]单位(像素) + public byte[] byRes = new byte[14]; + } + + //违规检测线参数结构 + public static class NET_ITC_VIOLATION_DETECT_LINE extends Structure { + public NET_ITC_LINE struLaneLine = new NET_ITC_LINE(); //车道线参数 + public NET_ITC_LINE struStopLine = new NET_ITC_LINE(); //停止线参数 + public NET_ITC_LINE struRedLightLine = new NET_ITC_LINE(); //闯红灯触发线参数 + public NET_ITC_LINE struCancelLine = new NET_ITC_LINE(); //直行触发位置取消线 + public NET_ITC_LINE struWaitLine = new NET_ITC_LINE(); //待行区停止线参数 + public NET_ITC_LINE[] struRes = new NET_ITC_LINE[8]; + } + + //单个车道视频电警触发参数结构 + public static class NET_ITC_LANE_VIDEO_EPOLICE_PARAM extends Structure { + public byte byLaneNO; //关联的车道号 + public byte bySensitivity; //线圈灵敏度,[1,100] + public byte byEnableRadar;//启用雷达测试0-不启用,1-启用 + //关联车道方向类型,参考ITC_RELA_LANE_DIRECTION_TYPE + //该参数为车道方向参数,与关联车道号对应,确保车道唯一性。 + public byte byRelaLaneDirectionType; + public NET_ITC_LANE_LOGIC_PARAM struLane; //车道参数 + public NET_ITC_VIOLATION_DETECT_PARAM struVioDetect; //违规检测参数 + public NET_ITC_VIOLATION_DETECT_LINE struLine; //违规检测线 + public NET_ITC_POLYGON struPlateRecog; //牌识区域参数 + public byte byRecordEnable;//闯红灯周期录像标志,0-不录像,1-录像 + public byte byRecordType;//闯红灯录像类型,0-预录,1-延时录像 + public byte byPreRecordTime;//闯红灯录像片段预录时间(默认0),单位:秒 + public byte byRecordDelayTime;//闯红灯录像片段延时时间(默认0),单位:秒 + public byte byRecordTimeOut;//闯红灯周期录像超时时间(秒) + public byte byCarSpeedLimit; //车速限制值,单位km/h + public byte byCarSignSpeed;//标志限速,单位km/h + public byte bySnapPicPreRecord; //抓拍图片预录时间点;0-默认值(第二张图片),1-第一张图片,2-第二张图片,3-第三张图片 + public NET_ITC_INTERVAL_PARAM struInterval;//抓拍间隔参数(20byte) + public byte[] byRes = new byte[36]; + } + + //视频电警触发参数结构 + public static class NET_ITC_VIDEO_EPOLICE_PARAM extends Structure { + public byte byEnable; //是否启用,0-不启用,1-启用 + public byte byLaneNum; //识别的车道个数 + public byte byLogicJudge;//闯红灯违规判断逻辑,设置值为:0-按方向,1-按车道 + public byte byRes1; + public NET_ITC_PLATE_RECOG_PARAM struPlateRecog; //牌识参数 + public NET_ITC_TRAFFIC_LIGHT_PARAM struTrafficLight; //交通信号灯参数 + public NET_ITC_LANE_VIDEO_EPOLICE_PARAM[] struLaneParam = new NET_ITC_LANE_VIDEO_EPOLICE_PARAM[MAX_ITC_LANE_NUM]; //单车道参数 + public NET_ITC_LINE struLaneBoundaryLine; //车道边界线(最右边车道的边界线) + public NET_ITC_LINE struLeftLine; //左转弯分界线 + public NET_ITC_LINE struRightLine; //右转弯分界线 + public NET_ITC_LINE struTopZebraLine; //上部斑马线 + public NET_ITC_LINE struBotZebraLine; //下部斑马线 + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_CURTRIGGERMODE extends Structure { + public int dwSize; + public int dwTriggerType; //触发类型,详见ITC_TRIGGERMODE_TYPE + public byte[] byRes = new byte[24]; + } + + public static class NET_ITC_VIDEO_TRIGGER_COND extends Structure { + public int dwSize; + public int dwChannel; + public int dwTriggerMode; //视频触发模式类型,详见ITC_TRIGGERMODE_TYPE + public byte[] byRes = new byte[16]; + } + + public static class NET_ITC_VIDEO_TRIGGER_PARAM_UNION extends Union { + public int[] uLen = new int[1150]; + public NET_ITC_VIDEO_EPOLICE_PARAM struVideoEP = new NET_ITC_VIDEO_EPOLICE_PARAM(); //视频电警参数 + } + + public static class NET_ITC_VIDEO_TRIGGER_PARAM extends Structure { + public int dwSize; + public int dwMode; //触发模式,详见ITC_TRIGGERMODE_TYPE + public NET_ITC_VIDEO_TRIGGER_PARAM_UNION uVideoTrigger = new NET_ITC_VIDEO_TRIGGER_PARAM_UNION(); //触发模式参数 + public byte[] byRes = new byte[32]; + } + + public static class NET_DVR_CMS_PARAM extends Structure { + public int dwSize; + public NET_DVR_IPADDR struAddr = new NET_DVR_IPADDR(); // 平台服务器IP + public short wServerPort; // 平台服务器侦听端口, + public byte bySeverProtocolType; //平台协议类型 1-私有,2-Ehome + public byte byStatus; //设备注册到该平台的状态,1-未注册,2-已注册 + public byte[] sDeviceId = new byte[NAME_LEN/*32*/]; //设备ID,由平台提供 + public byte[] sPassWord = new byte[PASSWD_LEN]; //密码 + /********* + * IPC5.1.7 新增参数 Begin 2014-03-21 + ***********/ + public byte[] sPlatformEhomeVersion = new byte[NAME_LEN];//平台EHOME协议版本 + /********* + * IPC5.1.7 新增参数 end 2014-03-21 + ***********/ + public byte byNetWork; //网络类型:0- 无意义,1-自动,2-有线网络优先,3-有线网络,4-3G网络(无线网络),5-有线网络1,6-有线网络2 + public byte byAddressType; //0 - 无意义, 1 - ipv4/ipv6地址,2 - 域名 + public byte byProtocolVersion; //协议版本 0 - 无意义, 1 – v2.0,2 – v4.0,3-v2.6 + public byte byRes1; + public byte[] sDomainName = new byte[MAX_DOMAIN_NAME/*64*/]; //平台服务器域名,byAddressType为2时有效 + public byte byEnable; //0-关闭,1-开启 + public byte[] byRes = new byte[139]; // 保留字节 + } + + //设置完全获取出厂值 + public static class NET_DVR_COMPLETE_RESTORE_INFO extends Structure { + public int dwSize; //结构体长度 + public int dwChannel; //通道号 + public byte[] byRes = new byte[64]; + } + + public static class NET_DVR_STD_ABILITY extends Structure { + public Pointer lpCondBuffer; //[in]条件参数(码字格式),例如通道号等.可以为NULL + public int dwCondSize; //[in] dwCondSize指向的内存大小 + public Pointer lpOutBuffer; //[out]输出参数(XML格式),不为NULL + public int dwOutSize; //[in] lpOutBuffer指向的内存大小 + public Pointer lpStatusBuffer; //[out]返回的状态参数(XML格式),获取成功时不会赋值,如果不需要,可以置NULL + public int dwStatusSize; //[in] lpStatusBuffer指向的内存大小 + public int dwRetSize; //[out]获取到的数据长度(lpOutBuffer或者lpStatusBuffer指向的实际数据长度) + public byte[] byRes = new byte[32]; //保留字节 + } + + public static class NET_DVR_STD_CONFIG extends Structure { + public Pointer lpCondBuffer; //[in]条件参数(结构体格式),例如通道号等.可以为NULL + public int dwCondSize; //[in] lpCondBuffer指向的内存大小 + public Pointer lpInBuffer; //[in]输入参数(结构体格式),设置时不为NULL,获取时为NULL + public int dwInSize; //[in] lpInBuffer指向的内存大小 + public Pointer lpOutBuffer; //[out]输出参数(结构体格式),获取时不为NULL,设置时为NULL + public int dwOutSize; //[in] lpOutBuffer指向的内存大小 + public Pointer lpStatusBuffer; //[out]返回的状态参数(XML格式),获取成功时不会赋值,如果不需要,可以置NULL + public int dwStatusSize; //[in] lpStatusBuffer指向的内存大小 + public Pointer lpXmlBuffer; //[in/out]byDataType = 1时有效,xml格式数据 + public int dwXmlSize; //[in/out]lpXmlBuffer指向的内存大小,获取时同时作为输入和输出参数,获取成功后会修改会实际长度,设置时表示实际长度,而不是整个内存大小 + public byte byDataType; //[in]输入/输出参数类型,0-使用结构体类型lpInBuffer/lpOutBuffer有效,1-使用XML类型lpXmlBuffer有效 + public byte[] byRes = new byte[23]; + } + + public static final int NET_SDK_MAX_FILE_PATH = 256;//路径长度 + + public static class NET_DVR_LOCAL_SDK_PATH extends Structure { + public byte[] sPath = new byte[NET_SDK_MAX_FILE_PATH];//组件库地址 + public byte[] byRes = new byte[128]; + } + + public static class BYTE_ARRAY extends Structure { + public byte[] byValue; + + public BYTE_ARRAY(int iLen) { + byValue = new byte[iLen]; + } + } + + public static class INT_ARRAY extends Structure { + public int[] intValue; + + public INT_ARRAY(int iLen) { + intValue = new int[iLen]; + } + } + + public static class INTRef_ARRAY extends Structure { + public IntByReference[] intValue; + + public INTRef_ARRAY(int iLen) { + intValue = new IntByReference[iLen]; + } + } + + + public static class NET_DVR_JSON_DATA_CFG extends Structure { + public int dwSize; //结构体大小 + public Pointer lpJsonData; //JSON报文 + public int dwJsonDataSize; //JSON报文大小 + public Pointer lpPicData; //图片内容 + public int dwPicDataSize; //图片内容大小 + public int lpInfraredFacePicBuffer; //红外人脸图片数据缓存 + public Pointer dwInfraredFacePicSize; //红外人脸图片数据大小,等于0时,代表无人脸图片数据(当JSON报文为当ResponseStatus(JSON)报文时,该字段无意义;当Inbound Data(JSON)报文中没有infraredFaceURL时,该字段需要带上二进制图片内容) + public byte[] byRes = new byte[248]; + } + + public static class CallBack_USER extends Structure { + public byte[] byDeviceID = new byte[16]; + public byte[] byCardNo = new byte[32]; + public byte[] byDevIP = new byte[16]; + } + + + public static class NET_DVR_CAMERAPARAMCFG_EX extends Structure { + public int dwSize; + public NET_DVR_VIDEOEFFECT struVideoEffect = new NET_DVR_VIDEOEFFECT();/*亮度、对比度、饱和度、锐度、色调配置*/ + public NET_DVR_GAIN struGain = new NET_DVR_GAIN();/*自动增益*/ + public NET_DVR_WHITEBALANCE struWhiteBalance = new NET_DVR_WHITEBALANCE();/*白平衡*/ + public NET_DVR_EXPOSURE struExposure = new NET_DVR_EXPOSURE(); /*曝光控制*/ + public NET_DVR_GAMMACORRECT struGammaCorrect = new NET_DVR_GAMMACORRECT();/*Gamma校正*/ + public NET_DVR_WDR struWdr = new NET_DVR_WDR();/*宽动态*/ + public NET_DVR_DAYNIGHT struDayNight = new NET_DVR_DAYNIGHT();/*日夜转换*/ + public NET_DVR_BACKLIGHT struBackLight = new NET_DVR_BACKLIGHT();/*背光补偿*/ + public NET_DVR_NOISEREMOVE struNoiseRemove = new NET_DVR_NOISEREMOVE();/*数字降噪*/ + public byte byPowerLineFrequencyMode; /*0-50HZ; 1-60HZ*/ + /* + 0-自动光圈, + 1-手动光圈, + 2-P-Iris1, + 3-Union 3-9mm F1.6-2.7 (T5280-PQ1) [IPC5.1.7] + 4-Union 2.8-12mm F1.6-2.7 (T5289-PQ1) [IPC5.1.7] + 5-HIK 3.8-16mm F1.5(HV3816P-8MPIR) + 6-HIK 11-40mm F1.7 (HV1140P-8MPIR) + 7-HIK 2.7-12mm F1.2(TV2712P-MPIR) + 8- MZ5721D-12MPIR + 9- MZ1555D-12MPIR + 10- MZ5721D-12MPIR(RS485) + 11- MZ1555D-12MPIR(RS485) + */ + public byte byIrisMode; + public byte byMirror; /* 镜像:0 off,1- leftright,2- updown,3-center 4-Auto*/ + public byte byDigitalZoom; /*数字缩放:0 dsibale 1 enable*/ + public byte byDeadPixelDetect; /*坏点检测,0 dsibale 1 enable*/ + public byte byBlackPwl;/*黑电平补偿 , 0-255*/ + public byte byEptzGate;// EPTZ开关变量:0-不启用电子云台,1-启用电子云台 + public byte byLocalOutputGate;//本地输出开关变量0-本地输出关闭1-本地BNC输出打开 2-HDMI输出关闭 + //20-HDMI_720P50输出开 + //21-HDMI_720P60输出开 + //22-HDMI_1080I60输出开 + //23-HDMI_1080I50输出开 + //24-HDMI_1080P24输出开 + //25-HDMI_1080P25输出开 + //26-HDMI_1080P30输出开 + //27-HDMI_1080P50输出开 + //28-HDMI_1080P60输出开 + public byte byCoderOutputMode;//编码器fpga输出模式0直通3像素搬家 + public byte byLineCoding; //是否开启行编码:0-否,1-是 + public byte byDimmerMode; //调光模式:0-半自动,1-自动 + public byte byPaletteMode; //调色板:0-白热,1-黑热,2-调色板2,…,8-调色板8, 9-融合1,10-彩虹,11-融合2,12-铁红1,13-铁红2,14-深褐色,15-色彩1,16-色彩2,17-冰火,18-雨,19-红热,20-绿热,21-深蓝,22-色彩3 + public byte byEnhancedMode; //增强方式(探测物体周边):0-不增强,1-1,2-2,3-3,4-4 + public byte byDynamicContrastEN; //动态对比度增强 0-1 + public byte byDynamicContrast; //动态对比度 0-100 + public byte byJPEGQuality; //JPEG图像质量 0-100 + public NET_DVR_CMOSMODECFG struCmosModeCfg = new NET_DVR_CMOSMODECFG();//CMOS模式下前端参数配置,镜头模式从能力集获取 + public byte byFilterSwitch; //滤波开关:0-不启用,1-启用 + public byte byFocusSpeed; //镜头调焦速度:0-10 + public byte byAutoCompensationInterval; //定时自动快门补偿:1-120,单位:分钟 + public byte bySceneMode; //场景模式:0-室外,1-室内,2-默认,3-弱光 + public NET_DVR_DEFOGCFG struDefogCfg = new NET_DVR_DEFOGCFG();//透雾参数 + public NET_DVR_ELECTRONICSTABILIZATION struElectronicStabilization = new NET_DVR_ELECTRONICSTABILIZATION();//电子防抖 + public NET_DVR_CORRIDOR_MODE_CCD struCorridorMode = new NET_DVR_CORRIDOR_MODE_CCD();//走廊模式 + public byte byExposureSegmentEnable; //0~不启用,1~启用 曝光时间和增益呈阶梯状调整,比如曝光往上调整时,先提高曝光时间到中间值,然后提高增益到中间值,再提高曝光到最大值,最后提高增益到最大值 + public byte byBrightCompensate;//亮度增强 [0~100] + /* + 0-关闭、1-640*480@25fps、2-640*480@30ps、3-704*576@25fps、4-704*480@30fps、5-1280*720@25fps、6-1280*720@30fps、 + 7-1280*720@50fps、8-1280*720@60fps、9-1280*960@15fps、10-1280*960@25fps、11-1280*960@30fps、 + 12-1280*1024@25fps、13--1280*1024@30fps、14-1600*900@15fps、15-1600*1200@15fps、16-1920*1080@15fps、 + 17-1920*1080@25fps、18-1920*1080@30fps、19-1920*1080@50fps、20-1920*1080@60fps、21-2048*1536@15fps、22-2048*1536@20fps、 + 23-2048*1536@24fps、24-2048*1536@25fps、25-2048*1536@30fps、26-2560*2048@25fps、27-2560*2048@30fps、 + 28-2560*1920@7.5fps、29-3072*2048@25fps、30-3072*2048@30fps、31-2048*1536@12.5、32-2560*1920@6.25、 + 33-1600*1200@25、34-1600*1200@30、35-1600*1200@12.5、36-1600*900@12.5、37-1280*960@12.5fps、38-800*600@25fps、39-800*600@30fps40、 + 4000*3000@12.5fps、41-4000*3000@15fps、42-4096*2160@20fps、43-3840*2160@20fps 、44-960*576@25fps、45-960*480@30fps、46-752*582@25fps、 + 47-768*494@30fps、48-2560*1440@25fps、49-2560*1440@30fps 、50-720P@100fps、51-720P@120fps、52-2048*1536@50fps、53-2048*1536@60fps、 + 54-3840*2160@25fps、55-3840*2160@30fps、56-4096*2160@25fps、57-4096*2160@30fps 、58-1280*1024@50fps、59-1280*1024@60fps、 + 60-3072*2048@50fps、61-3072*2048@60fps、62-3072*1728@25fps、63-3072*1728@30fps、64-3072*1728@50fps、65-3072*1728@60fps、66-336*256@50fps、67-336*256@60fps、 + 68-384*288@50fps、69-384*288@60fps 、70- 640 * 512@50fps 、71- 640 * 512@60fps、72-2592*1944@25fps、73-2592*1944@30fps、74-2688*1536@25fps、75-2688*1536@30fps + 76-2592*1944@20fps、77-2592*1944@15fps、78-2688*1520@20fps、79-2688*1520@15fps、80-2688*1520@25fps、81-2688*1520@30fps、82- 2720*2048@25fps、 83- 2720*2048@30fps、 + 84-336*256@25fps、85- 384*288@25fps、86-640*512@25fps、87-1280*960@50fps、88-1280*960@60fps、89-1280*960@100fps、90-1280*960@120fps、91-4000*3000@20fps、 + 92-1920*1200@25fps、93-1920*1200@30fps、94-2560*1920@25fps、95-2560*1920@20fps、96-2560*1920@30fps、97-1280*1920@25fps、98-1280*1920@30fps + 99-4000*3000@24fps、100-4000*3000@25fps、101-4000*3000@10fps、102- 384*288@30fps、103-2560*1920@15fps、104-2400*3840@25fps、105-1200*1920@25fps + 106-4096*1800@30fps、107-3840*1680@30fps、108-2560*1120@30fps、109-704*320@30fps、110-1280*560@30fps、111-4096*1800@25fps、112-3840*1680@25fps + 113-2560*1120@25fps、114-704*320@25fps、115-1280*560@25fps、116-2400*3840@24fps、117-3840*2400@24fps、118-3840*2400@25fps、119-2560*1920@12.5fps + 120-2560*2048@12fps、121-2560*2048@15fps、122-2560*1536@25fps、123-2560*1536@30fps、124-2256*2048@25fps、125-2256*2048@30fps、126-2592*2592@12.5fps、127-2592*2592@15fps、 + 128 - 640*512@30fps、129-2048*1520@30fps、130-2048*1520@25fps、131-3840*2160@24fps、132-2592*1520@25fps、133-2592*1520@30fps、134-2592*1536@25fps、135-2592*1536@30fps + 136-640*960@25fps、137-640*960@24fps、142-2992*2192@25fps、143-2992*2192@30fps、144-3008*2160@25fps、145-3008*2160@30fps、146-3072*1728@20fps、147-2560*1440@20fps、 + 148-2160*3840@25fps、149-2160*3840@30fps、150-7008*1080@25fps、151-7008*1080@30fps、152-3072*2048@20fps、153-1536*864@25fps、154-2560*1920@24fps、155-2400*3840@30fps、 + 156-3840*2400@30fps、157-3840*2160@15fps + 158-384*288@8.3fps、159-640*512@8.3fps、160-160*120@8.3fps、161-1024*768@8.3fps、162-640*480@8.3fps、163-3840*2160@12.5fps、164-2304*1296@30fps、165-2304*1296@25fps、 + 166-2560*1440@24fps、167-2688*1512@25fps、168-2688*1512@30fps、169-2688*1512@50fps、170-2688*1512@60fps、171-1536*864@30fps、172-2560*1440@50fps、173-2560*1440@60fps、 + 174-2048*2048@25fps、175-2048*2048@30fps、176-4000*3060@20fps、177-3060*3060@25fps、178-3060*3060@30fps、179-3000*3000@25fps、180-3000*3000@30fps、181-8160*3616@30fps、 + 182-8160*3616@25fps、183-3000*3000@20fps、184-3000*3000@15fps、185-3000*3000@12.5fps、186-5472*3648@25fps、187-5472*3648@30fps、188-7680*4320@25fps、189-7680*4320@30fps、 + 190-8160*2400@25fps、191-8160*2400@30fps、192-5520*2400@25fps、193-5520*2400@30fps、194-2560*1440@15fps、195-1944*1212@24fps、196-1944*1212@25fps、197-3456*1920@30fps、 + 198-4800*2688@25fps、199-4800*2688@30fps、200-6480*1080@25fps、201-6480*1080@30fps、202-8640*1440@25fps、203-8640*1440@30fps、204-3456*1920@25fps、205-2688*1520@50fps、 + 206-2688*1520@60fps、207-4976*1452@25fps、208-4976*1452@30fps、 209-3200*1800@25fps、210-3200*1800@30fps、211-5472*3648@24fps、212-1920*1080@12.5fps、213-2944*1656@20fps、 + 214-1920*1080@24fps、215-4800*1600@25fps、216-4800*1600@30fps、217-2560*1440@12.5fps、218-6560*3690@1fps、219-5120*1400@20fps*/ + public byte byCaptureModeN; //视频输入模式(N制) + public byte byCaptureModeP; //视频输入模式(P制) + public NET_DVR_SMARTIR_PARAM struSmartIRParam = new NET_DVR_SMARTIR_PARAM(); //红外放过爆配置信息 + public NET_DVR_PIRIS_PARAM struPIrisParam = new NET_DVR_PIRIS_PARAM();//PIris配置信息对应byIrisMode字段从2-PIris1开始生效 + //2014-02-25 新增参数 + public NET_DVR_LASER_PARAM_CFG struLaserParam = new NET_DVR_LASER_PARAM_CFG(); //激光参数 + public NET_DVR_FFC_PARAM struFFCParam = new NET_DVR_FFC_PARAM(); + public NET_DVR_DDE_PARAM struDDEParam = new NET_DVR_DDE_PARAM(); + public NET_DVR_AGC_PARAM struAGCParam = new NET_DVR_AGC_PARAM(); + public byte byLensDistortionCorrection;//镜头畸变校正 0-关闭,1-开启 + public byte byDistortionCorrectionLevel;//畸变校正等级:0-保留;1-等级一;2-等级二;3-等级三;255-自定义 + public byte byCalibrationAccurateLevel;// 畸变校正强度[0-100] + public byte byZoomedInDistantViewLevel;//远端放大等级[0-100] + public NET_DVR_SNAP_CAMERAPARAMCFG struSnapCCD = new NET_DVR_SNAP_CAMERAPARAMCFG(); //抓拍机CCD参数,只用于抓拍机 + public NET_DVR_OPTICAL_DEHAZE struOpticalDehaze = new NET_DVR_OPTICAL_DEHAZE();//光学透雾参数 + public NET_DVR_THERMOMETRY_AGC struThermAGC = new NET_DVR_THERMOMETRY_AGC();//测温AGC配置 + public byte byFusionMode;//双光谱视频融合模式,0~热成像模式,1~融合模式,2~画中画模式,3~可见光模式, 4~融合黑白模式, 5~融合彩色模式-草地,6~融合彩色模式-荒地,7~融合彩色模式-雪地,8~融合彩色模式-海洋,9~融合彩色模式-城市 + public byte byHorizontalFOV;//水平视场角[0-100] + public byte byVerticalFOV;//垂直视场角[0-100] + public byte byBrightnessSuddenChangeSuppression;//亮度突变抑制0-关闭,1-开启 + public byte byGPSEnabled;//GPS开关使能,0-关,1-开 + public byte[] byRes2 = new byte[155]; + } + + + public static class NET_DVR_VIDEOEFFECT extends Structure { + public byte byBrightnessLevel; /*0-100*/ + public byte byContrastLevel; /*0-100*/ + public byte bySharpnessLevel; /*0-100*/ + public byte bySaturationLevel; /*0-100*/ + public byte byHueLevel; /*0-100,(保留)*/ + public byte byEnableFunc; //使能,按位表示,bit0-SMART IR(防过曝),bit1-低照度,bit2-强光抑制使能,0-否,1-是 + public byte byLightInhibitLevel; //强光抑制等级,[1-3]表示等级 + public byte byGrayLevel; //灰度值域,0-[0-255],1-[16-235] + } + + + public static class NET_DVR_GAIN extends Structure { + public byte byGainLevel; /*增益:0-100*/ + public byte byGainUserSet; /*用户自定义增益;0-100,对于抓拍机,是CCD模式下的抓拍增益*/ + public byte[] byRes = new byte[2]; + public int dwMaxGainValue;/*最大增益值,单位dB*/ + } + + public static class NET_DVR_WHITEBALANCE extends Structure { + public byte byWhiteBalanceMode; /*0-手动白平衡(MWB),1-自动白平衡1(AWB1),2-自动白平衡2 (AWB2),3-自动控制改名为锁定白平衡(Locked WB), + 4-室外(Indoor),5-室内(Outdoor)6-日光灯(Fluorescent Lamp),7-钠灯(Sodium Lamp), + 8-自动跟踪(Auto-Track)9-一次白平衡(One Push),10-室外自动(Auto-Outdoor), + 11-钠灯自动 (Auto-Sodiumlight),12-水银灯(Mercury Lamp),13-自动白平衡(Auto), +14-白炽灯 (IncandescentLamp),15-暖光灯(Warm Light Lamp),16-自然光(Natural Light) */ + public byte byWhiteBalanceModeRGain; /*手动白平衡时有效,手动白平衡 R增益*/ + public byte byWhiteBalanceModeBGain; /*手动白平衡时有效,手动白平衡 B增益*/ + public byte[] byRes = new byte[5]; + } + + public static class NET_DVR_EXPOSURE extends Structure { + public byte byExposureMode; /*0 手动曝光 1自动曝光*/ + public byte byAutoApertureLevel; /* 自动光圈灵敏度, 0-10 */ + public byte[] byRes = new byte[2]; + public int dwVideoExposureSet; /* 自定义视频曝光时间(单位us)*//*注:自动曝光时该值为曝光最慢值 新增20-1s(1000000us)*/ + public int dwExposureUserSet; /* 自定义曝光时间,在抓拍机上应用时,CCD模式时是抓拍快门速度*/ + public int dwRes; + } + + public static class NET_DVR_GAMMACORRECT extends Structure { + public byte byGammaCorrectionEnabled; /*0 dsibale 1 enable*/ + public byte byGammaCorrectionLevel; /*0-100*/ + public byte[] byRes = new byte[6]; + } + + + public static class NET_DVR_WDR extends Structure { + public byte byWDREnabled; /*宽动态:0 dsibale 1 enable 2 auto*/ + public byte byWDRLevel1; /*0-F*/ + public byte byWDRLevel2; /*0-F*/ + public byte byWDRContrastLevel; /*0-100*/ + public byte[] byRes = new byte[16]; + } + + public static class NET_DVR_DAYNIGHT extends Structure { + public byte byDayNightFilterType; /*日夜切换:0-白天,1-夜晚,2-自动,3-定时,4-报警输入触发, 5-自动模式2(无光敏),6-黑光,7-黑光自动,8-黑光定时*/ + public byte bySwitchScheduleEnabled; /*0 dsibale 1 enable,(保留)*/ + //定时模式参数 + public byte byBeginTime; /*开始时间(小时),0-23*/ + public byte byEndTime; /*结束时间(小时),0-23*/ + //模式2 + public byte byDayToNightFilterLevel; //0-7 + public byte byNightToDayFilterLevel; //0-7 + public byte byDayNightFilterTime;//(60秒) + //定时模式参数 + public byte byBeginTimeMin; //开始时间(分),0-59 + public byte byBeginTimeSec; //开始时间(秒),0-59 + public byte byEndTimeMin; //结束时间(分),0-59 + public byte byEndTimeSec; //结束时间(秒),0-59 + //报警输入触发模式参数 + public byte byAlarmTrigState; //报警输入触发状态,0-白天,1-夜晚 + } + + public static class NET_DVR_BACKLIGHT extends Structure { + public byte byBacklightMode; /*背光补偿:0 off 1 UP、2 DOWN、3 LEFT、4 RIGHT、5MIDDLE、6自定义,10-开,11-自动,12-多区域背光补偿*/ + public byte byBacklightLevel; /*0x0-0xF*/ + public byte[] byRes1 = new byte[2]; + public int dwPositionX1; //(X坐标1) + public int dwPositionY1; //(Y坐标1) + public int dwPositionX2; //(X坐标2) + public int dwPositionY2; //(Y坐标2) + public byte[] byRes2 = new byte[4]; + } + + + public static class NET_DVR_NOISEREMOVE extends Structure { + public byte byDigitalNoiseRemoveEnable; /*0-不启用,1-普通模式数字降噪,2-专家模式数字降噪*/ + public byte byDigitalNoiseRemoveLevel; /*普通模式数字降噪级别:0x0-0xF*/ + public byte bySpectralLevel; /*专家模式下空域强度:0-100*/ + public byte byTemporalLevel; /*专家模式下时域强度:0-100*/ + public byte byDigitalNoiseRemove2DEnable; /* 抓拍帧2D降噪,0-不启用,1-启用 */ + public byte byDigitalNoiseRemove2DLevel; /* 抓拍帧2D降噪级别,0-100 */ + public byte[] byRes = new byte[2]; + } + + + public static class NET_DVR_CMOSMODECFG extends Structure { + public byte byCaptureMod; //抓拍模式:0-抓拍模式1;1-抓拍模式2 + public byte byBrightnessGate;//亮度阈值 + public byte byCaptureGain1; //抓拍增益1,0-100 + public byte byCaptureGain2; //抓拍增益2,0-100 + public int dwCaptureShutterSpeed1;//抓拍快门速度1 + public int dwCaptureShutterSpeed2;//抓拍快门速度2 + public byte[] byRes = new byte[4]; + } + + public static class NET_DVR_DEFOGCFG extends Structure { + public byte byMode; //模式,0-不启用,1-自动模式,2-常开模式 + public byte byLevel; //等级,0-100 + public byte[] byRes = new byte[6]; + } + + public static class NET_DVR_CMOSMODCFG extends Structure { + public byte byCaptureMod; //抓拍模式:0-抓拍模式1;1-抓拍模式2 + public byte byBrightnessGate;//亮度阈值 + public byte byCaptureGain1; //抓拍增益1,0-100 + public byte byCaptureGain2; //抓拍增益2,0-100 + public int dwCaptureShutterSpeed1;//抓拍快门速度1 + public int dwCaptureShutterSpeed2;//抓拍快门速度2 + public byte[] byRes = new byte[4]; + } + + public static class NET_DVR_ELECTRONICSTABILIZATION extends Structure { + public byte byEnable;//使能 0- 不启用,1- 启用 + public byte byLevel; //等级,0-100 + public byte[] byRes = new byte[6]; + } + + public static class NET_DVR_CORRIDOR_MODE_CCD extends Structure { + public byte byEnableCorridorMode; //是否启用走廊模式 0~不启用, 1~启用 + public byte[] byRes = new byte[11]; + } + + public static class NET_DVR_SMARTIR_PARAM extends Structure { + public byte byMode;//0~手动,1~自动 + public byte byIRDistance;//红外距离等级(等级,距离正比例)level:1~100 默认:50(手动模式下增加) + public byte byShortIRDistance;// 近光灯距离等级(1~100) + public byte byLongIRDistance;// 远光灯距离等级(1~100) + } + + public static class NET_DVR_PIRIS_PARAM extends Structure { + public byte byMode;//0-自动,1-手动 + public byte byPIrisAperture;//红外光圈大小等级(等级,光圈大小正比例)level:1~100 默认:50(手动模式下增加) + public byte[] byRes = new byte[6]; + } + + public static class NET_DVR_LASER_PARAM_CFG extends Structure { + public byte byControlMode; //控制模式 0-无效,1-自动,2-手动 默认自动 + public byte bySensitivity; //激光灯灵敏度 0-100 默认50 + public byte byTriggerMode; //激光灯触发模式 0-无效,1-机芯触发,2-光敏触发 默认机芯触发 + public byte byBrightness; //控制模式为手动模式下有效;激光灯亮度 0-255 默认100 + public byte byAngle; //激光灯角度 0-无效,范围1-36 默认12,激光灯照射范围为一个圆圈,调节激光角度是调节这个圆的半径的大小 + public byte byLimitBrightness; //控制模式为自动模式下有效;激光灯亮度限制 0~100 (新增)2014-01-26 + public byte byEnabled; //手动控制激光灯使能 0-关闭,1-启动 + public byte byIllumination; //激光灯强度配置0~100 + public byte byLightAngle; //补光角度 0~100 + public byte[] byRes = new byte[7]; //保留 + } + + public static class NET_DVR_FFC_PARAM extends Structure { + //1-Schedule Mode,2-Temperature Mode, 3-Off + public byte byMode; + //(时间:按能力显示,单位分钟,选项有10,20,30,40,50,60,120,180,240) + public byte byRes1; + public short wCompensateTime; //定时模式下生效 + public byte[] byRes2 = new byte[4]; + } + + public static class NET_DVR_DDE_PARAM extends Structure { + public byte byMode;//1-Off,2-Normal Mode,3-Expert Mode + public byte byNormalLevel;//普通模式等级范围[1,100],普通模式下生效 + public byte byExpertLevel;//专家模式等级范围[1,100],专家模式下生效 + public byte[] byRes = new byte[5]; + } + + public static class NET_DVR_AGC_PARAM extends Structure { + public byte bySceneType;//1-Normal Sence,2-Highlight Sence,3-Manual Sence + public byte byLightLevel;//亮度等级[1,100];手动模式下生效 + public byte byGainLevel; //增益等级[1,100];手动模式下生效 + public byte[] byRes = new byte[5]; + } + + public static class NET_DVR_SNAP_CAMERAPARAMCFG extends Structure { + public byte byWDRMode; // 宽动态模式;0~关闭,1~数字宽动态 2~宽动态 + public byte byWDRType; // 宽动态切换模式; 0~强制启用,1~按时间启用,2~按亮度启用 + public byte byWDRLevel; // 宽动态等级,0~6索引对应1-7,默认索引2(即3级); + public byte byRes1; + public NET_DVR_TIME_EX struStartTime = new NET_DVR_TIME_EX(); //开始宽动态时间 + public NET_DVR_TIME_EX struEndTime = new NET_DVR_TIME_EX(); //结束宽动态时间 + public byte byDayNightBrightness; //日夜转换亮度阈值,0-100,默认50; + //记忆色增强 + public byte byMCEEnabled;//记忆色增强使能,true:开启,false:关闭 + public byte byMCELevel;//记忆色增强强度,0~100,默认值50 + //自动对比度 + public byte byAutoContrastEnabled;//自动对比度使能,true:开启,false:关闭 + public byte byAutoContrastLevel;//自动对比等级(0-100),默认50 + //细节增强 + public byte byLSEDetailEnabled;//细节增强使能,true:开启,false:关闭 + public byte byLSEDetailLevel;//细节增强等级(0-100),默认50 + // License Plate Definition Enhancement车牌增强 + public byte byLPDEEnabled;//车牌增强使能,true:开启,false:关闭 + public byte byLPDELevel;//车牌增强等级(0-100),默认50 + //对比度增强 + public byte byLseEnabled; //对比度增强使能,true:开启,false:关闭 + public byte byLseLevel; //对比度增强等级(0-100),默认0 + public byte byLSEHaloLevel;//光晕抑制等级。范围 0-100,默认0 + public byte byLseType; //对比度增强切换模式; 0~强制启用,1~按时间启用,2~按亮度启用(该字段可同时控制byLseLevel、byLSEHaloLevel两个参数) + public byte[] byRes2 = new byte[3]; + public NET_DVR_TIME_EX struLSEStartTime = new NET_DVR_TIME_EX(); //开始对比度增强时间(当byLseType为1时生效) + public NET_DVR_TIME_EX struLSEEndTime = new NET_DVR_TIME_EX(); //结束对比度增强时间(当byLseType为1时生效) + public byte byLightLevel;//为亮度等级参数(0-100),默认0,(当byLseType为2时生效) + //车牌对比度 + public byte byPlateContrastLevel;//车牌对比度等级,0~100,默认0 + //车牌饱和度 + public byte byPlateSaturationLevel;//车牌饱和度等级,0~100,默认0 + public byte[] byRes = new byte[9]; + } + + public static class NET_DVR_OPTICAL_DEHAZE extends Structure { + public byte byEnable; //0~不启用光学透雾,1~启用光学透雾 + public byte[] byRes = new byte[7]; + } + + public static class NET_DVR_THERMOMETRY_AGC extends Structure { + public byte byMode;//AGC模式,0~无效,1~自动,2~手动 + public byte byRes1[] = new byte[3]; + public int iHighTemperature;//最高温度,范围为:-273~9999摄氏度(1~手动模式下生效) + public int iLowTemperature;//最低温度,范围为:-273~9999摄氏度(1~手动模式下生效) + public byte[] byRes = new byte[8]; + } + + public static class NET_DVR_CHECK_DEV_STATE extends Structure { + public int dwTimeout; //定时检测设备工作状态,单位ms,为0时,表示使用默认值(30000)。最小值为1000 + public DEV_WORK_STATE_CB fnStateCB; + Pointer pUserData; + public byte[] byRes = new byte[60]; + } + + public static class NET_DVR_FLOW_INFO extends Structure { + public int dwSize; //结构大小 + public int dwSendFlowSize; //发送流量大小,单位kbps + public int dwRecvFlowSize; //接收流量大小,单位kbps + public byte[] byRes = new byte[20]; //保留 + } + + public static class NET_DVR_AES_KEY_INFO extends Structure { + public byte[] sAESKey = new byte[16]; /*码流加密密钥*/ + public byte[] byRes = new byte[64]; /*保留字节*/ + } + + public static class NET_DVR_ALARM_RS485CFG extends Structure { + public int dwSize; // 结构体大小 + public byte[] sDeviceName = new byte[NAME_LEN]; // 前端设备名称 + public short wDeviceType; // 前端设备类型,通过NET_DVR_GetDeviceTypeList获取 + public short wDeviceProtocol; // 前端设备协议 通过获取协议列表获取 + public int dwBaudRate; //波特率(bps),0-50,1-75,2-110,3-150,4-300,5-600,6-1200,7-2400,8-4800,9-9600,10-19200,11-38400,12-57600,13-76800,14-115.2k + public byte byDataBit; // 数据有几位:0-5位,1-6位,2-7位,3-8位 + public byte byStopBit; // 停止位:0-1位,1-2位 + public byte byParity; //是否校验:0-无校验,1-奇校验,2-偶校验 + public byte byFlowcontrol; // 是否流控:0-无,1-软流控,2-硬流控 + public byte byDuplex; // 0 - 半双工1- 全双工 只有通道1可以是全双工其他都只能是半双工 + public byte byWorkMode; // 工作模式 0-控制台 1-透明通道,2-梯控,3-读卡器,4-门禁安全模块,0xfe-自定义,0xff-禁用 + public byte byChannel; //485通道号 + public byte bySerialType; //串口类型: 0--485, 1--232 + public byte byMode; //模式 0-连接读卡器 1-连接客户端 2-连接扩展模块 3-连接门禁主机 4-连接梯控主机 0xff-禁用 + public byte byOutputDataType; //0-无效,1-输出卡号,2-输出工号 + public byte byAddress; //串口地址 + public byte[] byRes = new byte[33]; // 保留字节 + } + + public static class NET_DVR_ALARMHOST_RS485_SLOT_CFG extends Structure { + public int dwSize; // 结构体大小 + public byte[] sDeviceName = new byte[NAME_LEN]; // 前端设备名称 + public short wDeviceType; // 前端设备类型ALARM_FRONT_DEVICE _TYPE + public byte wDeviceProtocol; // 前端设备协议 通过获取协议列表获取 + public short wAddress; //设备地址 + public byte byChannel; //485通道号 + public byte bySlotChan; //槽位号 + public byte[] byRes = new byte[60]; // 保留字节 + } + + + public static class NET_DVR_VIDEOWALLDISPLAYPOSITION extends Structure { + public int dwSize; + public byte byEnable; + public byte byCoordinateType;//坐标类型。0-基准坐标,1-实际坐标 + public byte[] byRes1 = new byte[2]; + //墙号,1字节墙号(高字节,对于合码器设备,为合码通道号)+3字节保留 + public int dwVideoWallNo; + public int dwDisplayNo;//显示输出号 + //坐标须为基准坐标的整数倍(1920*1920),宽度和高度值不用设置,即为基准值 + public NET_DVR_RECTCFG_EX struRectCfg; + public byte[] byRes2 = new byte[64]; + } + + public static final int MAX_DISPLAY_NUM = 512; //最大显示输出个数 + + public static class NET_DVR_DISPLAYCFG extends Structure { + public int dwSize; + public NET_DVR_DISPLAYPARAM[] struDisplayParam = new NET_DVR_DISPLAYPARAM[MAX_DISPLAY_NUM]; + public byte[] byRes2 = new byte[128]; + } + + public static class NET_DVR_DISPLAYPARAM extends Structure { + public int dwDisplayNo; + public byte byDispChanType; + public byte[] byRes = new byte[11]; + } + + public static class NET_DVR_WALLOUTPUTPARAM extends Structure { + public int dwSize; + public int dwResolution; //分辨率 + public NET_DVR_VIDEOEFFECT struRes; + public byte byVideoFormat; //视频制式,见VIDEO_STANDARD + public byte byDisplayMode;/*输出连接模式,1-BNC,2-VGA,3-HDMI,4-DVI,5-SDI, 6-FIBER, 7-RGB, 8-YPrPb, 9-VGA/HDMI/DVI自适应,0xff-无效*/ + public byte byBackgroundColor; //背景色,0-无效,不支持背景色,1-红,2-绿,3-蓝,4-黄,5-紫,6-青,7-黑,8-白,0xff-自定义 + public byte byUseEDIDResolution; //是否使用EDID分辨率,0-不使用,1-使用 + public short wLEDWidth; //LED屏输出分辨率宽 + public short wLEDHeight; //LED屏输出分辨率高 + public NET_DVR_RGB_COLOR struBackColor;//背景色,byBackgroundColor为0xff时有效 + public byte byLinkStatus;//输出口连接状态,0-无效,1-接入显示器,2-未接入显示器 + public byte[] byRes2 = new byte[51]; + } + + public static class WALLOUTPUTPARAM_ARRAY extends Structure { + public NET_DVR_WALLOUTPUTPARAM[] strWalloutputParm; + + public WALLOUTPUTPARAM_ARRAY(int iLen) { + strWalloutputParm = new NET_DVR_WALLOUTPUTPARAM[iLen]; + } + + } + + + /*** + * API函数声明,详细说明见API手册 + ***/ + public static interface FRealDataCallBack_V30 extends Callback { + public void invoke(int lRealHandle, int dwDataType, + ByteByReference pBuffer, int dwBufSize, Pointer pUser); + } + + public static interface FMSGCallBack extends Callback { + public void invoke(int lCommand, NET_DVR_ALARMER pAlarmer, Pointer pAlarmInfo, int dwBufLen, Pointer pUser); + } + + public static interface FMSGCallBack_V31 extends Callback { + public boolean invoke(int lCommand, NET_DVR_ALARMER pAlarmer, Pointer pAlarmInfo, int dwBufLen, Pointer pUser); + } + + public static interface FMessCallBack extends Callback { + public boolean invoke(int lCommand, String sDVRIP, String pBuf, int dwBufLen); + } + + public static interface FMessCallBack_EX extends Callback { + public boolean invoke(int lCommand, int lUserID, String pBuf, int dwBufLen); + } + + public static interface FMessCallBack_NEW extends Callback { + public boolean invoke(int lCommand, String sDVRIP, String pBuf, int dwBufLen, short dwLinkDVRPort); + } + + public static interface FMessageCallBack extends Callback { + public boolean invoke(int lCommand, String sDVRIP, String pBuf, int dwBufLen, int dwUser); + } + + public static interface FExceptionCallBack extends Callback { + public void invoke(int dwType, int lUserID, int lHandle, Pointer pUser); + } + +// public static interface FDrawFun extends Callback { +// public void invoke(int lRealHandle, W32API.HDC hDc, int dwUser); +// } + + public static interface FStdDataCallBack extends Callback { + public void invoke(int lRealHandle, int dwDataType, ByteByReference pBuffer, int dwBufSize, int dwUser); + } + + public static interface FPlayDataCallBack extends Callback { + public void invoke(int lPlayHandle, int dwDataType, ByteByReference pBuffer, int dwBufSize, int dwUser); + } + + public static interface FPlayESCallBack extends Callback { + public void invoke(int lPlayHandle, NET_DVR_PACKET_INFO_EX struPackInfo, Pointer pUser); + } + + public static interface FVoiceDataCallBack extends Callback { + public void invoke(int lVoiceComHandle, Pointer pRecvDataBuffer, int dwBufSize, byte byAudioFlag, int dwUser); + } + + public static interface FVoiceDataCallBack_V30 extends Callback { + public void invoke(int lVoiceComHandle, Pointer pRecvDataBuffer, int dwBufSize, byte byAudioFlag, int pUser); + } + + public static interface FVoiceDataCallBack_MR extends Callback { + public void invoke(int lVoiceComHandle, Pointer pRecvDataBuffer, int dwBufSize, byte byAudioFlag, int dwUser); + } + + + public static interface FVoiceDataCallBack2 extends Callback { + public void invoke(String pRecvDataBuffer, int dwBufSize, Pointer pUser); + } + + public static interface FSerialDataCallBack extends Callback { + public void invoke(int lSerialHandle, String pRecvDataBuffer, int dwBufSize, int dwUser); + } + + public static interface FRowDataCallBack extends Callback { + public void invoke(int lUserID, String sIPAddr, int lRowAmout, String pRecvDataBuffer, int dwBufSize, int dwUser); + } + + public static interface FColLocalDataCallBack extends Callback { + public void invoke(int lUserID, String sIPAddr, int lColumnAmout, String pRecvDataBuffer, int dwBufSize, int dwUser); + } + + public static interface FColGlobalDataCallBack extends Callback { + public void invoke(int lUserID, String sIPAddr, int lColumnAmout, String pRecvDataBuffer, int dwBufSize, int dwUser); + } + + public static interface FJpegdataCallBack extends Callback { + public int invoke(int lCommand, int lUserID, String sDVRIP, String sJpegName, String pJpegBuf, int dwBufLen, int dwUser); + } + + public static interface FPostMessageCallBack extends Callback { + public int invoke(int dwType, int lIndex); + } + + public static interface DEV_WORK_STATE_CB extends Callback { + public boolean invoke(Pointer pUserdata, int iUserID, NET_DVR_WORKSTATE_V40 lpWorkState); + } + + public static interface FLOWTESTCALLBACK extends Callback { + public void invoke(int lFlowHandle, NET_DVR_FLOW_INFO pFlowInfo, + Pointer pUser); + } + public static interface FVoiceDataCallback_MR_V30 extends Callback { + public void invoke(int lVoiceComHandle, Pointer pRecvDataBuffer, int dwBufSize, byte byAudioFlag, Pointer pUser); + } + + + boolean NET_DVR_Init(); + + boolean NET_DVR_Cleanup(); + + boolean NET_DVR_SetSDKInitCfg(int enumType, Pointer lpInBuff); + + boolean NET_DVR_SetSDKLocalCfg(int enumType, Pointer lpInBuff); + + boolean NET_DVR_GetSDKLocalCfg(int enumType, Pointer lpOutBuff); + + boolean NET_DVR_SetDVRMessage(int nMessage, int hWnd); + + //NET_DVR_SetDVRMessage的扩展 + boolean NET_DVR_SetExceptionCallBack_V30(int nMessage, int hWnd, FExceptionCallBack fExceptionCallBack, Pointer pUser); + + boolean NET_DVR_SetDVRMessCallBack(FMessCallBack fMessCallBack); + + boolean NET_DVR_SetDVRMessCallBack_EX(FMessCallBack_EX fMessCallBack_EX); + + + //2007-04-16增加查询结果带卡号的文件查找 + int NET_DVR_FindNextFile_Card(int lFindHandle, NET_DVR_FINDDATA_CARD lpFindData); + + int NET_DVR_FindFile_Card(int lUserID, int lChannel, int dwFileType, NET_DVR_TIME lpStartTime, NET_DVR_TIME lpStopTime); + + boolean NET_DVR_LockFileByName(int lUserID, String sLockFileName); + + boolean NET_DVR_UnlockFileByName(int lUserID, String sUnlockFileName); + + //int NET_DVR_PlayBackByName(int lUserID, String sPlayBackFileName, HWND hWnd); + + //int NET_DVR_PlayBackByTime(int lUserID, int lChannel, NET_DVR_TIME lpStartTime, NET_DVR_TIME lpStopTime, HWND hWnd); + + //int NET_DVR_PlayBackByTime_V40(int lUserID, NET_DVR_VOD_PARA pVodPara); + + boolean NET_DVR_PlayBackControl(int lPlayHandle, int dwControlCode, int dwInValue, IntByReference LPOutValue); + + boolean NET_DVR_PlayBackControl_V40(int lPlayHandle, int dwControlCode, Pointer lpInBuffer, int dwInLen, Pointer lpOutBuffer, IntByReference lpOutLen); + + boolean NET_DVR_StopPlayBack(int lPlayHandle); + + boolean NET_DVR_SetPlayDataCallBack(int lPlayHandle, FPlayDataCallBack fPlayDataCallBack, int dwUser); + + boolean NET_DVR_SetPlayBackESCallBack(int lPlayHandle, FPlayESCallBack fPlayESCallBack, Pointer pUser); + + boolean NET_DVR_PlayBackSaveData(int lPlayHandle, String sFileName); + + boolean NET_DVR_StopPlayBackSave(int lPlayHandle); + + boolean NET_DVR_GetPlayBackOsdTime(int lPlayHandle, NET_DVR_TIME lpOsdTime); + + boolean NET_DVR_PlayBackCaptureFile(int lPlayHandle, String sFileName); + + int NET_DVR_GetFileByName(int lUserID, String sDVRFileName, byte[] sSavedFileName); + + int NET_DVR_GetFileByTime(int lUserID, int lChannel, NET_DVR_TIME lpStartTime, NET_DVR_TIME lpStopTime, String sSavedFileName); + + int NET_DVR_GetFileByTime_V40(int lUserID, String sSavedFileName, NET_DVR_PLAYCOND pDownloadCond); + + boolean NET_DVR_StopGetFile(int lFileHandle); + + int NET_DVR_GetDownloadPos(int lFileHandle); + + int NET_DVR_GetPlayBackPos(int lPlayHandle); + + //图片查找 + int NET_DVR_FindPicture(int lUserID, NET_DVR_FIND_PICTURE_PARAM pFindParam); + + int NET_DVR_FindNextPicture_V50(int lFindHandle, NET_DVR_FIND_PICTURE_V50 lpFindData); + + int NET_DVR_FindNextPicture(int lFindHandle, NET_DVR_FIND_PICTURE lpFindData); + + boolean NET_DVR_CloseFindPicture(int lFindHandle); + + boolean NET_DVR_GetPicture_V50(int lUserID, NET_DVR_PIC_PARAM lpPicParam); + + boolean NET_DVR_SetDVRMessCallBack_NEW(FMessCallBack_NEW fMessCallBack_NEW); + + + boolean NET_DVR_SetDVRMessageCallBack(FMessageCallBack fMessageCallBack, int dwUser); + + boolean NET_DVR_SetDVRMessageCallBack_V30(FMSGCallBack fMessageCallBack, Pointer pUser); + + boolean NET_DVR_SetDVRMessageCallBack_V31(FMSGCallBack_V31 fMessageCallBack, Pointer pUser); + + boolean NET_DVR_SetDVRMessageCallBack_V50(int iIndex, FMSGCallBack_V31 fMessageCallBack, Pointer pUser); + + boolean NET_DVR_SetConnectTime(int dwWaitTime, int dwTryTimes); + + boolean NET_DVR_SetReconnect(int dwInterval, boolean bEnableRecon); + + int NET_DVR_GetSDKVersion(); + + int NET_DVR_GetSDKBuildVersion(); + + int NET_DVR_IsSupport(); + + boolean NET_DVR_StartListen(String sLocalIP, short wLocalPort); + + boolean NET_DVR_StopListen(); + + int NET_DVR_StartListen_V30(String sLocalIP, short wLocalPort, FMSGCallBack_V31 DataCallBack, Pointer pUserData); + + boolean NET_DVR_StopListen_V30(int lListenHandle); + + int NET_DVR_Login(String sDVRIP, short wDVRPort, String sUserName, String sPassword, NET_DVR_DEVICEINFO lpDeviceInfo); + + int NET_DVR_Login_V30(String sDVRIP, short wDVRPort, String sUserName, String sPassword, NET_DVR_DEVICEINFO_V30 lpDeviceInfo); + + int NET_DVR_Login_V40(NET_DVR_USER_LOGIN_INFO pLoginInfo, NET_DVR_DEVICEINFO_V40 lpDeviceInfo); + + boolean NET_DVR_Logout(int lUserID); + + boolean NET_DVR_Logout_V30(int lUserID); + + int NET_DVR_GetLastError(); + + String NET_DVR_GetErrorMsg(IntByReference pErrorNo); + + boolean NET_DVR_SetShowMode(int dwShowType, int colorKey); + + boolean NET_DVR_GetDVRIPByResolveSvr(String sServerIP, short wServerPort, String sDVRName, short wDVRNameLen, String sDVRSerialNumber, short wDVRSerialLen, String sGetIP); + + boolean NET_DVR_GetDVRIPByResolveSvr_EX(String sServerIP, short wServerPort, String sDVRName, short wDVRNameLen, String sDVRSerialNumber, short wDVRSerialLen, String sGetIP, IntByReference dwPort); + + //预览相关接口 + //int NET_DVR_RealPlay(int lUserID, NET_DVR_CLIENTINFO lpClientInfo); + + //int NET_DVR_RealPlay_V30(int lUserID, NET_DVR_CLIENTINFO lpClientInfo, FRealDataCallBack_V30 fRealDataCallBack_V30, Pointer pUser, boolean bBlocked); + + //int NET_DVR_RealPlay_V40(int lUserID, NET_DVR_PREVIEWINFO lpPreviewInfo, FRealDataCallBack_V30 fRealDataCallBack_V30, Pointer pUser); + + boolean NET_DVR_StopRealPlay(int lRealHandle); +// +// boolean NET_DVR_RigisterDrawFun(int lRealHandle, FDrawFun fDrawFun, int dwUser); + + boolean NET_DVR_SetPlayerBufNumber(int lRealHandle, int dwBufNum); + + boolean NET_DVR_ThrowBFrame(int lRealHandle, int dwNum); + + boolean NET_DVR_SetAudioMode(int dwMode); + + boolean NET_DVR_OpenSound(int lRealHandle); + + boolean NET_DVR_CloseSound(); + + boolean NET_DVR_OpenSoundShare(int lRealHandle); + + boolean NET_DVR_CloseSoundShare(int lRealHandle); + + boolean NET_DVR_Volume(int lRealHandle, short wVolume); + + boolean NET_DVR_SaveRealData(int lRealHandle, String sFileName); + + boolean NET_DVR_StopSaveRealData(int lRealHandle); + + boolean NET_DVR_SetRealDataCallBack(int lRealHandle, FRowDataCallBack fRealDataCallBack, int dwUser); + + boolean NET_DVR_SetStandardDataCallBack(int lRealHandle, FStdDataCallBack fStdDataCallBack, int dwUser); + + boolean NET_DVR_CapturePicture(int lRealHandle, String sPicFileName);//bmp + + //动态生成I帧 + boolean NET_DVR_MakeKeyFrame(int lUserID, int lChannel);//主码流 + + boolean NET_DVR_MakeKeyFrameSub(int lUserID, int lChannel);//子码流 + + //云台控制相关接口 + boolean NET_DVR_PTZControl(int lRealHandle, int dwPTZCommand, int dwStop); + + boolean NET_DVR_PTZControl_Other(int lUserID, int lChannel, int dwPTZCommand, int dwStop); + + boolean NET_DVR_TransPTZ(int lRealHandle, String pPTZCodeBuf, int dwBufSize); + + boolean NET_DVR_TransPTZ_Other(int lUserID, int lChannel, String pPTZCodeBuf, int dwBufSize); + + boolean NET_DVR_PTZPreset(int lRealHandle, int dwPTZPresetCmd, int dwPresetIndex); + + boolean NET_DVR_PTZPreset_Other(int lUserID, int lChannel, int dwPTZPresetCmd, int dwPresetIndex); + + boolean NET_DVR_TransPTZ_EX(int lRealHandle, String pPTZCodeBuf, int dwBufSize); + + boolean NET_DVR_PTZControl_EX(int lRealHandle, int dwPTZCommand, int dwStop); + + boolean NET_DVR_PTZPreset_EX(int lRealHandle, int dwPTZPresetCmd, int dwPresetIndex); + + boolean NET_DVR_PTZCruise(int lRealHandle, int dwPTZCruiseCmd, byte byCruiseRoute, byte byCruisePoint, short wInput); + + boolean NET_DVR_PTZCruise_Other(int lUserID, int lChannel, int dwPTZCruiseCmd, byte byCruiseRoute, byte byCruisePoint, short wInput); + + boolean NET_DVR_PTZCruise_EX(int lRealHandle, int dwPTZCruiseCmd, byte byCruiseRoute, byte byCruisePoint, short wInput); + + boolean NET_DVR_PTZTrack(int lRealHandle, int dwPTZTrackCmd); + + boolean NET_DVR_PTZTrack_Other(int lUserID, int lChannel, int dwPTZTrackCmd); + + boolean NET_DVR_PTZTrack_EX(int lRealHandle, int dwPTZTrackCmd); + + boolean NET_DVR_PTZControlWithSpeed(int lRealHandle, int dwPTZCommand, int dwStop, int dwSpeed); + + boolean NET_DVR_PTZControlWithSpeed_Other(int lUserID, int lChannel, int dwPTZCommand, int dwStop, int dwSpeed); + + boolean NET_DVR_PTZControlWithSpeed_EX(int lRealHandle, int dwPTZCommand, int dwStop, int dwSpeed); + + boolean NET_DVR_GetPTZCruise(int lUserID, int lChannel, int lCruiseRoute, NET_DVR_CRUISE_RET lpCruiseRet); + + boolean NET_DVR_PTZMltTrack(int lRealHandle, int dwPTZTrackCmd, int dwTrackIndex); + + boolean NET_DVR_PTZMltTrack_Other(int lUserID, int lChannel, int dwPTZTrackCmd, int dwTrackIndex); + + boolean NET_DVR_PTZMltTrack_EX(int lRealHandle, int dwPTZTrackCmd, int dwTrackIndex); + + //文件查找与回放 + int NET_DVR_FindFile(int lUserID, int lChannel, int dwFileType, NET_DVR_TIME lpStartTime, NET_DVR_TIME lpStopTime); + + int NET_DVR_FindNextFile(int lFindHandle, NET_DVR_FIND_DATA lpFindData); + + boolean NET_DVR_FindClose(int lFindHandle); + + int NET_DVR_FindNextFile_V30(int lFindHandle, NET_DVR_FINDDATA_V30 lpFindData); + + int NET_DVR_FindFile_V30(int lUserID, NET_DVR_FILECOND pFindCond); + + int NET_DVR_FindFile_V40(int lUserID, NET_DVR_FILECOND_V40 pFindCond); + + int NET_DVR_FindNextFile_V40(int lFindHandle, NET_DVR_FINDDATA_V40 lpFindData); + + int NET_DVR_FindFile_V50(int lUserID, NET_DVR_FILECOND_V50 pFindCond); + + int NET_DVR_FindNextFile_V50(int lFindHandle, NET_DVR_FINDDATA_V50 lpFindData); + + boolean NET_DVR_FindClose_V30(int lFindHandle); + + //按事件查找 + int NET_DVR_FindFileByEvent(int lUserID, NET_DVR_SEARCH_EVENT_PARAM lpSearchEventParam); + + int NET_DVR_FindNextEvent(int lSearchHandle, NET_DVR_SEARCH_EVENT_RET lpSearchEventRet); + + int NET_DVR_FindFileByEvent_V50(int lUserID, NET_DVR_SEARCH_EVENT_PARAM_V50 lpSearchEventParam); + + int NET_DVR_FindNextEvent_V50(int lFindHandle, NET_DVR_SEARCH_EVENT_RET_V50 lpSearchEventRet); + + + //升级 + int NET_DVR_Upgrade(int lUserID, String sFileName); + + int NET_DVR_GetUpgradeState(int lUpgradeHandle); + + int NET_DVR_GetUpgradeProgress(int lUpgradeHandle); + + boolean NET_DVR_CloseUpgradeHandle(int lUpgradeHandle); + + boolean NET_DVR_SetNetworkEnvironment(int dwEnvironmentLevel); + + //远程格式化硬盘 + int NET_DVR_FormatDisk(int lUserID, int lDiskNumber); + + boolean NET_DVR_GetFormatProgress(int lFormatHandle, IntByReference pCurrentFormatDisk, IntByReference pCurrentDiskPos, IntByReference pFormatStatic); + + boolean NET_DVR_CloseFormatHandle(int lFormatHandle); + + //报警 + int NET_DVR_SetupAlarmChan(int lUserID); + + boolean NET_DVR_CloseAlarmChan(int lAlarmHandle); + + int NET_DVR_SetupAlarmChan_V30(int lUserID); + + int NET_DVR_SetupAlarmChan_V41(int lUserID, NET_DVR_SETUPALARM_PARAM lpSetupParam); + + int NET_DVR_SetupAlarmChan_V50(int iUserID, NET_DVR_SETUPALARM_PARAM_V50 lpSetupParam, Pointer pSub, int dwSubSize); + + boolean NET_DVR_CloseAlarmChan_V30(int lAlarmHandle); + + //语音对讲 + int NET_DVR_StartVoiceCom(int lUserID, FVoiceDataCallBack fVoiceDataCallBack, int dwUser); + + int NET_DVR_StartVoiceCom_V30(int lUserID, int dwVoiceChan, boolean bNeedCBNoEncData, FVoiceDataCallBack_V30 fVoiceDataCallBack, Pointer pUser); + + boolean NET_DVR_SetVoiceComClientVolume(int lVoiceComHandle, short wVolume); + + boolean NET_DVR_StopVoiceCom(int lVoiceComHandle); + + //语音转发 + int NET_DVR_StartVoiceCom_MR(int lUserID, FVoiceDataCallBack_MR fVoiceDataCallBack, Pointer dwUser); + + int NET_DVR_StartVoiceCom_MR_V30(int lUserID, int dwVoiceChan, FVoiceDataCallback_MR_V30 fVoiceDataCallBack, Pointer pUser); + + boolean NET_DVR_VoiceComSendData(int lVoiceComHandle, byte[] pSendBuf, int dwBufSize); + + + //语音广播 + boolean NET_DVR_ClientAudioStart(); + + boolean NET_DVR_ClientAudioStart_V30(FVoiceDataCallBack2 fVoiceDataCallBack2, Pointer pUser); + + boolean NET_DVR_ClientAudioStop(); + + boolean NET_DVR_AddDVR(int lUserID); + + int NET_DVR_AddDVR_V30(int lUserID, int dwVoiceChan); + + boolean NET_DVR_DelDVR(int lUserID); + + boolean NET_DVR_DelDVR_V30(int lVoiceHandle); + + //////////////////////////////////////////////////////////// +//透明通道设置 + int NET_DVR_SerialStart(int lUserID, int lSerialPort, FSerialDataCallBack fSerialDataCallBack, int dwUser); + + public static interface FSerialDataCallBack_V40 extends Callback { + public void invoke(int lSerialHandle, int lCHannel, byte[] pRecvDataBuffer, int dwBufSize, Pointer pUser); + } + + int NET_DVR_SerialStart_V40(int lUserID, Pointer lpInBuffer, int dwInBufferSize, FSerialDataCallBack_V40 fSerialDataCallBack_V40, Pointer pUser); + + //485作为透明通道时,需要指明通道号,因为不同通道号485的设置可以不同(比如波特率) + boolean NET_DVR_SerialSend(int lSerialHandle, int lChannel, byte[] pSendBuf, int dwBufSize); + + boolean NET_DVR_SerialStop(int lSerialHandle); + + boolean NET_DVR_SendTo232Port(int lUserID, String pSendBuf, int dwBufSize); + + boolean NET_DVR_SendToSerialPort(int lUserID, int dwSerialPort, int dwSerialIndex, String pSendBuf, int dwBufSize); + + //Win64、Linux32、Linux64 + Pointer NET_DVR_InitG722Encoder(NET_DVR_AUDIOENC_INFO enc_info); + + boolean NET_DVR_EncodeG722Frame(Pointer handle, NET_DVR_AUDIOENC_PROCESS_PARAM param); + + void NET_DVR_ReleaseG722Encoder(Pointer pEncodeHandle); + + Pointer NET_DVR_InitG722Decoder(); + + boolean NET_DVR_DecodeG722Frame(Pointer handle, NET_DVR_AUDIODEC_PROCESS_PARAM param); + + void NET_DVR_ReleaseG722Decoder(Pointer pDecHandle); + + //G711: Win64、Linux32、Linux64 + Pointer NET_DVR_InitG711Encoder(NET_DVR_AUDIOENC_INFO enc_info);//NET_DVR_AUDIOENC_INFO + + boolean NET_DVR_EncodeG711Frame(Pointer handle, NET_DVR_AUDIOENC_PROCESS_PARAM p_enc_proc_param); + + boolean NET_DVR_ReleaseG711Encoder(Pointer pEncodeHandle); + + Pointer NET_DVR_InitG711Decoder(); + + boolean NET_DVR_DecodeG711Frame(Pointer handle, NET_DVR_AUDIODEC_PROCESS_PARAM p_dec_proc_param); + + boolean NET_DVR_ReleaseG711Decoder(Pointer pDecHandle); + + //远程控制本地显示 + boolean NET_DVR_ClickKey(int lUserID, int lKeyIndex); + + //远程控制设备端手动录像 + boolean NET_DVR_StartDVRRecord(int lUserID, int lChannel, int lRecordType); + + boolean NET_DVR_StopDVRRecord(int lUserID, int lChannel); + + //解码卡 + boolean NET_DVR_InitDevice_Card(IntByReference pDeviceTotalChan); + + boolean NET_DVR_ReleaseDevice_Card(); + + boolean NET_DVR_InitDDraw_Card(int hParent, int colorKey); + + boolean NET_DVR_ReleaseDDraw_Card(); + + int NET_DVR_RealPlay_Card(int lUserID, NET_DVR_CARDINFO lpCardInfo, int lChannelNum); + + boolean NET_DVR_ResetPara_Card(int lRealHandle, NET_DVR_DISPLAY_PARA lpDisplayPara); + + boolean NET_DVR_RefreshSurface_Card(); + + boolean NET_DVR_ClearSurface_Card(); + + boolean NET_DVR_RestoreSurface_Card(); + + boolean NET_DVR_OpenSound_Card(int lRealHandle); + + boolean NET_DVR_CloseSound_Card(int lRealHandle); + + boolean NET_DVR_SetVolume_Card(int lRealHandle, short wVolume); + + boolean NET_DVR_AudioPreview_Card(int lRealHandle, boolean bEnable); + + int NET_DVR_GetCardLastError_Card(); + + Pointer NET_DVR_GetChanHandle_Card(int lRealHandle); + + boolean NET_DVR_CapturePicture_Card(int lRealHandle, String sPicFileName); + + //获取解码卡序列号此接口无效,改用GetBoardDetail接口获得(2005-12-08支持) + boolean NET_DVR_GetSerialNum_Card(int lChannelNum, IntByReference pDeviceSerialNo); + + //日志 + int NET_DVR_FindDVRLog(int lUserID, int lSelectMode, int dwMajorType, int dwMinorType, NET_DVR_TIME lpStartTime, NET_DVR_TIME lpStopTime); + + int NET_DVR_FindNextLog(int lLogHandle, NET_DVR_LOG lpLogData); + + boolean NET_DVR_FindLogClose(int lLogHandle); + + int NET_DVR_FindDVRLog_V30(int lUserID, int lSelectMode, int dwMajorType, int dwMinorType, NET_DVR_TIME lpStartTime, NET_DVR_TIME lpStopTime, boolean bOnlySmart); + + int NET_DVR_FindNextLog_V30(int lLogHandle, NET_DVR_LOG_V30 lpLogData); + + boolean NET_DVR_FindLogClose_V30(int lLogHandle); + + //截止2004年8月5日,共113个接口 +//ATM DVR + int NET_DVR_FindFileByCard(int lUserID, int lChannel, int dwFileType, int nFindType, String sCardNumber, NET_DVR_TIME lpStartTime, NET_DVR_TIME lpStopTime); +//截止2004年10月5日,共116个接口 + + //2005-09-15 + boolean NET_DVR_CaptureJPEGPicture(int lUserID, int lChannel, NET_DVR_JPEGPARA lpJpegPara, byte[] sPicFileName); + + //JPEG抓图到内存 + boolean NET_DVR_CaptureJPEGPicture_NEW(int lUserID, int lChannel, NET_DVR_JPEGPARA lpJpegPara, Pointer sJpegPicBuffer, int dwPicSize, IntByReference lpSizeReturned); + + //带全屏测温数据的设备抓图 + boolean NET_DVR_CaptureJPEGPicture_WithAppendData(int lUserID, int iChannelNum, NET_DVR_JPEGPICTURE_WITH_APPENDDATA m_strJpegWithAppendData); + + //2006-02-16 + int NET_DVR_GetRealPlayerIndex(int lRealHandle); + + int NET_DVR_GetPlayBackPlayerIndex(int lPlayHandle); + + //2006-08-28 704-640 缩放配置 + boolean NET_DVR_SetScaleCFG(int lUserID, int dwScale); + + boolean NET_DVR_GetScaleCFG(int lUserID, IntByReference lpOutScale); + + boolean NET_DVR_SetScaleCFG_V30(int lUserID, NET_DVR_SCALECFG pScalecfg); + + boolean NET_DVR_GetScaleCFG_V30(int lUserID, NET_DVR_SCALECFG pScalecfg); + + //2006-08-28 ATM机端口设置 + boolean NET_DVR_SetATMPortCFG(int lUserID, short wATMPort); + + boolean NET_DVR_GetATMPortCFG(int lUserID, ShortByReference LPOutATMPort); + + //2006-11-10 支持显卡辅助输出 + boolean NET_DVR_InitDDrawDevice(); + + boolean NET_DVR_ReleaseDDrawDevice(); + + int NET_DVR_GetDDrawDeviceTotalNums(); + + boolean NET_DVR_SetDDrawDevice(int lPlayPort, int nDeviceNum); + + boolean NET_DVR_PTZSelZoomIn(int lRealHandle, NET_DVR_POINT_FRAME pStruPointFrame); + + boolean NET_DVR_PTZSelZoomIn_EX(int lUserID, int lChannel, NET_DVR_POINT_FRAME pStruPointFrame); + + boolean NET_DVR_FocusOnePush(int lUserID, int lChannel); + + //解码设备DS-6001D/DS-6001F + boolean NET_DVR_StartDecode(int lUserID, int lChannel, NET_DVR_DECODERINFO lpDecoderinfo); + + boolean NET_DVR_StopDecode(int lUserID, int lChannel); + + boolean NET_DVR_GetDecoderState(int lUserID, int lChannel, NET_DVR_DECODERSTATE lpDecoderState); + + //2005-08-01 + boolean NET_DVR_SetDecInfo(int lUserID, int lChannel, NET_DVR_DECCFG lpDecoderinfo); + + boolean NET_DVR_GetDecInfo(int lUserID, int lChannel, NET_DVR_DECCFG lpDecoderinfo); + + boolean NET_DVR_SetDecTransPort(int lUserID, NET_DVR_PORTCFG lpTransPort); + + boolean NET_DVR_GetDecTransPort(int lUserID, NET_DVR_PORTCFG lpTransPort); + + boolean NET_DVR_DecPlayBackCtrl(int lUserID, int lChannel, int dwControlCode, int dwInValue, IntByReference LPOutValue, NET_DVR_PLAYREMOTEFILE lpRemoteFileInfo); + + boolean NET_DVR_StartDecSpecialCon(int lUserID, int lChannel, NET_DVR_DECCHANINFO lpDecChanInfo); + + boolean NET_DVR_StopDecSpecialCon(int lUserID, int lChannel, NET_DVR_DECCHANINFO lpDecChanInfo); + + boolean NET_DVR_DecCtrlDec(int lUserID, int lChannel, int dwControlCode); + + boolean NET_DVR_DecCtrlScreen(int lUserID, int lChannel, int dwControl); + + boolean NET_DVR_GetDecCurLinkStatus(int lUserID, int lChannel, NET_DVR_DECSTATUS lpDecStatus); + + //多路解码器 +//2007-11-30 V211支持以下接口 //11 + boolean NET_DVR_MatrixStartDynamic(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_DYNAMIC_DEC lpDynamicInfo); + + boolean NET_DVR_MatrixStopDynamic(int lUserID, int dwDecChanNum); + + boolean NET_DVR_MatrixGetDecChanInfo(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_DEC_CHAN_INFO lpInter); + + boolean NET_DVR_MatrixSetLoopDecChanInfo(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_LOOP_DECINFO lpInter); + + boolean NET_DVR_MatrixGetLoopDecChanInfo(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_LOOP_DECINFO lpInter); + + boolean NET_DVR_MatrixSetLoopDecChanEnable(int lUserID, int dwDecChanNum, int dwEnable); + + boolean NET_DVR_MatrixGetLoopDecChanEnable(int lUserID, int dwDecChanNum, IntByReference lpdwEnable); + + boolean NET_DVR_MatrixGetLoopDecEnable(int lUserID, IntByReference lpdwEnable); + + boolean NET_DVR_MatrixSetDecChanEnable(int lUserID, int dwDecChanNum, int dwEnable); + + boolean NET_DVR_MatrixGetDecChanEnable(int lUserID, int dwDecChanNum, IntByReference lpdwEnable); + + boolean NET_DVR_MatrixGetDecChanStatus(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_DEC_CHAN_STATUS lpInter); + + boolean NET_DVR_MatrixStartDynamic_V41(int lUserID, int dwDecChanNum, Pointer lpDynamicInfo); + + boolean NET_DVR_MatrixGetLoopDecChanInfo_V41(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_LOOP_DECINFO_V41 lpOuter); + + boolean NET_DVR_MatrixSetLoopDecChanInfo_V41(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_LOOP_DECINFO_V41 lpInter); + int NET_DVR_MatrixStartPassiveDecode(int lUserID, int dwDecChanNum, Pointer lpPassiveMode); + boolean NET_DVR_MatrixSendData(int lPassiveHandle, Pointer pSendBuf, int dwBufSize); + boolean NET_DVR_MatrixStopPassiveDecode(int lPassiveHandle); + + //2007-12-22 增加支持接口 //18 + boolean NET_DVR_MatrixSetTranInfo(int lUserID, NET_DVR_MATRIX_TRAN_CHAN_CONFIG lpTranInfo); + + boolean NET_DVR_MatrixGetTranInfo(int lUserID, NET_DVR_MATRIX_TRAN_CHAN_CONFIG lpTranInfo); + + boolean NET_DVR_MatrixSetRemotePlay(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_DEC_REMOTE_PLAY lpInter); + + boolean NET_DVR_MatrixSetRemotePlayControl(int lUserID, int dwDecChanNum, int dwControlCode, int dwInValue, IntByReference LPOutValue); + + boolean NET_DVR_MatrixGetRemotePlayStatus(int lUserID, int dwDecChanNum, NET_DVR_MATRIX_DEC_REMOTE_PLAY_STATUS lpOuter); + + //end + boolean NET_DVR_RefreshPlay(int lPlayHandle); + + //恢复默认值 + boolean NET_DVR_RestoreConfig(int lUserID); + + //保存参数 + boolean NET_DVR_SaveConfig(int lUserID); + + //重启 + boolean NET_DVR_RebootDVR(int lUserID); + + //关闭DVR + boolean NET_DVR_ShutDownDVR(int lUserID); + + //参数配置 begin + boolean NET_DVR_GetDeviceConfig(int lUserID, int dwCommand, int dwCount, Pointer lpInBuffer, int dwInBufferSize, Pointer lpStatusList, Pointer lpOutBuffer, int dwOutBufferSize); + + boolean NET_DVR_SetDeviceConfig(int lUserID, int dwCommand, int dwCount, Pointer lpInBuffer, int dwInBufferSize, Pointer lpStatusList, Pointer lpInParamBuffer, int dwInParamBufferSize); + + boolean NET_DVR_SetDeviceConfigEx(int lUserID, int dwCommand, int dwCount, Pointer lpInParam, Pointer lpOutParam); + + boolean NET_DVR_GetDVRConfig(int lUserID, int dwCommand, int lChannel, Pointer lpOutBuffer, int dwOutBufferSize, IntByReference lpBytesReturned); + + boolean NET_DVR_SetDVRConfig(int lUserID, int dwCommand, int lChannel, Pointer lpInBuffer, int dwInBufferSize); + + boolean NET_DVR_GetSTDConfig(int lUserID, int dwCommand, NET_DVR_STD_CONFIG lpConfigParam); + + boolean NET_DVR_SetSTDConfig(int lUserID, int dwCommand, NET_DVR_STD_CONFIG lpConfigParam); + + boolean NET_DVR_GetDVRWorkState_V30(int lUserID, NET_DVR_WORKSTATE_V30 lpWorkState); + + boolean NET_DVR_GetDVRWorkState(int lUserID, NET_DVR_WORKSTATE lpWorkState); + + boolean NET_DVR_SetVideoEffect(int lUserID, int lChannel, int dwBrightValue, int dwContrastValue, int dwSaturationValue, int dwHueValue); + + boolean NET_DVR_GetVideoEffect(int lUserID, int lChannel, IntByReference pBrightValue, IntByReference pContrastValue, IntByReference pSaturationValue, IntByReference pHueValue); + + boolean NET_DVR_ClientGetframeformat(int lUserID, NET_DVR_FRAMEFORMAT lpFrameFormat); + + boolean NET_DVR_ClientSetframeformat(int lUserID, NET_DVR_FRAMEFORMAT lpFrameFormat); + + boolean NET_DVR_ClientGetframeformat_V30(int lUserID, NET_DVR_FRAMEFORMAT_V30 lpFrameFormat); + + boolean NET_DVR_ClientSetframeformat_V30(int lUserID, NET_DVR_FRAMEFORMAT_V30 lpFrameFormat); + + boolean NET_DVR_GetAlarmOut_V30(int lUserID, NET_DVR_ALARMOUTSTATUS_V30 lpAlarmOutState); + + boolean NET_DVR_GetAlarmOut(int lUserID, NET_DVR_ALARMOUTSTATUS lpAlarmOutState); + + boolean NET_DVR_SetAlarmOut(int lUserID, int lAlarmOutPort, int lAlarmOutStatic); + + //视频参数调节 + boolean NET_DVR_ClientSetVideoEffect(int lRealHandle, int dwBrightValue, int dwContrastValue, int dwSaturationValue, int dwHueValue); + + boolean NET_DVR_ClientGetVideoEffect(int lRealHandle, IntByReference pBrightValue, IntByReference pContrastValue, IntByReference pSaturationValue, IntByReference pHueValue); + + //配置文件 + boolean NET_DVR_GetConfigFile(int lUserID, String sFileName); + + boolean NET_DVR_SetConfigFile(int lUserID, String sFileName); + + boolean NET_DVR_GetConfigFile_V30(int lUserID, String sOutBuffer, int dwOutSize, IntByReference pReturnSize); + + boolean NET_DVR_GetConfigFile_EX(int lUserID, String sOutBuffer, int dwOutSize); + + boolean NET_DVR_SetConfigFile_EX(int lUserID, String sInBuffer, int dwInSize); + + //启用日志文件写入接口 + boolean NET_DVR_SetLogToFile(int bLogEnable, String strLogDir, boolean bAutoDel); + + boolean NET_DVR_GetSDKState(NET_DVR_SDKSTATE pSDKState); + + boolean NET_DVR_GetSDKAbility(NET_DVR_SDKABL pSDKAbl); + + boolean NET_DVR_GetPTZProtocol(int lUserID, NET_DVR_PTZCFG pPtzcfg); + + //前面板锁定 + boolean NET_DVR_LockPanel(int lUserID); + + boolean NET_DVR_UnLockPanel(int lUserID); + + boolean NET_DVR_SetRtspConfig(int lUserID, int dwCommand, NET_DVR_RTSPCFG lpInBuffer, int dwInBufferSize); + + boolean NET_DVR_GetRtspConfig(int lUserID, int dwCommand, NET_DVR_RTSPCFG lpOutBuffer, int dwOutBufferSize); + + boolean NET_DVR_ContinuousShoot(int lUserID, NET_DVR_SNAPCFG lpInter); + + boolean NET_DVR_ManualSnap(int lUserID, NET_DVR_MANUALSNAP lpInter, NET_DVR_PLATE_RESULT lpOuter); + + public static interface FRemoteConfigCallBack extends Callback { + public void invoke(int dwType, Pointer lpBuffer, int dwBufLen, Pointer pUserData); + } + + int NET_DVR_StartRemoteConfig(int lUserID, int dwCommand, Pointer lpInBuffer, int dwInBufferLen, FRemoteConfigCallBack cbStateCallBack, Pointer pUserData); + + boolean NET_DVR_SendRemoteConfig(int lHandle, int dwDataType, Pointer pSendBuf, int dwBufSize); + + int NET_DVR_GetNextRemoteConfig(int lHandle, Pointer lpOutBuff, int dwOutBuffSize); + + int NET_DVR_SendWithRecvRemoteConfig(int lHandle, Pointer lpInBuff, int dwInBuffSize, Pointer lpOutBuff, int dwOutBuffSize, IntByReference dwOutDataLen); + + boolean NET_DVR_StopRemoteConfig(int lHandle); + + boolean NET_DVR_RemoteControl(int lUserID, int dwCommand, Pointer lpInBuffer, int dwInBufferSize); + + boolean NET_DVR_STDXMLConfig(int lUserID, NET_DVR_XML_CONFIG_INPUT lpInputParam, NET_DVR_XML_CONFIG_OUTPUT lpOutputParam); + + boolean NET_DVR_GetSTDAbility(int lUserID, int dwAbilityType, NET_DVR_STD_ABILITY lpAbilityParam); + + boolean NET_DVR_GetDeviceAbility(int lUserID, int dwAbilityType, Pointer pInBuf, int dwInLength, Pointer pOutBuf, int dwOutLength); + + boolean NET_DVR_ControlGateway(int lUserID, int lGatewayIndex, int dwStaic); + + boolean NET_DVR_InquestStartCDW_V30(int lUserID, NET_DVR_INQUEST_ROOM lpInquestRoom, boolean bNotBurn); + + boolean NET_DVR_InquestStopCDW_V30(int lUserID, NET_DVR_INQUEST_ROOM lpInquestRoom, boolean bCancelWrite); + + boolean NET_DVR_GetArrayList(int lUserID, NET_DVR_ARRAY_LIST lpArrayList); + + int NET_DVR_InquestResumeEvent(int lUserID, NET_DVR_INQUEST_RESUME_EVENT lpResumeEvent); + + boolean NET_DVR_InquestGetResumeProgress(int lHandle, IntByReference pState); + + boolean NET_DVR_InquestStopResume(int lHandle); + + boolean NET_DVR_GetLocalIP(byte[] strIP, IntByReference pValidNum, boolean pEnableBind); + + boolean NET_DVR_SetValidIP(int dwIPIndex, boolean bEnableBind); + + boolean NET_DVR_AlarmHostAssistantControl(int lUserID, int dwType, int dwNumber, int dwCmdParam); + + boolean NET_DVR_GetPlanList(int lUserID, int dwDevNum, NET_DVR_PLAN_LIST lpPlanList); + + int NET_DVR_UploadFile_V40(int lUserID, int dwUploadType, Pointer lpInBuffer, int dwInBufferSize, String sFileName, Pointer lpOutBuffer, int dwOutBufferSize); + + int NET_DVR_UploadSend(int lUserID, NET_DVR_SEND_PARAM_IN pstruSendParamIN, Pointer lpOutBuffer); + + int NET_DVR_GetUploadState(int lUploadHandle, Pointer pProgress); + + boolean NET_DVR_GetUploadResult(int lUploadHandle, Pointer lpOutBuffer, int dwOutBufferSize); + + boolean NET_DVR_UploadClose(int lUploadHandle); + + int NET_DVR_StartNetworkFlowTest(int lUserID, NET_DVR_FLOW_TEST_PARAM pFlowTest, FLOWTESTCALLBACK fFlowTestCallback, Pointer pUser); + + boolean NET_DVR_StopNetworkFlowTest(int lHandle); + + boolean NET_DVR_InquiryRecordTimeSpan(int lUserID, int dwChannel, NET_DVR_RECORD_TIME_SPAN_INQUIRY lpInquiry, NET_DVR_RECORD_TIME_SPAN lpResult); + + boolean NET_DVR_StartGetDevState(NET_DVR_CHECK_DEV_STATE pParams); + + //gps相关结构定义 + public static class TimeSegParam extends Structure { + //GPS数据查找起始时间 + public NET_DVR_TIME struBeginTime; + //GPS数据查找结束时间 + public NET_DVR_TIME struEndTime; + //GPS点时间间隔,单位:秒 + public int dwInterval; + //保留 + public byte[] byRes = new byte[76]; + } + + //按时间点查询 + public static class TimePointParam extends Structure { + //GPS数据查找时间点 + public NET_DVR_TIME struTimePoint; + //保留 + public byte[] byRes = new byte[104]; + } + + public static class GpsDataParamUion extends Union { + //按时间段查询 + public TimeSegParam timeSeg = new TimeSegParam(); + //按时间点查询 + public TimePointParam timePoint = new TimePointParam(); + } + + //gps查询参数定义 + public static class NET_DVR_GET_GPS_DATA_PARAM extends Structure { + //查找方式:0- 按时间段查找GPS数据,1- 按时间点查找GPS数据 + public int dwCmdType; + public GpsDataParamUion gpsDataParam; + + public void read() { + super.read(); + switch (dwCmdType) { + case 0: + gpsDataParam.setType(TimeSegParam.class); + break; + case 1: + gpsDataParam.setType(TimePointParam.class); + break; + default: + break; + } + gpsDataParam.read(); + } + + public void write() { + super.write(); + gpsDataParam.write(); + } + } + + //gps数据结构定义 + public static class NET_DVR_GPS_INFO extends Structure { + public byte[] byDirection = new byte[2]; + public byte bySvs; + public byte byLocateMode; + public short wHDOP; + public short wHeight; + public int dwLatitude; + public int dwLongitude; + public int dwVehicleSpeed; + public int dwVehicleDirection; + public byte[] byRes = new byte[8]; + } + + //gps返回数据结构定义 + public static class NET_DVR_GPS_DATA extends Structure { + public NET_DVR_GPS_INFO struGPSInfo; + public NET_DVR_TIME struTime; + public byte[] byRes = new byte[12]; + } + + public static interface fGPSDataCallback extends Callback { + public void invoke(int nHandle, int dwState, Pointer lpBuffer, int dwBufLen, Pointer pUser); + } + + int NET_DVR_GetVehicleGpsInfo(int lUserID, NET_DVR_GET_GPS_DATA_PARAM lpGPSDataParam, fGPSDataCallback cbGPSDataCallBack, Pointer pUser); + + /** + * 热成像相关 + */ + //设备抓图附加全屏测温数据结构体 + public static class NET_DVR_JPEGPICTURE_WITH_APPENDDATA extends Structure { + public int dwSize; + public int dwChannel;//通道号 + public int dwJpegPicLen;//Jpeg图片长度 + public Pointer pJpegPicBuff;//Jpeg图片指针 + public int dwJpegPicWidth; // 图像宽度 + public int dwJpegPicHeight; //图像高度 + public int dwP2PDataLen;//全屏测温数据长度 + public Pointer pP2PDataBuff; //全屏测温数据指针 + public byte byIsFreezedata;//是否数据冻结 0-否 1-是 + public byte[] byRes = new byte[255]; + } + + + public static class DATE_TIME extends Structure { + public short year; /*APP->DSP 年*/ + public short month; /*APP->DSP 月*/ + public short dayOfWeek; /*APP->DSP 0:星期日-6:星期六*/ + public short day; /*APP->DSP 日*/ + public short hour; /*APP->DSP 小时*/ + public short minute; /*APP->DSP 分钟*/ + public short second; /*APP->DSP 秒*/ + public short milliSecond; /*APP->DSP 毫秒*/ + } + + //全屏测温数据解析 + public static class STREAM_RT_DATA_INFO_S extends Structure { + public int u32RTDataType; // 1-14bit裸数据; 2-全屏测温结果数据; 3-YUV数据 + public int u32FrmNum; + public int u32StdStamp; //DSP相对时间戳 + public DATE_TIME stTime; //绝对时间戳 + public int u32Width; + public int u32Height; + public int u32Len; + public int u32Fps; + public int u32Chan; + } + + public static class STREAM_FS_SUPPLE_INFO_TEMP extends Structure { + public int u32TmDataMode; /* 0为4字节,1为2字节 */ + public int u32TmScale; /* 测温缩放比例 */ + public int u32TmOffset; /* 测温偏移量,当前固定为0 */ + public int byIsFreezedata; /*是否是冻结数据,1:冻结,0:非冻结*/ + } + + public static class STREAM_FARME_INFO_TEMP extends Structure { + public int u32MagicNo; //0x70827773 "FRMI"的ascii码 + public int u32HeaderSize; //结构体长度 + public int u32StreamType; //数据类型: h264/h265, JPEG, Audio, MetaData, RTData: 参见 STREAM_TYPE_E + public int u32StreamLen; //数据长度 + public STREAM_RT_DATA_INFO_S stRTDataInfo; + public STREAM_FS_SUPPLE_INFO_TEMP stFsSuppleInfo; + public int[] res = new int[12]; + public int u32CrcVal; //结构体校验码 对结构体前面数据进行校验 + } + + //测温规则温度信息 + public static class NET_DVR_THERMOMETRYRULE_TEMPERATURE_INFO extends Structure { + public float fMaxTemperature; + public float fMinTemperature; + public float fAverageTemperature; + public NET_VCA_POINT struHighestPoint; + public NET_VCA_POINT struLowestPoint; + public byte byIsFreezedata; + public byte[] byRes = new byte[15]; + } + + public static class REMOTECONFIGSTATUS_THERMOMETRY extends Structure { + public byte[] byStatus = new byte[4]; + public byte[] byErrorCode = new byte[4]; + } + + public static class NET_DVR_FIREDETECTION_ALARM extends Structure { + public int dwSize; //结构体大小 + public int dwRelativeTime; //相对时标 + public int dwAbsTime; //绝对时标 + public NET_VCA_DEV_INFO struDevInfo; //前端设备信息 + public short wPanPos; + public short wTiltPos; + public short wZoomPos; + public byte byPicTransType; //图片数据传输方式: 0-二进制;1-url + public byte byRes1; + public int dwPicDataLen; //报警抓拍图片长度 + public Pointer pBuffer; //数据指针 + public NET_VCA_RECT struRect; //火点框 + public NET_VCA_POINT struPoint; //火点框内最高温度点坐标 + public short wFireMaxTemperature; //火点最高温度[300℃~4000℃] + public short wTargetDistance; //目标距离[100m ~ 10000m] + public byte byStrategyType; //策略类型;0~任意报警,1~协同报警,2~多系统报警,3~指定火点报警,4~指定烟雾报警 + public byte byAlarmSubType; //报警子类型。0~火点检测报警,1~烟雾检测报警,2~烟火报警 + /*是否启用PTZ坐标扩展, + 0~不启用,PTZ坐标值以wPanPos、wTiltPos、wZoomPos为准。 + 1~启用,PTZ坐标值以struPtzPosEx为准。但是新老PTZ都需返回。struPtzPosEx的值需转化为wPanPos、wTiltPos、wZoomPos值。 + */ + public byte byPTZPosExEnable; + public byte byRes2; + public NET_PTZ_INFO struPtzPosEx; // ptz坐标扩展(支持高精度PTZ值,精确到小数点后三位) + public int dwVisiblePicLen; // 可见光图片长度 + public Pointer pVisiblePicBuf; // 可见光图片数据指针 + // pSmokeBuf参数当byAlarmSubType报警子类型为1(烟雾检测报警)、2(烟火报警)时生效。 + public Pointer pSmokeBuf; //烟雾检测报警数据指针,指向一个NET_DVR_SMOKEDETECTION_ALARM结构体 + public short wDevInfoIvmsChannelEx; //与NET_VCA_DEV_INFO里的byIvmsChannel含义相同,能表示更大的值。老客户端用byIvmsChannel能继续兼容,但是最大到255。新客户端版本请使用wDevInfoIvmsChannelEx。 + public byte byRes3; + public byte byFireScanWaitMode; //火点扫描等待模式 0-自动 1-手动 + public int dwVisibleChannel; //可见光通道通道号 + public byte byTimeDiffFlag; //时差字段是否有效 0-时差无效, 1-时差有效 + public char cTimeDifferenceH; //与UTC的时差(小时),-12 ... +14, +表示东区,,byTimeDiffFlag为1时有效 + public char cTimeDifferenceM; //与UTC的时差(分钟),-30, 30, 45, +表示东区,byTimeDiffFlag为1时有效 + public byte[] byRes = new byte[49]; + } + + //模块服务配置结构体 + public static class NET_DVR_DEVSERVER_CFG extends Structure { + public int dwSize; //结构体大小 + public byte byIrLampServer; //红外灯设置:0- 禁用,1- 启用 + public byte bytelnetServer; //telnet设置:0- 禁用,1- 启用 + public byte byABFServer; //ABF设置:0- 启用,1- 禁用,请注意此处参数取值0、1和其他参数取值含义不同 + public byte byEnableLEDStatus; //状态指示灯控制:0- 禁用,1- 启用 + public byte byEnableAutoDefog; //自动除雾控制:0- 启用,1- 禁用,请注意此处参数取值0、1和其他参数取值含义不同 + public byte byEnableSupplementLight; //补光灯控制:0- 启用,1- 禁用,请注意此处参数取值0、1和其他参数取值含义不同 + public byte byEnableDeicing; //除冰功能:0- 关闭,1- 开启 + public byte byEnableVisibleMovementPower; //可见光机芯电源开关(低功耗模式下有效):0- 关闭,1- 开启 + public byte byEnableThermalMovementPower; //热成像机芯电源开关(低功耗模式下有效):0- 关闭,1- 开启 + public byte byEnablePtzPower; //云台电源开关(低功耗模式下有效):0- 关闭,1- 开启 + public byte byPowerSavingControl; //低功耗策略:0- 保留,1- 休眠模式,2-低功耗模式(低功耗模式下,可见光机芯电源、热成像机芯电源、云台电源控制生效) + public byte byCaptureWithSupplimentLightEnabled; //启用抓拍补光使能 0-关闭,1-开启 + public byte[] byRes = new byte[244]; //保留,置为0 + } + + public static final int MAX_UPLOADFILE_URL_LEN = 240; + public static final int IMPORT_DATA_TO_FACELIB = 39; //导入人脸数据(人脸图片+图片附件信息 到设备人脸库) + + public static class NET_DVR_UPLOAD_FILE_RET extends Structure { + + public byte[] sUrl = new byte[MAX_UPLOADFILE_URL_LEN]; //url + public byte[] byRes = new byte[260]; + } + + public static class NET_DVR_FLOW_TEST_PARAM extends Structure { + public int dwSize; //结构大小 + public int lCardIndex; //网卡索引 + public int dwInterval; //设备上传流量时间间隔, 单位:100ms + public byte[] byRes = new byte[8]; //保留字节 + } + + public static class NET_DVR_RECORD_TIME_SPAN_INQUIRY extends Structure { + public int dwSize; //结构体大小 + public byte byType; //0 正常音视频录像, 1图片通道录像, 2ANR通道录像, 3抽帧通道录像 + public byte[] byRes = new byte[63]; + } + + public static class NET_DVR_RECORD_TIME_SPAN extends Structure { + public int dwSize; //结构体大小 + public NET_DVR_TIME strBeginTime; //开始时间 + public NET_DVR_TIME strEndTime; //结束时间 + public byte byType; //0 正常音视频录像, 1图片通道录像, 2ANR通道录像, 3抽帧通道录像 + public byte[] byRes = new byte[35]; //保留 + } + + /* + * 月历录像分布查询条件结构体 + */ + public static class NET_DVR_MRD_SEARCH_PARAM extends Structure { + public int dwSize; // 结构体大小 + public NET_DVR_STREAM_INFO struStreamInfo = new NET_DVR_STREAM_INFO(); // 监控点 + public short wYear; // 年 + public byte byMonth; // 月 + public byte byDrawFrame; // 0-不抽帧 1-抽帧 + public byte byStreamType; //0-主码流 1-子码流 + public byte byLocalOrUTC; //0-设备本地时区 1-UTC + public byte[] byRes = new byte[30]; + } + + /* + * 月历录像分布查询结果结构体 + */ + public static class NET_DVR_MRD_SEARCH_RESULT extends Structure { + + public int dwSize; // 结构体大小 + public byte[] byRecordDistribution = new byte[32]; // 录像分布,byRecordDistribution[0]=1表示1日存在录像,byRecordDistribution[0]=0表示没有录像,byRecordDistribution[1]表示2日,以此类推 + public byte[] byHasEventRecode = new byte[31]; //事件录像 0-无事件录像,1-有事件录像 + public byte byRes; //保留 + } + + public static final int NET_DVR_GET_GISINFO = 3711; + //GIS信息 + + public static class NET_DVR_GIS_INFO extends Structure { + public int dwSize; + public float fAzimuth; + public float fHorizontalValue; + public float fVerticalValue; + public float fVisibleRadius; + public float fMaxViewRadius; + public byte byLatitudeType; + public byte byLongitudeType; + public byte byPTZPosExEnable; + public byte byRes1; + public NET_DVR_LLI_PARAM struLatitude = new NET_DVR_LLI_PARAM(); + public NET_DVR_LLI_PARAM struLongitude = new NET_DVR_LLI_PARAM(); + public NET_DVR_PTZPOS_PARAM struPtzPos = new NET_DVR_PTZPOS_PARAM(); + public NET_DVR_SENSOR_PARAM struSensorParam = new NET_DVR_SENSOR_PARAM(); + public NET_PTZ_INFO struPtzPosEx = new NET_PTZ_INFO(); + public float fMinHorizontalValue; + public float fMaxHorizontalValue; + public float fMinVerticalValue; + public float fMaxVerticalValue; + public byte[] byRes = new byte[220]; + } + + //GBT28181协议的设备编码通道配置 + public static class NET_DVR_GBT28181_CHANINFO_CFG extends Structure { + public int dwSize; + public byte[] szVideoChannelNumID = new byte[64];//设备视频通道编码ID:64字节字符串,仅限数字 + public byte[] byRes = new byte[256]; + } + + // 巡航路径配置条件结构体 + public static class NET_DVR_CRUISEPOINT_COND extends Structure { + public int dwSize; + public int dwChan; + public short wRouteNo; + public byte[] byRes = new byte[30]; + } + + // 巡航路径配置结构体 + public static class NET_DVR_CRUISEPOINT_V40 extends Structure { + public int dwSize; + public NET_DVR_CRUISEPOINT_PARAM[] struCruisePoint = (NET_DVR_CRUISEPOINT_PARAM[]) new NET_DVR_CRUISEPOINT_PARAM().toArray(128); + public byte[] byRes = new byte[64]; + } + + // 巡航路径配置结构体 + public static class NET_DVR_CRUISEPOINT_V50 extends Structure { + public int dwSize; + public NET_DVR_CRUISEPOINT_PARAM[] struCruisePoint = (NET_DVR_CRUISEPOINT_PARAM[]) new NET_DVR_CRUISEPOINT_PARAM().toArray(256); + public byte[] byRes = new byte[64]; + } + + // 巡航点参数结构体 + public static class NET_DVR_CRUISEPOINT_PARAM extends Structure { + public short wPresetNo; + public short wDwell; + public byte bySpeed; + public byte bySupport256PresetNo; + public byte[] byRes = new byte[6]; + } +} + diff --git a/src/main/java/net/javase/hksup/starter/service/CmsServer.java b/src/main/java/net/javase/hksup/starter/service/CmsServer.java new file mode 100644 index 0000000..98166cb --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/service/CmsServer.java @@ -0,0 +1,580 @@ +package net.javase.hksup.starter.service; + +import com.alibaba.fastjson2.JSONObject; +import com.sun.jna.Native; +import lombok.extern.slf4j.Slf4j; +import net.javase.hksup.starter.config.HkSupSdkProperties; +import net.javase.hksup.starter.model.FaceInfoParam; +import net.javase.hksup.starter.model.SearchFaceInfoParam; +import net.javase.hksup.starter.model.UserInfo; +import net.javase.hksup.starter.model.UserInfoDetail; +import net.javase.hksup.starter.sdk.HCISUPCMS; +import net.javase.hksup.starter.utils.SystemUtil; +import org.springframework.context.ApplicationContext; +import org.springframework.util.StringUtils; + +import java.io.File; +import java.nio.charset.StandardCharsets; +import java.util.*; + +/** + * CmsServer + * + * @author Frank + */ +@Slf4j +public class CmsServer { + + + private final HkSupSdkProperties supSdkProperties; + + private final ApplicationContext applicationContext; + + + public HCISUPCMS hcisupcms = null; + private int CmsHandle = -1; //CMS监听句柄 + private HCISUPCMS.DEVICE_REGISTER_CB deviceRegisterCb; + HCISUPCMS.NET_EHOME_CMS_LISTEN_PARAM struCMSListenPara = new HCISUPCMS.NET_EHOME_CMS_LISTEN_PARAM(); + + public CmsServer(HkSupSdkProperties supSdkProperties, ApplicationContext applicationContext) { + this.supSdkProperties = supSdkProperties; + this.applicationContext = applicationContext; + createSDKInstance(); + } + + /** + * 根据不同操作系统选择不同的库文件和库路径 + */ + private boolean createSDKInstance() { + if (hcisupcms == null) { + String libPath = libPath(); + synchronized (HCISUPCMS.class) { + String strDllPath = ""; + try { + SystemUtil.jnaDebugLoad(supSdkProperties.getJnaDebug()); + if (SystemUtil.isWindows()) { + strDllPath = libPath + "HCISUPCMS.dll"; + } else if (SystemUtil.isLinux()) { + strDllPath = libPath + "libHCISUPCMS.so"; + } + log.info("loadLibrary: {}", strDllPath); + hcisupcms = (HCISUPCMS) Native.loadLibrary(strDllPath, HCISUPCMS.class); + } catch (Exception ex) { + log.error("loadLibrary: {}, Error: {}", strDllPath, ex.getMessage()); + return false; + } + } + } + return true; + } + + /** + * cms服务初始化,开启监听 + */ + public void cmsInit() { + if (hcisupcms == null) { + if (!createSDKInstance()) { + throw new RuntimeException("Load CMS SDK fail!"); + } + } + String libPath = libPath(); + if (SystemUtil.isWindows()) { + HCISUPCMS.BYTE_ARRAY ptrByteArrayCrypto = new HCISUPCMS.BYTE_ARRAY(256); + String strPathCrypto = libPath + "libeay32.dll"; //Linux版本是libcrypto.so库文件的路径 + System.arraycopy(strPathCrypto.getBytes(), 0, ptrByteArrayCrypto.byValue, 0, strPathCrypto.length()); + ptrByteArrayCrypto.write(); + hcisupcms.NET_ECMS_SetSDKInitCfg(0, ptrByteArrayCrypto.getPointer()); + + //设置libssl.so所在路径 + HCISUPCMS.BYTE_ARRAY ptrByteArraySsl = new HCISUPCMS.BYTE_ARRAY(256); + String strPathSsl = libPath + "ssleay32.dll"; //Linux版本是libssl.so库文件的路径 + System.arraycopy(strPathSsl.getBytes(), 0, ptrByteArraySsl.byValue, 0, strPathSsl.length()); + ptrByteArraySsl.write(); + hcisupcms.NET_ECMS_SetSDKInitCfg(1, ptrByteArraySsl.getPointer()); + //注册服务初始化 + boolean binit = hcisupcms.NET_ECMS_Init(); + //设置HCAapSDKCom组件库文件夹所在路径 + HCISUPCMS.BYTE_ARRAY ptrByteArrayCom = new HCISUPCMS.BYTE_ARRAY(256); + String strPathCom = libPath + "HCAapSDKCom"; //只支持绝对路径,建议使用英文路径 + System.arraycopy(strPathCom.getBytes(), 0, ptrByteArrayCom.byValue, 0, strPathCom.length()); + ptrByteArrayCom.write(); + hcisupcms.NET_ECMS_SetSDKLocalCfg(5, ptrByteArrayCom.getPointer()); + + } else if (SystemUtil.isLinux()) { + HCISUPCMS.BYTE_ARRAY ptrByteArrayCrypto = new HCISUPCMS.BYTE_ARRAY(256); + String strPathCrypto = libPath + "libcrypto.so"; //Linux版本是libcrypto.so库文件的路径 + System.arraycopy(strPathCrypto.getBytes(), 0, ptrByteArrayCrypto.byValue, 0, strPathCrypto.length()); + ptrByteArrayCrypto.write(); + hcisupcms.NET_ECMS_SetSDKInitCfg(0, ptrByteArrayCrypto.getPointer()); + + //设置libssl.so所在路径 + HCISUPCMS.BYTE_ARRAY ptrByteArraySsl = new HCISUPCMS.BYTE_ARRAY(256); + String strPathSsl = libPath + "libssl.so"; //Linux版本是libssl.so库文件的路径 + System.arraycopy(strPathSsl.getBytes(), 0, ptrByteArraySsl.byValue, 0, strPathSsl.length()); + ptrByteArraySsl.write(); + hcisupcms.NET_ECMS_SetSDKInitCfg(1, ptrByteArraySsl.getPointer()); + //注册服务初始化 + boolean binit = hcisupcms.NET_ECMS_Init(); + //设置HCAapSDKCom组件库文件夹所在路径 + HCISUPCMS.BYTE_ARRAY ptrByteArrayCom = new HCISUPCMS.BYTE_ARRAY(256); + String strPathCom = libPath + "HCAapSDKCom/"; //只支持绝对路径,建议使用英文路径 + System.arraycopy(strPathCom.getBytes(), 0, ptrByteArrayCom.byValue, 0, strPathCom.length()); + ptrByteArrayCom.write(); + hcisupcms.NET_ECMS_SetSDKLocalCfg(5, ptrByteArrayCom.getPointer()); + + } + hcisupcms.NET_ECMS_SetLogToFile(3, logPath(), false); + } + + /** + * 开启监听 + */ + public void startCmsListen() { + if (deviceRegisterCb == null) { + Map beansOfType = applicationContext.getBeansOfType(HCISUPCMS.DEVICE_REGISTER_CB.class); + if (beansOfType.size() < 1) { + throw new RuntimeException("not found device register callback implement!"); + } + beansOfType.forEach((k, v) -> deviceRegisterCb = v); + } + System.arraycopy(supSdkProperties.getCmsServerIp().getBytes(), 0, struCMSListenPara.struAddress.szIP, 0, supSdkProperties.getCmsServerIp().length()); + struCMSListenPara.struAddress.wPort = Short.parseShort(supSdkProperties.getCmsServerPort().toString()); + struCMSListenPara.fnCB = deviceRegisterCb; + struCMSListenPara.write(); + //启动监听,接收设备注册信息 + CmsHandle = hcisupcms.NET_ECMS_StartListen(struCMSListenPara); + if (CmsHandle < -1) { + log.info("NET_ECMS_StartListen failed, error code: {}", hcisupcms.NET_ECMS_GetLastError()); + hcisupcms.NET_ECMS_Fini(); + return; + } + String CmsListenInfo = new String(struCMSListenPara.struAddress.szIP).trim() + "_" + struCMSListenPara.struAddress.wPort; + log.info("注册服务器: {}, NET_ECMS_StartListen succeed!\n", CmsListenInfo); + } + + /** + * 初始化CMS服务 + */ + void startCmsServer() { + try { + cmsInit(); + startCmsListen(); + } catch (Exception ex) { + log.error("启动CMS注册服务失败: " + ex.getMessage(), ex); + } + } + + /** + * 停止CMS服务,回收资源 + */ + void stopCmsServer() { + try { + if (CmsHandle >= 0) { + log.info("开始停止CMS注册服务"); + hcisupcms.NET_ECMS_StopListen(CmsHandle); + hcisupcms.NET_ECMS_Fini(); + log.info("停止CMS注册服务成功!"); + } + } catch (Exception ex) { + log.error("停止CMS注册服务失败: " + ex.getMessage(), ex); + } + } + + /** + * 添加人员工号信息 + * + * @param loginID 登录设备句柄ID + * @param userInfo 人员信息 + */ + public String addEmployeeInfo(int loginID, UserInfo userInfo) { + HCISUPCMS.NET_EHOME_PTXML_PARAM m_struParam2 = new HCISUPCMS.NET_EHOME_PTXML_PARAM(); + m_struParam2.read(); + //透传URL,不同功能对应不同的URL,完整协议报文说明需要参考ISAPI协议文档 + String urlInBuffer = "POST /ISAPI/AccessControl/UserInfo/Record?format=json"; //添加人员URL + HCISUPCMS.BYTE_ARRAY ptrurlInBuffer = new HCISUPCMS.BYTE_ARRAY(urlInBuffer.length() + 1); + System.arraycopy(urlInBuffer.getBytes(), 0, ptrurlInBuffer.byValue, 0, urlInBuffer.length()); + ptrurlInBuffer.write(); + m_struParam2.pRequestUrl = ptrurlInBuffer.getPointer(); + m_struParam2.dwRequestUrlLen = urlInBuffer.length(); + + //输入参数,XML或者JSON数据,下发人员信息json报文 + Map parameter = new HashMap<>(); + parameter.put("UserInfo", userInfo); // 员工ID + String input = JSONObject.toJSONString(parameter); + log.info("添加人员信息json报文: {}", input); + byte[] byInbuffer = input.getBytes(StandardCharsets.UTF_8); + int iInBufLen = byInbuffer.length; + HCISUPCMS.BYTE_ARRAY ptrInBuffer = new HCISUPCMS.BYTE_ARRAY(iInBufLen); + ptrInBuffer.read(); + System.arraycopy(byInbuffer, 0, ptrInBuffer.byValue, 0, iInBufLen); + ptrInBuffer.write(); + m_struParam2.pInBuffer = ptrInBuffer.getPointer();//GET获取时不需要输入参数,输入为null + m_struParam2.dwInSize = iInBufLen; + //输出参数,分配的内存用于存储返回的数据,需要大于等于实际内容大小 + int iOutSize2 = 2 * 1024 * 1024; + HCISUPCMS.BYTE_ARRAY ptrOutByte2 = new HCISUPCMS.BYTE_ARRAY(iOutSize2); + m_struParam2.pOutBuffer = ptrOutByte2.getPointer(); + m_struParam2.dwOutSize = iOutSize2; + m_struParam2.dwRecvTimeOut = 5000; //接收超时时间,单位毫秒 + m_struParam2.write(); + if (!hcisupcms.NET_ECMS_ISAPIPassThrough(loginID, m_struParam2)) { + log.info("添加人员失败,NET_ECMS_ISAPIPassThrough failed,error:{}", hcisupcms.NET_ECMS_GetLastError()); + return null; + } else { + m_struParam2.read(); + ptrOutByte2.read(); + String res = new String(ptrOutByte2.byValue).trim(); + log.info("NET_ECMS_ISAPIPassThrough succeed\n输出报文: {}", res); + return res; + } + } + + /** + * 删除人员工号信息 + * + * @param loginID 登录设备句柄ID + * @param employeeNos 员工编号 + */ + public String deleteEmployeeInfo(int loginID, String... employeeNos) { + HCISUPCMS.NET_EHOME_PTXML_PARAM m_struParam2 = new HCISUPCMS.NET_EHOME_PTXML_PARAM(); + m_struParam2.read(); + //透传URL,不同功能对应不同的URL,完整协议报文说明需要参考ISAPI协议文档 + String urlInBuffer = "PUT /ISAPI/AccessControl/UserInfoDetail/Delete?format=json"; //删除人员URL + HCISUPCMS.BYTE_ARRAY ptrurlInBuffer = new HCISUPCMS.BYTE_ARRAY(urlInBuffer.length() + 1); + System.arraycopy(urlInBuffer.getBytes(), 0, ptrurlInBuffer.byValue, 0, urlInBuffer.length()); + ptrurlInBuffer.write(); + m_struParam2.pRequestUrl = ptrurlInBuffer.getPointer(); + m_struParam2.dwRequestUrlLen = urlInBuffer.length(); + + //输入参数,XML或者JSON数据,删除人员信息json报文 + Map parameter = new HashMap<>(); + parameter.put("mode", "byEmployeeNo"); // 删除方式, byEmployeeNo: 按员工ID号 + UserInfoDetail detail = new UserInfoDetail(); + detail.setMode("byEmployeeNo"); + List list = new ArrayList<>(); + for (String no : employeeNos) { + list.add(new UserInfoDetail.EmployeeNo(no)); + } + detail.setEmployeeNoList(list); + parameter.put("UserInfoDetail", detail); + + String input = JSONObject.toJSONString(parameter); + log.info("删除人员信息json报文: {}", input); + byte[] byInbuffer = input.getBytes(StandardCharsets.UTF_8); + int iInBufLen = byInbuffer.length; + HCISUPCMS.BYTE_ARRAY ptrInBuffer = new HCISUPCMS.BYTE_ARRAY(iInBufLen); + ptrInBuffer.read(); + System.arraycopy(byInbuffer, 0, ptrInBuffer.byValue, 0, iInBufLen); + ptrInBuffer.write(); + m_struParam2.pInBuffer = ptrInBuffer.getPointer();//GET获取时不需要输入参数,输入为null + m_struParam2.dwInSize = iInBufLen; + //输出参数,分配的内存用于存储返回的数据,需要大于等于实际内容大小 + int iOutSize2 = 2 * 1024 * 1024; + HCISUPCMS.BYTE_ARRAY ptrOutByte2 = new HCISUPCMS.BYTE_ARRAY(iOutSize2); + m_struParam2.pOutBuffer = ptrOutByte2.getPointer(); + m_struParam2.dwOutSize = iOutSize2; + m_struParam2.dwRecvTimeOut = 5000; //接收超时时间,单位毫秒 + m_struParam2.write(); + if (!hcisupcms.NET_ECMS_ISAPIPassThrough(loginID, m_struParam2)) { + log.info("删除人员失败,NET_ECMS_ISAPIPassThrough failed,error:{}", hcisupcms.NET_ECMS_GetLastError()); + return null; + } else { + m_struParam2.read(); + ptrOutByte2.read(); + String res = new String(ptrOutByte2.byValue).trim(); + log.info("NET_ECMS_ISAPIPassThrough succeed\n删除人员成功, 输出报文: {}", res); + return res; + } + } + + + /** + * 查询人员工号信息 + * + * @param loginID 设备登录句柄ID + */ + public void searchEmployeeInfo(int loginID) { + searchEmployeeInfo(loginID, 30); + } + + /** + * 查询人员工号信息 + * + * @param loginID 登录设备句柄ID + */ + public String searchEmployeeInfo(int loginID, int maxResults) { + HCISUPCMS.NET_EHOME_PTXML_PARAM m_struParam2 = new HCISUPCMS.NET_EHOME_PTXML_PARAM(); + m_struParam2.read(); + //透传URL,不同功能对应不同的URL,完整协议报文说明需要参考ISAPI协议文档 + String urlInBuffer = "POST /ISAPI/AccessControl/UserInfo/Search?format=json"; //查询人员URL + HCISUPCMS.BYTE_ARRAY ptrurlInBuffer = new HCISUPCMS.BYTE_ARRAY(urlInBuffer.length() + 1); + System.arraycopy(urlInBuffer.getBytes(), 0, ptrurlInBuffer.byValue, 0, urlInBuffer.length()); + ptrurlInBuffer.write(); + m_struParam2.pRequestUrl = ptrurlInBuffer.getPointer(); + m_struParam2.dwRequestUrlLen = urlInBuffer.length(); + UUID uuid = UUID.randomUUID(); + + //输入参数,XML或者JSON数据,查询多条人员信息json报文 + Map parameter = new HashMap<>(); + Map userInfoSearchCond = new HashMap<>(); + userInfoSearchCond.put("searchID", uuid); // 查询id + userInfoSearchCond.put("searchResultPosition", 0); + userInfoSearchCond.put("maxResults", 30); // 最大查询数量 + parameter.put("UserInfoSearchCond", userInfoSearchCond); + String input = JSONObject.toJSONString(parameter); + + //输入参数,XML或者JSON数据,指定人员工号查询json报文 + log.info("查询人员工号信息json报文: {}", input); + + byte[] byInbuffer = input.getBytes(StandardCharsets.UTF_8); + int iInBufLen = byInbuffer.length; + HCISUPCMS.BYTE_ARRAY ptrInBuffer = new HCISUPCMS.BYTE_ARRAY(iInBufLen); + ptrInBuffer.read(); + System.arraycopy(byInbuffer, 0, ptrInBuffer.byValue, 0, iInBufLen); + ptrInBuffer.write(); + m_struParam2.pInBuffer = ptrInBuffer.getPointer();//GET获取时不需要输入参数,输入为null + m_struParam2.dwInSize = iInBufLen; + //输出参数,分配的内存用于存储返回的数据,需要大于等于实际内容大小 + int iOutSize2 = 2 * 1024 * 1024; + HCISUPCMS.BYTE_ARRAY ptrOutByte2 = new HCISUPCMS.BYTE_ARRAY(iOutSize2); + m_struParam2.pOutBuffer = ptrOutByte2.getPointer(); + m_struParam2.dwOutSize = iOutSize2; + m_struParam2.dwRecvTimeOut = 5000; //接收超时时间,单位毫秒 + m_struParam2.write(); + if (!hcisupcms.NET_ECMS_ISAPIPassThrough(loginID, m_struParam2)) { + log.info("查询人员失败,NET_ECMS_ISAPIPassThrough failed, error:{}", hcisupcms.NET_ECMS_GetLastError()); + return null; + } else { + m_struParam2.read(); + ptrOutByte2.read(); + String res = new String(ptrOutByte2.byValue).trim(); + log.info("NET_ECMS_ISAPIPassThrough succeed!\n查询人员成功, 输出报文: {}", res); + return res; + } + } + + + /** + * 下发门禁人脸图片数据 + * + * @param loginID 登录设备句柄ID + * @param param 人脸数据 + */ + public String addFacePicInfo(int loginID, FaceInfoParam param) { + HCISUPCMS.NET_EHOME_PTXML_PARAM m_struParam2 = new HCISUPCMS.NET_EHOME_PTXML_PARAM(); + m_struParam2.read(); + //透传URL,不同功能对应不同的URL,完整协议报文说明需要参考ISAPI协议文档 + String urlInBuffer = "POST /ISAPI/Intelligent/FDLib/FaceDataRecord?format=json"; //添加人脸URL + HCISUPCMS.BYTE_ARRAY ptrurlInBuffer = new HCISUPCMS.BYTE_ARRAY(urlInBuffer.length() + 1); + System.arraycopy(urlInBuffer.getBytes(), 0, ptrurlInBuffer.byValue, 0, urlInBuffer.length()); + ptrurlInBuffer.write(); + m_struParam2.pRequestUrl = ptrurlInBuffer.getPointer(); + m_struParam2.dwRequestUrlLen = urlInBuffer.length(); + + //输入参数,XML或者JSON数据,添加人脸图片json报文 + String input = JSONObject.toJSONString(param); + log.info("下发门禁人脸图片 json报文: {}", input); + + byte[] byInbuffer = input.getBytes(StandardCharsets.UTF_8); + int iInBufLen = byInbuffer.length; + HCISUPCMS.BYTE_ARRAY ptrInBuffer = new HCISUPCMS.BYTE_ARRAY(iInBufLen); + ptrInBuffer.read(); + System.arraycopy(byInbuffer, 0, ptrInBuffer.byValue, 0, iInBufLen); + ptrInBuffer.write(); + m_struParam2.pInBuffer = ptrInBuffer.getPointer();//GET获取时不需要输入参数,输入为null + m_struParam2.dwInSize = iInBufLen; + //输出参数,分配的内存用于存储返回的数据,需要大于等于实际内容大小 + int iOutSize2 = 2 * 1024 * 1024; + HCISUPCMS.BYTE_ARRAY ptrOutByte2 = new HCISUPCMS.BYTE_ARRAY(iOutSize2); + m_struParam2.pOutBuffer = ptrOutByte2.getPointer(); + m_struParam2.dwOutSize = iOutSize2; + m_struParam2.dwRecvTimeOut = 5000; //接收超时时间,单位毫秒 + m_struParam2.write(); + if (!hcisupcms.NET_ECMS_ISAPIPassThrough(loginID, m_struParam2)) { + log.info("下发门禁人脸失败,NET_ECMS_ISAPIPassThrough failed,error:{}", hcisupcms.NET_ECMS_GetLastError()); + return null; + } else { + m_struParam2.read(); + ptrOutByte2.read(); + String res = new String(ptrOutByte2.byValue).trim(); + log.info("NET_ECMS_ISAPIPassThrough succeed\n下发门禁人脸成功, 输出报文: {}", res); + return res; + } + } + + /** + * 修改门禁人脸图片数据 + * + * @param loginID 登录设备句柄ID + * @param param 人脸数据 + */ + public String modifyFacePicInfo(int loginID, FaceInfoParam param) { + HCISUPCMS.NET_EHOME_PTXML_PARAM m_struParam2 = new HCISUPCMS.NET_EHOME_PTXML_PARAM(); + m_struParam2.read(); + // 透传URL,不同功能对应不同的URL,完整协议报文说明需要参考ISAPI协议文档 + String urlInBuffer = "PUT /ISAPI/Intelligent/FDLib/FDModify?format=json"; //修改人脸URL + HCISUPCMS.BYTE_ARRAY ptrurlInBuffer = new HCISUPCMS.BYTE_ARRAY(urlInBuffer.length() + 1); + System.arraycopy(urlInBuffer.getBytes(), 0, ptrurlInBuffer.byValue, 0, urlInBuffer.length()); + ptrurlInBuffer.write(); + m_struParam2.pRequestUrl = ptrurlInBuffer.getPointer(); + m_struParam2.dwRequestUrlLen = urlInBuffer.length(); + + //输入参数,XML或者JSON数据,添加人脸图片json报文 + String input = JSONObject.toJSONString(param); + log.info("修改门禁人脸图片 json报文: {}", input); + + byte[] byInbuffer = input.getBytes(StandardCharsets.UTF_8); + int iInBufLen = byInbuffer.length; + HCISUPCMS.BYTE_ARRAY ptrInBuffer = new HCISUPCMS.BYTE_ARRAY(iInBufLen); + ptrInBuffer.read(); + System.arraycopy(byInbuffer, 0, ptrInBuffer.byValue, 0, iInBufLen); + ptrInBuffer.write(); + m_struParam2.pInBuffer = ptrInBuffer.getPointer();//GET获取时不需要输入参数,输入为null + m_struParam2.dwInSize = iInBufLen; + //输出参数,分配的内存用于存储返回的数据,需要大于等于实际内容大小 + int iOutSize2 = 2 * 1024 * 1024; + HCISUPCMS.BYTE_ARRAY ptrOutByte2 = new HCISUPCMS.BYTE_ARRAY(iOutSize2); + m_struParam2.pOutBuffer = ptrOutByte2.getPointer(); + m_struParam2.dwOutSize = iOutSize2; + m_struParam2.dwRecvTimeOut = 5000; //接收超时时间,单位毫秒 + m_struParam2.write(); + if (!hcisupcms.NET_ECMS_ISAPIPassThrough(loginID, m_struParam2)) { + log.info("修改门禁人脸失败,NET_ECMS_ISAPIPassThrough failed,error:" + hcisupcms.NET_ECMS_GetLastError()); + return null; + } else { + m_struParam2.read(); + ptrOutByte2.read(); + String res = new String(ptrOutByte2.byValue).trim(); + log.info("NET_ECMS_ISAPIPassThrough succeed\n修改门禁人脸成功, 输出报文: {}", res); + return res; + } + } + + /** + * 删除人脸图片数据 + * + * @param loginID 登录设备句柄ID + * @param employeeNo 人员工号,按照指定人员删除关联人脸图片 + */ + public String deleteFacePicInfo(int loginID, String employeeNo) { + HCISUPCMS.NET_EHOME_PTXML_PARAM m_struParam2 = new HCISUPCMS.NET_EHOME_PTXML_PARAM(); + m_struParam2.read(); + //透传URL,不同功能对应不同的URL,完整协议报文说明需要参考ISAPI协议文档 + String urlInBuffer = "PUT /ISAPI/Intelligent/FDLib/FDSearch/Delete?format=json&FDID=1&faceLibType=blackFD"; //删除人脸URL + HCISUPCMS.BYTE_ARRAY ptrurlInBuffer = new HCISUPCMS.BYTE_ARRAY(urlInBuffer.length() + 1); + System.arraycopy(urlInBuffer.getBytes(), 0, ptrurlInBuffer.byValue, 0, urlInBuffer.length()); + ptrurlInBuffer.write(); + m_struParam2.pRequestUrl = ptrurlInBuffer.getPointer(); + m_struParam2.dwRequestUrlLen = urlInBuffer.length(); + + //输入参数,XML或者JSON数据,删除人脸图片json报文 + Map parameter = new HashMap<>(); + List> list = new ArrayList<>(); + Map map = new HashMap<>(); + map.put("value", employeeNo); + list.add(map); + parameter.put("FPID", list); + + String input = JSONObject.toJSONString(parameter); + log.info("删除人脸图片数据 json报文: {}", input); + + byte[] byInbuffer = input.getBytes(StandardCharsets.UTF_8); + int iInBufLen = byInbuffer.length; + HCISUPCMS.BYTE_ARRAY ptrInBuffer = new HCISUPCMS.BYTE_ARRAY(iInBufLen); + ptrInBuffer.read(); + System.arraycopy(byInbuffer, 0, ptrInBuffer.byValue, 0, iInBufLen); + ptrInBuffer.write(); + m_struParam2.pInBuffer = ptrInBuffer.getPointer();//GET获取时不需要输入参数,输入为null + m_struParam2.dwInSize = iInBufLen; + //输出参数,分配的内存用于存储返回的数据,需要大于等于实际内容大小 + int iOutSize2 = 2 * 1024 * 1024; + HCISUPCMS.BYTE_ARRAY ptrOutByte2 = new HCISUPCMS.BYTE_ARRAY(iOutSize2); + m_struParam2.pOutBuffer = ptrOutByte2.getPointer(); + m_struParam2.dwOutSize = iOutSize2; + m_struParam2.dwRecvTimeOut = 5000; //接收超时时间,单位毫秒 + m_struParam2.write(); + if (!hcisupcms.NET_ECMS_ISAPIPassThrough(loginID, m_struParam2)) { + log.info("删除门禁人脸失败,NET_ECMS_ISAPIPassThrough failed,error:{}", hcisupcms.NET_ECMS_GetLastError()); + return null; + } else { + m_struParam2.read(); + ptrOutByte2.read(); + String res = new String(ptrOutByte2.byValue).trim(); + log.info("NET_ECMS_ISAPIPassThrough succeed\n删除门禁人脸成功, 输出报文: {}", res); + return res; + } + } + + /** + * 查询门禁人脸图片 + * + * @param loginID 登录设备句柄ID + * @param employeeNo 人员工号,按照指定人员查询关联人脸图片 + */ + public String searchFacePicInfo(int loginID, String employeeNo) { + HCISUPCMS.NET_EHOME_PTXML_PARAM m_struParam2 = new HCISUPCMS.NET_EHOME_PTXML_PARAM(); + m_struParam2.read(); + //透传URL,不同功能对应不同的URL,完整协议报文说明需要参考ISAPI协议文档 + String urlInBuffer = "POST /ISAPI/Intelligent/FDLib/FDSearch?format=json"; //查询人脸URL + HCISUPCMS.BYTE_ARRAY ptrurlInBuffer = new HCISUPCMS.BYTE_ARRAY(urlInBuffer.length() + 1); + System.arraycopy(urlInBuffer.getBytes(), 0, ptrurlInBuffer.byValue, 0, urlInBuffer.length()); + ptrurlInBuffer.write(); + m_struParam2.pRequestUrl = ptrurlInBuffer.getPointer(); + m_struParam2.dwRequestUrlLen = urlInBuffer.length(); + + //输入参数,XML或者JSON数据,查询人脸图片json报文 + SearchFaceInfoParam param = new SearchFaceInfoParam(employeeNo); + String input = JSONObject.toJSONString(param); + //批量查询人脸图片json报文 + log.info("查询门禁人脸图片 json报文: {}", input); + + byte[] byInbuffer = input.getBytes(StandardCharsets.UTF_8); + int iInBufLen = byInbuffer.length; + HCISUPCMS.BYTE_ARRAY ptrInBuffer = new HCISUPCMS.BYTE_ARRAY(iInBufLen); + ptrInBuffer.read(); + System.arraycopy(byInbuffer, 0, ptrInBuffer.byValue, 0, iInBufLen); + ptrInBuffer.write(); + m_struParam2.pInBuffer = ptrInBuffer.getPointer();//GET获取时不需要输入参数,输入为null + m_struParam2.dwInSize = iInBufLen; + //输出参数,分配的内存用于存储返回的数据,需要大于等于实际内容大小 + int iOutSize2 = 2 * 1024 * 1024; + HCISUPCMS.BYTE_ARRAY ptrOutByte2 = new HCISUPCMS.BYTE_ARRAY(iOutSize2); + m_struParam2.pOutBuffer = ptrOutByte2.getPointer(); + m_struParam2.dwOutSize = iOutSize2; + m_struParam2.dwRecvTimeOut = 5000; //接收超时时间,单位毫秒 + m_struParam2.write(); + if (!hcisupcms.NET_ECMS_ISAPIPassThrough(loginID, m_struParam2)) { + log.info("查询门禁人脸失败,NET_ECMS_ISAPIPassThrough failed,error:{}", hcisupcms.NET_ECMS_GetLastError()); + return null; + } else { + m_struParam2.read(); + ptrOutByte2.read(); + String res = new String(ptrOutByte2.byValue).trim(); + log.info("NET_ECMS_ISAPIPassThrough succeed\n查询门禁人脸成功, 输出报文: {}", res); + return res; + } + } + + + /** + * lib根目录 + */ + private String libPath() { + String libPath = supSdkProperties.getLibPath(); + if (!StringUtils.hasText(libPath)) { + return SystemUtil.userDir() + File.separator + "lib" + File.separator; + } + return libPath.endsWith(File.separator) ? libPath : libPath + File.separator; + } + + /** + * 日志根目录 + */ + private String logPath() { + String logPath = supSdkProperties.getSdkLogPath(); + return StringUtils.hasText(logPath) ? + logPath : + SystemUtil.userDir() + File.separator + "EHomeSDKLog"; + } + +} diff --git a/src/main/java/net/javase/hksup/starter/service/SsServer.java b/src/main/java/net/javase/hksup/starter/service/SsServer.java new file mode 100644 index 0000000..1581ee3 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/service/SsServer.java @@ -0,0 +1,373 @@ +package net.javase.hksup.starter.service; + +import com.sun.jna.Native; +import lombok.extern.slf4j.Slf4j; +import net.javase.hksup.starter.config.HkSupSdkProperties; +import net.javase.hksup.starter.sdk.HCISUPCMS; +import net.javase.hksup.starter.sdk.HCISUPSS; +import net.javase.hksup.starter.utils.SystemUtil; +import org.springframework.context.ApplicationContext; +import org.springframework.util.StringUtils; + +import java.io.File; +import java.util.Map; + +/** + * SsServer + * + * @author Frank + */ +@Slf4j +public class SsServer { + + public HCISUPSS hCEhomeSS = null; + String PSS_CLIENT_FILE_PATH_PARAM_NAME = "File-Path"; //图片文件路径 + String PSS_CLIENT_VRB_FILENAME_CODE = "Filename-Code";//VRB协议的FilenameCode + String PSS_CLIENT_KMS_USER_NAME = "KMS-Username"; //KMS图片服务器用户名 + String PSS_CLIENT_KMS_PASSWORD = "KMS-Password"; //KMS图片服务器密码 + String PSS_CLIENT_CLOUD_AK_NAME = "Access-Key"; //云存储协议AcessKey + String PSS_CLIENT_CLOUD_SK_NAME = "Secret-Key"; //云存储协议SecretKey + + private HCISUPSS.EHomeSSMsgCallBack eHomeSSMsgCallBack;// 信息回调函数(上报) + private HCISUPSS.EHomeSSStorageCallBack eHomeSSStorageCallBack;// 文件保存回调函数(下载) + private HCISUPSS.EHomeSSRWCallBackEx eHomeSSRWCallBackEx; //读写扩展回调函数 + private HCISUPSS.NET_EHOME_SS_LISTEN_PARAM pSSListenParam = new HCISUPSS.NET_EHOME_SS_LISTEN_PARAM(); + public static int ssHandle = -1; //存储服务监听句柄 + int client = -1; + static int iCount = 0; + byte[] szUrl = new byte[HCISUPSS.MAX_URL_LEN_SS]; + String url = ""; + + private final HkSupSdkProperties hkSupSdkProperties; + + private final ApplicationContext applicationContext; + + public SsServer(HkSupSdkProperties hkSupSdkProperties, ApplicationContext applicationContext) { + this.hkSupSdkProperties = hkSupSdkProperties; + this.applicationContext = applicationContext; + createSDKInstance(); + } + + /** + * 根据不同操作系统选择不同的库文件和库路径 + */ + private boolean createSDKInstance() { + String libPath = libPath(); + if (hCEhomeSS == null) { + synchronized (HCISUPSS.class) { + String strDllPath = ""; + try { + SystemUtil.jnaDebugLoad(hkSupSdkProperties.getJnaDebug()); + if (SystemUtil.isWindows()) { + strDllPath = libPath + "HCISUPSS.dll"; + } else if (SystemUtil.isLinux()) { + strDllPath = libPath + "libHCISUPSS.so"; + } + log.info("loadLibrary: {}", strDllPath); + hCEhomeSS = (HCISUPSS) Native.loadLibrary(strDllPath, HCISUPSS.class); + } catch (Exception ex) { + log.error("loadLibrary: {}, Error: {}", strDllPath, ex.getMessage()); + return false; + } + } + } + return true; + } + + private void eSSInit() { + if (hCEhomeSS == null) { + if (!createSDKInstance()) { + throw new RuntimeException("Load SS SDK fail"); + } + } + String libPath = libPath(); + if (SystemUtil.isWindows()) { + String strPathCrypto = libPath + "libeay32.dll"; //Linux版本是libcrypto.so库文件的路径 + int iPathCryptoLen = strPathCrypto.getBytes().length; + HCISUPCMS.BYTE_ARRAY ptrByteArrayCrypto = new HCISUPCMS.BYTE_ARRAY(iPathCryptoLen + 1); + System.arraycopy(strPathCrypto.getBytes(), 0, ptrByteArrayCrypto.byValue, 0, iPathCryptoLen); + ptrByteArrayCrypto.write(); + log.info(new String(ptrByteArrayCrypto.byValue)); + hCEhomeSS.NET_ESS_SetSDKInitCfg(4, ptrByteArrayCrypto.getPointer()); + + //设置libssl.so所在路径 + String strPathSsl = libPath + "ssleay32.dll"; //Linux版本是libssl.so库文件的路径 + int iPathSslLen = strPathSsl.getBytes().length; + HCISUPCMS.BYTE_ARRAY ptrByteArraySsl = new HCISUPCMS.BYTE_ARRAY(iPathSslLen + 1); + System.arraycopy(strPathSsl.getBytes(), 0, ptrByteArraySsl.byValue, 0, iPathSslLen); + ptrByteArraySsl.write(); + log.info(new String(ptrByteArraySsl.byValue)); + hCEhomeSS.NET_ESS_SetSDKInitCfg(5, ptrByteArraySsl.getPointer()); + + //设置sqlite3库的路径 + String strPathSqlite = libPath + "sqlite3.dll"; + int iPathSqliteLen = strPathSqlite.getBytes().length; + HCISUPCMS.BYTE_ARRAY ptrByteArraySqlite = new HCISUPCMS.BYTE_ARRAY(iPathSqliteLen + 1); + System.arraycopy(strPathSqlite.getBytes(), 0, ptrByteArraySqlite.byValue, 0, iPathSqliteLen); + ptrByteArraySqlite.write(); + log.info(new String(ptrByteArraySqlite.byValue)); + hCEhomeSS.NET_ESS_SetSDKInitCfg(6, ptrByteArraySqlite.getPointer()); + //SDK初始化 + boolean sinit = hCEhomeSS.NET_ESS_Init(); + if (!sinit) { + log.info("NET_ESS_Init失败,错误码:{}", hCEhomeSS.NET_ESS_GetLastError()); + } + //设置图片存储服务器公网地址 (当存在内外网映射时使用 + HCISUPCMS.NET_EHOME_IPADDRESS ipaddress = new HCISUPCMS.NET_EHOME_IPADDRESS(); + String ServerIP = hkSupSdkProperties.getPicServerIp(); + System.arraycopy(ServerIP.getBytes(), 0, ipaddress.szIP, 0, ServerIP.length()); + ipaddress.wPort = Short.parseShort(hkSupSdkProperties.getPicServerPort().toString()); + ipaddress.write(); + boolean b = hCEhomeSS.NET_ESS_SetSDKInitCfg(3, ipaddress.getPointer()); + if (!b) { + log.info("NET_ESS_SetSDKInitCfg失败,错误码:{}", hCEhomeSS.NET_ESS_GetLastError()); + } + + } else if (SystemUtil.isLinux()) { + HCISUPCMS.BYTE_ARRAY ptrByteArrayCrypto = new HCISUPCMS.BYTE_ARRAY(256); + String strPathCrypto = libPath + "libcrypto.so"; //Linux版本是libcrypto.so库文件的路径 + log.info(strPathCrypto); + System.arraycopy(strPathCrypto.getBytes(), 0, ptrByteArrayCrypto.byValue, 0, strPathCrypto.length()); + ptrByteArrayCrypto.write(); + hCEhomeSS.NET_ESS_SetSDKInitCfg(4, ptrByteArrayCrypto.getPointer()); + + //设置libssl.so所在路径 + HCISUPCMS.BYTE_ARRAY ptrByteArraySsl = new HCISUPCMS.BYTE_ARRAY(256); + String strPathSsl = libPath + "libssl.so"; //Linux版本是libssl.so库文件的路径 + log.info(strPathSsl); + System.arraycopy(strPathSsl.getBytes(), 0, ptrByteArraySsl.byValue, 0, strPathSsl.length()); + ptrByteArraySsl.write(); + hCEhomeSS.NET_ESS_SetSDKInitCfg(5, ptrByteArraySsl.getPointer()); + + //设置splite3.so所在路径 + HCISUPCMS.BYTE_ARRAY ptrByteArraysplite = new HCISUPCMS.BYTE_ARRAY(256); + String strPathsplite = libPath + "libsqlite3.so"; //Linux版本是libsqlite3.so库文件的路径 + log.info(strPathsplite); + System.arraycopy(strPathsplite.getBytes(), 0, ptrByteArraysplite.byValue, 0, strPathsplite.length()); + ptrByteArraysplite.write(); + hCEhomeSS.NET_ESS_SetSDKInitCfg(6, ptrByteArraysplite.getPointer()); + //SDK初始化 + boolean sinit = hCEhomeSS.NET_ESS_Init(); + if (!sinit) { + log.info("NET_ESS_Init失败,错误码:{}", hCEhomeSS.NET_ESS_GetLastError()); + } + //设置图片存储服务器公网地址 (当存在内外网映射时使用 + HCISUPCMS.NET_EHOME_IPADDRESS ipaddress = new HCISUPCMS.NET_EHOME_IPADDRESS(); + String ServerIP = hkSupSdkProperties.getPicServerIp(); + System.arraycopy(ServerIP.getBytes(), 0, ipaddress.szIP, 0, ServerIP.length()); + ipaddress.wPort = Short.parseShort(hkSupSdkProperties.getPicServerPort().toString()); + ipaddress.write(); + boolean b = hCEhomeSS.NET_ESS_SetSDKInitCfg(3, ipaddress.getPointer()); + if (!b) { + log.info("NET_ESS_SetSDKInitCfg失败,错误码:{}", hCEhomeSS.NET_ESS_GetLastError()); + } + + } + //启用SDK写日志 + boolean logToFile = hCEhomeSS.NET_ESS_SetLogToFile(3, logPath(), false); + } + + /** + * 开启存储服务监听 + */ + private void startSsListen() { + String SSIP = hkSupSdkProperties.getPicServerListenIp(); + System.arraycopy(SSIP.getBytes(), 0, pSSListenParam.struAddress.szIP, 0, SSIP.length()); + pSSListenParam.struAddress.wPort = Short.parseShort(hkSupSdkProperties.getPicServerListenPort().toString()); + String strKMS_UserName = hkSupSdkProperties.getKmsUsername(); + System.arraycopy(strKMS_UserName.getBytes(), 0, pSSListenParam.szKMS_UserName, 0, strKMS_UserName.length()); + String strKMS_Password = hkSupSdkProperties.getKmsPassword(); + System.arraycopy(strKMS_Password.getBytes(), 0, pSSListenParam.szKMS_Password, 0, strKMS_Password.length()); + String strAccessKey = hkSupSdkProperties.getSzAk(); + System.arraycopy(strAccessKey.getBytes(), 0, pSSListenParam.szAccessKey, 0, strAccessKey.length()); + String strSecretKey = hkSupSdkProperties.getSzSk(); + System.arraycopy(strSecretKey.getBytes(), 0, pSSListenParam.szSecretKey, 0, strSecretKey.length()); + pSSListenParam.byHttps = 0; + /****************************************************************** + * 存储信息回调 + */ + if (eHomeSSMsgCallBack == null) { + Map beansOfType = applicationContext.getBeansOfType(HCISUPSS.EHomeSSMsgCallBack.class); + if (beansOfType.size() < 1) { + throw new RuntimeException("not found EHomeSSMsgCallBack implement!"); + } + beansOfType.forEach((k, v) -> eHomeSSMsgCallBack = v); + } + pSSListenParam.fnSSMsgCb = eHomeSSMsgCallBack; + + /****************************************************************** + * 存储数据回调 + * fnSStorageCb或者fnSSRWCbEx,只需要设置一种回调函数 + * 简单功能测试可以使用存储回调(SDK底层使用db数据库自动存取数据,因此会受到db数据库的性能瓶颈影响) + * 需要自定义URL或者自己读写图片数据,则使用读写扩展回调(推荐) + */ + //存储信息回调 + if (eHomeSSStorageCallBack == null) { + Map beansOfType = applicationContext.getBeansOfType(HCISUPSS.EHomeSSStorageCallBack.class); + if (beansOfType.size() < 1) { + throw new RuntimeException("not found eHomeSSStorageCallBack implement!"); + } + beansOfType.forEach((k, v) -> eHomeSSStorageCallBack = v); + } + pSSListenParam.fnSStorageCb = eHomeSSStorageCallBack; + //读写扩展回调 +// if (eHomeSSRWCallBackEx == null) { +// eHomeSSRWCallBackEx = new cbEHomeSSRWCallBackEx(); +// } +// pSSListenParam.fnSSRWCbEx = eHomeSSRWCallBackEx; + + pSSListenParam.bySecurityMode = 1; + pSSListenParam.write(); + ssHandle = hCEhomeSS.NET_ESS_StartListen(pSSListenParam); + if (ssHandle == -1) { + int err = hCEhomeSS.NET_ESS_GetLastError(); + log.info("NET_ESS_StartListen failed,error: {}", err); + hCEhomeSS.NET_ESS_Fini(); + } else { + String SsListenInfo = new String(pSSListenParam.struAddress.szIP).trim() + "_" + pSSListenParam.struAddress.wPort; + log.info("存储服务器:{}, NET_ESS_StartListen succeed!\n", SsListenInfo); + } + } + + /** + * 创建存储客户端 + */ + private void ssCreateClient(String filePath) { + HCISUPSS.NET_EHOME_SS_CLIENT_PARAM pClientParam = new HCISUPSS.NET_EHOME_SS_CLIENT_PARAM(); + //存储服务器类型 + switch (hkSupSdkProperties.getPicServerType()) { + case 1: + pClientParam.enumType = HCISUPSS.NET_EHOME_SS_CLIENT_TYPE_VRB; + break; + case 2: + pClientParam.enumType = HCISUPSS.NET_EHOME_SS_CLIENT_TYPE_CLOUD; + break; + case 3: + pClientParam.enumType = HCISUPSS.NET_EHOME_SS_CLIENT_TYPE_KMS; + break; + default: + log.info("存储服务器类型选择错误"); + break; + } + pClientParam.struAddress.szIP = hkSupSdkProperties.getPicServerIp().getBytes(); + pClientParam.struAddress.wPort = Short.parseShort(hkSupSdkProperties.getPicServerPort().toString()); + pClientParam.byHttps = 0; + pClientParam.write(); + + client = hCEhomeSS.NET_ESS_CreateClient(pClientParam); + if (client < 0) { + int err = hCEhomeSS.NET_ESS_GetLastError(); + log.warn("创建图片上传/下载客户端出错,错误号:{}, client={}", err, client); + } else { + if (!hCEhomeSS.NET_ESS_ClientSetTimeout(client, 6000, 6000)) { + int err = hCEhomeSS.NET_ESS_GetLastError(); + log.warn("NET_ESS_ClientSetTimeout失败,错误号:{}", err); + } + boolean bSetParam = hCEhomeSS.NET_ESS_ClientSetParam(client, PSS_CLIENT_FILE_PATH_PARAM_NAME, filePath); + boolean bKMS_UserName = hCEhomeSS.NET_ESS_ClientSetParam(client, "SS_CLIENT_KMS_USER_NAME", hkSupSdkProperties.getKmsUsername()); + if (!bKMS_UserName) { + log.warn("NET_ESS_ClientSetParam失败\n err: {}", hCEhomeSS.NET_ESS_GetLastError()); + } + boolean bKMS_PassWord = hCEhomeSS.NET_ESS_ClientSetParam(client, "SS_CLIENT_KMS_PASSWIRD", hkSupSdkProperties.getKmsPassword()); + if(!bKMS_PassWord) { + log.warn("NET_ESS_ClientSetParam失败\n err: {}", hCEhomeSS.NET_ESS_GetLastError()); + } + boolean bCloud_AK = hCEhomeSS.NET_ESS_ClientSetParam(client, PSS_CLIENT_CLOUD_AK_NAME, hkSupSdkProperties.getSzAk()); + boolean bCloud_SK = hCEhomeSS.NET_ESS_ClientSetParam(client, PSS_CLIENT_CLOUD_SK_NAME, hkSupSdkProperties.getSzSk()); + log.info("ssCreateClient: bSetParam: {},bKMS_UserName: {}, bKMS_PassWord: {}, bCloud_AK: {}, bCloud_SK: {}", + bSetParam, bKMS_UserName, bKMS_PassWord, bCloud_AK, bCloud_SK); + } + } + + /** + * 上传图片到存储服务,返回URL + */ + private String ssUploadPic() { + iCount++; + szUrl = new byte[HCISUPSS.MAX_URL_LEN_SS]; + + boolean doUpload = hCEhomeSS.NET_ESS_ClientDoUpload(client, szUrl, HCISUPSS.MAX_URL_LEN_SS - 1); + if (!doUpload) { + int err = hCEhomeSS.NET_ESS_GetLastError(); + log.warn("NET_ESS_ClientDoUpload失败,错误号:{}", err); + return null; + } else { + url = "http://" + hkSupSdkProperties.getPicServerIp() + ":" + hkSupSdkProperties.getPicServerPort() + new String(szUrl).trim(); + log.info("NET_ESS_ClientDoUpload succeed, Count: {}, Pic Url: {}", iCount, url); + return url; + } + } + + /** + * 销毁存储客户端 + */ + private void ssDestroyClient() { + if (hCEhomeSS.NET_ESS_DestroyClient(client))//释放资源 + { + client = -1; + } + } + + /** + * 上传图片返回url + * + * @param fileAbsPath 文件路径 + * @return url + */ + public String uploadPic(String fileAbsPath) { + ssCreateClient(fileAbsPath); + String url = ssUploadPic(); + ssDestroyClient(); + return url; + } + + /** + * 启动服务 + */ + void startSsServer() { + try { + eSSInit(); + startSsListen(); + } catch (Exception ex) { + log.error("启动SS存储服务失败: " + ex.getMessage(), ex); + } + } + + /** + * 停止服务, 销毁 + */ + void stopSsServer() { + if (ssHandle >= 0) { + try { + log.info("开始停止存储SS服务"); + hCEhomeSS.NET_ESS_StopListen(ssHandle); + hCEhomeSS.NET_ESS_Fini(); + log.info("停止存储SS服务成功!"); + } catch (Exception ex) { + log.error("停止存储SS服务失败: " + ex.getMessage(), ex); + } + } + } + + /** + * lib根目录 + */ + private String libPath() { + String libPath = hkSupSdkProperties.getLibPath(); + if (!StringUtils.hasText(libPath)) { + return SystemUtil.userDir() + File.separator + "lib" + File.separator; + } + return libPath.endsWith(File.separator) ? libPath : libPath + File.separator; + } + + /** + * 日志根目录 + */ + private String logPath() { + String logPath = hkSupSdkProperties.getSdkLogPath(); + return StringUtils.hasText(logPath) ? + logPath : + SystemUtil.userDir() + File.separator + "EHomeSDKLog"; + } + +} diff --git a/src/main/java/net/javase/hksup/starter/utils/CommonMethod.java b/src/main/java/net/javase/hksup/starter/utils/CommonMethod.java new file mode 100755 index 0000000..388536a --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/utils/CommonMethod.java @@ -0,0 +1,63 @@ +package net.javase.hksup.starter.utils; + +import com.sun.jna.Pointer; + +import java.nio.charset.Charset; +import java.nio.charset.StandardCharsets; + +public class CommonMethod { + public static void WriteBuffToPointer(byte[] byData, Pointer pInBuffer) { + pInBuffer.write(0, byData, 0, byData.length); + } + + public static String byteToString(byte[] bytes) { + if (null == bytes || bytes.length == 0) { + return ""; + } + int iLengthOfBytes = 0; + for (byte st : bytes) { + if (st != 0) { + iLengthOfBytes++; + } else + break; + } + String strContent = ""; + strContent = new String(bytes, 0, iLengthOfBytes, StandardCharsets.UTF_8); + return strContent; + } + + /** + * utf8字节数组转gbk字节数组 + * + * @param utf8Bytes utf8字节数组 + * @return gbk字节数组 + */ + public static byte[] UTF8toGBK(byte[] utf8Bytes) { + String utf8Str = new String(utf8Bytes, StandardCharsets.UTF_8); + return utf8Str.getBytes(Charset.forName("GBK")); + } + + /** + * utf8字节数组转gbk字符串 + * + * @param utf8Bytes + * @return + */ + public static String UTF8toGBKStr(byte[] utf8Bytes) { + return new String(UTF8toGBK(utf8Bytes), Charset.forName("GBK")); + } + + /** + * 获取resource文件夹下的文件绝对路径 + * + * @param filePath 文件相对于resources文件夹的相对路径, 格式描述举例为 conf/XX/XX.json + * @return + */ + public static String getResFileAbsPath(String filePath) { + if (filePath == null) { + throw new RuntimeException("filePath null error!"); + } + return System.getProperty("user.dir") + "\\resources\\" + filePath; + } + +} diff --git a/src/main/java/net/javase/hksup/starter/utils/ConfigFileUtil.java b/src/main/java/net/javase/hksup/starter/utils/ConfigFileUtil.java new file mode 100755 index 0000000..0b2cc2e --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/utils/ConfigFileUtil.java @@ -0,0 +1,83 @@ +package net.javase.hksup.starter.utils; + +import org.apache.commons.text.StrSubstitutor; + +import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.Path; +import java.nio.file.Paths; +import java.util.Map; + +/** + * @author zhengxiaohui + * @date 2023/8/15 19:07 + * @desc 配置文件处理工具 + */ +public class ConfigFileUtil { + + /** + * 获取请求数据报文内容 + * + * @param templateFilePath 报文模板格式文件位置,位于resources文件夹下面(conf/--/--.xx) + * @param parameter 模板中可以替换的占位参数信息 + * @return + */ + public static String getReqBodyFromTemplate(String templateFilePath, Map parameter) { + String templateContent = ConfigFileUtil.readFileContent(templateFilePath); + return ConfigFileUtil.replace(templateContent, parameter); + } + + /** + * 读取xml配置文件 + * + * @param filePath 文件相对于resources文件夹的相对路径 + * @return + */ + public static String readFileContent(String filePath) { + String resourcePath = CommonMethod.getResFileAbsPath(filePath); + + // 读取指定文件路径的文件内容 + String contentStr = ""; + try { + Path path = Paths.get(resourcePath); + contentStr = new String(Files.readAllBytes(path)); + } catch (IOException e) { + e.printStackTrace(); + } + return contentStr; + } + + /** + * 替换 占位符变量固定为 ${}格式 + * + * @param source 源内容 + * @param parameter 占位符参数 + *

+ * 转义符默认为'$'。如果这个字符放在一个变量引用之前,这个引用将被忽略,不会被替换 如$${a}将直接输出${a} + * @return + */ + public static String replace(String source, Map parameter) { + return replace(source, parameter, "${", "}", false); + } + + /** + * 替换 + * + * @param source 源内容 + * @param parameter 占位符参数 + * @param prefix 占位符前缀 例如:${ + * @param suffix 占位符后缀 例如:} + * @param enableSubstitutionInVariables 是否在变量名称中进行替换 例如:${system-${版本}} + *

+ * 转义符默认为'$'。如果这个字符放在一个变量引用之前,这个引用将被忽略,不会被替换 如$${a}将直接输出${a} + * @return + */ + public static String replace(String source, Map parameter, String prefix, String suffix, boolean enableSubstitutionInVariables) { + //StrSubstitutor不是线程安全的类 + StrSubstitutor strSubstitutor = new StrSubstitutor(parameter, prefix, suffix); + //是否在变量名称中进行替换 + strSubstitutor.setEnableSubstitutionInVariables(enableSubstitutionInVariables); + return strSubstitutor.replace(source); + } + +} diff --git a/src/main/java/net/javase/hksup/starter/utils/SystemUtil.java b/src/main/java/net/javase/hksup/starter/utils/SystemUtil.java new file mode 100755 index 0000000..df521d1 --- /dev/null +++ b/src/main/java/net/javase/hksup/starter/utils/SystemUtil.java @@ -0,0 +1,24 @@ +package net.javase.hksup.starter.utils; + +public class SystemUtil { + + public static final String OS_NAME = System.getProperty("os.name"); + + public static boolean isLinux() { + return OS_NAME.toLowerCase().contains("linux"); + } + + public static boolean isWindows() { + return OS_NAME.toLowerCase().contains("windows"); + } + + public static String userDir() { + return System.getProperty("user.dir"); + } + + public static void jnaDebugLoad(boolean flag) { + if (flag) { + System.setProperty("jna.debug_load", "true"); + } + } +}