commit 2c8d7feb95bcde3fed1c4be2d4dfa88f20921b00 Author: liuguijing <123456> Date: Mon May 20 15:26:47 2024 +0800 初始化仓库 diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..549e00a --- /dev/null +++ b/.gitignore @@ -0,0 +1,33 @@ +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/ diff --git a/.mvn/wrapper/maven-wrapper.jar b/.mvn/wrapper/maven-wrapper.jar new file mode 100644 index 0000000..cb28b0e Binary files /dev/null and b/.mvn/wrapper/maven-wrapper.jar differ diff --git a/.mvn/wrapper/maven-wrapper.properties b/.mvn/wrapper/maven-wrapper.properties new file mode 100644 index 0000000..e70e7bc --- /dev/null +++ b/.mvn/wrapper/maven-wrapper.properties @@ -0,0 +1,2 @@ +distributionUrl=https://repo.maven.apache.org/maven2/org/apache/maven/apache-maven/3.9.6/apache-maven-3.9.6-bin.zip +wrapperUrl=https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar diff --git a/mvnw b/mvnw new file mode 100644 index 0000000..66df285 --- /dev/null +++ b/mvnw @@ -0,0 +1,308 @@ +#!/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. +# ---------------------------------------------------------------------------- + +# ---------------------------------------------------------------------------- +# Apache Maven Wrapper startup batch script, version 3.2.0 +# +# Required ENV vars: +# ------------------ +# JAVA_HOME - location of a JDK home dir +# +# Optional ENV vars +# ----------------- +# 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 + JAVA_HOME="$(/usr/libexec/java_home)"; export JAVA_HOME + else + JAVA_HOME="/Library/Java/Home"; export JAVA_HOME + fi + fi + ;; +esac + +if [ -z "$JAVA_HOME" ] ; then + if [ -r /etc/gentoo-release ] ; then + JAVA_HOME=$(java-config --jre-home) + fi +fi + +# For Cygwin, ensure paths are in UNIX format before anything is touched +if $cygwin ; then + [ -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 "$JAVA_HOME" ] && [ -d "$JAVA_HOME" ] && + JAVA_HOME="$(cd "$JAVA_HOME" || (echo "cannot cd into $JAVA_HOME."; exit 1); 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 2>/dev/null; \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 + +# 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/.." || exit 1; pwd) + fi + # end of workaround + done + printf '%s' "$(cd "$basedir" || exit 1; pwd)" +} + +# concatenates all lines of a file +concat_lines() { + if [ -f "$1" ]; then + # Remove \r in case we run on Windows within Git Bash + # and check out the repository with auto CRLF management + # enabled. Otherwise, we may read lines that are delimited with + # \r\n and produce $'-Xarg\r' rather than -Xarg due to word + # splitting rules. + tr -s '\r\n' ' ' < "$1" + fi +} + +log() { + if [ "$MVNW_VERBOSE" = true ]; then + printf '%s\n' "$1" + fi +} + +BASE_DIR=$(find_maven_basedir "$(dirname "$0")") +if [ -z "$BASE_DIR" ]; then + exit 1; +fi + +MAVEN_PROJECTBASEDIR=${MAVEN_BASEDIR:-"$BASE_DIR"}; export MAVEN_PROJECTBASEDIR +log "$MAVEN_PROJECTBASEDIR" + +########################################################################################## +# 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. +########################################################################################## +wrapperJarPath="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" +if [ -r "$wrapperJarPath" ]; then + log "Found $wrapperJarPath" +else + log "Couldn't find $wrapperJarPath, downloading it ..." + + if [ -n "$MVNW_REPOURL" ]; then + wrapperUrl="$MVNW_REPOURL/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar" + else + wrapperUrl="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar" + fi + while IFS="=" read -r key value; do + # Remove '\r' from value to allow usage on windows as IFS does not consider '\r' as a separator ( considers space, tab, new line ('\n'), and custom '=' ) + safeValue=$(echo "$value" | tr -d '\r') + case "$key" in (wrapperUrl) wrapperUrl="$safeValue"; break ;; + esac + done < "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.properties" + log "Downloading from: $wrapperUrl" + + if $cygwin; then + wrapperJarPath=$(cygpath --path --windows "$wrapperJarPath") + fi + + if command -v wget > /dev/null; then + log "Found wget ... using wget" + [ "$MVNW_VERBOSE" = true ] && QUIET="" || QUIET="--quiet" + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + wget $QUIET "$wrapperUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" + else + wget $QUIET --http-user="$MVNW_USERNAME" --http-password="$MVNW_PASSWORD" "$wrapperUrl" -O "$wrapperJarPath" || rm -f "$wrapperJarPath" + fi + elif command -v curl > /dev/null; then + log "Found curl ... using curl" + [ "$MVNW_VERBOSE" = true ] && QUIET="" || QUIET="--silent" + if [ -z "$MVNW_USERNAME" ] || [ -z "$MVNW_PASSWORD" ]; then + curl $QUIET -o "$wrapperJarPath" "$wrapperUrl" -f -L || rm -f "$wrapperJarPath" + else + curl $QUIET --user "$MVNW_USERNAME:$MVNW_PASSWORD" -o "$wrapperJarPath" "$wrapperUrl" -f -L || rm -f "$wrapperJarPath" + fi + else + log "Falling back to using Java to download" + javaSource="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/MavenWrapperDownloader.java" + javaClass="$MAVEN_PROJECTBASEDIR/.mvn/wrapper/MavenWrapperDownloader.class" + # For Cygwin, switch paths to Windows format before running javac + if $cygwin; then + javaSource=$(cygpath --path --windows "$javaSource") + javaClass=$(cygpath --path --windows "$javaClass") + fi + if [ -e "$javaSource" ]; then + if [ ! -e "$javaClass" ]; then + log " - Compiling MavenWrapperDownloader.java ..." + ("$JAVA_HOME/bin/javac" "$javaSource") + fi + if [ -e "$javaClass" ]; then + log " - Running MavenWrapperDownloader.java ..." + ("$JAVA_HOME/bin/java" -cp .mvn/wrapper MavenWrapperDownloader "$wrapperUrl" "$wrapperJarPath") || rm -f "$wrapperJarPath" + fi + fi + fi +fi +########################################################################################## +# End of extension +########################################################################################## + +# If specified, validate the SHA-256 sum of the Maven wrapper jar file +wrapperSha256Sum="" +while IFS="=" read -r key value; do + case "$key" in (wrapperSha256Sum) wrapperSha256Sum=$value; break ;; + esac +done < "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.properties" +if [ -n "$wrapperSha256Sum" ]; then + wrapperSha256Result=false + if command -v sha256sum > /dev/null; then + if echo "$wrapperSha256Sum $wrapperJarPath" | sha256sum -c > /dev/null 2>&1; then + wrapperSha256Result=true + fi + elif command -v shasum > /dev/null; then + if echo "$wrapperSha256Sum $wrapperJarPath" | shasum -a 256 -c > /dev/null 2>&1; then + wrapperSha256Result=true + fi + else + echo "Checksum validation was requested but neither 'sha256sum' or 'shasum' are available." + echo "Please install either command, or disable validation by removing 'wrapperSha256Sum' from your maven-wrapper.properties." + exit 1 + fi + if [ $wrapperSha256Result = false ]; then + echo "Error: Failed to validate Maven wrapper SHA-256, your Maven wrapper might be compromised." >&2 + echo "Investigate or delete $wrapperJarPath to attempt a clean download." >&2 + echo "If you updated your Maven version, you need to update the specified wrapperSha256Sum property." >&2 + exit 1 + fi +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 "$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 + +# shellcheck disable=SC2086 # safe args +exec "$JAVACMD" \ + $MAVEN_OPTS \ + $MAVEN_DEBUG_OPTS \ + -classpath "$MAVEN_PROJECTBASEDIR/.mvn/wrapper/maven-wrapper.jar" \ + "-Dmaven.multiModuleProjectDirectory=${MAVEN_PROJECTBASEDIR}" \ + ${WRAPPER_LAUNCHER} $MAVEN_CONFIG "$@" diff --git a/mvnw.cmd b/mvnw.cmd new file mode 100644 index 0000000..95ba6f5 --- /dev/null +++ b/mvnw.cmd @@ -0,0 +1,205 @@ +@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 Apache Maven Wrapper startup batch script, version 3.2.0 +@REM +@REM Required ENV vars: +@REM JAVA_HOME - location of a JDK home dir +@REM +@REM Optional ENV vars +@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 WRAPPER_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar" + +FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( + IF "%%A"=="wrapperUrl" SET WRAPPER_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 WRAPPER_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.2.0/maven-wrapper-3.2.0.jar" + ) + if "%MVNW_VERBOSE%" == "true" ( + echo Couldn't find %WRAPPER_JAR%, downloading it ... + echo Downloading from: %WRAPPER_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('%WRAPPER_URL%', '%WRAPPER_JAR%')"^ + "}" + if "%MVNW_VERBOSE%" == "true" ( + echo Finished downloading %WRAPPER_JAR% + ) +) +@REM End of extension + +@REM If specified, validate the SHA-256 sum of the Maven wrapper jar file +SET WRAPPER_SHA_256_SUM="" +FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO ( + IF "%%A"=="wrapperSha256Sum" SET WRAPPER_SHA_256_SUM=%%B +) +IF NOT %WRAPPER_SHA_256_SUM%=="" ( + powershell -Command "&{"^ + "$hash = (Get-FileHash \"%WRAPPER_JAR%\" -Algorithm SHA256).Hash.ToLower();"^ + "If('%WRAPPER_SHA_256_SUM%' -ne $hash){"^ + " Write-Output 'Error: Failed to validate Maven wrapper SHA-256, your Maven wrapper might be compromised.';"^ + " Write-Output 'Investigate or delete %WRAPPER_JAR% to attempt a clean download.';"^ + " Write-Output 'If you updated your Maven version, you need to update the specified wrapperSha256Sum property.';"^ + " exit 1;"^ + "}"^ + "}" + if ERRORLEVEL 1 goto error +) + +@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..6d94ed0 --- /dev/null +++ b/pom.xml @@ -0,0 +1,89 @@ + + + 4.0.0 + + org.springframework.boot + spring-boot-starter-parent + 2.5.6 + + + com.shxy + xyhkcamera + 0.0.1-SNAPSHOT + xyhkcamera + Demo project for Spring Boot + + 1.8 + 2.5.6 + + + + + org.springframework.boot + spring-boot-dependencies + ${spring-boot-dependencies.version} + pom + + + + org.springframework.boot + spring-boot-starter + + + + com.sun.jna + examples + 1.0 + + + + + org.projectlombok + lombok + + + + + com.sun.jna + jna + 3.0.9 + + + + + org.springframework.boot + spring-boot-starter-log4j2 + + + + org.springframework.boot + spring-boot-starter-test + test + + + org.slf4j + slf4j-log4j12 + + + org.springframework.boot + spring-boot-starter-logging + + + ch.qos.logback + logback-classic + + + + + + + + + org.springframework.boot + spring-boot-maven-plugin + + + + + diff --git a/sdk/hkliblinux64/HCNetSDKCom/libAudioIntercom.so b/sdk/hkliblinux64/HCNetSDKCom/libAudioIntercom.so new file mode 100644 index 0000000..49685d9 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libAudioIntercom.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCAlarm.so b/sdk/hkliblinux64/HCNetSDKCom/libHCAlarm.so new file mode 100644 index 0000000..a54dee3 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCAlarm.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCCoreDevCfg.so b/sdk/hkliblinux64/HCNetSDKCom/libHCCoreDevCfg.so new file mode 100644 index 0000000..5ada40f Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCCoreDevCfg.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCDisplay.so b/sdk/hkliblinux64/HCNetSDKCom/libHCDisplay.so new file mode 100644 index 0000000..9871c9e Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCDisplay.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCGeneralCfgMgr.so b/sdk/hkliblinux64/HCNetSDKCom/libHCGeneralCfgMgr.so new file mode 100644 index 0000000..7666233 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCGeneralCfgMgr.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCIndustry.so b/sdk/hkliblinux64/HCNetSDKCom/libHCIndustry.so new file mode 100644 index 0000000..4b11107 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCIndustry.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCPlayBack.so b/sdk/hkliblinux64/HCNetSDKCom/libHCPlayBack.so new file mode 100644 index 0000000..6137552 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCPlayBack.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCPreview.so b/sdk/hkliblinux64/HCNetSDKCom/libHCPreview.so new file mode 100644 index 0000000..035cd3d Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCPreview.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libHCVoiceTalk.so b/sdk/hkliblinux64/HCNetSDKCom/libHCVoiceTalk.so new file mode 100644 index 0000000..6a2ab90 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libHCVoiceTalk.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libStreamTransClient.so b/sdk/hkliblinux64/HCNetSDKCom/libStreamTransClient.so new file mode 100644 index 0000000..6b16337 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libStreamTransClient.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libSystemTransform.so b/sdk/hkliblinux64/HCNetSDKCom/libSystemTransform.so new file mode 100644 index 0000000..086c631 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libSystemTransform.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libanalyzedata.so b/sdk/hkliblinux64/HCNetSDKCom/libanalyzedata.so new file mode 100644 index 0000000..fa416e9 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libanalyzedata.so differ diff --git a/sdk/hkliblinux64/HCNetSDKCom/libiconv2.so b/sdk/hkliblinux64/HCNetSDKCom/libiconv2.so new file mode 100644 index 0000000..d17b0a8 Binary files /dev/null and b/sdk/hkliblinux64/HCNetSDKCom/libiconv2.so differ diff --git a/sdk/hkliblinux64/HCNetSDK_Log_Switch.xml b/sdk/hkliblinux64/HCNetSDK_Log_Switch.xml new file mode 100644 index 0000000..8b7e236 --- /dev/null +++ b/sdk/hkliblinux64/HCNetSDK_Log_Switch.xml @@ -0,0 +1,12 @@ + + + + 3 + ./SDKLOG/ + true + + + 120 + 1 + + \ No newline at end of file diff --git a/sdk/hkliblinux64/libAudioRender.so b/sdk/hkliblinux64/libAudioRender.so new file mode 100644 index 0000000..f39a4a1 Binary files /dev/null and b/sdk/hkliblinux64/libAudioRender.so differ diff --git a/sdk/hkliblinux64/libHCCore.so b/sdk/hkliblinux64/libHCCore.so new file mode 100644 index 0000000..7846902 Binary files /dev/null and b/sdk/hkliblinux64/libHCCore.so differ diff --git a/sdk/hkliblinux64/libNPQos.so b/sdk/hkliblinux64/libNPQos.so new file mode 100644 index 0000000..4972715 Binary files /dev/null and b/sdk/hkliblinux64/libNPQos.so differ diff --git a/sdk/hkliblinux64/libPlayCtrl.so b/sdk/hkliblinux64/libPlayCtrl.so new file mode 100644 index 0000000..e255c22 Binary files /dev/null and b/sdk/hkliblinux64/libPlayCtrl.so differ diff --git a/sdk/hkliblinux64/libSuperRender.so b/sdk/hkliblinux64/libSuperRender.so new file mode 100644 index 0000000..3f36846 Binary files /dev/null and b/sdk/hkliblinux64/libSuperRender.so differ diff --git a/sdk/hkliblinux64/libcrypto.so.1.1 b/sdk/hkliblinux64/libcrypto.so.1.1 new file mode 100644 index 0000000..88c3746 Binary files /dev/null and b/sdk/hkliblinux64/libcrypto.so.1.1 differ diff --git a/sdk/hkliblinux64/libhcnetsdk.so b/sdk/hkliblinux64/libhcnetsdk.so new file mode 100644 index 0000000..2607cee Binary files /dev/null and b/sdk/hkliblinux64/libhcnetsdk.so differ diff --git a/sdk/hkliblinux64/libhpr.so b/sdk/hkliblinux64/libhpr.so new file mode 100644 index 0000000..8efcabb Binary files /dev/null and b/sdk/hkliblinux64/libhpr.so differ diff --git a/sdk/hkliblinux64/libopenal.so.1 b/sdk/hkliblinux64/libopenal.so.1 new file mode 100644 index 0000000..a9dcb82 Binary files /dev/null and b/sdk/hkliblinux64/libopenal.so.1 differ diff --git a/sdk/hkliblinux64/libssl.so.1.1 b/sdk/hkliblinux64/libssl.so.1.1 new file mode 100644 index 0000000..f3e4481 Binary files /dev/null and b/sdk/hkliblinux64/libssl.so.1.1 differ diff --git a/sdk/hkliblinux64/libz.so b/sdk/hkliblinux64/libz.so new file mode 100644 index 0000000..13b4ed9 Binary files /dev/null and b/sdk/hkliblinux64/libz.so differ diff --git a/sdk/hklibwin64/AudioRender.dll b/sdk/hklibwin64/AudioRender.dll new file mode 100644 index 0000000..4935684 Binary files /dev/null and b/sdk/hklibwin64/AudioRender.dll differ diff --git a/sdk/hklibwin64/ClientDemo.exe b/sdk/hklibwin64/ClientDemo.exe new file mode 100644 index 0000000..75aedfa Binary files /dev/null and b/sdk/hklibwin64/ClientDemo.exe differ diff --git a/sdk/hklibwin64/ClientDemoDll/ReadMe.txt b/sdk/hklibwin64/ClientDemoDll/ReadMe.txt new file mode 100644 index 0000000..8006f36 --- /dev/null +++ b/sdk/hklibwin64/ClientDemoDll/ReadMe.txt @@ -0,0 +1 @@ +The dll in this directoryiconv.dll,libxml2.dll,zlib1.dll,calib.dllonly used in ClientDemo. \ No newline at end of file diff --git a/sdk/hklibwin64/ClientDemoDll/calib.dll b/sdk/hklibwin64/ClientDemoDll/calib.dll new file mode 100644 index 0000000..328c63e Binary files /dev/null and b/sdk/hklibwin64/ClientDemoDll/calib.dll differ diff --git a/sdk/hklibwin64/ClientDemoDll/iconv.dll b/sdk/hklibwin64/ClientDemoDll/iconv.dll new file mode 100644 index 0000000..df71882 Binary files /dev/null and b/sdk/hklibwin64/ClientDemoDll/iconv.dll differ diff --git a/sdk/hklibwin64/ClientDemoDll/libcrypto-1_1-x64.dll b/sdk/hklibwin64/ClientDemoDll/libcrypto-1_1-x64.dll new file mode 100644 index 0000000..f2f96d7 Binary files /dev/null and b/sdk/hklibwin64/ClientDemoDll/libcrypto-1_1-x64.dll differ diff --git a/sdk/hklibwin64/ClientDemoDll/libssl-1_1-x64.dll b/sdk/hklibwin64/ClientDemoDll/libssl-1_1-x64.dll new file mode 100644 index 0000000..8034d79 Binary files /dev/null and b/sdk/hklibwin64/ClientDemoDll/libssl-1_1-x64.dll differ diff --git a/sdk/hklibwin64/ClientDemoDll/libxml2.dll b/sdk/hklibwin64/ClientDemoDll/libxml2.dll new file mode 100644 index 0000000..c8d57f3 Binary files /dev/null and b/sdk/hklibwin64/ClientDemoDll/libxml2.dll differ diff --git a/sdk/hklibwin64/ClientDemoDll/zlib1.dll b/sdk/hklibwin64/ClientDemoDll/zlib1.dll new file mode 100644 index 0000000..82913fb Binary files /dev/null and b/sdk/hklibwin64/ClientDemoDll/zlib1.dll differ diff --git a/sdk/hklibwin64/GdiPlus.dll b/sdk/hklibwin64/GdiPlus.dll new file mode 100644 index 0000000..b759ed6 Binary files /dev/null and b/sdk/hklibwin64/GdiPlus.dll differ diff --git a/sdk/hklibwin64/GdiPlus.lib b/sdk/hklibwin64/GdiPlus.lib new file mode 100644 index 0000000..6fb1bb6 Binary files /dev/null and b/sdk/hklibwin64/GdiPlus.lib differ diff --git a/sdk/hklibwin64/HCCore.dll b/sdk/hklibwin64/HCCore.dll new file mode 100644 index 0000000..48f8411 Binary files /dev/null and b/sdk/hklibwin64/HCCore.dll differ diff --git a/sdk/hklibwin64/HCCore.lib b/sdk/hklibwin64/HCCore.lib new file mode 100644 index 0000000..495c74a Binary files /dev/null and b/sdk/hklibwin64/HCCore.lib differ diff --git a/sdk/hklibwin64/HCNetSDK.dll b/sdk/hklibwin64/HCNetSDK.dll new file mode 100644 index 0000000..2ed412e Binary files /dev/null and b/sdk/hklibwin64/HCNetSDK.dll differ diff --git a/sdk/hklibwin64/HCNetSDK.lib b/sdk/hklibwin64/HCNetSDK.lib new file mode 100644 index 0000000..ff8e9e2 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDK.lib differ diff --git a/sdk/hklibwin64/HCNetSDKCom/AnalyzeData.dll b/sdk/hklibwin64/HCNetSDKCom/AnalyzeData.dll new file mode 100644 index 0000000..2317b39 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/AnalyzeData.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/AudioIntercom.dll b/sdk/hklibwin64/HCNetSDKCom/AudioIntercom.dll new file mode 100644 index 0000000..071a5e2 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/AudioIntercom.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/AudioRender.dll b/sdk/hklibwin64/HCNetSDKCom/AudioRender.dll new file mode 100644 index 0000000..4935684 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/AudioRender.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCAlarm.dll b/sdk/hklibwin64/HCNetSDKCom/HCAlarm.dll new file mode 100644 index 0000000..bdb8406 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCAlarm.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCAlarm.lib b/sdk/hklibwin64/HCNetSDKCom/HCAlarm.lib new file mode 100644 index 0000000..0aa0d4c Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCAlarm.lib differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCCoreDevCfg.dll b/sdk/hklibwin64/HCNetSDKCom/HCCoreDevCfg.dll new file mode 100644 index 0000000..7cd924e Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCCoreDevCfg.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCDisplay.dll b/sdk/hklibwin64/HCNetSDKCom/HCDisplay.dll new file mode 100644 index 0000000..f0a2b7c Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCDisplay.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCGeneralCfgMgr.dll b/sdk/hklibwin64/HCNetSDKCom/HCGeneralCfgMgr.dll new file mode 100644 index 0000000..3719694 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCGeneralCfgMgr.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCGeneralCfgMgr.lib b/sdk/hklibwin64/HCNetSDKCom/HCGeneralCfgMgr.lib new file mode 100644 index 0000000..7091c25 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCGeneralCfgMgr.lib differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCIndustry.dll b/sdk/hklibwin64/HCNetSDKCom/HCIndustry.dll new file mode 100644 index 0000000..9af77a1 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCIndustry.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCPlayBack.dll b/sdk/hklibwin64/HCNetSDKCom/HCPlayBack.dll new file mode 100644 index 0000000..8d8e8a7 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCPlayBack.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCPreview.dll b/sdk/hklibwin64/HCNetSDKCom/HCPreview.dll new file mode 100644 index 0000000..005656d Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCPreview.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCPreview.lib b/sdk/hklibwin64/HCNetSDKCom/HCPreview.lib new file mode 100644 index 0000000..18d4d63 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCPreview.lib differ diff --git a/sdk/hklibwin64/HCNetSDKCom/HCVoiceTalk.dll b/sdk/hklibwin64/HCNetSDKCom/HCVoiceTalk.dll new file mode 100644 index 0000000..eb04a1e Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/HCVoiceTalk.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/OpenAL32.dll b/sdk/hklibwin64/HCNetSDKCom/OpenAL32.dll new file mode 100644 index 0000000..4b35df4 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/OpenAL32.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/StreamTransClient.dll b/sdk/hklibwin64/HCNetSDKCom/StreamTransClient.dll new file mode 100644 index 0000000..a69e9bf Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/StreamTransClient.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/SystemTransform.dll b/sdk/hklibwin64/HCNetSDKCom/SystemTransform.dll new file mode 100644 index 0000000..f704e49 Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/SystemTransform.dll differ diff --git a/sdk/hklibwin64/HCNetSDKCom/libiconv2.dll b/sdk/hklibwin64/HCNetSDKCom/libiconv2.dll new file mode 100644 index 0000000..978e2fa Binary files /dev/null and b/sdk/hklibwin64/HCNetSDKCom/libiconv2.dll differ diff --git a/sdk/hklibwin64/HXVA.dll b/sdk/hklibwin64/HXVA.dll new file mode 100644 index 0000000..b7ebfcc Binary files /dev/null and b/sdk/hklibwin64/HXVA.dll differ diff --git a/sdk/hklibwin64/HmMerge.dll b/sdk/hklibwin64/HmMerge.dll new file mode 100644 index 0000000..d46a6ac Binary files /dev/null and b/sdk/hklibwin64/HmMerge.dll differ diff --git a/sdk/hklibwin64/LocalSensorAdd.dat b/sdk/hklibwin64/LocalSensorAdd.dat new file mode 100644 index 0000000..e69de29 diff --git a/sdk/hklibwin64/LocalXml.zip b/sdk/hklibwin64/LocalXml.zip new file mode 100644 index 0000000..3620e68 Binary files /dev/null and b/sdk/hklibwin64/LocalXml.zip differ diff --git a/sdk/hklibwin64/MP_Render.dll b/sdk/hklibwin64/MP_Render.dll new file mode 100644 index 0000000..e5cde63 Binary files /dev/null and b/sdk/hklibwin64/MP_Render.dll differ diff --git a/sdk/hklibwin64/NPQos.dll b/sdk/hklibwin64/NPQos.dll new file mode 100644 index 0000000..c709f56 Binary files /dev/null and b/sdk/hklibwin64/NPQos.dll differ diff --git a/sdk/hklibwin64/OpenAL32.dll b/sdk/hklibwin64/OpenAL32.dll new file mode 100644 index 0000000..4b35df4 Binary files /dev/null and b/sdk/hklibwin64/OpenAL32.dll differ diff --git a/sdk/hklibwin64/PlayCtrl.dll b/sdk/hklibwin64/PlayCtrl.dll new file mode 100644 index 0000000..2a5eb97 Binary files /dev/null and b/sdk/hklibwin64/PlayCtrl.dll differ diff --git a/sdk/hklibwin64/PlayCtrl.lib b/sdk/hklibwin64/PlayCtrl.lib new file mode 100644 index 0000000..ddcf2f4 Binary files /dev/null and b/sdk/hklibwin64/PlayCtrl.lib differ diff --git a/sdk/hklibwin64/SuperRender.dll b/sdk/hklibwin64/SuperRender.dll new file mode 100644 index 0000000..b00c0c2 Binary files /dev/null and b/sdk/hklibwin64/SuperRender.dll differ diff --git a/sdk/hklibwin64/YUVProcess.dll b/sdk/hklibwin64/YUVProcess.dll new file mode 100644 index 0000000..d86ec3f Binary files /dev/null and b/sdk/hklibwin64/YUVProcess.dll differ diff --git a/sdk/hklibwin64/hlog.dll b/sdk/hklibwin64/hlog.dll new file mode 100644 index 0000000..fe2298a Binary files /dev/null and b/sdk/hklibwin64/hlog.dll differ diff --git a/sdk/hklibwin64/hpr.dll b/sdk/hklibwin64/hpr.dll new file mode 100644 index 0000000..eef0d55 Binary files /dev/null and b/sdk/hklibwin64/hpr.dll differ diff --git a/sdk/hklibwin64/libcrypto-1_1-x64.dll b/sdk/hklibwin64/libcrypto-1_1-x64.dll new file mode 100644 index 0000000..6731338 Binary files /dev/null and b/sdk/hklibwin64/libcrypto-1_1-x64.dll differ diff --git a/sdk/hklibwin64/libmmd.dll b/sdk/hklibwin64/libmmd.dll new file mode 100644 index 0000000..8becb5e Binary files /dev/null and b/sdk/hklibwin64/libmmd.dll differ diff --git a/sdk/hklibwin64/libssl-1_1-x64.dll b/sdk/hklibwin64/libssl-1_1-x64.dll new file mode 100644 index 0000000..ac5e8fd Binary files /dev/null and b/sdk/hklibwin64/libssl-1_1-x64.dll differ diff --git a/sdk/hklibwin64/zlib1.dll b/sdk/hklibwin64/zlib1.dll new file mode 100644 index 0000000..9c37a84 Binary files /dev/null and b/sdk/hklibwin64/zlib1.dll differ diff --git a/src/main/java/com/shxy/xyhkcamera/AppRunner.java b/src/main/java/com/shxy/xyhkcamera/AppRunner.java new file mode 100644 index 0000000..4266910 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/AppRunner.java @@ -0,0 +1,20 @@ +package com.shxy.xyhkcamera; + + +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.ApplicationArguments; +import org.springframework.boot.ApplicationRunner; +import org.springframework.stereotype.Component; + +@Component +public class AppRunner implements ApplicationRunner { + @Autowired + private SdkInitService hksdkInitService; + + @Override + public void run(ApplicationArguments args) throws Exception { + hksdkInitService.initSdk(); + } +} + + diff --git a/src/main/java/com/shxy/xyhkcamera/HCNetSDK.java b/src/main/java/com/shxy/xyhkcamera/HCNetSDK.java new file mode 100644 index 0000000..16e9889 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/HCNetSDK.java @@ -0,0 +1,10761 @@ +package com.shxy.xyhkcamera; + + +import com.sun.jna.*; +import com.sun.jna.examples.win32.W32API; +import com.sun.jna.examples.win32.W32API.HWND; +import com.sun.jna.ptr.ByteByReference; +import com.sun.jna.ptr.IntByReference; +import com.sun.jna.ptr.ShortByReference; +import com.sun.jna.win32.StdCallLibrary; + +import java.util.Arrays; +import java.util.List; + +//SDK接口说明,HCNetSDK.dll +public interface HCNetSDK extends StdCallLibrary { + + /** + * 通过这个常量,就可以获得这个接口的实例,从而使用接口的方法,也就是调用外部dll/so的函数 + * 第一个参数是动态链接库dll/so的全路径名称(可以是绝对路径或者相对路径) + * TODO 想让SDK起效,必须指明SDK的绝对路径;同时,要和linux中的环境配置路径一致 + */ +// HCNetSDK INSTANCE = (HCNetSDK) Native.loadLibrary("/home/hksdk/lib/libhcnetsdk.so",HCNetSDK.class); + + HCNetSDK INSTANCE = (HCNetSDK) Native.loadLibrary("D:\\Workspace\\HK\\HCNetSDK.dll", HCNetSDK.class); + + + /*** 宏定义 ***/ + //常量 + + 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指令, Pentium3以上支持SSE指令; + public static final int NET_DVR_SUPPORT_MMX = 0x100;//CPU支持MMX指令集, 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_GET_PTZLOCKCFG = 3287;//获取云台锁定信息 + public static final int NET_DVR_SET_PTZLOCKCFG = 3288;//设置云台锁定信息 + + 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 int dwChildLeaveNum; // 小孩离开人数 + public int dwChildEnterNum; // 小孩进入人数 + public int dwDuplicatePeople; // 重复人数 + public int dwXmlLen;//XML透传数据长度, 即EventNotificationAlert XML Block的数据长度 + public Pointer pXmlBuf; // XML报警信息指针,其XML对应到EventNotificationAlert XML Block + public byte[] byRes2 = new byte[8]; + + 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]; /* 保留 */ + + + } + + /* IP通道匹配参数 */ + public static class NET_DVR_IPCHANINFO extends Structure {/* IP通道匹配参数 */ + + public byte byEnable; /* 该通道是否在线 */ + public byte byIPID; //IP设备ID低8位,当设备ID为0时表示通道不可用 + public byte byChannel; /* 通道号 */ + public byte byIPIDHigh; // IP设备ID的高8位 + public byte byTransProtocol; //传输协议类型0-TCP/auto(具体有设备决定),1-UDP 2-多播 3-仅TCP 4-auto + public byte byGetStream; /* 是否对该通道取流,0-是,1-否*/ + public byte[] byres = new byte[30]; /* 保留 */ + + + } + + 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 int 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),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_U,2- G711_A,5- MP2L2,6- G726,7- AAC,8- PCM,9-G722,10-G723,11-G729,12-AAC_LC,13-AAC_LD,14-Opus,15-MP3,16-ADPCM + public byte byAudioSamplingRate;//音频采样率 0-默认,1-16kHZ,2-32kHZ,3-48kHZ, 4- 44.1kHZ,5-8kHZ + public byte byAudioBitRate;// 音频码率 参考 BITRATE_ENCODE_INDEX + public byte[] byres = new byte[4];//这里保留音频的压缩参数 + public byte bySupport;//bySupport Bit0表示 Mp2l2前4个字节的含义表示后面内容音频数据长度 + } + + 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: + uEventParam.setType(NET_VCA_AREA.class); + break; + case 3: + uEventParam.setType(NET_VCA_AREA.class); + break; + case 4: + uEventParam.setType(NET_VCA_INTRUSION.class); + break; + case 15: + uEventParam.setType(NET_VCA_LEAVE_POSITION.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 NET_VCA_INTRUSION struIntrusion; //区域入侵参数 + public NET_VCA_LEAVE_POSITION struLeavePos; //参数 + + } + + //穿越警戒面参数 + 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]; + } + + + //根据报警延迟时间来标识报警中带图片,报警间隔和IO报警一致,1秒发送一个。 +//入侵参数 + 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 ~ 其他, + 该字段支持多选,按位取值,例如3表示1+2. + */ + public byte byDetectionTarget; + public byte byPriority;//优先级,0~低,1~中,2~高 + public byte byAlarmConfidence; //报警置信度, 0-低,1-较低,2-较高,3-高 + public byte byRecordConfidence; //录像置信度, 0-低,1-较低,2-较高,3-高 + } + + public static class NET_VCA_LEAVE_POSITION extends Structure { + public NET_VCA_POLYGON struRegion; //区域范围 + public short wLeaveDelay; //无人报警时间,单位:s + public short wStaticDelay; //睡觉报警时间,单位:s + public byte byMode; //模式,0-事件,,3-在岗(当人员回到岗位) + public byte byPersonType; //值岗人数类型,0-单人值岗,1-双人值岗 + public byte byOnPosition; //在岗人数,1-10,默认1 + public byte bySensitivity; //灵敏度参数,范围[1,5] + } + + 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_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 bySensitivity; //灵敏度参数,范围[1,5] + /* + 检测目标,可支持多选,具体定义为: + 0~所有目标(表示不锁定检测目标,所有目标都将进行检测) + 0x01 ~ 人, + 0x02 ~ 车, + 0x04 ~ 其他, + 该字段支持多选,按位取值,例如3表示1+2. + */ + public byte byDetectionTarget; + public byte byPriority;//优先级,0~低,1~中,2~高 + public byte[] byRes = new byte[5]; + } + + //多边形结构体 + 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),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_GROUP_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 byte[] byRes2 = new byte[80]; // + 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式民用车牌 + 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_CARD_CFG_V51 extends Structure { + public int dwSize; //结构体大小 + public byte byProMode; //联动方式,0-事件,1-卡号,2-MAC地址,3-工号(人员ID) + public byte[] byRes1 = new byte[3]; + public int dwEventSourceID; //事件源ID,当主类型为设备事件时无效, 当主类型是门事件时为门编号;当主类型为读卡器事件时,为读卡器ID;当为报警输入事件时为防区报警输入ID或事件报警输入ID。0xffffffff表示联动全部 + public NET_DVR_EVETN_CARD_LINKAGE_UNION uLinkageInfo; //联动方式参数 + 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 byMainDevStopBuzzer; //主机停止蜂鸣 0-不联动,1-联动输出 + public short wAudioDisplayID; //联动语音播放ID:0-不联动,目前范围1-32 + public byte byAudioDisplayMode; //联动语音播放模式:0-关闭,1-单次播放,2-循环播放 + public byte[] byRes3 = new byte[25]; //保留 + 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[] byReaderStopBuzzer = new byte[MAX_CARD_READER_NUM_512]; //联动读卡器停止蜂鸣,按字节表示,0-不联动,1-联动 + public byte[] byRes = new byte[512]; //保留 + } + + + 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-普通卡,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- S50,2- 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 byBeginTimeFlag; //是否限制起始时间的标志,0-不限制,1-限制 + public byte byEnableTimeFlag; //是否限制终止时间的标志,0-不限制,1-限制 + public byte byTimeDurationNo; //有效期索引,从0开始(时间段通过SDK设置给锁,后续在制卡时,只需要传递有效期索引即可,以减少数据量) + 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-普通卡,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_ZONE_ALARM_INFO extends Structure { + public byte[] byZoneName = new byte[NAME_LEN]; //防区名称 + public int dwZonendex;//防区号 + public byte byZoneType;//防区类型 ENUM_ALARM_ZONE_TYPE_MANUAL-紧急开关报警;ENUM_ALARM_ZONE_TYPE_MAGNETIC-门磁报警;ENUM_ALARM_ZONE_TYPE_SMOKE-烟感报警;ENUM_ALARM_ZONE_TYPE_ACTIVE_INFRARED-主动红外报警;ENUM_ALARM_ZONE_TYPE_PASSIVE_INFRARED-被动红外报警;ENUM_ALARM_ZONE_TYPE_GAS-煤气报警 + public byte[] byRes = new byte[219]; //保留,置为0 + } + + //可视对讲报警信息联合体 + public static class NET_DVR_VIDEO_INTERCOM_ALARM_INFO_UNION extends Union { + public byte[] byLen = new byte[256]; //联合体大小 + public NET_DVR_ZONE_ALARM_INFO struZoneAlarm = new NET_DVR_ZONE_ALARM_INFO(); //开锁记录 + } + + //可视对讲报警信息结构体 + public static class NET_DVR_VIDEO_INTERCOM_ALARM 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 byAlarmType;//报警类型:1- 防区报警,2- 防拆报警,3- 劫持报警,4- 多次密码开锁失败报警,5- 门没开,6- 门没关,7- SOS(呼救报警),8- 通话对讲,9- 智能锁劫持指纹报警, + // 10- 智能锁劫持密码报警,11- 智能锁撬门报警,12- 智能锁门锁锁定报警,13- 智能锁电量不足报警, 14-禁止名单报警, 15-智能锁掉线, 16-门禁安全模块防拆报警 + public byte[] byRes1 = new byte[3]; //保留 + public NET_DVR_VIDEO_INTERCOM_ALARM_INFO_UNION uAlarmInfo = new NET_DVR_VIDEO_INTERCOM_ALARM_INFO_UNION(); //报警信息,byAlarmType为1时有效 + public short wLockID; //锁ID,(0-表示门口机本机控制器上接的锁、1-表示外接控制器上接的锁)(报警类型为5和6时有效) + public byte[] byRes2 = new byte[254]; //保留,置为0 + } + + //可视对讲事件记录信息联合体 + 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_VIDEO_CALL_PARAM extends Structure { + public int dwSize; + public int dwCmdType; //信令类型 0-请求呼叫,1-取消本次呼叫,2-接听本次呼叫 3-拒绝本地来电呼叫 4-被叫响铃超时 5-结束本次通话,6-设备正在通话中,7-客户端正在通话中,8室内机不在线 + public short wPeriod; //期号, 范围[0,9] + public short wBuildingNumber; //楼号 + public short wUnitNumber; //单元号 + public short wFloorNumber; //层号 + public short wRoomNumber; //房间号 + public short wDevIndex; //设备编号 + public byte byUnitType; //设备类型,1-门口机,2-管理机,3-室内机,4-围墙机,5-别墅门口机,6-二次确认机,7-8700客户端,8-4200客户端,9-APP + public byte[] byRes = new byte[115]; //保留 + } + + 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-普通卡,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),,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 byRes3; + public byte bySex; //性别, 0-表示“未知”(算法不支持),1 – 男 , 2 – 女, 0xff-算法支持,但是没有识别出来 + public byte byEyeGlass; //是否戴眼镜 0-表示“未知”(算法不支持),1 – 不戴, 2 – 戴,0xff-算法支持,但是没有识别出来 + //抓拍图片人脸年龄的使用方式,如byAge为15,byAgeDeviation为1,表示,实际人脸图片年龄的为14-16之间 + public byte byRes4;// 0-表示“未知”(算法不支持),0xff-算法支持,但是没有识别出来 + public byte byDeviation;//误差值 + 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 byRes2;// + public byte byDeviation;//误差值 + public byte byGroup;//段,详见HUMAN_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 byGroup;//段,,如传入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. + public float fRuleTemperatureDiff;/*配置规则温差,精确到小数点后一位(-40-1000))*/ + public float fCurTemperatureDiff;/*当前温差,精确到小数点后一位(-40-1000),(浮点数+100) */ + public 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]; + public 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-欧洲, 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) + */ + 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]; + } + + } + + public static class NET_DVR_VIDEO_CALL_COND extends Structure { + public int dwSize; + public byte[] byRes = new byte[128]; + } + + + /*** + * API函数声明,详细说明见API手册 + ***/ + public static interface FRealDataCallBack_V30 extends Callback { + public void invoke(int lRealHandle, int dwDataType, + Pointer 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, Pointer 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 FVoiceDataCallback_MR_V30 extends Callback { + public void invoke(int lVoiceComHandle, Pointer pRecvDataBuffer, int dwBufSize, byte byAudioFlag, Pointer pUser); + } + + 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); + } + + + 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_SetPlayDataCallBack_V40(int lPlayHandle, FPlayDataCallBack fPlayDataCallBack, Pointer 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 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_SaveRealData_V30(int lRealHandle, int dwTransType, 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); + + //语音转发 + + boolean NET_DVR_GetCurrentAudioCompress(int lUserID, NET_DVR_COMPRESSION_AUDIO lpCompressAudio); + + int NET_DVR_StartVoiceCom_MR(int lUserID, FVoiceDataCallBack_MR fVoiceDataCallBack, int 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//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_TWODIM[] 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 lUploadHandle, 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]; + } + + //因为Java没有二维数组,BYTE_TWODIM是自定义的结构体 + public static class BYTE_TWODIM extends Structure { + public byte[] strIP = new byte[16]; + } + + //云台锁定配置结构体 + public static class NET_DVR_PTZ_LOCKCFG extends Structure { + public int dwSize;//结构体大小 + public byte byWorkMode;//云台锁定控制:0- 解锁,1- 锁定 + public byte[] byRes = new byte[123]; + } +} + + +//播放库函数声明,PlayCtrl.dll +interface PlayCtrl extends Library { + public static final int STREAME_REALTIME = 0; + public static final int STREAME_FILE = 1; + + boolean PlayM4_GetPort(IntByReference nPort); + + boolean PlayM4_OpenStream(int nPort, Pointer pFileHeadBuf, int nSize, int nBufPoolSize); + + boolean PlayM4_InputData(int nPort, Pointer pBuf, int nSize); + + boolean PlayM4_CloseStream(int nPort); + + boolean PlayM4_SetStreamOpenMode(int nPort, int nMode); + + boolean PlayM4_Play(int nPort, HWND hWnd); + + boolean PlayM4_Stop(int nPort); + + boolean PlayM4_SetSecretKey(int nPort, int lKeyType, String pSecretKey, int lKeyLen); + + boolean PlayM4_GetPictureSize(int nPort, IntByReference pWidth, IntByReference pHeight); + + boolean PlayM4_GetJPEG(int nPort, Pointer pBitmap, int nBufSize, IntByReference pBmpSize); + + int PlayM4_GetLastError(int nPort); + + boolean PlayM4_SetDecCallBackExMend(int nPort, DecCallBack decCBFun, Pointer pDest, int nDestSize, int nUser); + + public static interface DecCallBack extends Callback { + void invoke(int nPort, Pointer pBuf, int nSize, FRAME_INFO pFrameInfo, int nReserved1, int nReserved2); + } + + public class FRAME_INFO extends Structure { + public int nWidth; /* 画面宽,单位像素。如果是音频数据,则为音频声道数 */ + public int nHeight; /* 画面高,单位像素。如果是音频数据,则为样位率 */ + public int nStamp; /* 时标信息,单位毫秒 */ + public int nType; /* 数据类型,T_AUDIO16, T_RGB32, T_YV12 */ + public int nFrameRate; /* 编码时产生的图像帧率,如果是音频数据则为采样率 */ + public int dwFrameNum; /* 帧号 */ + } + +} + +//windows gdi接口,gdi32.dll in system32 folder, 在设置遮挡区域,移动侦测区域等情况下使用 +interface GDI32 extends W32API { + GDI32 INSTANCE = (GDI32) Native.loadLibrary("gdi32", GDI32.class, DEFAULT_OPTIONS); + + public static final int TRANSPARENT = 1; + + int SetBkMode(HDC hdc, int i); + + HANDLE CreateSolidBrush(int icolor); +} + +//windows user32接口,user32.dll in system32 folder, 在设置遮挡区域,移动侦测区域等情况下使用 +interface USER32 extends W32API { + + USER32 INSTANCE = (USER32) Native.loadLibrary("user32", USER32.class, DEFAULT_OPTIONS); + + public static final int BF_LEFT = 0x0001; + public static final int BF_TOP = 0x0002; + public static final int BF_RIGHT = 0x0004; + public static final int BF_BOTTOM = 0x0008; + public static final int BDR_SUNKENOUTER = 0x0002; + public static final int BF_RECT = (BF_LEFT | BF_TOP | BF_RIGHT | BF_BOTTOM); + + boolean DrawEdge(HDC hdc, com.sun.jna.examples.win32.GDI32.RECT qrc, int edge, int grfFlags); + + int FillRect(HDC hDC, com.sun.jna.examples.win32.GDI32.RECT lprc, HANDLE hbr); +} + diff --git a/src/main/java/com/shxy/xyhkcamera/HcNetSdkUtil.java b/src/main/java/com/shxy/xyhkcamera/HcNetSdkUtil.java new file mode 100644 index 0000000..83c3777 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/HcNetSdkUtil.java @@ -0,0 +1,117 @@ +package com.shxy.xyhkcamera; + +import com.sun.jna.Native; +import lombok.extern.slf4j.Slf4j; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.stereotype.Component; + +import java.util.Objects; + +/** + * @description 海康 SDK封装类 + */ +@Slf4j +@Component +public class HcNetSdkUtil { + + private static final Logger logger = LoggerFactory.getLogger(HcNetSdkUtil.class); + + private HCNetSDK hCNetSDK = null; + /** + * 用户登录返回句柄 + */ + private int userID; + /** + * win32 dll文件路径 + */ + @Value("${hkconfig.winpath}") + private String winPath; + /** + * linux dll文件路径 + */ + @Value("${hkconfig.linuxpath}") + private String linuxPath; + + /** + * 动态库加载 + * + * @return + */ + + public HCNetSDK createSDKInstance() { + if (hCNetSDK == null) { + //Linux系统加载库路径 + String path = System.getProperty("user.dir") + "/lib"; + synchronized (HCNetSDK.class) { + if (OsSelect.isWindows()) { + //win系统加载库路径 + try { + hCNetSDK = (HCNetSDK) Native.loadLibrary(winPath, HCNetSDK.class); + } catch (Exception e) { + System.out.println(e.getMessage()); + } + log.info("海康动态库加载 Windows版"); + } else if (OsSelect.isLinux()) { + log.info(">>>> " + path + "/libhcnetsdk.so"); + hCNetSDK = HCNetSDK.INSTANCE; + log.info("海康动态库加载 Linux版"); + } + } + if (OsSelect.isLinux()) { + //Linux版额外加载 + load(path); + } + } + return hCNetSDK; + } + + /** + * 使用 linux环境加载额外文件 + * + * @param path sdk目录(不指定具体文件) + */ + private void load(String path) { + //设置HCNetSDKCom组件库所在路径 + String strPathCom = path + "/"; + HCNetSDK.NET_DVR_LOCAL_SDK_PATH struComPath = new HCNetSDK.NET_DVR_LOCAL_SDK_PATH(); + System.arraycopy(strPathCom.getBytes(), 0, struComPath.sPath, 0, strPathCom.length()); + struComPath.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(2, struComPath.getPointer()); + + //设置libcrypto.so所在路径 + HCNetSDK.BYTE_ARRAY ptrByteArrayCrypto = new HCNetSDK.BYTE_ARRAY(256); + String strPathCrypto = path + "/libcrypto.so.1.1"; + System.arraycopy(strPathCrypto.getBytes(), 0, ptrByteArrayCrypto.byValue, 0, strPathCrypto.length()); + ptrByteArrayCrypto.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(3, ptrByteArrayCrypto.getPointer()); + + //设置libssl.so所在路径 + HCNetSDK.BYTE_ARRAY ptrByteArraySsl = new HCNetSDK.BYTE_ARRAY(256); + String strPathSsl = path + "/libssl.so.1.1"; + System.arraycopy(strPathSsl.getBytes(), 0, ptrByteArraySsl.byValue, 0, strPathSsl.length()); + ptrByteArraySsl.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(4, ptrByteArraySsl.getPointer()); + } + + /** + * 初始化动态库 + */ + public void init() { + if (hCNetSDK == null) { + hCNetSDK = createSDKInstance(); + if (Objects.isNull(hCNetSDK)) { + log.error("海康 SDK 初始化动态库失败"); + throw new RuntimeException("海康 SDK 初始化动态库失败"); + } + } + // 初始化 + boolean initSuc = hCNetSDK.NET_DVR_Init(); + if (!initSuc) { + log.error("海康 SDK 初始化失败"); + throw new RuntimeException("海康 SDK 初始化失败"); + } + } + +} \ No newline at end of file diff --git a/src/main/java/com/shxy/xyhkcamera/InitSdkTask.java b/src/main/java/com/shxy/xyhkcamera/InitSdkTask.java new file mode 100644 index 0000000..fa3ec7c --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/InitSdkTask.java @@ -0,0 +1,80 @@ +package com.shxy.xyhkcamera; + + +import lombok.extern.slf4j.Slf4j; + +import java.util.Objects; + +@Slf4j +public class InitSdkTask implements Runnable { + /** + * 装配 sdk 所需依赖 + */ + private static HCNetSDK hCNetSDK = SdkInitService.hCNetSDK; + + @Override + public void run() { + try { + if (Objects.equals(OSUtils.getOsName(), "linux")) { + log.info("InitSdk-is-linux"); + String userDir = System.getProperty("user.dir"); + log.info("InitSdk-userDir={}", userDir); + String osPrefix = OSUtils.getOsPrefix(); + if (osPrefix.toLowerCase().startsWith("linux-i386")) { + HCNetSDK.BYTE_ARRAY ptrByteArray1 = new HCNetSDK.BYTE_ARRAY(256); + HCNetSDK.BYTE_ARRAY ptrByteArray2 = new HCNetSDK.BYTE_ARRAY(256); + //这里是库的绝对路径,请根据实际情况修改,注意改路径必须有访问权限 + //linux 下, 库加载参考:OSUtils.getLoadLibrary() + String strPath1 = System.getProperty("user.dir") + "/hkliblinux32/libcrypto.so.1.1"; + String strPath2 = System.getProperty("user.dir") + "/hkliblinux32/libssl.so.1.1"; + System.arraycopy(strPath1.getBytes(), 0, ptrByteArray1.byValue, 0, strPath1.length()); + ptrByteArray1.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(3, ptrByteArray1.getPointer()); + System.arraycopy(strPath2.getBytes(), 0, ptrByteArray2.byValue, 0, strPath2.length()); + ptrByteArray2.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(4, ptrByteArray2.getPointer()); + //linux 下, 库加载参考:OSUtils.getLoadLibrary() + String strPathCom = System.getProperty("user.dir") + "/hkliblinux32/HCNetSDKCom/"; + HCNetSDK.NET_DVR_LOCAL_SDK_PATH struComPath = new HCNetSDK.NET_DVR_LOCAL_SDK_PATH(); + System.arraycopy(strPathCom.getBytes(), 0, struComPath.sPath, 0, strPathCom.length()); + struComPath.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(2, struComPath.getPointer()); + } else if (osPrefix.toLowerCase().startsWith("linux-amd64")) { + HCNetSDK.BYTE_ARRAY ptrByteArray1 = new HCNetSDK.BYTE_ARRAY(256); + HCNetSDK.BYTE_ARRAY ptrByteArray2 = new HCNetSDK.BYTE_ARRAY(256); + //这里是库的绝对路径,请根据实际情况修改,注意改路径必须有访问权限 + //linux 下, 库加载参考:OSUtils.getLoadLibrary() + String strPath1 = System.getProperty("user.dir") + "/hkliblinux64/libcrypto.so.1.1"; + String strPath2 = System.getProperty("user.dir") + "/hkliblinux64/libssl.so.1.1"; + System.arraycopy(strPath1.getBytes(), 0, ptrByteArray1.byValue, 0, strPath1.length()); + ptrByteArray1.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(3, ptrByteArray1.getPointer()); + System.arraycopy(strPath2.getBytes(), 0, ptrByteArray2.byValue, 0, strPath2.length()); + ptrByteArray2.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(4, ptrByteArray2.getPointer()); + String strPathCom = System.getProperty("user.dir") + "/hkliblinux64/HCNetSDKCom/"; + //linux 下, 库加载参考:OSUtils.getLoadLibrary() + HCNetSDK.NET_DVR_LOCAL_SDK_PATH struComPath = new HCNetSDK.NET_DVR_LOCAL_SDK_PATH(); + System.arraycopy(strPathCom.getBytes(), 0, struComPath.sPath, 0, strPathCom.length()); + struComPath.write(); + hCNetSDK.NET_DVR_SetSDKInitCfg(2, struComPath.getPointer()); + } else { + log.info("osPrefix={}", osPrefix); + } + } + //初始化sdk + boolean isOk = hCNetSDK.NET_DVR_Init(); + hCNetSDK.NET_DVR_SetConnectTime(10, 1); + hCNetSDK.NET_DVR_SetReconnect(100, true); + if (!isOk) { + log.error("=================== InitSDK init fail ==================="); + } else { + log.info("============== InitSDK init success ===================="); + } + } catch (Exception e) { + log.error("InitSDK-error,e={}", e.getMessage()); + e.printStackTrace(); + } + } +} + diff --git a/src/main/java/com/shxy/xyhkcamera/OSUtils.java b/src/main/java/com/shxy/xyhkcamera/OSUtils.java new file mode 100644 index 0000000..44fb438 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/OSUtils.java @@ -0,0 +1,110 @@ +package com.shxy.xyhkcamera; + +import com.sun.jna.Platform; +import lombok.extern.slf4j.Slf4j; + +import java.io.File; + +@Slf4j +public class OSUtils { + // 获取操作平台信息 + public static String getOsPrefix() { + String arch = System.getProperty("os.arch").toLowerCase(); + final String name = System.getProperty("os.name"); + String osPrefix; + if (Platform.isWindows()) { + if ("i386".equals(arch)) { + arch = "x86"; + } + osPrefix = "win32-" + arch; + } else if (Platform.isLinux()) { + if ("x86".equals(arch)) { + arch = "i386"; + } else if ("x86_64".equals(arch)) { + arch = "amd64"; + } + osPrefix = "linux-" + arch; + } else { + osPrefix = name.toLowerCase(); + if ("x86".equals(arch)) { + arch = "i386"; + } + if ("x86_64".equals(arch)) { + arch = "amd64"; + } + int space = osPrefix.indexOf(" "); + if (space != -1) { + osPrefix = osPrefix.substring(0, space); + } + osPrefix += "-" + arch; + } + return osPrefix; + } + + public static String getOsName() { + String osName = ""; + String osPrefix = getOsPrefix(); + if (osPrefix.toLowerCase().startsWith("win32-x86") + || osPrefix.toLowerCase().startsWith("win32-amd64")) { + osName = "win"; + } else if (osPrefix.toLowerCase().startsWith("linux-i386") + || osPrefix.toLowerCase().startsWith("linux-amd64")) { + osName = "linux"; + } + return osName; + } + + /** + * 获取库文件 + * 区分win、linux + * + * @return + */ + public static String getLoadLibrary() { + if (isChecking()) { + return null; + } + String userDir = System.getProperty("user.dir"); + log.info("getLoadLibrary-userDir={}", userDir); + String loadLibrary = ""; + String library = ""; + String osPrefix = getOsPrefix(); + if (osPrefix.toLowerCase().startsWith("win32-x86")) { + loadLibrary = System.getProperty("user.dir") + File.separator + "sdk" + File.separator + "hklibwin32" + File.separator; + library = "HCNetSDK.dll"; + } else if (osPrefix.toLowerCase().startsWith("win32-amd64")) { + loadLibrary = System.getProperty("user.dir") + File.separator + "sdk" + File.separator + "hklibwin64" + File.separator; + library = "HCNetSDK.dll"; + } else if (osPrefix.toLowerCase().startsWith("linux-i386")) { + //同 linux-amd64 + loadLibrary = ""; + library = "libhcnetsdk.so"; + } else if (osPrefix.toLowerCase().startsWith("linux-amd64")) { + //方式一:使用系统默认的加载库路径,在系统的/usr/lib文件中加入你Java工程所需要使用的so文件,然后将HCNetSDKCom文件夹下的组件库也复制到/usr/lib目录,HCNetSDKCom文件夹中的组件库不要随意更换路径。CentOS 64位需拷贝到/usr/lib64下。 + //针对方式一,前缀就是绝对路径 + //loadLibrary = "/usr/lib64/lib/hkliblinux64/"; + //方式二:配置LD_LIBRARY_PATH环境变量加载库文件;配置/etc/ld.so.conf,加上你自己的Java工程所需要的so文件的路径 + //针对方式二,无需添加前缀,程序会从linux系统的so共享库中查找libhcnetsdk.so + loadLibrary = ""; + library = "libhcnetsdk.so"; + } + log.info("================= Load library Path :{} ==================", loadLibrary + library); + return loadLibrary + library; + } + + private static boolean checking = false; + + public static void setChecking() { + checking = true; + } + + public static void clearChecking() { + checking = false; + } + + public static boolean isChecking() { + return checking; + } +} + + diff --git a/src/main/java/com/shxy/xyhkcamera/OsSelect.java b/src/main/java/com/shxy/xyhkcamera/OsSelect.java new file mode 100644 index 0000000..a997e21 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/OsSelect.java @@ -0,0 +1,16 @@ +package com.shxy.xyhkcamera; + +/** + * @author jiangxin + * @create 2022-01-19-16:40 + */ +public class OsSelect { + + public static boolean isLinux() { + return System.getProperty("os.name").toLowerCase().contains("linux"); + } + + public static boolean isWindows() { + return System.getProperty("os.name").toLowerCase().contains("windows"); + } +} diff --git a/src/main/java/com/shxy/xyhkcamera/SdkInitService.java b/src/main/java/com/shxy/xyhkcamera/SdkInitService.java new file mode 100644 index 0000000..31e45a3 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/SdkInitService.java @@ -0,0 +1,46 @@ +package com.shxy.xyhkcamera; + +import com.sun.jna.Native; +import com.sun.jna.Pointer; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Component; + +import java.util.concurrent.ThreadPoolExecutor; + +@Slf4j +@Component +public class SdkInitService { + + @Autowired + private ThreadPoolExecutor executor; + + public static HCNetSDK hCNetSDK = null; + static FExceptionCallBack_Imp fExceptionCallBack; + + static class FExceptionCallBack_Imp implements HCNetSDK.FExceptionCallBack { + public void invoke(int dwType, int lUserID, int lHandle, Pointer pUser) { + System.out.println("异常事件类型:" + dwType); + return; + } + } + + public SdkInitService() { + if (hCNetSDK == null) { + synchronized (HCNetSDK.class) { + try { + hCNetSDK = (HCNetSDK) Native.loadLibrary(OSUtils.getLoadLibrary(), HCNetSDK.class); + } catch (Exception ex) { + log.error("SdkInitService-init-hCNetSDK-error"); + } + } + } + } + + @Autowired + public void initSdk() { + log.info("HKSDKInitService-init-coming"); + executor.execute(new InitSdkTask()); + } +} + diff --git a/src/main/java/com/shxy/xyhkcamera/Test.java b/src/main/java/com/shxy/xyhkcamera/Test.java new file mode 100644 index 0000000..bbd6158 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/Test.java @@ -0,0 +1,13 @@ +//package com.shxy.xyhkcamera; +// +//public class Test { +// public static void main(String[] args) { +// +//// HcNetSdkUtil hcNetSdkUtil = new HcNetSdkUtil(56, "", ""); +//// HCNetSDK sdkInstance = hcNetSdkUtil.createSDKInstance(); +//// sdkInstance.NET_DVR_Init(); +//// sdkInstance.NET_DVR_Login_V40(); +//// sdkInstance.NET_DVR_STDXMLConfig(); +//// sdkInstance.NET_DVR_StartRemoteConfig() +// } +//} diff --git a/src/main/java/com/shxy/xyhkcamera/XyhkcameraApplication.java b/src/main/java/com/shxy/xyhkcamera/XyhkcameraApplication.java new file mode 100644 index 0000000..e8a3943 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/XyhkcameraApplication.java @@ -0,0 +1,16 @@ +package com.shxy.xyhkcamera; + +import lombok.extern.slf4j.Slf4j; +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; + + +@SpringBootApplication +@Slf4j +public class XyhkcameraApplication { + + public static void main(String[] args) { + SpringApplication.run(XyhkcameraApplication.class, args); + } + +} diff --git a/src/main/java/com/shxy/xyhkcamera/impl/TempMeasureServiceImpl.java b/src/main/java/com/shxy/xyhkcamera/impl/TempMeasureServiceImpl.java new file mode 100644 index 0000000..d16bdae --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/impl/TempMeasureServiceImpl.java @@ -0,0 +1,14 @@ +package com.shxy.xyhkcamera.impl; + +import com.shxy.xyhkcamera.service.TempMeasureService; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +@Service +@Slf4j +public class TempMeasureServiceImpl implements TempMeasureService { + @Override + public void measure() { +// hcNetSdkUtil.createSDKInstance(); + } +} diff --git a/src/main/java/com/shxy/xyhkcamera/schedule/ScheduledTask.java b/src/main/java/com/shxy/xyhkcamera/schedule/ScheduledTask.java new file mode 100644 index 0000000..d5f701f --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/schedule/ScheduledTask.java @@ -0,0 +1,24 @@ +package com.shxy.xyhkcamera.schedule; + +import lombok.extern.slf4j.Slf4j; +import org.springframework.scheduling.annotation.EnableScheduling; +import org.springframework.scheduling.annotation.Scheduled; +import org.springframework.stereotype.Component; + +/** + * @author jingjing + * @date 2023-11-16 15:06 + */ +@Component +@EnableScheduling +@Slf4j +public class ScheduledTask { + + + @Scheduled(fixedDelay = 60 * 60 * 1000) + public void cacyspupload() { + log.info("开始测温"); +// webservcies.uploadyspData(); + } + +} diff --git a/src/main/java/com/shxy/xyhkcamera/service/TempMeasureService.java b/src/main/java/com/shxy/xyhkcamera/service/TempMeasureService.java new file mode 100644 index 0000000..3dce641 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/service/TempMeasureService.java @@ -0,0 +1,5 @@ +package com.shxy.xyhkcamera.service; + +public interface TempMeasureService { + void measure(); +} diff --git a/src/main/java/com/shxy/xyhkcamera/test/CapturePictureModule.java b/src/main/java/com/shxy/xyhkcamera/test/CapturePictureModule.java new file mode 100644 index 0000000..494ac8b --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/CapturePictureModule.java @@ -0,0 +1,85 @@ +package com.shxy.xyhkcamera.test; + + +import com.sun.jna.ptr.IntByReference; + +/** + * \if ENGLISH_LANG + * Capture Picture Interface + * contains:local、remote、timer and stop capture picture + * \else + * 抓图接口实现 + * 包含: 本地、远程、定时和停止抓图 + * \endif + */ +public class CapturePictureModule { + /** + * \if ENGLISH_LANG + * Remote Capture Picture + * \else + * 远程抓图 + * \endif + */ + public static boolean remoteCapturePicture(int chn) { + return snapPicture(chn, 0, 0); + } + + /** + * \if ENGLISH_LANG + * Timer Capture Picture + * \else + * 定时抓图 + * \endif + */ + public static boolean timerCapturePicture(int chn) { + return snapPicture(chn, 1, 2); + } + + /** + * \if ENGLISH_LANG + * Stop Timer Capture Picture + * \else + * 停止定时抓图 + * \endif + */ + public static boolean stopCapturePicture(int chn) { + return snapPicture(chn, -1, 0); + } + + /** + * \if ENGLISH_LANG + * Capture Picture (except local capture picture, others all call this interface) + * \else + * 抓图 (除本地抓图外, 其他全部调用此接口) + * \endif + */ + private static boolean snapPicture(int chn, int mode, int interval) { + // send caputre picture command to device + NetSDKLib.SNAP_PARAMS stuSnapParams = new NetSDKLib.SNAP_PARAMS(); + stuSnapParams.Channel = chn; // channel + stuSnapParams.mode = mode; // capture picture mode + stuSnapParams.Quality = 3; // picture quality + stuSnapParams.InterSnap = interval; // timer capture picture time interval + stuSnapParams.CmdSerial = 0; // request serial + + IntByReference reserved = new IntByReference(0); + if (!INetSDK.netsdk.CLIENT_SnapPictureEx(INetSDK.m_hLoginHandle, stuSnapParams, reserved)) { + System.err.printf("CLIENT_SnapPictureEx Failed!" + INetSDK.netsdk.CLIENT_GetLastError()); + return false; + } else { + System.out.println("CLIENT_SnapPictureEx success"); + } + return true; + } + + /** + * \if ENGLISH_LANG + * Set Capture Picture Callback + * \else + * 设置抓图回调函数 + * \endif + */ + public static void setSnapRevCallBack(NetSDKLib.fSnapRev cbSnapReceive){ + INetSDK.netsdk.CLIENT_SetSnapRevCallBack(cbSnapReceive, null); + } +} diff --git a/src/main/java/com/shxy/xyhkcamera/test/DBHelper.java b/src/main/java/com/shxy/xyhkcamera/test/DBHelper.java new file mode 100644 index 0000000..85e345b --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/DBHelper.java @@ -0,0 +1,192 @@ +/* + * 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 com.shxy.xyhkcamera.test; + +import java.io.BufferedReader; +import java.lang.reflect.Field; +import java.sql.Connection; +import java.sql.DriverManager; +import java.sql.PreparedStatement; +import java.sql.ResultSet; +import java.sql.ResultSetMetaData; +import java.sql.SQLException; +import java.util.ArrayList; +import java.util.List; + +import java.io.File; +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.FileReader; +import java.io.IOException; +import java.io.InputStream; +/** + * + * @author LENOVO + */ +public class DBHelper { + + private static String DRIVER=""; + //private static final String URL="jdbc:mysql://192.168.1.188/dss"; + private static String URL=""; + private static String USER=""; + private static String PASSWORD=""; + + public void GetText(String path){ + if(DRIVER!=""){ + return; + } + // 1.定义目标文件 + File srcFile = new File(path); + // 2.创建一个流,指向目标文件 + BufferedReader is = null; + try { + is = new BufferedReader(new FileReader(srcFile)); + int i= 0; + String s = null; + while ((s = is.readLine()) != null) {// 使用readLine方法,一次读一行 + if(i==0){ + DRIVER = s; + } + if(i==1){ + URL = s; + } + if(i==2){ + USER = s; + } + if(i==3){ + PASSWORD = s; + } + i++; + } + } catch (FileNotFoundException e) { + e.printStackTrace(); + } catch (IOException e) { + e.printStackTrace(); + } finally { + // 关闭io流 + try { + is.close(); + } catch (IOException e) { + e.printStackTrace(); + } + } + } + /** + * 连接数据库 + * @return 链接数据库对象 + */ + public Connection getConnection(){ + // GetText("D://shjdconfig.txt"); + GetText("/home/shjdconfig.txt"); + Connection conn=null; + try { + Class.forName(DRIVER); + } catch (ClassNotFoundException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + try { + conn=DriverManager.getConnection(URL, USER, PASSWORD); + } catch (SQLException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + return conn; + } + + /** + * 释放相应的资源 + * @param rs + * @param pstmt + * @param conn + */ + public void closeAll(ResultSet rs,PreparedStatement pstmt,Connection conn){ + try { + if(rs!=null){ + rs.close(); + } + if(pstmt!=null){ + pstmt.close(); + } + if(conn!=null){ + conn.close(); + } + } catch (SQLException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + + /** + * 此方法可以完成增删改所有的操作 + * @param sql + * @return true or false + */ + public int excuteUpdate(String sql){ + int res=0;//受影响的行数 + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + try { + conn=getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + + res=pstmt.executeUpdate(); + + } catch (SQLException e) { + // TODO Auto-generated catch block + e.printStackTrace(); + }finally{ + closeAll(rs, pstmt, conn); + } + return res; + } + + /** + * 使用泛型方法和反射机制进行封装 + * @param sql + * @param params + * @param cls + * @return + */ + public List executeQuery(String sql,List params,Class cls) throws Exception{ + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + List data=new ArrayList(); + try { + conn=getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + if(params!=null){ + //加入有?占位符,在执行之前把?占位符替换掉 + for(int i=0;i + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/main/java/com/shxy/xyhkcamera/test/Hot.java b/src/main/java/com/shxy/xyhkcamera/test/Hot.java new file mode 100644 index 0000000..d2b7e3c --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/Hot.java @@ -0,0 +1,1902 @@ +/* + * To change this template, choose Tools | Templates + * and open the template in the editor. + */ + +/* + * ClientDemo.java + * + * Created on 2009-9-14, 19:31:34 + */ +/** + * + * @author Xubinfeng + */ + +package com.shxy.xyhkcamera.test; + +import com.sun.jna.Native; +import com.sun.jna.NativeLong; +import com.sun.jna.Pointer; +import com.sun.jna.examples.win32.W32API.HWND; +import com.sun.jna.examples.win32.W32API.LPARAM; +import com.sun.jna.examples.win32.W32API.WPARAM; +import com.sun.jna.ptr.ByteByReference; +import com.sun.jna.ptr.IntByReference; +import com.sun.jna.ptr.NativeLongByReference; +import java.text.DateFormat; +import java.text.SimpleDateFormat; +import javax.swing.JFrame; +import javax.swing.JOptionPane; +import javax.swing.table.DefaultTableModel; +import java.util.Date; +import java.awt.Container; +import java.awt.Dimension; +import java.awt.Toolkit; +import java.sql.ResultSet; +import java.sql.SQLException; +import java.text.MessageFormat; +import java.util.ArrayList; +import java.util.List; +import javax.swing.JPopupMenu; +import javax.swing.JWindow; +import javax.swing.tree.DefaultMutableTreeNode; +import javax.swing.tree.DefaultTreeModel; +import javax.swing.tree.TreePath; +import java.awt.*; +import java.awt.event.*; +import java.awt.image.BufferedImage; +import java.io.BufferedReader; +import java.io.ByteArrayInputStream; +import java.io.File; +import java.io.FileWriter; +import java.io.IOException; +import java.io.InputStreamReader; +import java.math.BigInteger; +import java.net.InetAddress; +import java.net.NetworkInterface; +import java.security.MessageDigest; +import java.sql.Connection; +import java.sql.PreparedStatement; +import java.sql.ResultSetMetaData; +import java.util.Enumeration; +import java.util.Scanner; +import java.util.TimerTask; +import java.util.Timer; +import java.util.logging.Level; +import java.util.logging.Logger; +import javax.imageio.ImageIO; +import javax.swing.*; + +/***************************************************************************** + *主类 :ClientDemo + *用途 :用户注册,预览,参数配置菜单 + *容器:Jframe + ****************************************************************************/ +public class Hot extends JFrame +{ + /************************************************* + 函数: 主类构造函数 + 函数描述: 初始化成员 + *************************************************/ + public String getResult(String inputStr) + { + BigInteger bigInteger=null; + + try { + MessageDigest md = MessageDigest.getInstance("MD5"); + byte[] inputData = inputStr.getBytes(); + md.update(inputData); + bigInteger = new BigInteger(md.digest()); + } catch (Exception e) {e.printStackTrace();} + return bigInteger.toString(16); + } + public Hot() + { + + String key = "C2049AB66FFC4CFA8E6AD94D18FC4E2B"; + try{ + /*if(!rs.next()){ + JOptionPane.showMessageDialog(null, "该软件未注册"); + System.exit(0); + return; + }else{*/ + JPopupMenu.setDefaultLightWeightPopupEnabled(false);//防止被播放窗口(AWT组件)覆盖 + initComponents(); + lUserID = new NativeLong(-1); + lAlarmHandle = new NativeLong(-1); + lListenHandle = new NativeLong(-1); + nRuleIdSel.addItem("点"); + nRuleIdSel.addItem("线"); + nRuleIdSel.addItem("区域"); + this.setTitle("热成像"); + m_iTreeNodeNum = 0; + INetSDK.init(disConnect, haveReConnect); // 打开工程,初始化 + Timereqm.schedule(new TimerTask() { + @Override + public void run() { + try{ + DBHelper help=new DBHelper(); + + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + String checksql = "select * from sys_rg"; + pstmt=conn.prepareStatement(checksql);//装载sql语句 + ResultSet checkrt=null; + checkrt=pstmt.executeQuery(); + int checknum; + while(checkrt.next()){ + String mc = checkrt.getString("mc"); + String ac4 = checkrt.getString("ac4"); + String ck4 = checkrt.getString("ck4"); + String encrypt = getResult(mc+key); + if(!ac4.equals(encrypt)){ + checknum = 0; + }else{ + checknum = 1; + } + String checkupsql = "UPDATE sys_rg SET ck4= '"+checknum+"' WHERE mc='"+checkrt.getString("mc")+"'"; + help.getConnection(); + int num = help.excuteUpdate(checkupsql); + } + pstmt=conn.prepareStatement(checksql);//装载sql语句 + checkrt=null; + checkrt=pstmt.executeQuery(); + while(checkrt.next()){ + int ck ; + for(int i=0;i<9;i++){ + ck = checkrt.getInt("ck"+(i+1)); + if(ck!=1){ + JOptionPane.showMessageDialog(null, "该软件未注册"); + System.exit(0); + return; + } + } + } + String sql ="SELECT * FROM modev where modevtid='9' "; + + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + while(rs.next()){ + String ip = rs.getString("ip"); + int port = rs.getInt("port"); + String username = rs.getString("username"); + String pwd = rs.getString("pwd"); + String theeqmid = rs.getString("id"); + System.out.println(ip+","+port+","+username+","+pwd); + LoginEqm(ip,port,username,pwd); + if(!CapturePictureModule.remoteCapturePicture(0)) { + System.out.println("远程抓图失败"); + } + Thread.sleep(5000); + if(eqmid>0){ + try{ + sql ="SELECT * FROM modev_eaif where eqmid='"+theeqmid+"'"; + Connection connchild=null; + PreparedStatement pstmtchild = null; + ResultSet rschild=null; + connchild=help.getConnection(); + pstmtchild=connchild.prepareStatement(sql);//装载sql语句 + System.out.println(sql); + rschild=pstmtchild.executeQuery(); + System.out.println(rschild); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsdchild=rschild.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + while(rschild.next()){ + if(rschild.getInt("nPresetId")>0){ + boolean ispresrtid = INetSDK.ptzControlnPresetId(0,0,Integer.parseInt(rschild.getString("nPresetId")),0,0,null); + if(ispresrtid){ + System.out.println("预置点设置成功"); + try { + Thread.sleep(5000); + } catch (InterruptedException ex) { + Logger.getLogger(Hot.class.getName()).log(Level.SEVERE, null, ex); + } + }else{ + + return; + } + } + NetSDKLib.NET_IN_RADIOMETRY_GETTEMPER stuRadioMetryInTemper = new NetSDKLib.NET_IN_RADIOMETRY_GETTEMPER(); + NetSDKLib.NET_OUT_RADIOMETRY_GETTEMPER stuRadioMetryOutTemper = new NetSDKLib.NET_OUT_RADIOMETRY_GETTEMPER(); + + if(rschild.getInt("nPresetId")>0){ + stuRadioMetryInTemper.stCondition.nChannel = 1; + }else{ + stuRadioMetryInTemper.stCondition.nChannel = 0; + } + stuRadioMetryInTemper.stCondition.nPresetId = Integer.parseInt(rschild.getString("nPresetId")); + stuRadioMetryInTemper.stCondition.nRuleId = Integer.parseInt(rschild.getString("nRuleId")); + stuRadioMetryInTemper.stCondition.nMeterType =Integer.parseInt(rschild.getString("nMeterType")); + stuRadioMetryInTemper.write(); + stuRadioMetryOutTemper.write(); + boolean Isdate = INetSDK.CLIENT_QueryDevInfo(NetSDKLib.NET_QUERY_DEV_RADIOMETRY_TEMPER,stuRadioMetryInTemper.getPointer(),stuRadioMetryOutTemper.getPointer(),null,3000); + stuRadioMetryInTemper.read(); + stuRadioMetryOutTemper.read(); + System.out.println(Isdate); + if(Isdate){ + System.out.println(stuRadioMetryOutTemper); + conn=help.getConnection(); + SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//设置日期格式 + sql ="INSERT INTO data_eaif_h(eqmid,areaid,capturetime,maxtemp,mintemp,avgtemp,unit,type,mid,std) values('"+theeqmid+"','1','"+df.format(new Date())+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperMax+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperMin+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperAver+"','"+stuRadioMetryOutTemper.stTempInfo.nTemperUnit+"','"+stuRadioMetryOutTemper.stTempInfo.nMeterType+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperMid+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperStd+"')"; + System.out.println(sql); + help.getConnection(); + int ret = help.excuteUpdate(sql); + System.out.println(ret); + } + } + help.getConnection(); + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + //System.out.println(struLoginInfo); + //TreeAddDevice(nlUserID,ip,struDeviceInfo,deviceInfo); + } + sql ="SELECT * FROM modev where modevtid='12' "; + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + //把查询出来的记录封装成对应的实体类对象 + while(rs.next()){ + String ip = rs.getString("ip"); + int port = rs.getInt("port"); + String username = rs.getString("username"); + String pwd = rs.getString("pwd"); + String theeqmid = rs.getString("id"); + System.out.println(ip+","+port+","+username+","+pwd); + LoginEqm(ip,port,username,pwd); + if(!CapturePictureModule.remoteCapturePicture(0)) { + System.out.println("远程抓图失败"); + } + Thread.sleep(5000); + } + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + }, 0, 3600000); + //} + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + private Timer Timereqm = new Timer() ; + NetSDKLib netSDKLib = NetSDKLib.NETSDK_INSTANCE; + + // 设备断线通知回调 + private DisConnect disConnect = new DisConnect(); + + // 网络连接恢复 + private static HaveReConnect haveReConnect = new HaveReConnect(); + + // 开始时间 + private NetSDKLib.NET_TIME stTimeStart = new NetSDKLib.NET_TIME(); + + // 结束时间 + private NetSDKLib.NET_TIME stTimeEnd = new NetSDKLib.NET_TIME(); + + boolean login;//是否登录. + boolean bRealPlay;//是否在播放. + String m_sDeviceIP;//已登录设备的IP地址 + + NativeLong lUserID;//用户句柄 + HWND hwnd ;//窗体句柄 + int eqmconn;//链接返回 + int play;//播放链接 + int plays;//视频返回 + NativeLong lAlarmHandle;//报警布防句柄 + NativeLong lListenHandle;//报警监听句柄 + int setspot=1;//获取温度到点 + int setline=1;//获取温度到线 + int setarea=1;//获取温度到框 + int eqmid;//用户设备编号 + + //JFramePTZControl framePTZControl;//云台控制窗口 + + int m_iTreeNodeNum;//通道树节点数目 + DefaultMutableTreeNode m_DeviceRoot;//通道树根节点 + private fCaptureReceiveCB m_CaptureReceiveCB = new fCaptureReceiveCB(); + int m_iTreeArea;//区域树节点数目 + DefaultMutableTreeNode m_AreaRoot;//区域树根节点 + int m_iTreeLine;//线树节点数目 + DefaultMutableTreeNode m_LineRoot;//线树根节点 + int m_iTreePoint;//点树节点数目 + DefaultMutableTreeNode m_PointRoot;//点树根节点 +///////////////// 面板////////////////// + // 设备断线回调: 通过 CLIENT_Init 设置该回调函数,当设备出现断线时,SDK会调用该函数 + private class DisConnect implements NetSDKLib.fDisConnect { + public void invoke(NativeLong m_hLoginHandle, String pchDVRIP, int nDVRPort, NativeLong dwUser) { + System.out.printf("Device[%s] Port[%d] DisConnect!\n", pchDVRIP, nDVRPort); + // 断线提示 + SwingUtilities.invokeLater(new Runnable() { + public void run() { + + } + }); + } + } + //public void invoke( NativeLong lLoginID ,Pointer pBuf, int RevLen, int EncodeType, NativeLong CmdSerial, NativeLong dwUser); + private class fCaptureReceiveCB implements NetSDKLib.fSnapRev{ + BufferedImage bufferedImage = null; + public void invoke( NativeLong lLoginID, Pointer pBuf, int RevLen, int EncodeType, NativeLong CmdSerial, NativeLong dwUser) { + if(pBuf != null && RevLen > 0) { + String strFileName = SavePath.getSavePath().getSaveSnapPath(); + + System.out.println("strFileName = " + strFileName); + + byte[] buf = pBuf.getByteArray(0, RevLen); + ByteArrayInputStream byteArrInput = new ByteArrayInputStream(buf); + try { + bufferedImage = ImageIO.read(byteArrInput); + if(bufferedImage == null) { + return; + } + ImageIO.write(bufferedImage, "jpg", new File(strFileName)); + //上传文件 + Thread.sleep(3000); + //获取当前时间 + Date d = new Date(); + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + SimpleDateFormat sdfs = new SimpleDateFormat("yyyyMMddHHmmss"); + String date = sdf.format(d); + DBHelper help=new DBHelper(); + String sql ="INSERT INTO data_video_h(d_time,photopath) values('"+date+"','"+strFileName+"')"; + //System.out.println(sql); + help.getConnection(); + help.excuteUpdate(sql); + help.getConnection().close(); + } catch (IOException e) { + e.printStackTrace(); + } catch (InterruptedException ex) { + Logger.getLogger(Hot.class.getName()).log(Level.SEVERE, null, ex); + } catch (SQLException ex) { + Logger.getLogger(Hot.class.getName()).log(Level.SEVERE, null, ex); + } + } + } + } + + // 网络连接恢复,设备重连成功回调 + // 通过 CLIENT_SetAutoReconnect 设置该回调函数,当已断线的设备重连成功时,SDK会调用该函数 + private static class HaveReConnect implements NetSDKLib.fHaveReConnect { + public void invoke(NativeLong m_hLoginHandle, String pchDVRIP, int nDVRPort, NativeLong dwUser) { + System.out.printf("ReConnect Device[%s] Port[%d]\n", pchDVRIP, nDVRPort); + + // 重连提示 + SwingUtilities.invokeLater(new Runnable() { + public void run() { + + } + }); + } + } + + // 登出 + public void logout() { + INetSDK.logout(); + } + + @SuppressWarnings("unchecked") + // //GEN-BEGIN:initComponents + private void initComponents() { + + jFrame1 = new JFrame(); + jFrame2 = new JFrame(); + TypeGroup = new ButtonGroup(); + jSplitPaneHorizontal = new JSplitPane(); + jPanelUserInfo = new JPanel(); + jButtonRealPlay = new JButton(); + jButtonLogin = new JButton(); + jLabelIPAddress = new JLabel(); + jTextFieldUser = new JTextField(); + jTextFieldIPAddress = new JTextField(); + jLabelPortNumber = new JLabel(); + jScrollPaneTree = new JScrollPane(); + jTreeDevice = new JTree(); + jButton2 = new JButton(); + jTextFieldPortNumber = new JTextField(); + jLabelPortNumber1 = new JLabel(); + jLabelIPAddress1 = new JLabel(); + jTextFieldPwd = new JTextField(); + jLabelPortNumber2 = new JLabel(); + nMeterType = new JTextField(); + jLabelPortNumber3 = new JLabel(); + jLabelPortNumber4 = new JLabel(); + nPresetIdTxt = new JTextField(); + nRuleIdSel = new JComboBox<>(); + jSplitPaneVertical = new JSplitPane(); + jLabel1 = new JLabel(); + panel1 = new Panel(); + jLabel2 = new JLabel(); + nMeterTypeTxt = new JTextField(); + jLabel3 = new JLabel(); + nTemperUnitTxt = new JTextField(); + jLabel4 = new JLabel(); + fTemperAverTxt = new JTextField(); + jLabel5 = new JLabel(); + fTemperMidTxt = new JTextField(); + fTemperMinTxt = new JTextField(); + jLabel6 = new JLabel(); + jLabel7 = new JLabel(); + fTemperMaxTxt = new JTextField(); + fTemperStdTxt = new JTextField(); + jLabel8 = new JLabel(); + jPanelRealplayArea = new JPanel(); + Realplay = new Panel(); + + GroupLayout jFrame1Layout = new GroupLayout(jFrame1.getContentPane()); + jFrame1.getContentPane().setLayout(jFrame1Layout); + jFrame1Layout.setHorizontalGroup( + jFrame1Layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGap(0, 400, Short.MAX_VALUE) + ); + jFrame1Layout.setVerticalGroup( + jFrame1Layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGap(0, 300, Short.MAX_VALUE) + ); + + GroupLayout jFrame2Layout = new GroupLayout(jFrame2.getContentPane()); + jFrame2.getContentPane().setLayout(jFrame2Layout); + jFrame2Layout.setHorizontalGroup( + jFrame2Layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGap(0, 400, Short.MAX_VALUE) + ); + jFrame2Layout.setVerticalGroup( + jFrame2Layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGap(0, 300, Short.MAX_VALUE) + ); + + setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE); + setTitle("ClientDemo"); + setFont(new Font("宋体", 0, 10)); // NOI18N + + jSplitPaneHorizontal.setBorder(BorderFactory.createEmptyBorder(1, 1, 1, 1)); + jSplitPaneHorizontal.setDividerLocation(155); + jSplitPaneHorizontal.setDividerSize(2); + + jPanelUserInfo.setBorder(BorderFactory.createEtchedBorder(new Color(204, 255, 255), null)); + jPanelUserInfo.setPreferredSize(new Dimension(500, 878)); + + jButtonRealPlay.setText("预览"); + jButtonRealPlay.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent evt) { + jButtonRealPlayActionPerformed(evt); + } + }); + + jButtonLogin.setText("退出预览"); + jButtonLogin.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent evt) { + jButtonLoginActionPerformed(evt); + } + }); + + jLabelIPAddress.setText("IP地址:"); + + jTextFieldUser.setText("admin"); + + jTextFieldIPAddress.setText("127.0.0.108"); + + jLabelPortNumber.setText("用户名:"); + + jTreeDevice.setModel(this.initialTreeModel()); + jScrollPaneTree.setViewportView(jTreeDevice); + + jButton2.setText("获取温度"); + jButton2.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent evt) { + jButton2ActionPerformed(evt); + } + }); + + jTextFieldPortNumber.setText("37777"); + + jLabelPortNumber1.setText("端口:"); + + jLabelIPAddress1.setText("密码:"); + + jTextFieldPwd.setText("shxy@12345"); + jTextFieldPwd.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent evt) { + jTextFieldPwdActionPerformed(evt); + } + }); + + jLabelPortNumber2.setText("规则编号:"); + + nMeterType.setText("0"); + + jLabelPortNumber3.setText("测温项类型:"); + + jLabelPortNumber4.setText("预置点编号:"); + + nPresetIdTxt.setText("0"); + + nRuleIdSel.setModel(new DefaultComboBoxModel<>(new String[] { "请选择类型" })); + + GroupLayout jPanelUserInfoLayout = new GroupLayout(jPanelUserInfo); + jPanelUserInfo.setLayout(jPanelUserInfoLayout); + jPanelUserInfoLayout.setHorizontalGroup( + jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addContainerGap() + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addComponent(jLabelIPAddress1) + .addGap(26, 26, 26) + .addComponent(jTextFieldPwd)) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addComponent(jButtonRealPlay, GroupLayout.PREFERRED_SIZE, 87, GroupLayout.PREFERRED_SIZE) + .addPreferredGap(LayoutStyle.ComponentPlacement.UNRELATED) + .addComponent(jButtonLogin, GroupLayout.DEFAULT_SIZE, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addComponent(jLabelPortNumber1) + .addGap(26, 26, 26) + .addComponent(jTextFieldPortNumber)))) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addContainerGap() + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jScrollPaneTree) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addComponent(jLabelPortNumber4) + .addGap(26, 26, 26) + .addComponent(nPresetIdTxt)) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jButton2, GroupLayout.PREFERRED_SIZE, 87, GroupLayout.PREFERRED_SIZE) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jLabelPortNumber3) + .addComponent(jLabelPortNumber2)) + .addGap(26, 26, 26) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING, false) + .addComponent(nMeterType) + .addComponent(nRuleIdSel, 0, GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)))) + .addGap(0, 0, Short.MAX_VALUE)))) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addGap(10, 10, 10) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jLabelIPAddress) + .addComponent(jLabelPortNumber)) + .addGap(14, 14, 14) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jTextFieldIPAddress) + .addComponent(jTextFieldUser)))) + .addContainerGap()) + ); + jPanelUserInfoLayout.setVerticalGroup( + jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(jPanelUserInfoLayout.createSequentialGroup() + .addGap(18, 18, 18) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jLabelIPAddress) + .addComponent(jTextFieldIPAddress, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabelPortNumber) + .addComponent(jTextFieldUser, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addGap(9, 9, 9) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jLabelIPAddress1) + .addComponent(jTextFieldPwd, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jLabelPortNumber1) + .addComponent(jTextFieldPortNumber, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.UNRELATED) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jButtonLogin) + .addComponent(jButtonRealPlay)) + .addGap(30, 30, 30) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(nPresetIdTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE) + .addComponent(jLabelPortNumber4)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabelPortNumber3) + .addComponent(nRuleIdSel, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(jPanelUserInfoLayout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(nMeterType, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE) + .addComponent(jLabelPortNumber2)) + .addPreferredGap(LayoutStyle.ComponentPlacement.UNRELATED) + .addComponent(jButton2) + .addGap(22, 22, 22) + .addComponent(jScrollPaneTree, GroupLayout.PREFERRED_SIZE, 167, GroupLayout.PREFERRED_SIZE) + .addContainerGap(357, Short.MAX_VALUE)) + ); + + jSplitPaneHorizontal.setLeftComponent(jPanelUserInfo); + + jSplitPaneVertical.setDividerLocation(579); + jSplitPaneVertical.setDividerSize(2); + jSplitPaneVertical.setOrientation(JSplitPane.VERTICAL_SPLIT); + + jLabel1.setText("jLabel1"); + jSplitPaneVertical.setRightComponent(jLabel1); + + jLabel2.setText("测温类型:"); + + jLabel3.setText("测温单位:"); + + jLabel4.setText("平均温度:"); + + jLabel5.setText("中间值:"); + + jLabel6.setText("最小温度:"); + + jLabel7.setText("最高温度:"); + + jLabel8.setText("标准方差值:"); + + jPanelRealplayArea.setBorder(BorderFactory.createLineBorder(new Color(153, 255, 102))); + + Realplay.setPreferredSize(new Dimension(500, 500)); + Realplay.addMouseListener(new MouseAdapter() { + public void mousePressed(MouseEvent evt) { + RealplayMousePressed(evt); + } + }); + + GroupLayout RealplayLayout = new GroupLayout(Realplay); + Realplay.setLayout(RealplayLayout); + RealplayLayout.setHorizontalGroup( + RealplayLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGap(0, 500, Short.MAX_VALUE) + ); + RealplayLayout.setVerticalGroup( + RealplayLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGap(0, 500, Short.MAX_VALUE) + ); + + GroupLayout jPanelRealplayAreaLayout = new GroupLayout(jPanelRealplayArea); + jPanelRealplayArea.setLayout(jPanelRealplayAreaLayout); + jPanelRealplayAreaLayout.setHorizontalGroup( + jPanelRealplayAreaLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(jPanelRealplayAreaLayout.createSequentialGroup() + .addGap(19, 19, 19) + .addComponent(Realplay, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE) + .addContainerGap(14579, Short.MAX_VALUE)) + ); + jPanelRealplayAreaLayout.setVerticalGroup( + jPanelRealplayAreaLayout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(jPanelRealplayAreaLayout.createSequentialGroup() + .addGap(28, 28, 28) + .addComponent(Realplay, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE) + .addContainerGap(49, Short.MAX_VALUE)) + ); + + GroupLayout panel1Layout = new GroupLayout(panel1); + panel1.setLayout(panel1Layout); + panel1Layout.setHorizontalGroup( + panel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(panel1Layout.createSequentialGroup() + .addGap(25, 25, 25) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.TRAILING) + .addGroup(panel1Layout.createSequentialGroup() + .addComponent(jLabel8) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addComponent(fTemperStdTxt, GroupLayout.PREFERRED_SIZE, 118, GroupLayout.PREFERRED_SIZE)) + .addGroup(panel1Layout.createSequentialGroup() + .addComponent(jLabel5) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addComponent(fTemperMidTxt, GroupLayout.PREFERRED_SIZE, 118, GroupLayout.PREFERRED_SIZE)) + .addGroup(panel1Layout.createSequentialGroup() + .addComponent(jLabel6) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addComponent(fTemperMinTxt, GroupLayout.PREFERRED_SIZE, 118, GroupLayout.PREFERRED_SIZE)) + .addGroup(panel1Layout.createSequentialGroup() + .addComponent(jLabel7) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addComponent(fTemperMaxTxt, GroupLayout.PREFERRED_SIZE, 118, GroupLayout.PREFERRED_SIZE)) + .addGroup(panel1Layout.createSequentialGroup() + .addComponent(jLabel4) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addComponent(fTemperAverTxt, GroupLayout.PREFERRED_SIZE, 118, GroupLayout.PREFERRED_SIZE)) + .addGroup(panel1Layout.createSequentialGroup() + .addComponent(jLabel3) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addComponent(nTemperUnitTxt, GroupLayout.PREFERRED_SIZE, 118, GroupLayout.PREFERRED_SIZE)) + .addGroup(panel1Layout.createSequentialGroup() + .addComponent(jLabel2) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addComponent(nMeterTypeTxt, GroupLayout.PREFERRED_SIZE, 118, GroupLayout.PREFERRED_SIZE))) + .addContainerGap(GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) + .addGroup(GroupLayout.Alignment.TRAILING, panel1Layout.createSequentialGroup() + .addContainerGap(GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE) + .addComponent(jPanelRealplayArea, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE) + .addContainerGap()) + ); + panel1Layout.setVerticalGroup( + panel1Layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addGroup(panel1Layout.createSequentialGroup() + .addContainerGap() + .addComponent(jPanelRealplayArea, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE) + .addGap(27, 27, 27) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabel2) + .addComponent(nMeterTypeTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.UNRELATED) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabel3) + .addComponent(nTemperUnitTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabel4) + .addComponent(fTemperAverTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabel7) + .addComponent(fTemperMaxTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.UNRELATED) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabel6) + .addComponent(fTemperMinTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabel5) + .addComponent(fTemperMidTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addPreferredGap(LayoutStyle.ComponentPlacement.RELATED) + .addGroup(panel1Layout.createParallelGroup(GroupLayout.Alignment.BASELINE) + .addComponent(jLabel8) + .addComponent(fTemperStdTxt, GroupLayout.PREFERRED_SIZE, GroupLayout.DEFAULT_SIZE, GroupLayout.PREFERRED_SIZE)) + .addContainerGap(GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)) + ); + + jLabel2.getAccessibleContext().setAccessibleDescription(""); + nMeterTypeTxt.getAccessibleContext().setAccessibleName(""); + + jSplitPaneVertical.setRightComponent(panel1); + + jSplitPaneHorizontal.setRightComponent(jSplitPaneVertical); + + GroupLayout layout = new GroupLayout(getContentPane()); + getContentPane().setLayout(layout); + layout.setHorizontalGroup( + layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jSplitPaneHorizontal, GroupLayout.DEFAULT_SIZE, 15401, Short.MAX_VALUE) + ); + layout.setVerticalGroup( + layout.createParallelGroup(GroupLayout.Alignment.LEADING) + .addComponent(jSplitPaneHorizontal) + ); + + pack(); + }// //GEN-END:initComponents + + /** + * 获得主机IP + * + * @return String + */ + public static boolean isWindowsOS(){ + boolean isWindowsOS = false; + String osName = System.getProperty("os.name"); + if(osName.toLowerCase().indexOf("windows")>-1){ + isWindowsOS = true; + } + return isWindowsOS; + } + + /** + * 获取本机ip地址,并自动区分Windows还是linux操作系统 + * @return String + */ + public static String getLocalIP(){ + String sIP = ""; + InetAddress ip = null; + try { + //如果是Windows操作系统 + if(isWindowsOS()){ + ip = InetAddress.getLocalHost(); + } + //如果是Linux操作系统 + else{ + boolean bFindIP = false; + Enumeration netInterfaces = (Enumeration) NetworkInterface + .getNetworkInterfaces(); + while (netInterfaces.hasMoreElements()) { + if(bFindIP){ + break; + } + NetworkInterface ni = (NetworkInterface) netInterfaces.nextElement(); + //----------特定情况,可以考虑用ni.getName判断 + //遍历所有ip + Enumeration ips = ni.getInetAddresses(); + while (ips.hasMoreElements()) { + ip = (InetAddress) ips.nextElement(); + if( ip.isSiteLocalAddress() + && !ip.isLoopbackAddress() //127.开头的都是lookback地址 + && ip.getHostAddress().indexOf(":")==-1){ + bFindIP = true; + break; + } + } + + } + } + } + catch (Exception e) { + e.printStackTrace(); + } + + if(null != ip){ + sIP = ip.getHostAddress(); + } + return sIP; + } + + + public static String getMotherboardSN() { + String result = ""; + try { + File file = File.createTempFile("realhowto", ".vbs"); + file.deleteOnExit(); + FileWriter fw = new FileWriter(file); + String vbs = "Set objWMIService = GetObject(\"winmgmts:\\\\.\\root\\cimv2\")\n" + + "Set colItems = objWMIService.ExecQuery _ \n" + + " (\"Select * from Win32_BaseBoard\") \n" + + "For Each objItem in colItems \n" + + " Wscript.Echo objItem.SerialNumber \n" + + " exit for ' do the first cpu only! \n" + "Next \n"; + fw.write(vbs); + fw.close(); + Process p = Runtime.getRuntime().exec("cscript //NoLogo " + file.getPath()); + BufferedReader input = new BufferedReader(new InputStreamReader(p.getInputStream())); + String line; + while ((line = input.readLine()) != null) { + result += line; + } + input.close(); + } catch (Exception e) { + e.printStackTrace(); + } + return result.trim(); + } + public String getSerialNumber(String drive) { + String result = ""; + try { + File file = File.createTempFile("realhowto",".vbs"); + file.deleteOnExit(); + FileWriter fw = new FileWriter(file); + String vbs = "Set objFSO = CreateObject(\"Scripting.FileSystemObject\")\n" + +"Set colDrives = objFSO.Drives\n" + +"Set objDrive = colDrives.item(\"" + drive + "\")\n" + +"Wscript.Echo objDrive.SerialNumber"; // see note + fw.write(vbs); + fw.close(); + Process p = Runtime.getRuntime().exec("cscript //NoLogo " + file.getPath()); + BufferedReader input = + new BufferedReader + (new InputStreamReader(p.getInputStream())); + String line; + while ((line = input.readLine()) != null) { + result += line; + } + input.close(); + }catch(Exception e){ + e.printStackTrace(); + } + return result.trim(); + } + public String Getserial(){ + String serial=""; + try{ + long start = System.currentTimeMillis(); + Process process = Runtime.getRuntime().exec( + new String[] { "wmic", "cpu", "get", "ProcessorId" }); + process.getOutputStream().close(); + Scanner sc = new Scanner(process.getInputStream()); + String property = sc.next(); + serial = sc.next(); + }catch(Exception e){ + e.printStackTrace(); + } + return serial; + } + private String MD5(String s) { + try { + MessageDigest md = MessageDigest.getInstance("MD5"); + byte[] bytes = md.digest(s.getBytes("utf-8")); + return toHex(bytes); + } + catch (Exception e) { + throw new RuntimeException(e); + } +} + +private static String toHex(byte[] bytes) { + + final char[] HEX_DIGITS = "0123456789ABCDEF".toCharArray(); + StringBuilder ret = new StringBuilder(bytes.length * 2); + for (int i=0; i> 4) & 0x0f]); + ret.append(HEX_DIGITS[bytes[i] & 0x0f]); + } + return ret.toString(); +} + /************************************************* + 函数: initialTableModel + 函数描述: 初始化报警信息列表,写入列名称 + *************************************************/ + public DefaultTableModel initialTableModel() + { + String tabeTile[]; + tabeTile = new String[]{"时间", "报警信息", "设备信息" }; + DefaultTableModel alarmTableModel = new DefaultTableModel(tabeTile, 0); + return alarmTableModel; + } + /************************************************* + 函数: 主函数 + 函数描述:新建ClientDemo窗体并调用接口初始化SDK + *************************************************/ + public static void main(String args[]) + { + try + { + //javax.swing.UIManager.setLookAndFeel("com.sun.java.swing.plaf.windows.WindowsLookAndFeel"); + } catch (Exception e) + { + e.printStackTrace(); + } + + EventQueue.invokeLater(new Runnable() + { + public void run() + { + Hot Demo = new Hot(); + centerWindow(Demo); + Demo.setVisible(true); + } + }); + } + /************************************************* + 函数: "注册" 按钮单击响应函数 + 函数描述: 注册登录设备 + *************************************************/ + private void jButtonLoginActionPerformed(ActionEvent evt) {//GEN-FIRST:event_jButtonLoginActionPerformed + INetSDK.stopRealPlay(); + INetSDK.logout(); + INetSDK.cleanup(); // 关闭工程,释放资源 + dispose(); + System.exit(0); + }//GEN-LAST:event_jButtonLoginActionPerformed + + /************************************************* + 函数: initialTreeModelArea + 函数描述: 初始化区域树 + *************************************************/ + private DefaultTreeModel initialTreeModelArea(){ + m_AreaRoot = new DefaultMutableTreeNode("Area"); + DefaultTreeModel myDefaultTreeModel = new DefaultTreeModel(m_AreaRoot);//使用根节点创建模型 + //LoadArea(); + return myDefaultTreeModel; + } + /************************************************* + 函数: initialTreeModelLine + 函数描述: 初始化线树 + *************************************************/ + private DefaultTreeModel initialTreeModelLine(){ + m_LineRoot = new DefaultMutableTreeNode("Line"); + DefaultTreeModel myDefaultTreeModel = new DefaultTreeModel(m_LineRoot);//使用根节点创建模型 + // LoadLine(); + return myDefaultTreeModel; + } + /************************************************* + 函数: initialTreeModelPoint + 函数描述: 初始化区域树 + *************************************************/ + private DefaultTreeModel initialTreeModelPoint(){ + m_PointRoot = new DefaultMutableTreeNode("Point"); + DefaultTreeModel myDefaultTreeModel = new DefaultTreeModel(m_PointRoot);//使用根节点创建模型 + //LoadPoint(); + return myDefaultTreeModel; + } + /************************************************* + 函数: initialTreeModel + 函数描述: 初始化设备树 + *************************************************/ + private DefaultTreeModel initialTreeModel() + { + m_DeviceRoot = new DefaultMutableTreeNode("Device"); + DefaultTreeModel myDefaultTreeModel = new DefaultTreeModel(m_DeviceRoot);//使用根节点创建模型 + LoadEqm(); + return myDefaultTreeModel; + } + + /* private JPopupMenu Areamenu = new JPopupMenu(); + private void LoadArea() { + try{ + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeArea.getModel()); + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM data_dahuaeqmarea WHERE eqmid='"+eqmid+"'"; + System.out.println(sql); + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + System.out.println(rs); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + while(rs.next()){ + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(rs.getString("areaid")); + DefaultMutableTreeNode rootNode = (DefaultMutableTreeNode) TreeModel.getRoot(); + rootNode.removeAllChildren(); + TreeModel.insertNodeInto(newNode,m_AreaRoot,newNode.getChildCount()); + } + TreeModel.reload(); + JMenuItem eqmPlay, eqmDel; + Areamenu = new JPopupMenu(); + Areamenu.size(); + eqmPlay = new JMenuItem("修改(U)"); + Areamenu.add(eqmPlay); + eqmDel = new JMenuItem("删除(D)"); + Areamenu.add(eqmDel); + jTreeArea.addMouseListener(new MouseAdapter() { + public void mousePressed(MouseEvent e ) { + System.out.println(e.getWhen()); + TreePath path = jTreeArea.getPathForLocation(e.getX(),e.getY()); + jTreeArea.setSelectionPath(path); + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeArea.getLastSelectedPathComponent();//返回最后选定的节点 + //if(!selectedNode.toString().equals("Point")){ + if( SwingUtilities.isRightMouseButton (e) ) + if (e.getButton()==MouseEvent.BUTTON3) { + //弹出右键菜单 + Areamenu.show(jTreeArea, e.getX(), e.getY()); + } + // }else{ + //JOptionPane.showMessageDialog(null, "请先选择通道"); + //} + } + }); + eqmPlay.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeArea.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Area")){ + Updatearea(selectedNode.toString()); + } + } + }); + eqmDel.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeArea.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Area")){ + System.out.println(selectedNode.toString()); + Delarea(selectedNode.toString()); + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeArea.getModel()); + TreeModel.removeNodeFromParent(selectedNode); + TreeModel.reload(); + } + } + }); + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + /** + * 修改区域 + * areaId 区域编号 + **/ + private void Updatearea(String areaId){ + setarea = Integer.parseInt(areaId); + } + /** + * 删除点 + * areaId 区域编号 + **/ + + /*private void Delarea(String areaId){ + int delout = netSDKLib.DM_ClearSpot(play,Integer.parseInt(areaId)); + System.out.println(delout); + if(delout>0){ + DBHelper help=new DBHelper(); + String sql ="DELETE FROM data_dahuaeqmarea WHERE eqmid='"+eqmid+"' AND areaid='"+areaId+"'"; + help.getConnection(); + help.excuteUpdate(sql); + } + } + + private JPopupMenu Linemenu = new JPopupMenu(); + private void LoadLine() { + try{ + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeLine.getModel()); + DefaultMutableTreeNode rootNode = (DefaultMutableTreeNode) TreeModel.getRoot(); + rootNode.removeAllChildren(); + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM data_dahuaeqmline WHERE eqmid='"+eqmid+"'"; + System.out.println(sql); + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + System.out.println(rs); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + while(rs.next()){ + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(rs.getString("lineid")); + + TreeModel.insertNodeInto(newNode,m_LineRoot,newNode.getChildCount()); + } + TreeModel.reload(); + JMenuItem eqmPlay, eqmDel; + Linemenu = new JPopupMenu(); + Linemenu.size(); + eqmPlay = new JMenuItem("修改(U)"); + Linemenu.add(eqmPlay); + eqmDel = new JMenuItem("删除(D)"); + Linemenu.add(eqmDel); + jTreeLine.addMouseListener(new MouseAdapter() { + public void mousePressed(MouseEvent e ) { + System.out.println(e.getWhen()); + TreePath path = jTreeLine.getPathForLocation(e.getX(),e.getY()); + jTreeLine.setSelectionPath(path); + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeLine.getLastSelectedPathComponent();//返回最后选定的节点 + //if(!selectedNode.toString().equals("Point")){ + if( SwingUtilities.isRightMouseButton (e) ) + if (e.getButton()==MouseEvent.BUTTON3) { + //弹出右键菜单 + Linemenu.show(jTreeLine, e.getX(), e.getY()); + } + // }else{ + //JOptionPane.showMessageDialog(null, "请先选择通道"); + //} + } + }); + eqmPlay.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeLine.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Point")){ + Updatepoint(selectedNode.toString()); + } + } + }); + eqmDel.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeLine.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Point")){ + System.out.println(selectedNode.toString()); + Delline(selectedNode.toString()); + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeLine.getModel()); + TreeModel.removeNodeFromParent(selectedNode); + TreeModel.reload(); + } + } + }); + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + }*/ + /** + * 删除线 + * lineId 线编号 + **/ + + /* private void Delline(String lineId){ + int delout = NetSDKLib.DM_ClearLine(play,Integer.parseInt(lineId)); + System.out.println(delout); + if(delout>0){ + DBHelper help=new DBHelper(); + String sql ="DELETE FROM data_dahuaeqmline WHERE eqmid='"+eqmid+"' AND lineId='"+lineId+"'"; + help.getConnection(); + help.excuteUpdate(sql); + } + } + private JPopupMenu Pointmenu = new JPopupMenu(); + private void LoadPoint() { + try{ + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeSpot.getModel()); + DefaultMutableTreeNode rootNode = (DefaultMutableTreeNode) TreeModel.getRoot(); + rootNode.removeAllChildren(); + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM data_dahuaeqmpoint WHERE eqmid='"+eqmid+"'"; + System.out.println(sql); + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + System.out.println(rs); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + while(rs.next()){ + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(rs.getString("pointid")); + TreeModel.insertNodeInto(newNode,m_PointRoot,newNode.getChildCount()); + } + TreeModel.reload(); + JMenuItem eqmPlay, eqmDel; + Pointmenu = new JPopupMenu(); + Pointmenu.size(); + eqmPlay = new JMenuItem("修改(U)"); + Pointmenu.add(eqmPlay); + eqmDel = new JMenuItem("删除(D)"); + Pointmenu.add(eqmDel); + jTreeSpot.addMouseListener(new MouseAdapter() { + public void mousePressed(MouseEvent e ) { + System.out.println(e.getWhen()); + TreePath path = jTreeSpot.getPathForLocation(e.getX(),e.getY()); + jTreeSpot.setSelectionPath(path); + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeSpot.getLastSelectedPathComponent();//返回最后选定的节点 + //if(!selectedNode.toString().equals("Point")){ + if( SwingUtilities.isRightMouseButton (e) ) + if (e.getButton()==MouseEvent.BUTTON3) { + //弹出右键菜单 + Pointmenu.show(jTreeSpot, e.getX(), e.getY()); + } + // }else{ + //JOptionPane.showMessageDialog(null, "请先选择通道"); + //} + } + }); + + eqmPlay.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeSpot.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Point")){ + Updatepoint(selectedNode.toString()); + } + } + }); + eqmDel.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeSpot.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Point")){ + System.out.println(selectedNode.toString()); + Delpoint(selectedNode.toString()); + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeSpot.getModel()); + TreeModel.removeNodeFromParent(selectedNode); + TreeModel.reload(); + } + } + }); + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + }*/ + /** + * 修改点 + * pointId 点编号 + **/ + /* + private void Updatepoint(String pointId){ + setspot = Integer.parseInt(pointId); + } + /** + * 删除点 + * pointId 点编号 + **/ + /* + private void Delpoint(String pointId){ + int delout = NetSDKLib.DM_ClearSpot(play,Integer.parseInt(pointId)); + System.out.println(delout); + if(delout>0){ + DBHelper help=new DBHelper(); + String sql ="DELETE FROM data_dahuaeqmpoint WHERE eqmid='"+eqmid+"' AND pointid='"+pointId+"'"; + help.getConnection(); + help.excuteUpdate(sql); + } + }*/ + private JPopupMenu Eqmmenu = new JPopupMenu(); + private void LoadEqm(){ + try{ + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeDevice.getModel()); + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM modev where modevtid='9'"; + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + System.out.println(rs); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + while(rs.next()){ + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(rs.getString("ip")); + TreeModel.insertNodeInto(newNode,m_DeviceRoot,newNode.getChildCount()); + } + JMenuItem eqmPlay, eqmDel; + Eqmmenu = new JPopupMenu(); + Eqmmenu.size(); + eqmPlay = new JMenuItem("预览(P)"); + Eqmmenu.add(eqmPlay); + eqmDel = new JMenuItem("删除(D)"); + Eqmmenu.add(eqmDel); + jTreeDevice.addMouseListener(new MouseAdapter() { + public void mousePressed(MouseEvent e ) { + System.out.println(e.getWhen()); + TreePath path = jTreeDevice.getPathForLocation(e.getX(),e.getY()); + jTreeDevice.setSelectionPath(path); + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeDevice.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Device")){ + if( SwingUtilities.isRightMouseButton (e) ) + if (e.getButton()==MouseEvent.BUTTON3) { + //弹出右键菜单 + Eqmmenu.show(jTreeDevice, e.getX(), e.getY()); + } + }else{ + JOptionPane.showMessageDialog(null, "请先选择设备"); + } + } + }); + eqmPlay.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeDevice.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Device")){ + ToLoginInfo(selectedNode.toString()); + } + } + }); + eqmDel.addActionListener(new ActionListener() { + public void actionPerformed(ActionEvent e) { + DefaultMutableTreeNode selectedNode=(DefaultMutableTreeNode) jTreeDevice.getLastSelectedPathComponent();//返回最后选定的节点 + if(!selectedNode.toString().equals("Device")){ + System.out.println(selectedNode.toString()); + LogoutEqm(selectedNode.toString()); + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeDevice.getModel()); + TreeModel.removeNodeFromParent(selectedNode); + TreeModel.reload(); + } + } + }); + }catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + /** + * 登录设备 + * DeviceIP 设备Ip + * Port 设备端口 + **/ + private void ToLoginInfo(String DeviceIP){ + try{ + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM modev WHERE ip='"+DeviceIP+"'"; + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + if(rs.next()){ + System.out.println(rs); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + //is yes + eqmid = Integer.parseInt(rs.getString("id")); + int Port = Integer.parseInt(rs.getString("port")); + String User = String.valueOf(rs.getString("username")); + String Pwd = String.valueOf(rs.getString("pwd")); + LoginEqm(DeviceIP,Port,User,Pwd); + System.out.println(eqmid); + } + }catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + /** + * 登录设备 + * DeviceIP 设备Ip + * Port 设备端口 + **/ + private void LoginEqm(String DeviceIP,int Port,String User,String Pwd){ + try { + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeDevice.getModel()); + m_sDeviceIP = DeviceIP; + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM modev WHERE ip='"+DeviceIP+"'"; + + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + if(rs.next()){ + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + //is yes + eqmid = Integer.parseInt(rs.getString("id")); + + }else{ + sql ="INSERT INTO modev(ip,username,pwd,port,modevtid,zsbid,iedid) values('"+m_sDeviceIP+"','"+User+"','"+Pwd+"','"+Port+"','9','3','1')"; + + help.getConnection(); + eqmid = help.excuteUpdate(sql); + if(eqmid>0){ + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(m_sDeviceIP); + TreeModel.insertNodeInto(newNode,m_DeviceRoot,0); + } + } + if(eqmid>0){ + //Realplay.removeAll(); + login = INetSDK.login(DeviceIP,Port, User,Pwd); + if(login){ + hwnd = new HWND(Native.getComponentPointer(Realplay)); + bRealPlay = INetSDK.startRealPlay(1,0,Realplay); + System.out.println("预览成功"); + }else{ + System.out.println("预览失败"); + } + /* + //int open= NetSDKLib.DM_Open(conn); + eqmconn = NetSDKLib.DM_Connect(hwnd,DeviceIP,Port); + play = NetSDKLib.DM_PlayerInit(hwnd); + //int nums = NetSDKLib.DM_GetDateTime(hwnd,"yyyy-mm-dd hh-mm-ss"); + plays = NetSDKLib.DM_OpenMonitor(hwnd,DeviceIP,5000,0); + if(plays>0){ + //预览成功 + bRealPlay=true; + }*/ + } + //LoadPoint(); + //LoadLine(); + //LoadArea(); + TreeModel.reload();//将添加的节点显示到界面 + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + } + /** + * 退出设备 + * DeviceIP 设备Ip + * Port 设备端口 + **/ + private void LogoutEqm(String DeviceIP){ + Realplay.removeAll(); + INetSDK.stopRealPlay(); + INetSDK.logout(); + INetSDK.cleanup(); // 关闭工程,释放资源 + DBHelper help=new DBHelper(); + String sql ="DELETE FROM modev WHERE ip='"+DeviceIP+"'"; + help.getConnection(); + help.excuteUpdate(sql); + } + /************************************************* + 函数: "预览" 按钮单击响应函数 + 函数描述: 获取通道号,打开播放窗口,开始此通道的预览 + *************************************************/ + private void jButtonRealPlayActionPerformed(ActionEvent evt)//GEN-FIRST:event_jButtonRealPlayActionPerformed + {//GEN-HEADEREND:event_jButtonRealPlayActionPerformed + try { + //获取树模型 + String DeviceIP = jTextFieldIPAddress.getText();//设备ip地址 + String User = jTextFieldUser.getText();//用户名 + String Pwd = jTextFieldPwd.getText();//密码 + int Port = Integer.parseInt(jTextFieldPortNumber.getText());//设备端口 + LoginEqm(DeviceIP,Port,User,Pwd); + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } +}//GEN-LAST:event_jButtonRealPlayActionPerformed + + + /************************************************* + 函数: "播放窗口" 双击响应函数 + 函数描述: 双击全屏预览当前预览通道 + *************************************************/ + private void RealplayMousePressed(MouseEvent evt)//GEN-FIRST:event_RealplayMousePressed + {//GEN-HEADEREND:event_RealplayMousePressed + if(!bRealPlay) + { + return; + } + //鼠标单击事件为双击 + if(evt.getClickCount() == 2) + { + + + } + }//GEN-LAST:event_RealplayMousePressed + + int flag; //flag=1代表Mouse Moved,flag=2代表Mouse Dragged + int x = 0; int y = 0; int startx, starty, endx, endy;//起始坐标与终点坐标 + int type=0;//1=>点,2=>线条,3->框 + public class NET_RADIOMETRY_METERTYPE { + public int NET_RADIOMETRY_METERTYPE_UNKNOWN=0; //无 + public int NET_RADIOMETRY_METERTYPE_SPOT=1; //点 + public int NET_RADIOMETRY_METERTYPE_LINE=2; //线 + public int NET_RADIOMETRY_METERTYPE_AREA=3; //区域 + } + private void jButton2ActionPerformed(ActionEvent evt) {//GEN-FIRST:event_jButton2ActionPerformed + // TODO add your handling code here: + if(Integer.parseInt(nMeterType.getText())==0){ + JOptionPane.showMessageDialog(this, "请填写规则编号!"); + }else if(nRuleIdSel.getSelectedIndex()==0){ + JOptionPane.showMessageDialog(this, "请选择类型!"); + }else{ + if(Integer.parseInt(nPresetIdTxt.getText())>0){ + boolean ispresrtid = INetSDK.ptzControlnPresetId(0,0,Integer.parseInt(nPresetIdTxt.getText()),0,0,null); + if(ispresrtid){ + System.out.println("预置点设置成功"); + try { + Thread.sleep(5000); + } catch (InterruptedException ex) { + Logger.getLogger(Hot.class.getName()).log(Level.SEVERE, null, ex); + } + }else{ + JOptionPane.showMessageDialog(this, "预置点设置失败!"); + return; + } + } + NetSDKLib.NET_IN_RADIOMETRY_GETTEMPER stuRadioMetryInTemper = new NetSDKLib.NET_IN_RADIOMETRY_GETTEMPER(); + NetSDKLib.NET_OUT_RADIOMETRY_GETTEMPER stuRadioMetryOutTemper = new NetSDKLib.NET_OUT_RADIOMETRY_GETTEMPER(); + if(Integer.parseInt(nPresetIdTxt.getText())>0){ + stuRadioMetryInTemper.stCondition.nChannel = 1; + }else{ + stuRadioMetryInTemper.stCondition.nChannel = 0; + } + stuRadioMetryInTemper.stCondition.nPresetId = Integer.parseInt(nPresetIdTxt.getText()); + stuRadioMetryInTemper.stCondition.nRuleId = Integer.parseInt(nMeterType.getText()); + stuRadioMetryInTemper.stCondition.nMeterType =nRuleIdSel.getSelectedIndex(); + stuRadioMetryInTemper.write(); + stuRadioMetryOutTemper.write(); + boolean Isdate = INetSDK.CLIENT_QueryDevInfo(NetSDKLib.NET_QUERY_DEV_RADIOMETRY_TEMPER,stuRadioMetryInTemper.getPointer(),stuRadioMetryOutTemper.getPointer(),null,3000); + stuRadioMetryInTemper.read(); + stuRadioMetryOutTemper.read(); + if(Isdate){ + int nMeterType = stuRadioMetryOutTemper.stTempInfo.nMeterType; + if(nMeterType==1){ + nMeterTypeTxt.setText("点"); + }else if(nMeterType==2){ + nMeterTypeTxt.setText("线"); + }else if(nMeterType==3){ + nMeterTypeTxt.setText("区域"); + }else{ + nMeterTypeTxt.setText("未知类型"); + } + int nTemperUnit = stuRadioMetryOutTemper.stTempInfo.nTemperUnit; + if(nTemperUnit==1){ + nTemperUnitTxt.setText("摄氏度"); + }else if(nTemperUnit==2){ + nTemperUnitTxt.setText("华氏度"); + }else{ + nTemperUnitTxt.setText("未知单位"); + } + fTemperAverTxt.setText(String.valueOf(stuRadioMetryOutTemper.stTempInfo.fTemperAver)); + fTemperMaxTxt.setText(String.valueOf(stuRadioMetryOutTemper.stTempInfo.fTemperMax)); + fTemperMinTxt.setText(String.valueOf(stuRadioMetryOutTemper.stTempInfo.fTemperMin)); + fTemperMidTxt.setText(String.valueOf(stuRadioMetryOutTemper.stTempInfo.fTemperMid)); + fTemperStdTxt.setText(String.valueOf(stuRadioMetryOutTemper.stTempInfo.fTemperStd)); + DBHelper help=new DBHelper(); + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");//设置日期格式 + String sql ="INSERT INTO data_eaif_h(eqmid,areaid,capturetime,maxtemp,mintemp,avgtemp,unit,type,mid,std) values('"+eqmid+"','1','"+df.format(new Date())+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperMax+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperMin+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperAver+"','"+stuRadioMetryOutTemper.stTempInfo.nTemperUnit+"','"+stuRadioMetryOutTemper.stTempInfo.nMeterType+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperMid+"','"+stuRadioMetryOutTemper.stTempInfo.fTemperStd+"')"; + + help.getConnection(); + int ret = help.excuteUpdate(sql); + if(ret>0){ + JOptionPane.showMessageDialog(this, "获取成功,保存成功"); + }else{ + JOptionPane.showMessageDialog(this, "获取成功,保存失败"); + } + }else{ + JOptionPane.showMessageDialog(this, "获取失败"); + } + } + + /*int delout = NetSDKLib.DM_GetTemp(play,1); + int delout1 = NetSDKLib.DM_GetSpotTemp(play,1,0); + //OnMsgTempValue(NetSDKLib.WM_DM_TEMP_VALUE,hwnd); + System.out.println(delout); + System.out.println(delout1);*/ + }//GEN-LAST:event_jButton2ActionPerformed + + private void jTextFieldPwdActionPerformed(ActionEvent evt) {//GEN-FIRST:event_jTextFieldPwdActionPerformed + // TODO add your handling code here: + }//GEN-LAST:event_jTextFieldPwdActionPerformed + + //void OnMsgTempValue(String wParam,HWND lParam){ + //System.out.println(wParam); + //System.out.println(lParam); + //} + private void LoadPanel(){ + NewPanel p = new NewPanel(); + p.setOpaque(false); + Realplay.add(p); //将面板添加到JFrame上 + p.setVisible(true); + p.setSize(Realplay.getWidth(), Realplay.getHeight()); + if(!bRealPlay){ + JOptionPane.showMessageDialog(this, "请先预览"); + }else{ + + } + + } + /************************************************* + 函数: centerWindow + 函数描述:窗口置中 + *************************************************/ + public static void centerWindow(Container window) { + Dimension dim = Toolkit.getDefaultToolkit().getScreenSize(); + int w = window.getSize().width; + int h = window.getSize().height; + int x = (dim.width - w) / 2; + int y = (dim.height - h) / 2; + window.setLocation(x, y); + } + + + + + + // Variables declaration - do not modify//GEN-BEGIN:variables + private Panel Realplay; + private ButtonGroup TypeGroup; + private JTextField fTemperAverTxt; + private JTextField fTemperMaxTxt; + private JTextField fTemperMidTxt; + private JTextField fTemperMinTxt; + private JTextField fTemperStdTxt; + private JButton jButton2; + private JButton jButtonLogin; + private JButton jButtonRealPlay; + private JFrame jFrame1; + private JFrame jFrame2; + private JLabel jLabel1; + private JLabel jLabel2; + private JLabel jLabel3; + private JLabel jLabel4; + private JLabel jLabel5; + private JLabel jLabel6; + private JLabel jLabel7; + private JLabel jLabel8; + private JLabel jLabelIPAddress; + private JLabel jLabelIPAddress1; + private JLabel jLabelPortNumber; + private JLabel jLabelPortNumber1; + private JLabel jLabelPortNumber2; + private JLabel jLabelPortNumber3; + private JLabel jLabelPortNumber4; + private JPanel jPanelRealplayArea; + private JPanel jPanelUserInfo; + private JScrollPane jScrollPaneTree; + private JSplitPane jSplitPaneHorizontal; + private JSplitPane jSplitPaneVertical; + private JTextField jTextFieldIPAddress; + private JTextField jTextFieldPortNumber; + private JTextField jTextFieldPwd; + private JTextField jTextFieldUser; + private JTree jTreeDevice; + private JTextField nMeterType; + private JTextField nMeterTypeTxt; + private JTextField nPresetIdTxt; + private JComboBox nRuleIdSel; + private JTextField nTemperUnitTxt; + private Panel panel1; + // End of variables declaration//GEN-END:variables + JButton button; + static Point origin = new Point(); + Point p; + int width; + int height; + Graphics gs; + + + + class NewPanel extends JPanel implements MouseListener, MouseMotionListener + { + private BasicStroke stokeLine = new BasicStroke(2.0f); + public NewPanel() + { + Realplay.addMouseListener(this); + Realplay.addMouseMotionListener(this); + button.setBounds(width/2, height/2, 20, 20); + add(button); + } + public void paintComponent(Graphics g) + { + gs= g; + width=getSize().width; + height=getSize().height; + super.paintComponent(g); + Graphics2D g2=(Graphics2D)g; + g2.setStroke( stokeLine ); + g2.setColor(Color.BLUE); + g2.drawLine(width/2,height/2,width,height); + g2.drawLine(0,height/2,width,height/2); + } + @Override + public void mouseClicked(MouseEvent e) { + // TODO Auto-generated method stub + endx = e.getX(); + endy = e.getY(); + repaint(); + } + @Override + public void mouseEntered(MouseEvent e) { + // TODO Auto-generated method stub + + } + @Override + public void mouseExited(MouseEvent e) { + // TODO Auto-generated method stub + + } + @Override + public void mousePressed(MouseEvent e) { + startx = e.getX(); + starty = e.getY(); + } + @Override + public void mouseReleased(MouseEvent e) { + // TODO Auto-generated method stub + endx = e.getX(); + endy = e.getY(); + repaint(); + } + @Override + public void mouseDragged(MouseEvent e) { + flag = 2; + x = e.getX(); + y = e.getY(); + //repaint(); + } + @Override + public void mouseMoved(MouseEvent e) { + // TODO Auto-generated method stub + flag = 1; + x = e.getX(); + y = e.getY(); + } + public void update(Graphics g) { + g.setColor(this.getBackground()); + //g.fillRect(0, 0, getWidth(), getHeight()); + //清除当前的窗口内容 + paint(g); + } + public void paint(Graphics g) { + /* try { + System.out.println("out: "+ getWidth()); + g.drawString("鼠标坐标:(" + x + "," + y + ")", 10, 50); + g.setColor(Color.gray); + if(type==1){ + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeSpot.getModel()); + g.drawLine(startx, starty, endx, endy); + System.out.println("setspot: "+ setspot); + int setisspot = NetSDKLib.DM_SetSpot(play, setspot, x, y, 90); + System.out.println("setisspot: "+ setisspot); + if(setisspot>0){ + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM data_dahuaeqmpoint WHERE eqmid='"+eqmid+"' AND pointid='"+setspot+"'"; + System.out.println(sql); + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + //is yes + if(!rs.next()){ + sql ="INSERT INTO data_dahuaeqmpoint(eqmid,pointid,x,y) values('"+eqmid+"','"+setspot+"','"+x+"','"+y+"')"; + System.out.println(sql); + help.getConnection(); + help.excuteUpdate(sql); + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(setspot); + TreeModel.insertNodeInto(newNode,m_PointRoot,0); + TreeModel.reload();//将添加的节点显示到界面 + setspot = setspot+1; + }else{ + sql ="UPDATE data_dahuaeqmpoint SET x='"+x+"',y='"+y+"' WHERE eqmid='"+eqmid+"' AND pointid='"+setspot+"'"; + System.out.println(sql); + help.getConnection(); + help.excuteUpdate(sql); + } + System.out.println("out: "+ x+":"+y); + System.out.println("setspot: "+ setspot); + }else{ + JOptionPane.showMessageDialog(this, "设置点失败"); + } + } + if(type==2){ + g.drawLine(startx, starty, endx, endy); + int setisline = NetSDKLib.DM_SetLine(play,setline, startx, starty, endx,endy,endx,endy, 90); + if(setisline>0){ + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeLine.getModel()); + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM data_dahuaeqmline WHERE eqmid='"+eqmid+"' AND lineid='"+setline+"'"; + System.out.println(sql); + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + //is yes + if(!rs.next()){ + sql ="INSERT INTO data_dahuaeqmline(eqmid,lineid,startx,starty,endx,endy,testx,testy) values('"+eqmid+"','"+setline+"','"+startx+"','"+starty+"','"+endx+"','"+endy+"','"+endx+"','"+endy+"')"; + System.out.println(sql); + help.getConnection(); + help.excuteUpdate(sql); + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(setline); + TreeModel.insertNodeInto(newNode,m_LineRoot,0); + TreeModel.reload();//将添加的节点显示到界面 + }else{ + sql ="UPDATE data_dahuaeqmline SET startx='"+startx+"',starty='"+starty+"',endx='"+endx+"',endy='"+endy+"',testx='"+endx+"',testy='"+endy+"' WHERE eqmid='"+eqmid+"' AND lineid='"+setline+"'"; + System.out.println(sql); + help.getConnection(); + help.excuteUpdate(sql); + } + System.out.println("setline: "+ setline); + }else{ + JOptionPane.showMessageDialog(this, "设置线失败"); + } + } + if(type==3){ + int ax1=Math.min(startx, endx); + int ayx1=Math.min(endx, endy); + int ax2=Math.abs(startx - endx); + int ay2=Math.abs(endx - endy); + g.drawRect(ax1, ayx1, ax2,ay2); + int setisarea = NetSDKLib.DM_SetArea(play,setarea,startx,starty,endx,endy,90,2); + System.out.println("setisspot: "+ setarea); + if(setisarea>0){ + DefaultTreeModel TreeModel = ((DefaultTreeModel) jTreeArea.getModel()); + DBHelper help=new DBHelper(); + String sql ="SELECT * FROM data_dahuaeqmarea WHERE eqmid='"+eqmid+"' AND areaid='"+setarea+"'"; + System.out.println(sql); + Connection conn=null; + PreparedStatement pstmt = null; + ResultSet rs=null; + conn=help.getConnection(); + pstmt=conn.prepareStatement(sql);//装载sql语句 + rs=pstmt.executeQuery(); + //把查询出来的记录封装成对应的实体类对象 + ResultSetMetaData rsd=rs.getMetaData();//获得列对象,通过此对象可以得到表的结构,包括,列名,列的个数,列的数据类型 + //is yes + if(!rs.next()){ + sql ="INSERT INTO data_dahuaeqmarea(eqmid,areaid,startx,starty,endx,endy) values('"+eqmid+"','"+setarea+"','"+startx+"','"+starty+"','"+endx+"','"+endy+"')"; + System.out.println(sql); + help.getConnection(); + help.excuteUpdate(sql); + DefaultMutableTreeNode newNode = new DefaultMutableTreeNode(setarea); + TreeModel.insertNodeInto(newNode,m_AreaRoot,0); + TreeModel.reload();//将添加的节点显示到界面 + setarea = setarea+1; + }else{ + sql ="UPDATE data_dahuaeqmarea SET startx='"+startx+"',starty='"+starty+"',endx='"+endx+"',endy='"+endy+"' WHERE eqmid='"+eqmid+"' AND areaid='"+setarea+"'"; + System.out.println(sql); + help.getConnection(); + help.excuteUpdate(sql); + } + }else{ + JOptionPane.showMessageDialog(this, "设置区域失败"); + } + System.out.println("setarea: "+ setarea); + } + //g.drawLine(200,205,getWidth(),205); + }catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + }*/ + } + } +} + diff --git a/src/main/java/com/shxy/xyhkcamera/test/INetSDK.java b/src/main/java/com/shxy/xyhkcamera/test/INetSDK.java new file mode 100644 index 0000000..159ede2 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/INetSDK.java @@ -0,0 +1,678 @@ +package com.shxy.xyhkcamera.test; + +import java.awt.Panel; +import java.io.File; + +import com.sun.jna.Native; +import com.sun.jna.NativeLong; +import com.sun.jna.Pointer; +import com.sun.jna.Structure; +import com.sun.jna.examples.win32.W32API; +import com.sun.jna.ptr.IntByReference; +import com.sun.jna.win32.StdCallLibrary; +import com.sun.jna.win32.StdCallLibrary.StdCallCallback; + +import javax.swing.SwingUtilities; + +public class INetSDK { + static NetSDKLib netsdk = NetSDKLib.NETSDK_INSTANCE; + private static NetSDKLib playsdk = NetSDKLib.CONFIG_dhplay; + + // 设备信息 + public static NetSDKLib.NET_DEVICEINFO_Ex m_stDeviceInfo = new NetSDKLib.NET_DEVICEINFO_Ex(); + + // 登陆句柄 + public static NativeLong m_hLoginHandle = new NativeLong(0); + + // 预览句柄 + public static NativeLong m_hPlayHandle = new NativeLong(0); + + // 智能订阅句柄 + public static NativeLong m_hAttachHandle = new NativeLong(0); + + // 下载句柄 + public static NativeLong m_hDownLoadHandle = new NativeLong(0); + + private static boolean bInit = false; + private static boolean bLogopen = false; + + /** + * \if ENGLISH_LANG + * Init + * \else + * 初始化 + * \endif + */ + public static boolean init(NetSDKLib.fDisConnect disConnect, NetSDKLib.fHaveReConnect haveReConnect) { + bInit = netsdk.CLIENT_Init(disConnect, new NativeLong(0)); + if (!bInit) { + System.out.println("Initialize SDK failed"); + return false; + } + + //打开日志,可选 + NetSDKLib.LOG_SET_PRINT_INFO setLog = new NetSDKLib.LOG_SET_PRINT_INFO(); + File path = new File("./sdklog/"); + if (!path.exists()) { + path.mkdir(); + } + String logPath = path.getAbsoluteFile().getParent() + "\\sdklog\\" + ToolKits.getDate() + ".log"; + setLog.nPrintStrategy = 0; + setLog.bSetFilePath = 1; + System.arraycopy(logPath.getBytes(), 0, setLog.szLogFilePath, 0, logPath.getBytes().length); + System.out.println(logPath); + setLog.bSetPrintStrategy = 1; + setLog.nPrintStrategy = 0; + bLogopen = netsdk.CLIENT_LogOpen(setLog); + if (!bLogopen) { + System.err.println("Failed to open NetSDK log"); + } + + // 设置断线重连回调接口,设置过断线重连成功回调函数后,当设备出现断线情况,SDK内部会自动进行重连操作 + // 此操作为可选操作,但建议用户进行设置 + netsdk.CLIENT_SetAutoReconnect(haveReConnect, new NativeLong(0)); + + //设置登录超时时间和尝试次数,可选 + int waitTime = 5000; //登录请求响应超时时间设置为5S + int tryTimes = 1; //登录时尝试建立链接1次 + netsdk.CLIENT_SetConnectTime(waitTime, tryTimes); + + // 设置更多网络参数,NET_PARAM的nWaittime,nConnectTryNum成员与CLIENT_SetConnectTime + // 接口设置的登录设备超时时间和尝试次数意义相同,可选 + NetSDKLib.NET_PARAM netParam = new NetSDKLib.NET_PARAM(); + netParam.nConnectTime = 10000; //登录时尝试建立链接的超时时间 + netsdk.CLIENT_SetNetworkParam(netParam); + + return true; + } + + /** + * \if ENGLISH_LANG + * CleanUp + * \else + * 清除环境 + * \endif + */ + public static void cleanup() { + if (bLogopen) { + netsdk.CLIENT_LogClose(); + } + + if (bInit) { + netsdk.CLIENT_Cleanup(); + } + } + + /** + * \if ENGLISH_LANG + * Login Device + * \else + * 登录设备 + * \endif + */ + public static boolean login(String m_strIp, int m_nPort, String m_strUser, String m_strPassword) { + IntByReference nError = new IntByReference(0); + m_hLoginHandle = netsdk.CLIENT_LoginEx2(m_strIp, m_nPort, m_strUser, m_strPassword, 0, null, m_stDeviceInfo, nError); + if (m_hLoginHandle.longValue() == 0) { + System.err.printf("Login Device[%s] Port[%d]Failed. Last Error[0x%x]\n", m_strIp, m_nPort, netsdk.CLIENT_GetLastError()); + } else { + System.out.println("Login Success [ " + m_strIp + " ]"); + } + return m_hLoginHandle.longValue() == 0 ? false : true; + } + + /** + * \if ENGLISH_LANG + * Logout Device + * \else + * 登出设备 + * \endif + */ + public static boolean logout() { + if (m_hLoginHandle.longValue() == 0) { + return false; + } + + boolean bRet = netsdk.CLIENT_Logout(m_hLoginHandle); + if (bRet) { + m_hLoginHandle.setValue(0); + } + + return bRet; + } + + /** + * 登录设备设备错误状态 + */ + public static String getErrorCode() { + return Res.string().getErrorCode(netsdk.CLIENT_GetLastError()); + } + + /** + * 预置点 + */ + public static boolean ptzControlnPresetId(int nChannelID, int lParam1, int lParam2, int lParam3, int dwStop, Pointer param4) { + return netsdk.CLIENT_DHPTZControlEx2(m_hLoginHandle, nChannelID, NetSDKLib.NET_PTZ_ControlType.NET_PTZ_POINT_MOVE_CONTROL, lParam1, lParam2, lParam3, dwStop, param4); + } + + /** + * \if ENGLISH_LANG + * Start RealPlay + * \else + * 开始预览 + * \endif + */ + + public static fRealDataCallBackEx fReal = new fRealDataCallBackEx(); + + public static W32API.HWND hwnd;//窗体句柄 + + public static boolean startRealPlay(int channel, int stream, Panel realPlayWindow) { + hwnd = new W32API.HWND(Native.getComponentPointer(realPlayWindow)); + boolean bOpenRet = playsdk.PLAY_OpenStream(new NativeLong(0), null, 0, 1024 * 500); + if (bOpenRet) { + // 开始播放 + boolean bPlayRet = playsdk.PLAY_Play(new NativeLong(0), hwnd); + if (bPlayRet) { + m_hPlayHandle = netsdk.CLIENT_RealPlayEx(m_hLoginHandle, channel, null, stream); + //m_hPlayHandle = netsdk.CLIENT_RealPlayEx(m_hLoginHandle, channel, Native.getComponentPointer(realPlayWindow), stream); + } + boolean real = netsdk.CLIENT_SetRealDataCallBackEx(m_hPlayHandle, fReal, m_hLoginHandle, 0x1f); + } + + if (m_hPlayHandle.longValue() == 0) { + System.err.println("开始实时监视失败,错误码" + String.format("[0x%x]", netsdk.CLIENT_GetLastError())); + } else { + //boolean real = netsdk.CLIENT_SetRealDataCallBackEx(m_hPlayHandle,fReal,m_hLoginHandle,0x1f); + System.out.println("Success to start realplay"); + } + + return m_hPlayHandle.longValue() == 0 ? false : true; + } + + //摄像头回调: 通过 startRealPlay + public static class fRealDataCallBackEx implements NetSDKLib.fRealDataCallBackEx { + public void invoke(NativeLong lRealHandle, int dwDataType, Pointer pBuffer, int dwBufSize, int param, NativeLong dwUser) { + boolean bInput = false; + if (0 != lRealHandle.intValue()) { + switch (dwDataType) { + case 0: + //原始音视频混合数据 + bInput = playsdk.PLAY_InputData(new NativeLong(0), pBuffer, dwBufSize); + if (!bInput) { + System.out.println("error"); + } + break; + case 1: + //标准视频数据 + + break; + case 2: + //yuv 数据 + + break; + case 3: + //pcm 音频数据 + + break; + case 4: + //原始音频数据 + + break; + default: + break; + } + } + + } + } + + /** + * \if ENGLISH_LANG + * Start CLIENT_QueryDevInfo + * \else + * 查看设备信息 + * \endif + */ + + //Pointer a = new Pointer(MemoryBlockFactory.createMemoryBlock(4 * 10)); + public static boolean CLIENT_QueryDevInfo(int nQueryType, Pointer pInBuf, Pointer pOutBuf, Pointer pReservedL, int nWaitTime) { + //m_hLoginHandle.setValue(123); + boolean Isdate = netsdk.CLIENT_QueryDevInfo(m_hLoginHandle, nQueryType, pInBuf, pOutBuf, null, 3000); + if (!Isdate) { + System.err.println("查看失败,错误码:" + String.format("[0x%x]", netsdk.CLIENT_GetLastError())); + } else { + System.out.println("Success Look"); + } + return Isdate; + } + + /** + * \if ENGLISH_LANG + * Start RealPlay + * \else + * 停止预览 + * \endif + */ + public static void stopRealPlay() { + if (m_hPlayHandle.longValue() == 0) { + return; + } + + boolean bRet = netsdk.CLIENT_StopRealPlayEx(m_hPlayHandle); + if (bRet) { + m_hPlayHandle.setValue(0); + } + } + + public static void SetSnapRevCallBack(NetSDKLib.fSnapRev m_SnapReceiveCB) { + //设置抓图回调函数, 图片主要在m_SnapReceiveCB中返回 + netsdk.CLIENT_SetSnapRevCallBack(m_SnapReceiveCB, new NativeLong(0)); + } + + /** + * 远程抓图 + */ + public static boolean snapPicture(int chn) { + // 发送抓图命令给前端设备,抓图的信息 + NetSDKLib.SNAP_PARAMS stuSnapParams = new NetSDKLib.SNAP_PARAMS(); + stuSnapParams.Channel = chn; //抓图通道 + stuSnapParams.mode = 0; //表示请求一帧 + stuSnapParams.Quality = 3; + stuSnapParams.InterSnap = 5; + stuSnapParams.CmdSerial = 0; // 请求序列号,有效值范围 0~65535,超过范围会被截断为 + + IntByReference reserved = new IntByReference(0); + if (!netsdk.CLIENT_SnapPictureEx(m_hLoginHandle, stuSnapParams, reserved)) { + System.err.printf("CLIENT_SnapPictureEx Failed!Last Error[%x]\n", netsdk.CLIENT_GetLastError()); + return false; + } else { + System.out.println("CLIENT_SnapPictureEx success"); + } + return true; + } + + /******************************************************************************** + * 云台功能 * + ********************************************************************************/ + /** + * 向上 + */ + public static boolean ptzControlUpStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_UP_CONTROL, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlUpEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_UP_CONTROL, + 0, 0, 0, 1); + } + + /** + * 向下 + */ + public static boolean ptzControlDownStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_DOWN_CONTROL, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlDownEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_DOWN_CONTROL, + 0, 0, 0, 1); + } + + /** + * 向左 + */ + public static boolean ptzControlLeftStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, NetSDKLib.NET_PTZ_ControlType.NET_PTZ_LEFT_CONTROL, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlLeftEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_LEFT_CONTROL, + 0, 0, 0, 1); + } + + /** + * 向右 + */ + public static boolean ptzControlRightStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_RIGHT_CONTROL, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlRightEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_RIGHT_CONTROL, + 0, 0, 0, 1); + } + + /** + * 向左上 + */ + public static boolean ptzControlLeftUpStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTTOP, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlLeftUpEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTTOP, + 0, 0, 0, 1); + } + + /** + * 向右上 + */ + public static boolean ptzControlRightUpStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTTOP, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlRightUpEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTTOP, + 0, 0, 0, 1); + } + + /** + * 向左下 + */ + public static boolean ptzControlLeftDownStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTDOWN, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlLeftDownEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTDOWN, + 0, 0, 0, 1); + } + + /** + * 向右下 + */ + public static boolean ptzControlRightDownStart(int nChannelID, int lParam1, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTDOWN, + lParam1, lParam2, 0, 0); + } + + public static boolean ptzControlRightDownEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTDOWN, + 0, 0, 0, 1); + } + + /** + * 变倍+ + */ + public static boolean ptzControlZoomAddStart(int nChannelID, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_ZOOM_ADD_CONTROL, + 0, lParam2, 0, 0); + } + + public static boolean ptzControlZoomAddEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_ZOOM_ADD_CONTROL, + 0, 0, 0, 1); + } + + /** + * 变倍- + */ + public static boolean ptzControlZoomDecStart(int nChannelID, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_ZOOM_DEC_CONTROL, + 0, lParam2, 0, 0); + } + + public static boolean ptzControlZoomDecEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_ZOOM_DEC_CONTROL, + 0, 0, 0, 1); + } + + /** + * 变焦+ + */ + public static boolean ptzControlFocusAddStart(int nChannelID, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_FOCUS_ADD_CONTROL, + 0, lParam2, 0, 0); + } + + public static boolean ptzControlFocusAddEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_FOCUS_ADD_CONTROL, + 0, 0, 0, 1); + } + + /** + * 变焦- + */ + public static boolean ptzControlFocusDecStart(int nChannelID, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_FOCUS_DEC_CONTROL, + 0, lParam2, 0, 0); + } + + public static boolean ptzControlFocusDecEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_FOCUS_DEC_CONTROL, + 0, 0, 0, 1); + } + + /** + * 光圈+ + */ + public static boolean ptzControlIrisAddStart(int nChannelID, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_APERTURE_ADD_CONTROL, + 0, lParam2, 0, 0); + } + + public static boolean ptzControlIrisAddEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_APERTURE_ADD_CONTROL, + 0, 0, 0, 1); + } + + /** + * 光圈- + */ + public static boolean ptzControlIrisDecStart(int nChannelID, int lParam2) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_APERTURE_DEC_CONTROL, + 0, lParam2, 0, 0); + } + + public static boolean ptzControlIrisDecEnd(int nChannelID) { + return netsdk.CLIENT_DHPTZControlEx(m_hLoginHandle, nChannelID, + NetSDKLib.NET_PTZ_ControlType.NET_PTZ_APERTURE_DEC_CONTROL, + 0, 0, 0, 1); + } + + /******************************************************************************** + * 智能交通功能 * + ********************************************************************************/ + /** + * 老版本开闸按钮 + */ + public static void Old_OpenStrobe(int bTriggerBtnClick) { + if (m_hLoginHandle.longValue() != 0) { + System.out.println("Trigger Button Action"); + + NetSDKLib.ALARMCTRL_PARAM param = new NetSDKLib.ALARMCTRL_PARAM(); + param.nAction = bTriggerBtnClick; + ; // 1:触发报警;0:停止报警. 按钮按下 + if (netsdk.CLIENT_ControlDeviceEx(m_hLoginHandle, NetSDKLib.CtrlType.CTRLTYPE_TRIGGER_ALARM_OUT, param.getPointer(), null, 3000)) { + System.out.println("控制成功"); + } else { + System.err.printf("Failed to Open 0x%x", netsdk.CLIENT_GetLastError()); + } + } + } + + /** + * 新版本开闸 + */ + public static boolean New_OpenStrobe() { + NetSDKLib.NET_CTRL_OPEN_STROBE openStrobe = new NetSDKLib.NET_CTRL_OPEN_STROBE(); + openStrobe.nChannelId = 0; + String plate = new String("浙A888888"); + + System.arraycopy(plate.getBytes(), 0, openStrobe.szPlateNumber, 0, plate.getBytes().length); + openStrobe.write(); + if (netsdk.CLIENT_ControlDeviceEx(m_hLoginHandle, NetSDKLib.CtrlType.CTRLTYPE_CTRL_OPEN_STROBE, openStrobe.getPointer(), null, 3000)) { + System.out.println("Open Success!"); + } else { + System.err.printf("Failed to Open 0x%x\n", netsdk.CLIENT_GetLastError()); + return false; + } + openStrobe.read(); + + return true; + } + + /** + * 新版本关闸 + */ + public static void New_CloseStrobe() { + NetSDKLib.NET_CTRL_CLOSE_STROBE closeStrobe = new NetSDKLib.NET_CTRL_CLOSE_STROBE(); + closeStrobe.nChannelId = 0; + closeStrobe.write(); + if (netsdk.CLIENT_ControlDeviceEx(m_hLoginHandle, NetSDKLib.CtrlType.CTRLTYPE_CTRL_CLOSE_STROBE, closeStrobe.getPointer(), null, 3000)) { + System.out.println("Close Success!"); + } else { + System.err.printf("Failed to Close 0x%x\n", netsdk.CLIENT_GetLastError()); + } + closeStrobe.read(); + } + + /** + * 手动抓图按钮事件 + */ + public static boolean manualSnapPicture(int chn) { + NetSDKLib.MANUAL_SNAP_PARAMETER snapParam = new NetSDKLib.MANUAL_SNAP_PARAMETER(); + snapParam.nChannel = chn; + String sequence = "11111"; // 抓图序列号,必须用数组拷贝 + System.arraycopy(sequence.getBytes(), 0, snapParam.bySequence, 0, sequence.getBytes().length); + + snapParam.write(); + boolean bRet = netsdk.CLIENT_ControlDeviceEx(m_hLoginHandle, NetSDKLib.CtrlType.CTRLTYPE_MANUAL_SNAP, snapParam.getPointer(), null, 5000); + if (!bRet) { + System.err.println("Failed to manual snap, last error " + String.format("[0x%x]", netsdk.CLIENT_GetLastError())); + return false; + } else { + System.out.println("Seccessed to manual snap"); + } + snapParam.read(); + return true; + } + + /** + * 订阅实时上传智能分析数据 + * + * @return + */ + public static boolean attachIVSEvent(int ChannelId, NetSDKLib.fAnalyzerDataCallBack m_AnalyzerDataCB) { + /** + * 说明: + * 通道数可以在有登录是返回的信息 m_stDeviceInfo.byChanNum 获取 + * 下列仅订阅了0通道的智能事件. + */ + int bNeedPicture = 1; // 是否需要图片 + + m_hAttachHandle = netsdk.CLIENT_RealLoadPictureEx(m_hLoginHandle, ChannelId, NetSDKLib.EVENT_IVS_ALL, + bNeedPicture, m_AnalyzerDataCB, null, null); + if (m_hAttachHandle.longValue() != 0) { + System.out.println("CLIENT_RealLoadPictureEx Success ChannelId : \n" + ChannelId); + } else { + System.err.printf("CLIENT_RealLoadPictureEx Failed!LastError = %x\n", netsdk.CLIENT_GetLastError()); + return false; + } + + return true; + } + + /** + * 停止上传智能分析数据-图片 + */ + public static void detachIVSEvent() { + if (0 != m_hAttachHandle.longValue()) { + netsdk.CLIENT_StopLoadPic(m_hAttachHandle); + System.out.println("Stop detach IVS event"); + m_hAttachHandle.setValue(0); + } + } + + + // 查找录像文件 + public static boolean queryRecordFile(int nChannelId, + NetSDKLib.NET_TIME stTimeStart, + NetSDKLib.NET_TIME stTimeEnd, + NetSDKLib.NET_RECORDFILE_INFO[] stFileInfo, + IntByReference nFindCount) { + // RecordFileType 录像类型 0:所有录像 1:外部报警 2:动态监测报警 3:所有报警 4:卡号查询 5:组合条件查询 6:录像位置与偏移量长度 8:按卡号查询图片(目前仅HB-U和NVS特殊型号的设备支持) 9:查询图片(目前仅HB-U和NVS特殊型号的设备支持) 10:按字段查询 15:返回网络数据结构(金桥网吧) 16:查询所有透明串数据录像文件 + int nRecordFileType = 0; + boolean bRet = netsdk.CLIENT_QueryRecordFile(m_hLoginHandle, nChannelId, nRecordFileType, stTimeStart, stTimeEnd, null, stFileInfo, stFileInfo.length * stFileInfo[0].size(), nFindCount, 5000, false); + + if (bRet) { + System.out.println("QueryRecordFile Succeed! \n" + "查询到的视频个数:" + nFindCount.getValue()); + } else { + System.err.println("QueryRecordFile Failed!" + netsdk.CLIENT_GetLastError()); + return false; + } + return true; + } + + public static void setStreamType(int m_streamType) { + // 设置回放时的码流类型 + IntByReference steamType = new IntByReference(m_streamType);// 0-主辅码流,1-主码流,2-辅码流 + int emType = NetSDKLib.EM_USEDEV_MODE.NET_RECORD_STREAM_TYPE; + + boolean bret = netsdk.CLIENT_SetDeviceMode(m_hLoginHandle, emType, steamType.getPointer()); + if (!bret) { + System.err.printf("Set Stream Type Failed, Get last error [0x%x]\n", netsdk.CLIENT_GetLastError()); + } else { + System.out.println("Set Stream Type Succeed!"); + } + } + + public static NativeLong downloadRecordFile(int nChannelId, + int nRecordFileType, + NetSDKLib.NET_TIME stTimeStart, + NetSDKLib.NET_TIME stTimeEnd, + String SavedFileName, + NetSDKLib.fTimeDownLoadPosCallBack cbTimeDownLoadPos) { + + m_hDownLoadHandle = netsdk.CLIENT_DownloadByTimeEx(m_hLoginHandle, nChannelId, nRecordFileType, + stTimeStart, stTimeEnd, SavedFileName, + cbTimeDownLoadPos, null, null, null, null); + if (m_hDownLoadHandle.longValue() != 0) { + System.out.println("Downloading RecordFile!"); + } else { + System.err.println("Download RecordFile Failed!" + netsdk.CLIENT_GetLastError()); + } + return m_hDownLoadHandle; + } + + public static void stopDownLoadRecordFile(NativeLong m_hDownLoadHandle) { + if (m_hDownLoadHandle.longValue() == 0) { + return; + } + netsdk.CLIENT_StopDownload(m_hDownLoadHandle); + } +} diff --git a/src/main/java/com/shxy/xyhkcamera/test/Login.form b/src/main/java/com/shxy/xyhkcamera/test/Login.form new file mode 100644 index 0000000..c638b68 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/Login.form @@ -0,0 +1,28 @@ + + +
+ + + + + + + + + + + + + + + + + + + + + + + + +
diff --git a/src/main/java/com/shxy/xyhkcamera/test/Login.java b/src/main/java/com/shxy/xyhkcamera/test/Login.java new file mode 100644 index 0000000..f4dece6 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/Login.java @@ -0,0 +1,45 @@ +/* + * 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 com.shxy.xyhkcamera.test; + +/** + * + * @author LENOVO + */ +public class Login extends javax.swing.JPanel { + + /** + * Creates new form Login + */ + public Login() { + initComponents(); + } + + /** + * This method is called from within the constructor to initialize the form. + * WARNING: Do NOT modify this code. The content of this method is always + * regenerated by the Form Editor. + */ + @SuppressWarnings("unchecked") + // //GEN-BEGIN:initComponents + private void initComponents() { + + javax.swing.GroupLayout layout = new javax.swing.GroupLayout(this); + this.setLayout(layout); + layout.setHorizontalGroup( + layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) + .addGap(0, 400, Short.MAX_VALUE) + ); + layout.setVerticalGroup( + layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING) + .addGap(0, 300, Short.MAX_VALUE) + ); + }// //GEN-END:initComponents + + + // Variables declaration - do not modify//GEN-BEGIN:variables + // End of variables declaration//GEN-END:variables +} diff --git a/src/main/java/com/shxy/xyhkcamera/test/NativeString.java b/src/main/java/com/shxy/xyhkcamera/test/NativeString.java new file mode 100644 index 0000000..b9ee095 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/NativeString.java @@ -0,0 +1,124 @@ +package com.shxy.xyhkcamera.test; + +import java.io.UnsupportedEncodingException; +import java.nio.CharBuffer; + +import com.sun.jna.Memory; +import com.sun.jna.Native; +import com.sun.jna.Pointer; + + +/** Provides a temporary allocation of an immutable C string + * (const char* or const wchar_t*) for use when + * converting a Java String into a native memory function argument. + * + * @author Todd Fast, todd.fast@sun.com + * @author twall@users.sf.net + */ +public class NativeString implements CharSequence, Comparable { + + private Pointer pointer; + private boolean wide; + + /** Create a native string (NUL-terminated array of char).

+ * If the system property jna.encoding is set, its value will + * be used to encode the native string. If not set or if the encoding + * is unavailable, the default platform encoding will be used. + */ + public NativeString(String string) { + this(string, false); + } + + /** Create a native string as a NUL-terminated array of wchar_t + * (if wide is true) or char.

+ * If the system property jna.encoding is set, its value will + * be used to encode the native charstring. + * If not set or if the encoding is unavailable, the default platform + * encoding will be used. + * + * @param string value to write to native memory + * @param wide whether to store the String as wchar_t + */ + public NativeString(String string, boolean wide) { + if (string == null) { + throw new NullPointerException("String must not be null"); + } + // Allocate the memory to hold the string. Note, we have to + // make this 1 element longer in order to accommodate the terminating + // NUL (which is generated in Pointer.setString()). + this.wide = wide; + if (wide) { + int len = (string.length() + 1 ) * Native.WCHAR_SIZE; + pointer = new Memory(len); + pointer.setString(0, string, true); + } + else { + byte[] data = getBytes(string); + pointer = new Memory(data.length + 1); + pointer.write(0, data, 0, data.length); + pointer.setByte(data.length, (byte)0); + } + } + + static byte[] getBytes(String s) { + try { + return getBytes(s, System.getProperty("jna.encoding")); + } + catch (UnsupportedEncodingException e) { + return s.getBytes(); + } + } + + /** Return a byte array corresponding to the given String, using the given + encoding. + */ + static byte[] getBytes(String s, String encoding) throws UnsupportedEncodingException { + if (encoding != null) { + return s.getBytes(encoding); + } + return s.getBytes(); + } + + public int hashCode() { + return toString().hashCode(); + } + + public boolean equals(Object other) { + + if (other instanceof CharSequence) { + return compareTo(other) == 0; + } + return false; + } + + public String toString() { + String s = wide ? "const wchar_t*" : "const char*"; + s += "(" + pointer.getString(0, wide) + ")"; + return s; + } + + public Pointer getPointer() { + return pointer; + } + + public char charAt(int index) { + return toString().charAt(index); + } + + public int length() { + return toString().length(); + } + + public CharSequence subSequence(int start, int end) { + return CharBuffer.wrap(toString()).subSequence(start, end); + } + + public int compareTo(Object other) { + + if (other == null) + return 1; + + return toString().compareTo(other.toString()); + } +} + diff --git a/src/main/java/com/shxy/xyhkcamera/test/NetSDKLib.java b/src/main/java/com/shxy/xyhkcamera/test/NetSDKLib.java new file mode 100644 index 0000000..e8771e7 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/NetSDKLib.java @@ -0,0 +1,12123 @@ +/* + * 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 com.shxy.xyhkcamera.test; + +import com.sun.jna.IntegerType; +import com.sun.jna.Library; +import com.sun.jna.Memory; +import com.sun.jna.Native; +import com.sun.jna.NativeLong; +import com.sun.jna.Pointer; +import com.sun.jna.Structure; +import com.sun.jna.Union; +import com.sun.jna.examples.win32.GDI32.RECT; +import com.sun.jna.examples.win32.W32API; +import com.sun.jna.examples.win32.W32API.DWORD; +import com.sun.jna.examples.win32.W32API.HWND; +import com.sun.jna.examples.win32.W32API.LPARAM; +import com.sun.jna.examples.win32.W32API.WPARAM; +import com.sun.jna.ptr.ByteByReference; +import com.sun.jna.win32.StdCallLibrary; +import com.sun.jna.ptr.IntByReference; +import com.sun.jna.ptr.NativeLongByReference; +import com.sun.jna.ptr.ShortByReference; +import com.sun.jna.win32.StdCallLibrary.StdCallCallback; +import java.util.Arrays; +import java.util.List; +//SDK接口说明,HCNetSDK.dll +public interface NetSDKLib extends Library { + + NetSDKLib NETSDK_INSTANCE = (NetSDKLib) Native.loadLibrary("dhnetsdk", NetSDKLib.class); + NetSDKLib CONFIG_INSTANCE = (NetSDKLib)Native.loadLibrary("dhconfigsdk", NetSDKLib.class); + NetSDKLib CONFIG_dhplay = (NetSDKLib)Native.loadLibrary("dhplay", NetSDKLib.class); + public static class LLong extends IntegerType { + private static final long serialVersionUID = 1L; + + /** Size of a native long, in bytes. */ + public static int size; + static { + size = Native.LONG_SIZE; + /*if (Utils.getOsPrefix().toLowerCase().equals("linux-amd64") + || Utils.getOsPrefix().toLowerCase().equals("win32-amd64")) { + size = 8; + } else if (Utils.getOsPrefix().toLowerCase().equals("linux-i386") + || Utils.getOsPrefix().toLowerCase().equals("win32-x86")) { + size = 4; + }*/ + } + + /** Create a zero-valued LLong. */ + public LLong() { + this(0); + } + + /** Create a LLong with the given value. */ + public LLong(long value) { + super(size, value); + } + } + + /************************************************************************ + ** 常量定义 + ***********************************************************************/ + public static final int NET_SERIALNO_LEN = 48; // 设备序列号字符长度 + public static final int NET_CFG_Max_VideoColor = 24; // 每个通道最大视频输入颜色配置数量 + public static final int NET_CFG_Custom_Title_Len = 1024; // 自定义标题名称长度(扩充到1024) + public static final int NET_CFG_Custom_TitleType_Len = 32; // 自定义标题类型长度 + public static final int NET_CFG_Max_Video_Widget_Cover = 16; // 编码区域覆盖最大数量 + public static final int NET_CFG_Max_Video_Widget_Custom_Title = 8; // 编码物件自定义标题最大数量 + public static final int NET_CFG_Max_Video_Widget_Sensor_Info = 2; // 编码物件叠加传感器信息的最大数目 + public static final int NET_CFG_Max_Description_Num = 4; // 叠加区域描述信息的最大个数 + + // 错误类型代号,对应CLIENT_GetLastError接口的返回值, 十进制 + public static final int NET_NOERROR = 0; // 没有错误 + public static final int NET_ERROR = -1; // 未知错误 + public static final int NET_SYSTEM_ERROR = (0x80000000|1); // Windows系统出错 + public static final int NET_NETWORK_ERROR = (0x80000000|2); // 网络错误,可能是因为网络超时 + public static final int NET_DEV_VER_NOMATCH = (0x80000000|3); // 设备协议不匹配 + public static final int NET_INVALID_HANDLE = (0x80000000|4); // 句柄无效 + public static final int NET_OPEN_CHANNEL_ERROR = (0x80000000|5); // 打开通道失败 + public static final int NET_CLOSE_CHANNEL_ERROR = (0x80000000|6); // 关闭通道失败 + public static final int NET_ILLEGAL_PARAM = (0x80000000|7); // 用户参数不合法 + public static final int NET_SDK_INIT_ERROR = (0x80000000|8); // SDK初始化出错 + public static final int NET_SDK_UNINIT_ERROR = (0x80000000|9); // SDK清理出错 + public static final int NET_RENDER_OPEN_ERROR = (0x80000000|10); // 申请render资源出错 + public static final int NET_DEC_OPEN_ERROR = (0x80000000|11); // 打开解码库出错 + public static final int NET_DEC_CLOSE_ERROR = (0x80000000|12); // 关闭解码库出错 + public static final int NET_MULTIPLAY_NOCHANNEL = (0x80000000|13); // 多画面预览中检测到通道数为0 + public static final int NET_TALK_INIT_ERROR = (0x80000000|14); // 录音库初始化失败 + public static final int NET_TALK_NOT_INIT = (0x80000000|15); // 录音库未经初始化 + public static final int NET_TALK_SENDDATA_ERROR = (0x80000000|16); // 发送音频数据出错 + public static final int NET_REAL_ALREADY_SAVING = (0x80000000|17); // 实时数据已经处于保存状态 + public static final int NET_NOT_SAVING = (0x80000000|18); // 未保存实时数据 + public static final int NET_OPEN_FILE_ERROR = (0x80000000|19); // 打开文件出错 + public static final int NET_PTZ_SET_TIMER_ERROR = (0x80000000|20); // 启动云台控制定时器失败 + public static final int NET_RETURN_DATA_ERROR = (0x80000000|21); // 对返回数据的校验出错 + public static final int NET_INSUFFICIENT_BUFFER = (0x80000000|22); // 没有足够的缓存 + public static final int NET_NOT_SUPPORTED = (0x80000000|23); // 当前SDK未支持该功能 + public static final int NET_NO_RECORD_FOUND = (0x80000000|24); // 查询不到录像 + public static final int NET_NOT_AUTHORIZED = (0x80000000|25); // 无操作权限 + public static final int NET_NOT_NOW = (0x80000000|26); // 暂时无法执行 + public static final int NET_NO_TALK_CHANNEL = (0x80000000|27); // 未发现对讲通道 + public static final int NET_NO_AUDIO = (0x80000000|28); // 未发现音频 + public static final int NET_NO_INIT = (0x80000000|29); // 网络SDK未经初始化 + public static final int NET_DOWNLOAD_END = (0x80000000|30); // 下载已结束 + public static final int NET_EMPTY_LIST = (0x80000000|31); // 查询结果为空 + public static final int NET_ERROR_GETCFG_SYSATTR = (0x80000000|32); // 获取系统属性配置失败 + public static final int NET_ERROR_GETCFG_SERIAL = (0x80000000|33); // 获取序列号失败 + public static final int NET_ERROR_GETCFG_GENERAL = (0x80000000|34); // 获取常规属性失败 + public static final int NET_ERROR_GETCFG_DSPCAP = (0x80000000|35); // 获取DSP能力描述失败 + public static final int NET_ERROR_GETCFG_NETCFG = (0x80000000|36); // 获取网络配置失败 + public static final int NET_ERROR_GETCFG_CHANNAME = (0x80000000|37); // 获取通道名称失败 + public static final int NET_ERROR_GETCFG_VIDEO = (0x80000000|38); // 获取视频属性失败 + public static final int NET_ERROR_GETCFG_RECORD = (0x80000000|39); // 获取录象配置失败 + public static final int NET_ERROR_GETCFG_PRONAME = (0x80000000|40); // 获取解码器协议名称失败 + public static final int NET_ERROR_GETCFG_FUNCNAME = (0x80000000|41); // 获取232串口功能名称失败 + public static final int NET_ERROR_GETCFG_485DECODER = (0x80000000|42); // 获取解码器属性失败 + public static final int NET_ERROR_GETCFG_232COM = (0x80000000|43); // 获取232串口配置失败 + public static final int NET_ERROR_GETCFG_ALARMIN = (0x80000000|44); // 获取外部报警输入配置失败 + public static final int NET_ERROR_GETCFG_ALARMDET = (0x80000000|45); // 获取动态检测报警失败 + public static final int NET_ERROR_GETCFG_SYSTIME = (0x80000000|46); // 获取设备时间失败 + public static final int NET_ERROR_GETCFG_PREVIEW = (0x80000000|47); // 获取预览参数失败 + public static final int NET_ERROR_GETCFG_AUTOMT = (0x80000000|48); // 获取自动维护配置失败 + public static final int NET_ERROR_GETCFG_VIDEOMTRX = (0x80000000|49); // 获取视频矩阵配置失败 + public static final int NET_ERROR_GETCFG_COVER = (0x80000000|50); // 获取区域遮挡配置失败 + public static final int NET_ERROR_GETCFG_WATERMAKE = (0x80000000|51); // 获取图象水印配置失败 + public static final int NET_ERROR_SETCFG_GENERAL = (0x80000000|55); // 修改常规属性失败 + public static final int NET_ERROR_SETCFG_NETCFG = (0x80000000|56); // 修改网络配置失败 + public static final int NET_ERROR_SETCFG_CHANNAME = (0x80000000|57); // 修改通道名称失败 + public static final int NET_ERROR_SETCFG_VIDEO = (0x80000000|58); // 修改视频属性失败 + public static final int NET_ERROR_SETCFG_RECORD = (0x80000000|59); // 修改录象配置失败 + public static final int NET_ERROR_SETCFG_485DECODER = (0x80000000|60); // 修改解码器属性失败 + public static final int NET_ERROR_SETCFG_232COM = (0x80000000|61); // 修改232串口配置失败 + public static final int NET_ERROR_SETCFG_ALARMIN = (0x80000000|62); // 修改外部输入报警配置失败 + public static final int NET_ERROR_SETCFG_ALARMDET = (0x80000000|63); // 修改动态检测报警配置失败 + public static final int NET_ERROR_SETCFG_SYSTIME = (0x80000000|64); // 修改设备时间失败 + public static final int NET_ERROR_SETCFG_PREVIEW = (0x80000000|65); // 修改预览参数失败 + public static final int NET_ERROR_SETCFG_AUTOMT = (0x80000000|66); // 修改自动维护配置失败 + public static final int NET_ERROR_SETCFG_VIDEOMTRX = (0x80000000|67); // 修改视频矩阵配置失败 + public static final int NET_ERROR_SETCFG_COVER = (0x80000000|68); // 修改区域遮挡配置失败 + public static final int NET_ERROR_SETCFG_WATERMAKE = (0x80000000|69); // 修改图象水印配置失败 + public static final int NET_ERROR_SETCFG_WLAN = (0x80000000|70); // 修改无线网络信息失败 + public static final int NET_ERROR_SETCFG_WLANDEV = (0x80000000|71); // 选择无线网络设备失败 + public static final int NET_ERROR_SETCFG_REGISTER = (0x80000000|72); // 修改主动注册参数配置失败 + public static final int NET_ERROR_SETCFG_CAMERA = (0x80000000|73); // 修改摄像头属性配置失败 + public static final int NET_ERROR_SETCFG_INFRARED = (0x80000000|74); // 修改红外报警配置失败 + public static final int NET_ERROR_SETCFG_SOUNDALARM = (0x80000000|75); // 修改音频报警配置失败 + public static final int NET_ERROR_SETCFG_STORAGE = (0x80000000|76); // 修改存储位置配置失败 + public static final int NET_AUDIOENCODE_NOTINIT = (0x80000000|77); // 音频编码接口没有成功初始化 + public static final int NET_DATA_TOOLONGH = (0x80000000|78); // 数据过长 + public static final int NET_UNSUPPORTED = (0x80000000|79); // 设备不支持该操作 + public static final int NET_DEVICE_BUSY = (0x80000000|80); // 设备资源不足 + public static final int NET_SERVER_STARTED = (0x80000000|81); // 服务器已经启动 + public static final int NET_SERVER_STOPPED = (0x80000000|82); // 服务器尚未成功启动 + public static final int NET_LISTER_INCORRECT_SERIAL = (0x80000000|83); // 输入序列号有误 + public static final int NET_QUERY_DISKINFO_FAILED = (0x80000000|84); // 获取硬盘信息失败 + public static final int NET_ERROR_GETCFG_SESSION = (0x80000000|85); // 获取连接Session信息 + public static final int NET_USER_FLASEPWD_TRYTIME = (0x80000000|86); // 输入密码错误超过限制次数 + public static final int NET_LOGIN_ERROR_PASSWORD = (0x80000000|100); // 密码不正确 + public static final int NET_LOGIN_ERROR_USER = (0x80000000|101); // 帐户不存在 + public static final int NET_LOGIN_ERROR_TIMEOUT = (0x80000000|102); // 等待登录返回超时 + public static final int NET_LOGIN_ERROR_RELOGGIN = (0x80000000|103); // 帐号已登录 + public static final int NET_LOGIN_ERROR_LOCKED = (0x80000000|104); // 帐号已被锁定 + public static final int NET_LOGIN_ERROR_BLACKLIST = (0x80000000|105); // 帐号已被列为黑名单 + public static final int NET_LOGIN_ERROR_BUSY = (0x80000000|106); // 资源不足,系统忙 + public static final int NET_LOGIN_ERROR_CONNECT = (0x80000000|107); // 登录设备超时,请检查网络并重试 + public static final int NET_LOGIN_ERROR_NETWORK = (0x80000000|108); // 网络连接失败 + public static final int NET_LOGIN_ERROR_SUBCONNECT = (0x80000000|109); // 登录设备成功,但无法创建视频通道,请检查网络状况 + public static final int NET_LOGIN_ERROR_MAXCONNECT = (0x80000000|110); // 超过最大连接数 + public static final int NET_LOGIN_ERROR_PROTOCOL3_ONLY = (0x80000000|111); // 只支持3代协议 + public static final int NET_LOGIN_ERROR_UKEY_LOST = (0x80000000|112); // 未插入U盾或U盾信息错误 + public static final int NET_LOGIN_ERROR_NO_AUTHORIZED = (0x80000000|113); // 客户端IP地址没有登录权限 + public static final int NET_LOGIN_ERROR_USER_OR_PASSOWRD = (0x80000000|117); // 账号或密码错误 + public static final int NET_RENDER_SOUND_ON_ERROR = (0x80000000|120); // Render库打开音频出错 + public static final int NET_RENDER_SOUND_OFF_ERROR = (0x80000000|121); // Render库关闭音频出错 + public static final int NET_RENDER_SET_VOLUME_ERROR = (0x80000000|122); // Render库控制音量出错 + public static final int NET_RENDER_ADJUST_ERROR = (0x80000000|123); // Render库设置画面参数出错 + public static final int NET_RENDER_PAUSE_ERROR = (0x80000000|124); // Render库暂停播放出错 + public static final int NET_RENDER_SNAP_ERROR = (0x80000000|125); // Render库抓图出错 + public static final int NET_RENDER_STEP_ERROR = (0x80000000|126); // Render库步进出错 + public static final int NET_RENDER_FRAMERATE_ERROR = (0x80000000|127); // Render库设置帧率出错 + public static final int NET_RENDER_DISPLAYREGION_ERROR = (0x80000000|128); // Render库设置显示区域出错 + public static final int NET_GROUP_EXIST = (0x80000000|140); // 组名已存在 + public static final int NET_GROUP_NOEXIST = (0x80000000|141); // 组名不存在 + public static final int NET_GROUP_RIGHTOVER = (0x80000000|142); // 组的权限超出权限列表范围 + public static final int NET_GROUP_HAVEUSER = (0x80000000|143); // 组下有用户,不能删除 + public static final int NET_GROUP_RIGHTUSE = (0x80000000|144); // 组的某个权限被用户使用,不能出除 + public static final int NET_GROUP_SAMENAME = (0x80000000|145); // 新组名同已有组名重复 + public static final int NET_USER_EXIST = (0x80000000|146); // 用户已存在 + public static final int NET_USER_NOEXIST = (0x80000000|147); // 用户不存在 + public static final int NET_USER_RIGHTOVER = (0x80000000|148); // 用户权限超出组权限 + public static final int NET_USER_PWD = (0x80000000|149); // 保留帐号,不容许修改密码 + public static final int NET_USER_FLASEPWD = (0x80000000|150); // 密码不正确 + public static final int NET_USER_NOMATCHING = (0x80000000|151); // 密码不匹配 + public static final int NET_USER_INUSE = (0x80000000|152); // 账号正在使用中 + public static final int NET_ERROR_GETCFG_ETHERNET = (0x80000000|300); // 获取网卡配置失败 + public static final int NET_ERROR_GETCFG_WLAN = (0x80000000|301); // 获取无线网络信息失败 + public static final int NET_ERROR_GETCFG_WLANDEV = (0x80000000|302); // 获取无线网络设备失败 + public static final int NET_ERROR_GETCFG_REGISTER = (0x80000000|303); // 获取主动注册参数失败 + public static final int NET_ERROR_GETCFG_CAMERA = (0x80000000|304); // 获取摄像头属性失败 + public static final int NET_ERROR_GETCFG_INFRARED = (0x80000000|305); // 获取红外报警配置失败 + public static final int NET_ERROR_GETCFG_SOUNDALARM = (0x80000000|306); // 获取音频报警配置失败 + public static final int NET_ERROR_GETCFG_STORAGE = (0x80000000|307); // 获取存储位置配置失败 + public static final int NET_ERROR_GETCFG_MAIL = (0x80000000|308); // 获取邮件配置失败 + public static final int NET_CONFIG_DEVBUSY = (0x80000000|309); // 暂时无法设置 + public static final int NET_CONFIG_DATAILLEGAL = (0x80000000|310); // 配置数据不合法 + public static final int NET_ERROR_GETCFG_DST = (0x80000000|311); // 获取夏令时配置失败 + public static final int NET_ERROR_SETCFG_DST = (0x80000000|312); // 设置夏令时配置失败 + public static final int NET_ERROR_GETCFG_VIDEO_OSD = (0x80000000|313); // 获取视频OSD叠加配置失败 + public static final int NET_ERROR_SETCFG_VIDEO_OSD = (0x80000000|314); // 设置视频OSD叠加配置失败 + public static final int NET_ERROR_GETCFG_GPRSCDMA = (0x80000000|315); // 获取CDMA\GPRS网络配置失败 + public static final int NET_ERROR_SETCFG_GPRSCDMA = (0x80000000|316); // 设置CDMA\GPRS网络配置失败 + public static final int NET_ERROR_GETCFG_IPFILTER = (0x80000000|317); // 获取IP过滤配置失败 + public static final int NET_ERROR_SETCFG_IPFILTER = (0x80000000|318); // 设置IP过滤配置失败 + public static final int NET_ERROR_GETCFG_TALKENCODE = (0x80000000|319); // 获取语音对讲编码配置失败 + public static final int NET_ERROR_SETCFG_TALKENCODE = (0x80000000|320); // 设置语音对讲编码配置失败 + public static final int NET_ERROR_GETCFG_RECORDLEN = (0x80000000|321); // 获取录像打包长度配置失败 + public static final int NET_ERROR_SETCFG_RECORDLEN = (0x80000000|322); // 设置录像打包长度配置失败 + public static final int NET_DONT_SUPPORT_SUBAREA = (0x80000000|323); // 不支持网络硬盘分区 + public static final int NET_ERROR_GET_AUTOREGSERVER = (0x80000000|324); // 获取设备上主动注册服务器信息失败 + public static final int NET_ERROR_CONTROL_AUTOREGISTER = (0x80000000|325); // 主动注册重定向注册错误 + public static final int NET_ERROR_DISCONNECT_AUTOREGISTER = (0x80000000|326); // 断开主动注册服务器错误 + public static final int NET_ERROR_GETCFG_MMS = (0x80000000|327); // 获取mms配置失败 + public static final int NET_ERROR_SETCFG_MMS = (0x80000000|328); // 设置mms配置失败 + public static final int NET_ERROR_GETCFG_SMSACTIVATION = (0x80000000|329); // 获取短信激活无线连接配置失败 + public static final int NET_ERROR_SETCFG_SMSACTIVATION = (0x80000000|330); // 设置短信激活无线连接配置失败 + public static final int NET_ERROR_GETCFG_DIALINACTIVATION = (0x80000000|331); // 获取拨号激活无线连接配置失败 + public static final int NET_ERROR_SETCFG_DIALINACTIVATION = (0x80000000|332); // 设置拨号激活无线连接配置失败 + public static final int NET_ERROR_GETCFG_VIDEOOUT = (0x80000000|333); // 查询视频输出参数配置失败 + public static final int NET_ERROR_SETCFG_VIDEOOUT = (0x80000000|334); // 设置视频输出参数配置失败 + public static final int NET_ERROR_GETCFG_OSDENABLE = (0x80000000|335); // 获取osd叠加使能配置失败 + public static final int NET_ERROR_SETCFG_OSDENABLE = (0x80000000|336); // 设置osd叠加使能配置失败 + public static final int NET_ERROR_SETCFG_ENCODERINFO = (0x80000000|337); // 设置数字通道前端编码接入配置失败 + public static final int NET_ERROR_GETCFG_TVADJUST = (0x80000000|338); // 获取TV调节配置失败 + public static final int NET_ERROR_SETCFG_TVADJUST = (0x80000000|339); // 设置TV调节配置失败 + public static final int NET_ERROR_CONNECT_FAILED = (0x80000000|340); // 请求建立连接失败 + public static final int NET_ERROR_SETCFG_BURNFILE = (0x80000000|341); // 请求刻录文件上传失败 + public static final int NET_ERROR_SNIFFER_GETCFG = (0x80000000|342); // 获取抓包配置信息失败 + public static final int NET_ERROR_SNIFFER_SETCFG = (0x80000000|343); // 设置抓包配置信息失败 + public static final int NET_ERROR_DOWNLOADRATE_GETCFG = (0x80000000|344); // 查询下载限制信息失败 + public static final int NET_ERROR_DOWNLOADRATE_SETCFG = (0x80000000|345); // 设置下载限制信息失败 + public static final int NET_ERROR_SEARCH_TRANSCOM = (0x80000000|346); // 查询串口参数失败 + public static final int NET_ERROR_GETCFG_POINT = (0x80000000|347); // 获取预制点信息错误 + public static final int NET_ERROR_SETCFG_POINT = (0x80000000|348); // 设置预制点信息错误 + public static final int NET_SDK_LOGOUT_ERROR = (0x80000000|349); // SDK没有正常登出设备 + public static final int NET_ERROR_GET_VEHICLE_CFG = (0x80000000|350); // 获取车载配置失败 + public static final int NET_ERROR_SET_VEHICLE_CFG = (0x80000000|351); // 设置车载配置失败 + public static final int NET_ERROR_GET_ATM_OVERLAY_CFG = (0x80000000|352); // 获取atm叠加配置失败 + public static final int NET_ERROR_SET_ATM_OVERLAY_CFG = (0x80000000|353); // 设置atm叠加配置失败 + public static final int NET_ERROR_GET_ATM_OVERLAY_ABILITY = (0x80000000|354); // 获取atm叠加能力失败 + public static final int NET_ERROR_GET_DECODER_TOUR_CFG = (0x80000000|355); // 获取解码器解码轮巡配置失败 + public static final int NET_ERROR_SET_DECODER_TOUR_CFG = (0x80000000|356); // 设置解码器解码轮巡配置失败 + public static final int NET_ERROR_CTRL_DECODER_TOUR = (0x80000000|357); // 控制解码器解码轮巡失败 + public static final int NET_GROUP_OVERSUPPORTNUM = (0x80000000|358); // 超出设备支持最大用户组数目 + public static final int NET_USER_OVERSUPPORTNUM = (0x80000000|359); // 超出设备支持最大用户数目 + public static final int NET_ERROR_GET_SIP_CFG = (0x80000000|368); // 获取SIP配置失败 + public static final int NET_ERROR_SET_SIP_CFG = (0x80000000|369); // 设置SIP配置失败 + public static final int NET_ERROR_GET_SIP_ABILITY = (0x80000000|370); // 获取SIP能力失败 + public static final int NET_ERROR_GET_WIFI_AP_CFG = (0x80000000|371); // 获取WIFI ap配置失败 + public static final int NET_ERROR_SET_WIFI_AP_CFG = (0x80000000|372); // 设置WIFI ap配置失败 + public static final int NET_ERROR_GET_DECODE_POLICY = (0x80000000|373); // 获取解码策略配置失败 + public static final int NET_ERROR_SET_DECODE_POLICY = (0x80000000|374); // 设置解码策略配置失败 + public static final int NET_ERROR_TALK_REJECT = (0x80000000|375); // 拒绝对讲 + public static final int NET_ERROR_TALK_OPENED = (0x80000000|376); // 对讲被其他客户端打开 + public static final int NET_ERROR_TALK_RESOURCE_CONFLICIT = (0x80000000|377); // 资源冲突 + public static final int NET_ERROR_TALK_UNSUPPORTED_ENCODE = (0x80000000|378); // 不支持的语音编码格式 + public static final int NET_ERROR_TALK_RIGHTLESS = (0x80000000|379); // 无权限 + public static final int NET_ERROR_TALK_FAILED = (0x80000000|380); // 请求对讲失败 + public static final int NET_ERROR_GET_MACHINE_CFG = (0x80000000|381); // 获取机器相关配置失败 + public static final int NET_ERROR_SET_MACHINE_CFG = (0x80000000|382); // 设置机器相关配置失败 + public static final int NET_ERROR_GET_DATA_FAILED = (0x80000000|383); // 设备无法获取当前请求数据 + public static final int NET_ERROR_MAC_VALIDATE_FAILED = (0x80000000|384); // MAC地址验证失败 + public static final int NET_ERROR_GET_INSTANCE = (0x80000000|385); // 获取服务器实例失败 + public static final int NET_ERROR_JSON_REQUEST = (0x80000000|386); // 生成的json字符串错误 + public static final int NET_ERROR_JSON_RESPONSE = (0x80000000|387); // 响应的json字符串错误 + public static final int NET_ERROR_VERSION_HIGHER = (0x80000000|388); // 协议版本低于当前使用的版本 + public static final int NET_SPARE_NO_CAPACITY = (0x80000000|389); // 热备操作失败, 容量不足 + public static final int NET_ERROR_SOURCE_IN_USE = (0x80000000|390); // 显示源被其他输出占用 + public static final int NET_ERROR_REAVE = (0x80000000|391); // 高级用户抢占低级用户资源 + public static final int NET_ERROR_NETFORBID = (0x80000000|392); // 禁止入网 + public static final int NET_ERROR_GETCFG_MACFILTER = (0x80000000|393); // 获取MAC过滤配置失败 + public static final int NET_ERROR_SETCFG_MACFILTER = (0x80000000|394); // 设置MAC过滤配置失败 + public static final int NET_ERROR_GETCFG_IPMACFILTER = (0x80000000|395); // 获取IP/MAC过滤配置失败 + public static final int NET_ERROR_SETCFG_IPMACFILTER = (0x80000000|396); // 设置IP/MAC过滤配置失败 + public static final int NET_ERROR_OPERATION_OVERTIME = (0x80000000|397); // 当前操作超时 + public static final int NET_ERROR_SENIOR_VALIDATE_FAILED = (0x80000000|398); // 高级校验失败 + public static final int NET_ERROR_DEVICE_ID_NOT_EXIST = (0x80000000|399); // 设备ID不存在 + public static final int NET_ERROR_UNSUPPORTED = (0x80000000|400); // 不支持当前操作 + public static final int NET_ERROR_PROXY_DLLLOAD = (0x80000000|401); // 代理库加载失败 + public static final int NET_ERROR_PROXY_ILLEGAL_PARAM = (0x80000000|402); // 代理用户参数不合法 + public static final int NET_ERROR_PROXY_INVALID_HANDLE = (0x80000000|403); // 代理句柄无效 + public static final int NET_ERROR_PROXY_LOGIN_DEVICE_ERROR = (0x80000000|404); // 代理登入前端设备失败 + public static final int NET_ERROR_PROXY_START_SERVER_ERROR = (0x80000000|405); // 启动代理服务失败 + + // CLIENT_StartListenEx报警事件 + public static final int NET_ALARM_ALARM_EX = 0x2101; // 外部报警,数据字节数与设备报警通道个数相同,每个字节表示一个报警通道的报警状态,1为有报警,0为无报警。 + public static final int NET_VIDEOLOST_ALARM_EX = 0x2103; // 视频丢失报警,数据字节数与设备视频通道个数相同,每个字节表示一个视频通道的视频丢失报警状态,1为有报警,0为无报警。 + public static final int NET_SHELTER_ALARM_EX = 0x2104; // 视频遮挡报警,数据字节数与设备视频通道个数相同,每个字节表示一个视频通道的遮挡(黑屏)报警状态,1为有报警,0为无报警。 + public static final int NET_DISKFULL_ALARM_EX = 0x2106; // 硬盘满报警,数据为1个字节,1为有硬盘满报警,0为无报警。 + public static final int NET_DISKERROR_ALARM_EX = 0x2107; // 坏硬盘报警,数据为32个字节,每个字节表示一个硬盘的故障报警状态,1为有报警,0为无报警。 + public static final int NET_ALARM_ACC_POWEROFF = 0x211E; // ACC断电报警,数据为 DWORD 0:ACC通电 1:ACC断电 + public static final int NET_ALARM_FRONTDISCONNECT = 0x2132; // 前端IPC断网报警(对应结构体 ALARM_FRONTDISCONNET_INFO) + public static final int NET_ALARM_BATTERYLOWPOWER = 0x2134; // 电池电量低报警(对应结构体 ALARM_BATTERYLOWPOWER_INFO) + public static final int NET_ALARM_TEMPERATURE = 0x2135; // 温度过高报警(对应结构体 ALARM_TEMPERATURE_INFO) + public static final int NET_ALARM_STORAGE_FAILURE_EX = 0x2163; // 存储错误报警(对应结构体 ALARM_STORAGE_FAILURE_EX) + public static final int NET_ALARM_TALKING_INVITE = 0x2171; // 设备请求对方发起对讲事件(对应结构体 ALARM_TALKING_INVITE_INFO) + public static final int NET_ALARM_ALARM_EX2 = 0x2175; // 本地报警事件(对应结构体ALARM_ALARM_INFO_EX2,对NET_ALARM_ALARM_EX升级) + public static final int NET_EVENT_VIDEOABNORMALDETECTION = 0x218e; // 视频异常事件(对应ALARM_VIDEOABNORMAL_DETECTION_INFO) + public static final int NET_ALARM_STORAGE_NOT_EXIST = 0x3167; // 存储组不存在事件(对应结构体 ALARM_STORAGE_NOT_EXIST_INFO) + public static final int NET_ALARM_SCADA_DEV_ALARM = 0x31a2; // 检测采集设备报警事件(对应结构体 ALARM_SCADA_DEV_INFO) + public static final int NET_ALARM_PARKING_CARD = 0x31a4; // 停车刷卡事件(对应结构体 ALARM_PARKING_CARD) + public static final int NET_ALARM_VEHICLE_ACC = 0x31a6; // 车辆ACC报警事件(对应结构体 ALARM_VEHICLE_ACC_INFO) + public static final int NET_ALARM_NEW_FILE = 0x31b3; // 新文件事件(对应ALARM_NEW_FILE_INFO) + public static final int NET_ALARM_HUMAM_NUMBER_STATISTIC = 0x31cc; // 人数量/客流量统计事件 (对应结构体 ALARM_HUMAN_NUMBER_STATISTIC_INFO) + public static final int NET_ALARM_ARMMODE_CHANGE_EVENT = 0x3175; // 布撤防状态变化事件(对应结构体 ALARM_ARMMODE_CHANGE_INFO) + public static final int NET_ALARM_ACCESS_CTL_EVENT = 0x3181; // 门禁事件(对应结构体 ALARM_ACCESS_CTL_EVENT_INFO) + public static final int NET_URGENCY_ALARM_EX2 = 0x3182; // 紧急报警EX2(对 NET_URGENCY_ALARM_EX 的升级,对应结构体 ALARM_URGENCY_ALARM_EX2, 人为触发的紧急事件, 一般处理是联动外部通讯功能请求帮助 + public static final int NET_ALARM_ALARMCLEAR = 0x3187; // 消警事件(对应结构体 ALARM_ALARMCLEAR_INFO ) + public static final int NET_ALARM_RCEMERGENCY_CALL = 0x318b; // 紧急呼叫报警事件(对应结构体 ALARM_RCEMERGENCY_CALL_INFO) + public static final int NET_ALARM_BUS_SHARP_ACCELERATE = 0x31ae; // 车辆急加速事件(对应结构体 ALARM_BUS_SHARP_ACCELERATE_INFO) + public static final int NET_ALARM_BUS_SHARP_DECELERATE = 0x31af; // 车辆急减速事件(对应结构体 ALARM_BUS_SHARP_DECELERATE_INFO) + public static final int NET_ALARM_HOTSPOT_WARNING = 0X31d8; // 热成像热点异常报警(对应结构体 ALARM_HOTSPOT_WARNING_INFO) + public static final int NET_ALARM_COLDSPOT_WARNING = 0X31d9; // 热成像冷点异常报警(对应结构体 ALARM_COLDSPOT_WARNING_INFO) + public static final int NET_ALARM_FIREWARNING_INFO = 0X31da; // 热成像火情报警信息上报(对应结构体 ALARM_FIREWARNING_INFO_DETAIL) + public static final int NET_ALARM_RADAR_HIGH_SPEED = 0x31df; // 雷达监测超速报警事件 智能楼宇专用 (对应结构体 ALARM_RADAR_HIGH_SPEED_INFO) + public static final int NET_ALARM_POLLING_ALARM = 0x31e0; // 设备巡检报警事件 智能楼宇专用 (对应结构体 ALARM_POLLING_ALARM_INFO) + public static final int NET_ALARM_GPS_NOT_ALIGNED = 0x321d; // GPS未定位报警(对应结构体 ALARM_GPS_NOT_ALIGNED_INFO) + public static final int NET_ALARM_VIDEOBLIND = 0x323e; // 视频遮挡事件(对应结构体 ALARM_VIDEO_BLIND_INFO) + public static final int NET_ALARM_DRIVER_NOTCONFIRM = 0x323f; // 司机未按确认按钮报警事件(对应结构体 ALARM_DRIVER_NOTCONFIRM_INFO) + public static final int NET_ALARM_FACEINFO_COLLECT = 0x3240; // 人脸信息录入事件(对应 ALARM_FACEINFO_COLLECT_INFO) + public static final int NET_ALARM_HIGH_SPEED = 0x3241; // 车辆超速报警事件(对应 ALARM_HIGH_SPEED_INFO ) + public static final int NET_ALARM_VIDEO_LOSS = 0x3242; // 视频丢失事件(对应 ALARM_VIDEO_LOSS_INFO ) + + // 订阅Bus状态对应事件上报(CLIENT_AttachBusState) + public static final int NET_ALARM_BUS_PASSENGER_CARD_CHECK = 0x0009; // 乘客刷卡事件(对应结构体 ALARM_PASSENGER_CARD_CHECK ) + + // 帧类型掩码定义 + public static final int FRAME_TYPE_MOTION = 0x00000001; // 动检帧 + + // CLIENT_RealLoadPictureEx 智能抓图事件 + public static final int EVENT_IVS_ALL = 0x00000001; // 订阅所有事件 + public static final int EVENT_IVS_CROSSLINEDETECTION = 0x00000002; // 警戒线事件(对应 DEV_EVENT_CROSSLINE_INFO) + public static final int EVENT_IVS_CROSSREGIONDETECTION = 0x00000003; // 警戒区事件(对应 DEV_EVENT_CROSSREGION_INFO) + public static final int EVENT_IVS_WANDERDETECTION = 0x00000007; // 徘徊事件(对应 DEV_EVENT_WANDER_INFO) + public static final int EVENT_IVS_FIGHTDETECTION = 0x0000000E; // 斗殴事件(对应 DEV_EVENT_FIGHT_INFO) + public static final int EVENT_IVS_TRAFFICJUNCTION = 0x00000017; // 交通路口事件----老规则(对应 DEV_EVENT_TRAFFICJUNCTION_INFO) + public static final int EVENT_IVS_TRAFFICGATE = 0x00000018; // 交通卡口事件----老规则(对应 DEV_EVENT_TRAFFICGATE_INFO) + public static final int EVENT_IVS_FACEDETECT = 0x0000001A; // 人脸检测事件 (对应 DEV_EVENT_FACEDETECT_INFO) + public static final int EVENT_IVS_TRAFFICJAM = 0x0000001B; // 交通拥堵事件(对应 DEV_EVENT_TRAFFICJAM_INFO) + public static final int EVENT_IVS_TRAFFIC_RUNREDLIGHT = 0x00000100; // 交通违章-闯红灯事件(对应 DEV_EVENT_TRAFFIC_RUNREDLIGHT_INFO) + public static final int EVENT_IVS_TRAFFIC_OVERLINE = 0x00000101; // 交通违章-压车道线事件(对应 DEV_EVENT_TRAFFIC_OVERLINE_INFO) + public static final int EVENT_IVS_TRAFFIC_RETROGRADE = 0x00000102; // 交通违章-逆行事件(对应 DEV_EVENT_TRAFFIC_RETROGRADE_INFO) + public static final int EVENT_IVS_TRAFFIC_TURNLEFT = 0x00000103; // 交通违章-违章左转(对应 DEV_EVENT_TRAFFIC_TURNLEFT_INFO) + public static final int EVENT_IVS_TRAFFIC_TURNRIGHT = 0x00000104; // 交通违章-违章右转(对应 DEV_EVENT_TRAFFIC_TURNRIGHT_INFO) + public static final int EVENT_IVS_TRAFFIC_UTURN = 0x00000105; // 交通违章-违章掉头(对应 DEV_EVENT_TRAFFIC_UTURN_INFO) + public static final int EVENT_IVS_TRAFFIC_OVERSPEED = 0x00000106; // 交通违章-超速(对应 DEV_EVENT_TRAFFIC_OVERSPEED_INFO) + public static final int EVENT_IVS_TRAFFIC_UNDERSPEED = 0x00000107; // 交通违章-低速(对应 DEV_EVENT_TRAFFIC_UNDERSPEED_INFO) + public static final int EVENT_IVS_TRAFFIC_PARKING = 0x00000108; // 交通违章-违章停车(对应 DEV_EVENT_TRAFFIC_PARKING_INFO) + public static final int EVENT_IVS_TRAFFIC_WRONGROUTE = 0x00000109; // 交通违章-不按车道行驶(对应 DEV_EVENT_TRAFFIC_WRONGROUTE_INFO) + public static final int EVENT_IVS_TRAFFIC_CROSSLANE = 0x0000010A; // 交通违章-违章变道(对应 DEV_EVENT_TRAFFIC_CROSSLANE_INFO) + public static final int EVENT_IVS_TRAFFIC_OVERYELLOWLINE = 0x0000010B; // 交通违章-压黄线 (对应 DEV_EVENT_TRAFFIC_OVERYELLOWLINE_INFO) + public static final int EVENT_IVS_TRAFFIC_YELLOWPLATEINLANE = 0x0000010E; // 交通违章-黄牌车占道事件(对应 DEV_EVENT_TRAFFIC_YELLOWPLATEINLANE_INFO) + public static final int EVENT_IVS_TRAFFIC_PEDESTRAINPRIORITY = 0x0000010F; // 交通违章-斑马线行人优先事件(对应 DEV_EVENT_TRAFFIC_PEDESTRAINPRIORITY_INFO) + public static final int EVENT_IVS_TRAFFIC_NOPASSING = 0x00000111; // 交通违章-禁止通行事件(对应 DEV_EVENT_TRAFFIC_NOPASSING_INFO) + public static final int EVENT_IVS_FACERECOGNITION = 0x00000117; // 人脸识别事件(对应 DEV_EVENT_FACERECOGNITION_INFO + public static final int EVENT_IVS_TRAFFIC_MANUALSNAP = 0x00000118; // 交通手动抓拍事件(对应 DEV_EENT_TRAFFIC_MANUALSNAP_INFO) + public static final int EVENT_IVS_TRAFFIC_FLOWSTATE = 0x00000119; // 交通流量统计事件(对应 DEV_EVENT_TRAFFIC_FLOW_STATE) + public static final int EVENT_IVS_TRAFFIC_VEHICLEINROUTE = 0x0000011B; // 有车占道事件(对应 DEV_EVENT_TRAFFIC_VEHICLEINROUTE_INFO) + public static final int EVENT_IVS_TRAFFIC_TOLLGATE = 0x00000120; // 交通违章--卡口事件----新规则(对应 DEV_EVENT_TRAFFICJUNCTION_INFO) + public static final int EVENT_IVS_TRAFFIC_VEHICLEINBUSROUTE = 0x00000124; // 交通违章--占用公交车道事件(对应 DEV_EVENT_TRAFFIC_VEHICLEINBUSROUTE_INFO) + public static final int EVENT_IVS_TRAFFIC_BACKING = 0x00000125; // 交通违章--违章倒车事件(对应 DEV_EVENT_IVS_TRAFFIC_BACKING_INFO) + public static final int EVENT_IVS_AUDIO_ABNORMALDETECTION = 0x00000126; // 声音异常检测(对应 DEV_EVENT_IVS_AUDIO_ABNORMALDETECTION_INFO) + public static final int EVENT_IVS_TRAFFIC_RUNYELLOWLIGHT = 0x00000127; // 交通违章-闯黄灯事件(对应 DEV_EVENT_TRAFFIC_RUNYELLOWLIGHT_INFO) + public static final int EVENT_IVS_CLIMBDETECTION = 0x00000128; // 攀高检测事件(对应 DEV_EVENT_IVS_CLIMB_INFO) + public static final int EVENT_IVS_LEAVEDETECTION = 0x00000129; // 离岗检测事件(对应 DEV_EVENT_IVS_LEAVE_INFO) + public static final int EVENT_IVS_TRAFFIC_PARKINGONYELLOWBOX = 0x0000012A; // 交通违章--黄网格线抓拍事件(对应 DEV_EVENT_TRAFFIC_PARKINGONYELLOWBOX_INFO) + public static final int EVENT_IVS_TRAFFIC_PARKINGSPACEPARKING = 0x0000012B; // 车位有车事件(对应 DEV_EVENT_TRAFFIC_PARKINGSPACEPARKING_INFO ) + public static final int EVENT_IVS_TRAFFIC_PARKINGSPACENOPARKING = 0x0000012C; // 车位无车事件(对应 DEV_EVENT_TRAFFIC_PARKINGSPACENOPARKING_INFO ) + public static final int EVENT_IVS_TRAFFIC_PEDESTRAIN = 0x0000012D; // 交通行人事件(对应 DEV_EVENT_TRAFFIC_PEDESTRAIN_INFO) + public static final int EVENT_IVS_TRAFFIC_THROW = 0x0000012E; // 交通抛洒物品事件(对应 DEV_EVENT_TRAFFIC_THROW_INFO) + public static final int EVENT_IVS_TRAFFIC_OVERSTOPLINE = 0X00000137; // 交通违章--压停止线事件(对应 DEV_EVENT_TRAFFIC_OVERSTOPLINE) + public static final int EVENT_IVS_TRAFFIC_WITHOUT_SAFEBELT = 0x00000138; // 交通违章--交通未系安全带事件(对应 DEV_EVENT_TRAFFIC_WITHOUT_SAFEBELT) + public static final int EVENT_IVS_TRAFFIC_PASSNOTINORDER = 0x0000013C; // 交通违章--未按规定依次通行(对应 DEV_EVENT_TRAFFIC_PASSNOTINORDER_INFO) + public static final int EVENT_IVS_TRAFFIC_JAM_FORBID_INTO = 0x00000163; // 交通违章--车辆拥堵禁入事件(对应 DEV_EVENT_ALARM_JAMFORBIDINTO_INFO) + public static final int EVENT_IVS_TRAFFIC_FCC = 0x0000016B; // 加油站提枪、挂枪事件(对应 DEV_EVENT_TRAFFIC_FCC_INFO) + + // CLIENT_GetNewDevConfig / CLIENT_SetNewDevConfig 配置项 + public static final String CFG_CMD_VIDEOWIDGET = "VideoWidget"; // 视频编码物件配置(对应 NET_CFG_VideoWidget ) + public static final String CFG_CMD_ANALYSEMODULE = "VideoAnalyseModule"; // 物体的检测模块配置(对应 CFG_ANALYSEMODULES_INFO) + public static final String CFG_CMD_ANALYSERULE = "VideoAnalyseRule"; // 视频分析规则配置(对应 CFG_ANALYSERULES_INFO) + public static final String CFG_CMD_VIDEOINOPTIONS = "VideoInOptions"; // 视频输入前端选项(对应CFG_VIDEO_IN_OPTIONS) + public static final String CFG_CMD_RAINBRUSHMODE = "RainBrushMode"; // 雨刷模式相关配置(对应CFG_RAINBRUSHMODE_INFO数组) + public static final String CFG_CMD_RAINBRUSH = "RainBrush"; // 雨刷配置(对应CFG_RAINBRUSH_INFO) + public static final String CFG_CMD_ENCODE = "Encode"; // 图像通道属性配置(对应CFG_ENCODE_INFO) + public static final String CFG_CMD_VIDEO_IN_ZOOM = "VideoInZoom"; // 云台通道变倍配置(对应CFG_VIDEO_IN_ZOOM) + public static final String CFG_CMD_REMOTEDEVICE = "RemoteDevice"; // 远程设备信息(对应 AV_CFG_RemoteDevice 数组, 通道无关) + public static final String CFG_CMD_ANALYSESOURCE = "VideoAnalyseSource"; // 视频分析资源配置(对应 CFG_ANALYSESOURCE_INFO) + public static final String CFG_CMD_TRAFFICGLOBAL = "TrafficGlobal"; // 智能交通全局配置(CFG_TRAFFICGLOBAL_INFO) + public static final String CFG_CMD_RECORDMODE = "RecordMode"; // 录像模式(对应 AV_CFG_RecordMode ) + public static final String CFG_CMD_ALARMLAMP = "AlarmLamp"; // 警灯配置(对应 CFG_ALARMLAMP_INFO) + public static final String CFG_CMD_ALARMOUT = "AlarmOut"; // 报警输出通道配置(对应 CFG_ALARMOUT_INFO ) + public static final String CFG_CMD_INTELLECTIVETRAFFIC = "TrafficSnapshot"; // 智能交通抓拍(对应 CFG_TRAFFICSNAPSHOT_INFO ) + public static final String CFG_CMD_TRAFFICSNAPSHOT_MULTI = "TrafficSnapshotNew" ; // 智能交通抓拍( CFG_TRAFFICSNAPSHOT_NEW_INFO ) + public static final String CFG_CMD_NTP = "NTP"; // 时间同步服务器(对应 CFG_NTP_INFO ) + public static final String CFG_CMD_THERMOMETRY_RULE = "ThermometryRule"; // 热成像测温规则配置(对应 CFG_RADIOMETRY_RULE_INFO ) + public static final String CFG_CMD_ALARMINPUT = "Alarm"; // 外部输入报警配置(对应 CFG_ALARMIN_INFO) + + // CLIENT_FileTransmit接口传输文件类型 + public static final int NET_DEV_BLACKWHITETRANS_START = 0x0003; // 开始发送黑白名单(对应结构体 DHDEV_BLACKWHITE_LIST_INFO) + public static final int NET_DEV_BLACKWHITETRANS_SEND = 0x0004; // 发送黑白名单 + public static final int NET_DEV_BLACKWHITETRANS_STOP = 0x0005; // 停止发送黑白名单 + + // 配置类型,对应CLIENT_GetDevConfig和CLIENT_SetDevConfig接口 + public static final int NET_DEV_DEVICECFG = 0x0001; // 设备属性配置 + public static final int NET_DEV_NETCFG_EX = 0x005b; // 网络扩展配置(对应结构体 NETDEV_NET_CFG_EX ) + public static final int NET_DEV_TIMECFG = 0x0008; // DVR时间配置 + + // 命令类型, 对应 CLIENT_QueryNewSystemInfo 接口 + public static final String CFG_CAP_CMD_DEVICE_STATE = "trafficSnap.getDeviceStatus"; // 获取设备状态信息 (对应 CFG_CAP_TRAFFIC_DEVICE_STATUS) + public static final String CFG_CAP_CMD_RECORDFINDER = "RecordFinder.getCaps"; // 获取查询记录能力集, (对应结构体 CFG_CAP_RECORDFINDER_INFO) + + // 远程配置结构体相关常量 + public static final int NET_MAX_MAIL_ADDR_LEN = 128; // 邮件发(收)地址最大长度 + public static final int NET_MAX_MAIL_SUBJECT_LEN = 64; // 邮件主题最大长度 + public static final int NET_MAX_IPADDR_LEN = 16; // IP地址字符串长度 + public static final int NET_MAX_IPADDR_LEN_EX = 40; // 扩展IP地址字符串长度, 支持IPV6 + + public static final int NET_MAX_DEV_ID_LEN = 48; // 机器编号最大长度 + public static final int NET_MAX_HOST_NAMELEN = 64; // 主机名长度, + public static final int NET_MAX_HOST_PSWLEN = 32; // 密码长度 + public static final int NET_MAX_ETHERNET_NUM = 2; // 以太网口最大个数 + public static final int NET_MAX_ETHERNET_NUM_EX = 10; // 扩展以太网口最大个数 + public static final int NET_DEV_CLASS_LEN = 16; // 设备类型字符串(如"IPC")长度 + public static final int NET_N_WEEKS = 7; // 一周的天数 + public static final int NET_N_TSECT = 6; // 通用时间段个数 + public static final int NET_N_REC_TSECT = 6; // 录像时间段个数 + public static final int NET_N_COL_TSECT = 2; // 颜色时间段个数 + public static final int NET_N_ENCODE_AUX = 3; // 扩展码流个数 + public static final int NET_N_TALK = 1; // 最多对讲通道个数 + public static final int NET_N_COVERS = 1; // 遮挡区域个数 + public static final int NET_N_CHANNEL = 16; // 最大通道个数 + public static final int NET_N_ALARM_TSECT = 2; // 报警提示时间段个数 + public static final int NET_MAX_ALARMOUT_NUM = 16; // 报警输出口个数上限 + public static final int NET_MAX_AUDIO_IN_NUM = 16; // 音频输入口个数上限 + public static final int NET_MAX_VIDEO_IN_NUM = 16; // 视频输入口个数上限 + public static final int NET_MAX_ALARM_IN_NUM = 16; // 报警输入口个数上限 + public static final int NET_MAX_DISK_NUM = 16; // 硬盘个数上限,暂定为16 + public static final int NET_MAX_DECODER_NUM = 16; // 解码器(485)个数上限 + public static final int NET_MAX_232FUNCS = 10; // 232串口功能个数上限 + public static final int NET_MAX_232_NUM = 2; // 232串口个数上限 + public static final int NET_MAX_232_NUM_EX = 16; // 扩展串口配置个数上限 + public static final int NET_MAX_DECPRO_LIST_SIZE = 100; // 解码器协议列表个数上限 + public static final int NET_FTP_MAXDIRLEN = 240; // FTP文件目录最大长度 + public static final int NET_MATRIX_MAXOUT = 16; // 矩阵输出口最大个数 + public static final int NET_TOUR_GROUP_NUM = 6; // 矩阵输出组最大个数 + public static final int NET_MAX_DDNS_NUM = 10; // 设备支持的ddns服务器最大个数 + public static final int NET_MAX_SERVER_TYPE_LEN = 32; // ddns服务器类型,最大字符串长度 + public static final int NET_MAX_DOMAIN_NAME_LEN = 256; // ddns域名,最大字符串长度 + public static final int NET_MAX_DDNS_ALIAS_LEN = 32; // ddns服务器别名,最大字符串长度 + public static final int NET_MAX_DEFAULT_DOMAIN_LEN = 60; // ddns默认域名,最大字符串长度 + public static final int NET_MOTION_ROW = 32; // 动态检测区域的行数 + public static final int NET_MOTION_COL = 32; // 动态检测区域的列数 + public static final int NET_STATIC_ROW = 32; // 静态检测区域的行数 + public static final int NET_STATIC_COL = 32; // 静态检测区域的列数 + public static final int NET_FTP_USERNAME_LEN = 64; // FTP配置,用户名最大长度 + public static final int NET_FTP_PASSWORD_LEN = 64; // FTP配置,密码最大长度 + public static final int NET_TIME_SECTION = 2; // FTP配置,每天时间段个数 + public static final int NET_FTP_MAX_PATH = 240; // FTP配置,文件路径名最大长度 + public static final int NET_FTP_MAX_SUB_PATH = 128; // FTP配置,文件路径名最大长度 + public static final int NET_INTERVIDEO_UCOM_CHANID = 32; // 平台接入配置,U网通通道ID + public static final int NET_INTERVIDEO_UCOM_DEVID = 32; // 平台接入配置,U网通设备ID + public static final int NET_INTERVIDEO_UCOM_REGPSW = 16; // 平台接入配置,U网通注册密码 + public static final int NET_INTERVIDEO_UCOM_USERNAME = 32; // 平台接入配置,U网通用户名 + public static final int NET_INTERVIDEO_UCOM_USERPSW = 32; // 平台接入配置,U网通密码 + public static final int NET_INTERVIDEO_NSS_IP = 32; // 平台接入配置,中兴力维IP + public static final int NET_INTERVIDEO_NSS_SERIAL = 32; // 平台接入配置,中兴力维serial + public static final int NET_INTERVIDEO_NSS_USER = 32; // 平台接入配置,中兴力维user + public static final int NET_INTERVIDEO_NSS_PWD = 50; // 平台接入配置,中兴力维password + public static final int NET_MAX_VIDEO_COVER_NUM = 16; // 遮挡区域最大个数 + public static final int NET_MAX_WATERMAKE_DATA = 4096; // 水印图片数据最大长度 + public static final int NET_MAX_WATERMAKE_LETTER = 128; // 水印文字最大长度 + public static final int NET_MAX_WLANDEVICE_NUM = 10; // 最多搜索出的无线设备个数 + public static final int NET_MAX_WLANDEVICE_NUM_EX = 32; // 最多搜索出的无线设备个数 + public static final int NET_MAX_ALARM_NAME = 64; // 地址长度 + public static final int NET_MAX_REGISTER_SERVER_NUM = 10; // 主动注册服务器个数 + public static final int NET_SNIFFER_FRAMEID_NUM = 6; // 6个FRAME ID 选项 + public static final int NET_SNIFFER_CONTENT_NUM = 4; // 每个FRAME对应的4个抓包内容 + public static final int NET_SNIFFER_CONTENT_NUM_EX = 8; // 每个FRAME对应的8个抓包内容 + public static final int NET_SNIFFER_PROTOCOL_SIZE = 20; // 协议名字长度 + public static final int NET_MAX_PROTOCOL_NAME_LENGTH = 20; + public static final int NET_SNIFFER_GROUP_NUM = 4; // 4组抓包设置 + public static final int NET_ALARM_OCCUR_TIME_LEN = 40; // 新的报警上传时间的长度 + public static final int NET_VIDEO_OSD_NAME_NUM = 64; // 叠加的名称长度,目前支持32个英文,16个中文 + public static final int NET_VIDEO_CUSTOM_OSD_NUM = 8; // 支持的自定义叠加的数目,不包含时间和通道 + public static final int NET_VIDEO_CUSTOM_OSD_NUM_EX = 256; // 支持的自定义叠加的数目,不包含时间和通道 + public static final int NET_CONTROL_AUTO_REGISTER_NUM = 100; // 支持定向主动注册服务器的个数 + public static final int NET_MMS_RECEIVER_NUM = 100; // 支持短信接收者的个数 + public static final int NET_MMS_SMSACTIVATION_NUM = 100; // 支持短信发送者的个数 + public static final int NET_MMS_DIALINACTIVATION_NUM = 100; // 支持拨号发送者的个数 + public static final int NET_MAX_ALARM_IN_NUM_EX = 32; // 报警输入口个数上限 + public static final int NET_MAX_IPADDR_OR_DOMAIN_LEN = 64; // IP地址字符串长度 + public static final int NET_MAX_CALLID = 32; // 呼叫ID + public static final int NET_MAX_FENCE_LINE_NUM = 2; // 围栏最大曲线数 + public static final int MAX_SMART_VALUE_NUM = 30; // 最多的smart信息个数 + public static final int NET_INTERVIDEO_AMP_DEVICESERIAL = 48; // 平台接入配置,天地阳光 设备序列号字符串长度 + public static final int NET_INTERVIDEO_AMP_DEVICENAME = 16; // 平台接入配置,天地阳光 设备名称字符串长度 + public static final int NET_INTERVIDEO_AMP_USER = 32; // 平台接入配置,天地阳光 注册用户名字符串长度 + public static final int NET_INTERVIDEO_AMP_PWD = 32; // 平台接入配置,天地阳光 注册密码字符串长度 + public static final int MAX_SUBMODULE_NUM = 32; // 最多子模块信息个数 + public static final int NET_MAX_CARWAY_NUM = 8; // 交通抓拍,最大车道数 + public static final int NET_MAX_SNAP_SIGNAL_NUM = 3; // 一个车道的最大抓拍张数 + public static final int NET_MAX_CARD_NUM = 128; // 卡号的最大个数 + public static final int NET_MAX_CARDINFO_LEN = 32; // 每条卡号最长字符数 + public static final int NET_MAX_CONTROLER_NUM = 64; // 最大支持控制器数目 + public static final int NET_MAX_LIGHT_NUM = 32; // 最多控制灯组数 + public static final int NET_MAX_SNMP_COMMON_LEN = 64; // snmp 读写数据长度 + public static final int NET_MAX_DDNS_STATE_LEN = 128; // DDNS 状态信息长度 + public static final int NET_MAX_PHONE_NO_LEN = 16; // 电话号码长度 + public static final int NET_MAX_MSGTYPE_LEN = 32; // 导航类型或短信息类型长度 + public static final int NET_MAX_MSG_LEN = 256; // 导航和短信息长度 + public static final int NET_MAX_GRAB_INTERVAL_NUM = 4; // 多张图片抓拍个数 + public static final int NET_MAX_FLASH_NUM = 5; // 最多支持闪光灯个数 + public static final int NET_MAX_ISCSI_PATH_NUM = 64; // ISCSI远程目录最大数量 + public static final int NET_MAX_WIRELESS_CHN_NUM = 256; // 无线路由最大信道数 + public static final int NET_PROTOCOL3_BASE = 100; // 三代协议版本基数 + public static final int NET_PROTOCOL3_SUPPORT = 11; // 只支持3代协议 + public static final int NET_MAX_STAFF_NUM = 20; // 浓缩视频配置信息中标尺数上限 + public static final int NET_MAX_CALIBRATEBOX_NUM = 10; // 浓缩视频配置信息中标定区域数上限 + public static final int NET_MAX_EXCLUDEREGION_NUM = 10; // 浓缩视频配置信息中排除区域数上限 + public static final int NET_MAX_POLYLINE_NUM = 20; // 浓缩视频配置信息中标尺线数 + public static final int NET_MAX_COLOR_NUM = 16; // 最大颜色数目 + public static final int MAX_OBJFILTER_NUM = 16; // 最大过滤种类个数 + public static final int NET_MAX_SYNOPSIS_STATE_NAME = 64; // 视频浓缩状态字符串长度 + public static final int NET_MAX_SYNOPSIS_QUERY_FILE_COUNT = 10; // 视频浓缩相关原始文件按照路径查找时文件个数上限 + public static final int NET_MAX_SSID_LEN = 36; // SSID长度 + public static final int NET_MAX_APPIN_LEN = 16; // PIN码长度 + public static final int NET_NETINTERFACE_NAME_LEN = 260; // 网口名称长度 + public static final int NET_NETINTERFACE_TYPE_LEN = 260; // 网络类型长度 + public static final int NET_MAX_CONNECT_STATUS_LEN = 260; // 连接状态字符串长度 + public static final int NET_MAX_MODE_LEN = 64; // 3G支持的网络模式长度 + public static final int NET_MAX_MODE_NUM = 64; // 3G支持的网络模式个数 + public static final int NET_MAX_COMPRESSION_TYPES_NUM = 16; // 视频编码格式最多种类个数 + public static final int NET_MAX_CAPTURE_SIZE_NUM = 64; // 视频分辨率个数 + public static final int NET_NODE_NAME_LEN = 64; // 组织结构节点名称长度 + public static final int MAX_CALIBPOINTS_NUM = 256; // 支持最大标定点数 + public static final int NET_MAX_ATTR_NUM = 32; // 显示单元属性最大数量 + public static final int NET_MAX_CLOUDCONNECT_STATE_LEN = 128; // 云注册连接状态信息长度 + public static final int NET_MAX_IPADDR_EX_LEN = 128; // 扩展IP地址最大长度 + public static final int MAX_EVENT_NAME = 128; // 最长事件名 + public static final int NET_MAX_ETH_NAME = 64; // 最大网卡名 + public static final int NET_N_SCHEDULE_TSECT = 8; // 时间表元素个数 + public static final int NET_MAX_URL_NUM = 8; // URL最大个数 + public static final int NET_MAX_LOWER_MITRIX_NUM = 16; // 最大下位矩阵数 + public static final int NET_MAX_BURN_CHANNEL_NUM = 32; // 最大刻录通道数 + public static final int NET_MAX_NET_STRORAGE_BLOCK_NUM = 64; // 最大远程存储区块数量 + public static final int NET_MAX_CASE_PERSON_NUM = 32; // 案件人员最大数量 + public static final int NET_MAX_MULTIPLAYBACK_CHANNEL_NUM = 64; // 最大多通道预览回放通道数 + public static final int NET_MAX_MULTIPLAYBACK_SPLIT_NUM = 32; // 最大多通道预览回放分割模式数 + public static final int NET_MAX_AUDIO_ENCODE_TYPE = 64; // 最大语音编码类型个数 + public static final int MAX_CARD_RECORD_FIELD_NUM = 16; // 卡号录像最大域数量 + public static final int NET_BATTERY_NUM_MAX = 16; // 最大电池数量 + public static final int NET_POWER_NUM_MAX = 16; // 最大电源数量 + public static final int NET_MAX_AUDIO_PATH = 260; // 最大音频文件路长度 + public static final int NET_MAX_DOORNAME_LEN = 128; // 最大门禁名称长度 + public static final int NET_MAX_CARDPWD_LEN = 64; // 最大门禁名称长度 + public static final int NET_MAX_FISHEYE_MOUNTMODE_NUM = 4; // 最大鱼眼安装模式个数 + public static final int NET_MAX_FISHEYE_CALIBRATEMODE_NUM = 16; // 最大鱼眼矫正模式个数 + public static final int NET_MAX_FISHEYE_EPTZCMD_NUM = 64; // 最大鱼眼电子云台操作个数 + public static final int POINT_NUM_IN_PAIR = 2; // 标定点对中的点数量 + public static final int MAX_POINT_PAIR_NUM = 128; // 标定点最大数量 + public static final int CHANNEL_NUM_IN_POINT_GROUP = 2; // 标定点中的视频通道数 + public static final int MAX_POINT_GROUP_NUM = 32; // 标定点组最大数量, 每两个通道进行拼接需要一组标定点 + public static final int MAX_LANE_INFO_NUM = 32; // 最大车道信息数 + public static final int MAX_LANE_DIRECTION_NUM = 8; // 车道方向总数 + public static final int NET_MAX_MONITORWALL_NUM = 32; // 电视墙最大数量 + public static final int NET_MAX_OPTIONAL_URL_NUM = 8; // 备用url最大数量 + public static final int NET_MAX_CAMERA_CHANNEL_NUM = 1024; // 最大摄像机通道数 + public static final int MAX_FILE_SUMMARY_NUM = 32; // 最大文件摘要数 + public static final int MAX_AUDIO_ENCODE_NUM = 64; // 最大支持音频编码个数 + + public static final int MAX_FLASH_LIGHT_NUM = 8; // 最大支持的爆闪灯(闪光灯)个数 + public static final int MAX_STROBOSCOPIC_LIGHT_NUM = 8; // 最大支持的频闪灯个数 + public static final int MAX_MOSAIC_NUM = 8; // 最大支持的马赛克数量 + public static final int MAX_MOSAIC_CHANNEL_NUM = 256; // 支持马赛克叠加的最多通道数量 + public static final int MAX_FIREWARNING_INFO_NUM = 4; // 最大热成像着火点报警信息个数 + public static final int MAX_AXLE_NUM = 8; // 最大车轴数量 + public static final int MAX_ACCESSDOOR_NUM = 128; // 最大门数量 + + public static final int NET_MAX_BULLET_HOLES = 10; // 最大的弹孔数 + + public static final int MAX_NTP_SERVER = 4; // 最大备用NTP服务器地址 + public static final int MAX_PLATE_NUM = 64; // 每张图片中包含的最大车牌个数 + public static final int MAX_PREVIEW_CHANNEL_NUM = 64; // 最大导播预览的通道数量 + public static final int MAX_ADDRESS_LEN = 256; // 最大的地址长度 + + public static final int MAX_EVENT_RESTORE_UUID = 36; // 事件重传uuid数组大小 + public static final int MAX_EVENT_RESTORE_CODE_NUM = 8; // 最大事件重传类型个数 + public static final int MAX_EVENT_RESOTER_CODE_TYPE = 32; // 事件重传类型数组大小 + public static final int MAX_SNAP_TYPE = 3; // 抓图类型数量 + public static final int MAX_MAINFORMAT_NUM = 4; // 最大支持主码流类型数量 + + public static final int CUSTOM_TITLE_LEN = 1024; // 自定义标题名称长度(扩充到1024) + public static final int MAX_CUSTOM_TITLE_NUM = 8; // 编码物件自定义标题最大数量 + public static final int FORMAT_TYPE_LEN = 16; // 编码类型名最大长度 + + public static final int MAX_CHANNEL_NAME_LEN = 256; // 通道名称最大长度 + + public static final int MAX_VIRTUALINFO_DOMAIN_LEN = 64; // 虚拟身份上网域名长度 + public static final int MAX_VIRTUALINFO_TITLE_LEN = 64; // 虚拟身份上网标题长度 + public static final int MAX_VIRTUALINFO_USERNAME_LEN = 32; // 虚拟身份用户名长度 + public static final int MAX_VIRTUALINFO_PASSWORD_LEN = 32; // 虚拟身份密码长度 + public static final int MAX_VIRTUALINFO_PHONENUM_LEN = 12; // 虚拟身份手机号长度 + public static final int MAX_VIRTUALINFO_IMEI_LEN = 16; // 虚拟身份国际移动设备标识长度 + public static final int MAX_VIRTUALINFO_IMSI_LEN = 16; // 虚拟身份国际移动用户识别码长度 + public static final int MAX_VIRTUALINFO_LATITUDE_LEN = 16; // 虚拟身份经度长度 + public static final int MAX_VIRTUALINFO_LONGITUDE_LEN = 16; // 虚拟身份纬度长度 + public static final int MAX_VIRTUALINFO_NUM = 1024; // 最大虚拟身份信息个数 + + public static final int MAX_CALL_ID_LEN = 64; // 呼叫ID长度 + + public static final int MAX_REMOTEDEVICEINFO_IPADDR_LEN = 128; // 远程设备IP地址最大长度 + public static final int MAX_REMOTEDEVICEINFO_USERNAME_LEN = 128; // 远程设备用户名最大长度 + public static final int MAX_REMOTEDEVICEINFO_USERPSW_LENGTH = 128; // 远程设备密码最大长度 + + // 查询类型,对应CLIENT_QueryDevState接口 + public static final int NET_DEVSTATE_COMM_ALARM = 0x0001; // 查询普通报警状态(包括外部报警,视频丢失,动态检测) + public static final int NET_DEVSTATE_SHELTER_ALARM = 0x0002; // 查询遮挡报警状态 + public static final int NET_DEVSTATE_RECORDING = 0x0003; // 查询录象状态 + public static final int NET_DEVSTATE_DISK = 0x0004; // 查询硬盘信息 + public static final int NET_DEVSTATE_RESOURCE = 0x0005; // 查询系统资源状态 + public static final int NET_DEVSTATE_BITRATE = 0x0006; // 查询通道码流 + public static final int NET_DEVSTATE_CONN = 0x0007; // 查询设备连接状态 + public static final int NET_DEVSTATE_PROTOCAL_VER = 0x0008; // 查询网络协议版本号,pBuf = int* + public static final int NET_DEVSTATE_TALK_ECTYPE = 0x0009; // 查询设备支持的语音对讲格式列表,见结构体NETDEV_TALKFORMAT_LIST + public static final int NET_DEVSTATE_SD_CARD = 0x000A; // 查询SD卡信息(IPC类产品) + public static final int NET_DEVSTATE_BURNING_DEV = 0x000B; // 查询刻录机信息 + public static final int NET_DEVSTATE_BURNING_PROGRESS = 0x000C; // 查询刻录进度 + public static final int NET_DEVSTATE_PLATFORM = 0x000D; // 查询设备支持的接入平台 + public static final int NET_DEVSTATE_CAMERA = 0x000E; // 查询摄像头属性信息(IPC类产品),pBuf = NETDEV_CAMERA_INFO *,可以有多个结构体 + public static final int NET_DEVSTATE_SOFTWARE = 0x000F; // 查询设备软件版本信息 NETDEV_VERSION_INFO + public static final int NET_DEVSTATE_LANGUAGE = 0x0010; // 查询设备支持的语音种类 + public static final int NET_DEVSTATE_DSP = 0x0011; // 查询DSP能力描述(对应结构体NET_DEV_DSP_ENCODECAP) + public static final int NET_DEVSTATE_OEM = 0x0012; // 查询OEM信息 + public static final int NET_DEVSTATE_NET = 0x0013; // 查询网络运行状态信息 + public static final int NET_DEVSTATE_TYPE = 0x0014; // 查询设备类型 + public static final int NET_DEVSTATE_SNAP = 0x0015; // 查询功能属性(IPC类产品) + public static final int NET_DEVSTATE_RECORD_TIME = 0x0016; // 查询最早录像时间和最近录像时间 + public static final int NET_DEVSTATE_NET_RSSI = 0x0017; // 查询无线网络信号强度,见结构体NETDEV_WIRELESS_RSS_INFO + public static final int NET_DEVSTATE_BURNING_ATTACH = 0x0018; // 查询附件刻录选项 + public static final int NET_DEVSTATE_BACKUP_DEV = 0x0019; // 查询备份设备列表 + public static final int NET_DEVSTATE_BACKUP_DEV_INFO = 0x001a; // 查询备份设备详细信息 NETDEV_BACKUP_INFO + public static final int NET_DEVSTATE_BACKUP_FEEDBACK = 0x001b; // 备份进度反馈 + public static final int NET_DEVSTATE_ATM_QUERY_TRADE = 0x001c; // 查询ATM交易类型 + public static final int NET_DEVSTATE_SIP = 0x001d; // 查询sip状态 + public static final int NET_DEVSTATE_VICHILE_STATE = 0x001e; // 查询车载wifi状态 + public static final int NET_DEVSTATE_TEST_EMAIL = 0x001f; // 查询邮件配置是否成功 + public static final int NET_DEVSTATE_SMART_HARD_DISK = 0x0020; // 查询硬盘smart信息 + public static final int NET_DEVSTATE_TEST_SNAPPICTURE = 0x0021; // 查询抓图设置是否成功 + public static final int NET_DEVSTATE_STATIC_ALARM = 0x0022; // 查询静态报警状态 + public static final int NET_DEVSTATE_SUBMODULE_INFO = 0x0023; // 查询设备子模块信息 + public static final int NET_DEVSTATE_DISKDAMAGE = 0x0024; // 查询硬盘坏道能力 + public static final int NET_DEVSTATE_IPC = 0x0025; // 查询设备支持的IPC能力, 见结构体NET_DEV_IPC_INFO + public static final int NET_DEVSTATE_ALARM_ARM_DISARM = 0x0026; // 查询报警布撤防状态 + public static final int NET_DEVSTATE_ACC_POWEROFF_ALARM = 0x0027; // 查询ACC断电报警状态(返回一个DWORD, 1表示断电,0表示通电) + public static final int NET_DEVSTATE_TEST_FTP_SERVER = 0x0028; // 测试FTP服务器连接 + public static final int NET_DEVSTATE_3GFLOW_EXCEED = 0x0029; // 查询3G流量超出阈值状态,(见结构体 NETDEV_3GFLOW_EXCEED_STATE_INFO) + public static final int NET_DEVSTATE_3GFLOW_INFO = 0x002a; // 查询3G网络流量信息,见结构体 NET_DEV_3GFLOW_INFO + public static final int NET_DEVSTATE_VIHICLE_INFO_UPLOAD = 0x002b; // 车载自定义信息上传(见结构体 ALARM_VEHICLE_INFO_UPLOAD) + public static final int NET_DEVSTATE_SPEED_LIMIT = 0x002c; // 查询限速报警状态(见结构体ALARM_SPEED_LIMIT) + public static final int NET_DEVSTATE_DSP_EX = 0x002d; // 查询DSP扩展能力描述(对应结构体 NET_DEV_DSP_ENCODECAP_EX) + public static final int NET_DEVSTATE_3GMODULE_INFO = 0x002e; // 查询3G模块信息(对应结构体NET_DEV_3GMODULE_INFO) + public static final int NET_DEVSTATE_MULTI_DDNS = 0x002f; // 查询多DDNS状态信息(对应结构体NET_DEV_MULTI_DDNS_INFO) + public static final int NET_DEVSTATE_CONFIG_URL = 0x0030; // 查询设备配置URL信息(对应结构体NET_DEV_URL_INFO) + public static final int NET_DEVSTATE_HARDKEY = 0x0031; // 查询HardKey状态(对应结构体NETDEV_HARDKEY_STATE) + public static final int NET_DEVSTATE_ISCSI_PATH = 0x0032; // 查询ISCSI路径列表(对应结构体NETDEV_ISCSI_PATHLIST) + public static final int NET_DEVSTATE_DLPREVIEW_SLIPT_CAP = 0x0033; // 查询设备本地预览支持的分割模式(对应结构体DEVICE_LOCALPREVIEW_SLIPT_CAP) + public static final int NET_DEVSTATE_WIFI_ROUTE_CAP = 0x0034; // 查询无线路由能力信息(对应结构体NETDEV_WIFI_ROUTE_CAP) + public static final int NET_DEVSTATE_ONLINE = 0x0035; // 查询设备的在线状态(返回一个DWORD, 1表示在线, 0表示断线) + public static final int NET_DEVSTATE_PTZ_LOCATION = 0x0036; // 查询云台状态信息(对应结构体 NET_PTZ_LOCATION_INFO) + public static final int NET_DEVSTATE_MONITOR_INFO = 0x0037; // 画面监控辅助信息(对应结构体NETDEV_MONITOR_INFO) + public static final int NET_DEVSTATE_SUBDEVICE = 0x0300; // 查询子设备(电源, 风扇等)状态(对应结构体CFG_DEVICESTATUS_INFO) + public static final int NET_DEVSTATE_RAID_INFO = 0x0038; // 查询RAID状态(对应结构体ALARM_RAID_INFO) + public static final int NET_DEVSTATE_TEST_DDNSDOMAIN = 0x0039; // 测试DDNS域名是否可用 + public static final int NET_DEVSTATE_VIRTUALCAMERA = 0x003a; // 查询虚拟摄像头状态(对应 NETDEV_VIRTUALCAMERA_STATE_INFO) + public static final int NET_DEVSTATE_TRAFFICWORKSTATE = 0x003b; // 获取设备工作视频/线圈模式状态等(对应NETDEV_TRAFFICWORKSTATE_INFO) + public static final int NET_DEVSTATE_ALARM_CAMERA_MOVE = 0x003c; // 获取摄像机移位报警事件状态(对应ALARM_CAMERA_MOVE_INFO) + public static final int NET_DEVSTATE_ALARM = 0x003e; // 获取外部报警状态(对应 NET_CLIENT_ALARM_STATE) + public static final int NET_DEVSTATE_VIDEOLOST = 0x003f; // 获取视频丢失报警状态(对应 NET_CLIENT_VIDEOLOST_STATE) + public static final int NET_DEVSTATE_MOTIONDETECT = 0x0040; // 获取动态监测报警状态(对应 NET_CLIENT_MOTIONDETECT_STATE) + public static final int NET_DEVSTATE_DETAILEDMOTION = 0x0041; // 获取详细的动态监测报警状态(对应 NET_CLIENT_DETAILEDMOTION_STATE) + public static final int NET_DEVSTATE_VEHICLE_INFO = 0x0042; // 获取车载自身各种硬件信息(对应 NETDEV_VEHICLE_INFO) + public static final int NET_DEVSTATE_VIDEOBLIND = 0x0043; // 获取视频遮挡报警状态(对应 NET_CLIENT_VIDEOBLIND_STATE) + public static final int NET_DEVSTATE_3GSTATE_INFO = 0x0044; // 查询3G模块相关信息(对应结构体NETDEV_VEHICLE_3GMODULE) + public static final int NET_DEVSTATE_NETINTERFACE = 0x0045; // 查询网络接口信息(对应 NETDEV_NETINTERFACE_INFO) + + public static final int NET_DEVSTATE_PICINPIC_CHN = 0x0046; // 查询画中画通道号(对应DWORD数组) + public static final int NET_DEVSTATE_COMPOSITE_CHN = 0x0047; // 查询融合屏通道信息(对应DH_COMPOSITE_CHANNEL数组) + public static final int NET_DEVSTATE_WHOLE_RECORDING = 0x0048; // 查询设备整体录像状态(对应BOOL), 只要有一个通道在录像,即为设备整体状态为录像 + public static final int NET_DEVSTATE_WHOLE_ENCODING = 0x0049; // 查询设备整体编码状态(对应BOOL), 只要有一个通道在编码,即为设备整体状态为编码 + public static final int NET_DEVSTATE_DISK_RECORDE_TIME = 0x004a; // 查询设备硬盘录像时间信息(pBuf = DEV_DISK_RECORD_TIME*,可以有多个结构体) + public static final int NET_DEVSTATE_BURNER_DOOR = 0x004b; // 是否已弹出刻录机光驱门(对应结构体 NET_DEVSTATE_BURNERDOOR) + public static final int NET_DEVSTATE_GET_DATA_CHECK = 0x004c; // 查询光盘数据校验进度(对应 NET_DEVSTATE_DATA_CHECK) + public static final int NET_DEVSTATE_ALARM_IN_CHANNEL = 0x004f; // 查询报警输入通道信息(对应NET_ALARM_IN_CHANNEL数组) + public static final int NET_DEVSTATE_ALARM_CHN_COUNT = 0x0050; // 查询报警通道数(对应NET_ALARM_CHANNEL_COUNT) + public static final int NET_DEVSTATE_PTZ_VIEW_RANGE = 0x0051; // 查询云台可视域状态(对应 NET_OUT_PTZ_VIEW_RANGE_STATUS ) + public static final int NET_DEVSTATE_DEV_CHN_COUNT = 0x0052; // 查询设备通道信息(对应NET_DEV_CHN_COUNT_INFO) + public static final int NET_DEVSTATE_RTSP_URL = 0x0053; // 查询设备支持的RTSP URL列表,见结构体DEV_RTSPURL_LIST + public static final int NET_DEVSTATE_LIMIT_LOGIN_TIME = 0x0054; // 查询设备登录的在线超时时间,返回一个BTYE,(单位:分钟) ,0表示不限制,非零正整数表示限制的分钟数 + public static final int NET_DEVSTATE_GET_COMM_COUNT = 0x0055; // 获取串口数 见结构体NET_GET_COMM_COUNT + public static final int NET_DEVSTATE_RECORDING_DETAIL = 0x0056; // 查询录象状态详细信息(pBuf = NET_RECORD_STATE_DETAIL*) + public static final int NET_DEVSTATE_PTZ_PRESET_LIST = 0x0057; // 获取当前云台的预置点列表(对应结构NET_PTZ_PRESET_LIST) + public static final int NET_DEVSTATE_EXTERNAL_DEVICE = 0x0058; // 外接设备信息(pBuf = NET_EXTERNAL_DEVICE*) + public static final int NET_DEVSTATE_GET_UPGRADE_STATE = 0x0059; // 获取设备升级状态(对应结构 NETDEV_UPGRADE_STATE_INFO) + public static final int NET_DEVSTATE_MULTIPLAYBACK_SPLIT_CAP = 0x005a; // 获取多通道预览分割能力( 对应结构体 NET_MULTIPLAYBACK_SPLIT_CAP ) + public static final int NET_DEVSTATE_BURN_SESSION_NUM = 0x005b; // 获取刻录会话总数(pBuf = int*) + public static final int NET_DEVSTATE_PROTECTIVE_CAPSULE = 0X005c; // 查询防护舱状态(对应结构体ALARM_PROTECTIVE_CAPSULE_INFO) + public static final int NET_DEVSTATE_GET_DOORWORK_MODE = 0X005d; // 获取门锁控制模式( 对应 NET_GET_DOORWORK_MODE) + public static final int NET_DEVSTATE_PTZ_ZOOM_INFO = 0x005e; // 查询云台获取光学变倍信息(对应 NET_OUT_PTZ_ZOOM_INFO ) + + public static final int NET_DEVSTATE_POWER_STATE = 0x0152; // 查询电源状态(对应结构体NET_POWER_STATUS) + public static final int NET_DEVSTATE_ALL_ALARM_CHANNELS_STATE = 0x153; // 查询报警通道状态(对应结构体 NET_CLIENT_ALARM_CHANNELS_STATE) + public static final int NET_DEVSTATE_ALARMKEYBOARD_COUNT = 0x0154; // 查询串口上连接的报警键盘数(对应结构体NET_ALARMKEYBOARD_COUNT) + public static final int NET_DEVSTATE_EXALARMCHANNELS = 0x0155; // 查询扩展报警模块通道映射关系(对应结构体 NET_EXALARMCHANNELS) + public static final int NET_DEVSTATE_GET_BYPASS = 0x0156; // 查询通道旁路状态(对应结构体 NET_DEVSTATE_GET_BYPASS) + public static final int NET_DEVSTATE_ACTIVATEDDEFENCEAREA = 0x0157; // 获取激活的防区信息(对应结构体 NET_ACTIVATEDDEFENCEAREA) + public static final int NET_DEVSTATE_DEV_RECORDSET = 0x0158; // 查询设备记录集信息(对应 NET_CTRL_RECORDSET_PARAM) + public static final int NET_DEVSTATE_DOOR_STATE = 0x0159; // 查询门禁状态(对应NET_DOOR_STATUS_INFO) + public static final int NET_DEVSTATE_ANALOGALARM_CHANNELS = 0x1560; // 模拟量报警输入通道映射关系(对应NET_ANALOGALARM_CHANNELS) + public static final int NET_DEVSTATE_GET_SENSORLIST = 0x1561; // 获取设备支持的传感器列表(对应 NET_SENSOR_LIST) + public static final int NET_DEVSTATE_ALARM_CHANNELS = 0x1562; // 查询开关量报警模块通道映射关系(对应结构体 NET_ALARM_CHANNELS) + // 如果设备不支持查询扩展报警模块通道,可以用该功能查询扩展通道的逻辑通道号,并当做本地报警通道使用 + public static final int NET_DEVSTATE_GET_ALARM_SUBSYSTEM_ACTIVATESTATUS = 0x1563; // 获取当前子系统启用状态( 对应 NET_GET_ALARM_SUBSYSTEM_ACTIVATE_STATUES) + public static final int NET_DEVSTATE_AIRCONDITION_STATE = 0x1564; // 获取空调工作状态(对应 NET_GET_AIRCONDITION_STATE) + public static final int NET_DEVSTATE_ALARMSUBSYSTEM_STATE = 0x1565; // 获取子系统状态(对应NET_ALARM_SUBSYSTEM_STATE) + public static final int NET_DEVSTATE_ALARM_FAULT_STATE = 0x1566; // 获取故障状态(对应 NET_ALARM_FAULT_STATE_INFO) + public static final int NET_DEVSTATE_DEFENCE_STATE = 0x1567; // 获取防区状态(对应 NET_DEFENCE_STATE_INFO, 和旁路状态变化事件、本地报警事件、报警信号源事件的状态描述有区别,不能混用,仅个别设备使用) + public static final int NET_DEVSTATE_CLUSTER_STATE = 0x1568; // 获取集群状态(对应 NET_CLUSTER_STATE_INFO) + public static final int NET_DEVSTATE_SCADA_POINT_LIST = 0x1569; // 获取点位表路径信息(对应 NET_SCADA_POINT_LIST_INFO) + public static final int NET_DEVSTATE_SCADA_INFO = 0x156a; // 获取监测点位信息(对应 NET_SCADA_INFO) + public static final int NET_DEVSTATE_SCADA_CAPS = 0X156b; // 获取SCADA能力集(对应 NET_SCADA_CAPS) + public static final int NET_DEVSTATE_GET_CODEID_COUNT = 0x156c; // 获取对码成功的总条数(对应 NET_GET_CODEID_COUNT) + public static final int NET_DEVSTATE_GET_CODEID_LIST = 0x156d; // 查询对码信息(对应 NET_GET_CODEID_LIST) + public static final int NET_DEVSTATE_ANALOGALARM_DATA = 0x156e; // 查询模拟量通道数据(对应 NET_GET_ANALOGALARM_DATA) + public static final int NET_DEVSTATE_VTP_CALLSTATE = 0x156f; // 获取视频电话呼叫状态(对应 NET_GET_VTP_CALLSTATE) + public static final int NET_DEVSTATE_SCADA_INFO_BY_ID = 0x1570; // 通过设备、获取监测点位信息(对应 NET_SCADA_INFO_BY_ID) + public static final int NET_DEVSTATE_SCADA_DEVICE_LIST = 0x1571; // 获取当前主机所接入的外部设备ID(对应 NET_SCADA_DEVICE_LIST) + public static final int NET_DEVSTATE_DEV_RECORDSET_EX = 0x1572; // 查询设备记录集信息(带二进制数据)(对应NET_CTRL_RECORDSET_PARAM) + public static final int NET_DEVSTATE_ACCESS_LOCK_VER = 0x1573; // 获取门锁软件版本号(对应 NET_ACCESS_LOCK_VER) + public static final int NET_DEVSTATE_MONITORWALL_TVINFO = 0x1574; // 获取电视墙显示信息(对应 NET_CTRL_MONITORWALL_TVINFO) + public static final int NET_DEVSTATE_GET_ALL_POS = 0x1575; // 获取所有用户可用Pos设备配置信息(对应 NET_POS_ALL_INFO) + public static final int NET_DEVSTATE_GET_ROAD_LIST = 0x1576; // 获取城市及路段编码信息,哥伦比亚项目专用(对应 NET_ROAD_LIST_INFO) + public static final int NET_DEVSTATE_GET_HEAT_MAP = 0x1577; // 获取热度统计信息(对应 NET_QUERY_HEAT_MAP) + public static final int NET_DEVSTATE_GET_WORK_STATE = 0x1578; // 获取盒子工作状态信息(对应 NET_QUERY_WORK_STATE ) + public static final int NET_DEVSTATE_GET_WIRESSLESS_STATE = 0x1579; // 获取无线设备状态信息(对应 NET_GET_WIRELESS_DEVICE_STATE) + public static final int NET_DEVSTATE_GET_REDUNDANCE_POWER_INFO = 0x157a; // 获取冗余电源信息(对应 NET_GET_REDUNDANCE_POWER_INFO) + + + // 查询设备信息类型, 对应接口 CLIENT_QueryDevInfo + // 设备信息类型,对应CLIENT_QueryDevInfo接口 + public static final int NET_QUERY_DEV_STORAGE_NAMES = 0x01; // 查询设备的存储模块名列表 , pInBuf=NET_IN_STORAGE_DEV_NAMES *, pOutBuf=NET_OUT_STORAGE_DEV_NAMES * + public static final int NET_QUERY_DEV_STORAGE_INFOS = 0x02; // 查询设备的存储模块信息列表, pInBuf=NET_IN_STORAGE_DEV_INFOS*, pOutBuf= NET_OUT_STORAGE_DEV_INFOS * + public static final int NET_QUERY_RECENCY_JNNCTION_CAR_INFO = 0x03; // 查询最近的卡口车辆信息接口, pInBuf=NET_IN_GET_RECENCY_JUNCTION_CAR_INFO*, pOutBuf=NET_OUT_GET_RECENCY_JUNCTION_CAR_INFO* + public static final int NET_QUERY_LANES_STATE = 0x04; // 查询车道信息,pInBuf = NET_IN_GET_LANES_STATE , pOutBuf = NET_OUT_GET_LANES_STATE + public static final int NET_QUERY_DEV_FISHEYE_WININFO = 0x05; // 查询鱼眼窗口信息 , pInBuf= NET_IN_FISHEYE_WININFO*, pOutBuf=NET_OUT_FISHEYE_WININFO * + public static final int NET_QUERY_DEV_REMOTE_DEVICE_INFO = 0x06;; // 查询远程设备信息 , pInBuf= NET_IN_GET_DEVICE_INFO*, pOutBuf= NET_OUT_GET_DEVICE_INFO * + public static final int NET_QUERY_SYSTEM_INFO = 0x07; // 查询设备系统信息 , pInBuf= NET_IN_SYSTEM_INFO*, pOutBuf= NET_OUT_SYSTEM_INFO* + public static final int NET_QUERY_REG_DEVICE_NET_INFO = 0x08; // 查询主动注册设备的网络连接 , pInBuf=NET_IN_REGDEV_NET_INFO * , pOutBuf=NET_OUT_REGDEV_NET_INFO * + public static final int NET_QUERY_DEV_THERMO_GRAPHY_PRESET = 0x09; // 查询热成像预设信息 , pInBuf= NET_IN_THERMO_GET_PRESETINFO*, pOutBuf= NET_OUT_THERMO_GET_PRESETINFO * + public static final int NET_QUERY_DEV_THERMO_GRAPHY_OPTREGION = 0x0a; // 查询热成像感兴趣区域信息,pInBuf= NET_IN_THERMO_GET_OPTREGION*, pOutBuf= NET_OUT_THERMO_GET_OPTREGION * + public static final int NET_QUERY_DEV_THERMO_GRAPHY_EXTSYSINFO = 0x0b; // 查询热成像外部系统信息, pInBuf= NET_IN_THERMO_GET_EXTSYSINFO*, pOutBuf= NET_OUT_THERMO_GET_EXTSYSINFO * + public static final int NET_QUERY_DEV_RADIOMETRY_POINT_TEMPER = 0x0c; // 查询测温点的参数值, pInBuf= NET_IN_RADIOMETRY_GETPOINTTEMPER*, pOutBuf= NET_OUT_RADIOMETRY_GETPOINTTEMPER * + public static final int NET_QUERY_DEV_RADIOMETRY_TEMPER = 0x0d; // 查询测温项的参数值, pInBuf= NET_IN_RADIOMETRY_GETTEMPER*, pOutBuf= NET_OUT_RADIOMETRY_GETTEMPER * + public static final int NET_QUERY_GET_CAMERA_STATE = 0x0e; // 获取摄像机状态, pInBuf= NET_IN_GET_CAMERA_STATEINFO*, pOutBuf= NET_OUT_GET_CAMERA_STATEINFO * + public static final int NET_QUERY_GET_REMOTE_CHANNEL_AUDIO_ENCODE = 0x0f; // 获取远程通道音频编码方式, pInBuf= NET_IN_GET_REMOTE_CHANNEL_AUDIO_ENCODEINFO*, pOutBuf= NET_OUT_GET_REMOTE_CHANNEL_AUDIO_ENCODEINFO * + public static final int NET_QUERY_GET_COMM_PORT_INFO = 0x10; // 获取设备串口信息, pInBuf=NET_IN_GET_COMM_PORT_INFO* , pOutBuf=NET_OUT_GET_COMM_PORT_INFO* + public static final int NET_QUERY_GET_LINKCHANNELS = 0x11; // 查询某视频通道的关联通道列表,pInBuf=NET_IN_GET_LINKCHANNELS* , pOutBuf=NET_OUT_GET_LINKCHANNELS* + public static final int NET_QUERY_GET_VIDEOOUTPUTCHANNELS = 0x12; // 获取解码通道数量统计信息, pInBuf=NET_IN_GET_VIDEOOUTPUTCHANNELS*, pOutBuf=NET_OUT_GET_VIDEOOUTPUTCHANNELS* + public static final int NET_QUERY_GET_VIDEOINFO = 0x13; // 获取解码通道信息, pInBuf=NET_IN_GET_VIDEOINFO*, pOutBuf=NET_OUT_GET_VIDEOINFO* + public static final int NET_QUERY_GET_ALLLINKCHANNELS = 0x14; // 查询全部视频关联通道列表,pInBuf=NET_IN_GET_ALLLINKCHANNELS* , pOutBuf=NET_OUT_GET_ALLLINKCHANNELS* + public static final int NET_QUERY_VIDEOCHANNELSINFO = 0x15; // 查询视频通道信息,pInBuf=NET_IN_GET_VIDEOCHANNELSINFO* , pOutBuf=NET_OUT_GET_VIDEOCHANNELSINFO* + public static final int NET_QUERY_TRAFFICRADAR_VERSION = 0x16; // 查询雷达设备版本,pInBuf=NET_IN_TRAFFICRADAR_VERSION* , pOutBuf=NET_OUT_TRAFFICRADAR_VERSION* + public static final int NET_QUERY_WORKGROUP_NAMES = 0x17; // 查询所有的工作目录组名,pInBuf=NET_IN_WORKGROUP_NAMES* , pOutBuf=NET_OUT_WORKGROUP_NAMES* + public static final int NET_QUERY_WORKGROUP_INFO = 0x18; // 查询工作组信息,pInBuf=NET_IN_WORKGROUP_INFO* , pOutBuf=NET_OUT_WORKGROUP_INFO* + public static final int NET_QUERY_WLAN_ACCESSPOINT = 0x19; // 查询无线网络接入点信息,pInBuf=NET_IN_WLAN_ACCESSPOINT* , pOutBuf=NET_OUT_WLAN_ACCESSPOINT* + public static final int NET_QUERY_GPS_INFO = 0x1a; // 查询设备GPS信息,pInBuf=NET_IN_DEV_GPS_INFO* , pOutBuf=NET_OUT_DEV_GPS_INFO* + public static final int NET_QUERY_IVS_REMOTE_DEVICE_INFO = 0x1b; // 查询IVS的前端设备所关联的远程设备信息, pInBuf = NET_IN_IVS_REMOTE_DEV_INFO*, pOutBuf = NET_OUT_IVS_REMOTE_DEV_INFO* + + /////////////////////////////////// 矩阵 /////////////////////////////////////// + + public static final int NET_MATRIX_INTERFACE_LEN = 16; // 信号接口名称长度 + public static final int NET_MATRIX_MAX_CARDS = 128; // 矩阵子卡最大数量 + public static final int NET_SPLIT_PIP_BASE = 1000; // 分割模式画中画的基础值 + public static final int NET_MAX_SPLIT_MODE_NUM = 64; // 最大分割模式数 + public static final int NET_MATRIX_MAX_CHANNEL_IN = 1500; // 矩阵最大输入通道数 + public static final int NET_MATRIX_MAX_CHANNEL_OUT = 256; // 矩阵最大输出通道数 + public static final int NET_DEVICE_NAME_LEN = 64; // 设备名称长度 + public static final int NET_MAX_CPU_NUM = 16; // 最大CPU数量 + public static final int NET_MAX_FAN_NUM = 16; // 最大风扇数量 + public static final int NET_MAX_POWER_NUM = 16; // 最大电源数量 + public static final int NET_MAX_BATTERY_NUM = 16; // 最大电池数量 + public static final int NET_MAX_TEMPERATURE_NUM = 256; // 最大温度传感器数量 + public static final int NET_MAX_ISCSI_NAME_LEN = 128; // ISCSI名称长度 + public static final int NET_VERSION_LEN = 64; // 版本信息长度 + public static final int NET_MAX_STORAGE_PARTITION_NUM = 32; // 存储分区最大数量 + public static final int NET_STORAGE_MOUNT_LEN = 64; // 挂载点长度 + public static final int NET_STORAGE_FILE_SYSTEM_LEN = 16; // 文件系统名称长度 + public static final int NET_MAX_MEMBER_PER_RAID = 32; // RAID成员最大数量 + public static final int NET_DEV_ID_LEN_EX = 128; // 设备ID最大长度 + public static final int NET_MAX_BLOCK_NUM = 32; // 最大区块数量 + public static final int NET_MAX_SPLIT_WINDOW = 128; // 最大分割窗口数量 + public static final int NET_FILE_TYPE_LEN = 64; // 文件类型长度 + public static final int NET_DEV_ID_LEN = 128; // 设备ID最大长度 + public static final int NET_DEV_NAME_LEN = 128; // 设备名称最大长度 + public static final int NET_TSCHE_DAY_NUM = 8; // 时间表第一维大小, 表示天数 + public static final int NET_TSCHE_SEC_NUM = 6; // 时间表第二维大小, 表示时段数 + public static final int NET_SPLIT_INPUT_NUM = 256; // 司法设备二级切换时第一级split支持的输入通道数 + + public static final String NET_DEVICE_ID_LOCAL = "Local"; // 本地设备ID + public static final String NET_DEVICE_ID_REMOTE = "Remote"; // 远程设备ID + public static final String NET_DEVICE_ID_UNIQUE = "Unique"; // 设备内统一编号 + + //其他定义 + public static final int NET_MAX_NAME_LEN = 16; // 通用名字字符串长度 + public static final int NET_MAX_PERSON_ID_LEN = 32; // 人员id最大长度 + public static final int NET_MAX_PERSON_IMAGE_NUM = 48; // 每个人员对应的最大人脸图片数 + public static final int NET_MAX_PROVINCE_NAME_LEN = 64; // 省份名称最大长度 + public static final int NET_MAX_CITY_NAME_LEN = 64; // 城市名称最大长度 + public static final int NET_MAX_PERSON_NAME_LEN = 64; // 人员名字最大长度 + public static final int MAX_FACE_AREA_NUM = 8; // 最大人脸区域个数 + public static final int MAX_PATH = 260; + public static final int MAX_FACE_DB_NUM = 8; // 最大人脸数据库个数 + public static final int MAX_GOURP_NUM = 128; // 人脸库最大个数 + + public static final int MAX_FIND_COUNT = 20; + public static final int NET_MAX_POLYGON_NUM = 16; // 多边形最大顶点个数 + public static final int NET_MAX_CANDIDATE_NUM = 50; // 人脸识别最大匹配数 + public static final int MAX_POLYGON_NUM = 20; // 视频分析设备区域顶点个数上限 + public static final int MAX_CALIBRATEBOX_NUM = 10; // 智能分析校准框个数上限 + public static final int MAX_NAME_LEN = 128; // 通用名字字符串长度 + public static final int MAX_EXCLUDEREGION_NUM = 10; // 智能分析检测区域中需要排除的区域个数上限 + public static final int MAX_OBJECT_LIST_SIZE = 16; // 视频分析设备支持的检测物体类型列表个数上限 + public static final int MAX_SPECIALDETECT_NUM = 10; // 智能分析特殊检测区域上限 + public static final int MAX_OBJECT_ATTRIBUTES_SIZE = 16; // 视频分析设备支持的检测物体属性类型列表个数上限 + public static final int MAX_CATEGORY_TYPE_NUMBER = 128; // 子类别类型数 + public static final int MAX_ANALYSE_MODULE_NUM = 16; // 视频分析设备最大检测模块个数 + public static final int MAX_LOG_PATH_LEN = 260; // 日志路径名最大长度 + public static final int MAX_CHANNELNAME_LEN = 64; // 最大通道名称长度 + public static final int MAX_VIDEO_CHANNEL_NUM = 256; // 最大通道数256 + public static final int MAX_PSTN_SERVER_NUM = 8; // 最大报警电话服务器数 + public static final int MAX_TIME_SCHEDULE_NUM = 8; // 时间表元素个数 + public static final int MAX_REC_TSECT = 6; // 录像时间段个数 + public static final int MAX_REC_TSECT_EX = 10; // 录像时间段扩展个数 + public static final int MAX_CHANNEL_COUNT = 16; + public static final int MAX_ACCESSCONTROL_NUM = 8; // 最大门禁操作的组合数 + public static final int MAX_DBKEY_NUM = 64; // 数据库关键字最大值 + public static final int MAX_SUMMARY_LEN = 1024; // 叠加到JPEG图片的摘要信息最大长度 + public static final int WEEK_DAY_NUM = 7; // 一周的天数 + public static final int NET_MAX_FACEDETECT_FEATURE_NUM = 32; // 人脸特征最大个数 + public static final int NET_MAX_OBJECT_LIST = 16; // 智能分析设备检测到的物体ID个数上限 + public static final int NET_MAX_RULE_LIST = 16; // 智能分析设备规则个数上限 + public static final int NET_MAX_DETECT_REGION_NUM = 20; // 规则检测区域最大顶点数 + public static final int NET_MAX_DETECT_LINE_NUM = 20; // 规则检测线最大顶点数 + public static final int NET_MAX_TRACK_LINE_NUM = 20; // 物体运动轨迹最大顶点数 + public static final int NET_MACADDR_LEN = 40; // MAC地址字符串长度 + public static final int NET_DEV_TYPE_LEN = 32; // 设备型号字符串(如"IPC-F725")长度 + public static final int NET_DEV_SERIALNO_LEN = 48; // 序列号字符串长度 + public static final int NET_MAX_URL_LEN = 128; // URL字符串长度 + public static final int NET_MAX_STRING_LEN = 128; + public static final int NET_MACHINE_NAME_NUM = 64; // 机器名称长度 + public static final int NET_USER_NAME_LENGTH_EX = 16; // 用户名长度 + public static final int NET_USER_NAME_LENGTH = 8; // 用户名长度 + public static final int NET_USER_PSW_LENGTH = 8; // 用户密码长度 + public static final int NET_EVENT_NAME_LEN = 128; // 事件名称长度 + public static final int NET_MAX_LANE_NUM = 8; // 视频分析设备每个通道对应车道数上限 + public static final int MAX_DRIVING_DIR_NUM = 16; // 车道行驶方向最大个数 + public static final int FLOWSTAT_ADDR_NAME = 16; // 上下行地点名长 + public static final int NET_MAX_DRIVINGDIRECTION = 256; // 行驶方向字符串长度 + public static final int COMMON_SEAT_MAX_NUMBER = 8; // 默认检测最大座驾个数 + public static final int NET_MAX_ATTACHMENT_NUM = 8; // 最大车辆物件数量 + public static final int NET_MAX_ANNUUALINSPECTION_NUM = 8; // 最大年检标识位置 + public static final int NET_MAX_EVENT_PIC_NUM = 6; // 最大原始图片张数 + public static final int NET_COMMON_STRING_32 = 32; // 通用字符串长度32 + public static final int NET_COMMON_STRING_16 = 16; // 通用字符串长度16 + public static final int NET_COMMON_STRING_64 = 64; // 通用字符串长度64 + public static final int NET_COMMON_STRING_128 = 128; // 通用字符串长度128 + public static final int NET_COMMON_STRING_256 = 256; // 通用字符串长度256 + public static final int NET_COMMON_STRING_512 = 512; // 通用字符串长度512 + public static final int NET_COMMON_STRING_1024 = 1024; // 通用字符串长度1024 + public static final int NET_COMMON_STRING_2048 = 2048; // 通用字符串长度2048 + public static final int MAX_VIDEOSTREAM_NUM = 4; // 最大码流个数 + public static final int MAX_VIDEO_COVER_NUM = 16; // 最大遮挡区域个数 + public static final int MAX_VIDEO_IN_ZOOM = 32; // 单通道最大变速配置个数 + public static final int NET_EVENT_CARD_LEN = 36; // 卡片名称长度 + public static final int NET_EVENT_MAX_CARD_NUM = 16; // 事件上报信息包含最大卡片个数 + public static final int MAX_STATUS_NUM = 16; // 交通设备状态最大个数 + public static final int NET_MAX_CHANMASK = 64; // 通道掩码最大值 + public static final int NET_CHAN_NAME_LEN = 32; // 通道名长度,DVR DSP能力限制,最多32字节 + + public static final int NET_NEW_MAX_RIGHT_NUM = 1024; // 用户权限个数上限 + public static final int NET_MAX_GROUP_NUM = 20; // 用户组个数上限 + public static final int NET_MAX_USER_NUM = 200; // 用户个数上限 + public static final int NET_RIGHT_NAME_LENGTH = 32; // 权限名长度 + public static final int NET_MEMO_LENGTH = 32; // 备注长度 + public static final int NET_NEW_USER_NAME_LENGTH = 128; // 用户名长度 + public static final int NET_NEW_USER_PSW_LENGTH = 128; // 密码 + + public static final int AV_CFG_Device_ID_Len = 64; // 设备ID长度 + public static final int AV_CFG_IP_Address_Len = 32; // IP 长度 + public static final int AV_CFG_Protocol_Len = 32; // 协议名长度 + public static final int AV_CFG_User_Name_Len = 64; // 用户名长度 + public static final int AV_CFG_Password_Len = 64; // 密码长度 + public static final int AV_CFG_Serial_Len = 32; // 序列号长度 + public static final int AV_CFG_Device_Class_Len = 16; // 设备类型长度 + public static final int AV_CFG_Device_Type_Len = 32; // 设备具体型号长度 + public static final int AV_CFG_Device_Name_Len = 128; // 机器名称 + public static final int AV_CFG_Address_Len = 128; // 机器部署地点 + public static final int AV_CFG_Max_Path = 260; // 路径长度 + public static final int AV_CFG_Group_Name_Len = 64; // 分组名称长度 + public static final int AV_CFG_DeviceNo_Len = 32; // 设备编号长度 + public static final int AV_CFG_Group_Memo_Len = 128; // 分组说明长度 + public static final int AV_CFG_Max_Channel_Num = 1024; // 最大通道数量 + public static final int MAX_DEVICE_NAME_LEN = 64; // 机器名称 + public static final int MAX_DEV_ID_LEN_EX = 128; // 设备ID最大长度 + public static final int MAX_PATH_STOR = 240; // 远程目录的长度 + public static final int MAX_REMOTE_DEV_NUM = 256; // 最大远程设备数量 + public static final int NET_MAX_PLATE_NUMBER_LEN = 32; // 车牌字符长度 + public static final int NET_MAX_AUTHORITY_LIST_NUM = 16; // 权限列表最大个数 + public static final int NET_MAX_ALARMOUT_NUM_EX = 32; //报警输出口个数上限扩展 + public static final int NET_MAX_VIDEO_IN_NUM_EX = 32; //视频输入口个数上限扩展 + public static final int NET_MAX_SAERCH_IP_NUM = 256; // 最大搜索IP个数 + public static final int NET_MAX_POS_MAC_NUM = 8; // 刷卡机Mac码最大长度 + public static final int NET_MAX_BUSCARD_NUM = 64; // 公交卡号最大长度 + public static final int NET_STORAGE_NAME_LEN = 128; // 存储设备名称长度 + + public static final int NET_MAX_DOOR_NUM = 32; // 最大有权限门禁数目 + public static final int NET_MAX_TIMESECTION_NUM = 32; // 最大有效时间段数目 + public static final int NET_MAX_CARDNAME_LEN = 64; // 门禁卡命名最大长度 + public static final int NET_MAX_CARDNO_LEN = 32; // 门禁卡号最大长度 + public static final int NET_MAX_USERID_LEN = 32; // 门禁卡用户ID最大长度 + public static final int NET_MAX_IC_LEN = 32; // 身份证最大长度 + public static final int NET_MAX_QRCODE_LEN = 128; // QRCode 最大长度 + public static final int NET_MAX_CARD_INFO_LEN = 256; // 卡号信息最大长度 + public static final int NET_MAX_SIM_LEN = 16; // SIM卡的值的最大长度 + public static final int NET_MAX_DISKNUM = 256; // 最大硬盘个数 + public static final int MAX_FACE_DATA_NUM = 20; // 人脸模版最大个数 + public static final int MAX_FINGERPRINT_NUM = 10; // 最大指纹个数 + public static final int MAX_FACE_DATA_LEN = 2 * 1024; // 人脸模版数据最大长度 + public static final int MAX_COMMON_STRING_8 = 8; // 通用字符串长度8 + public static final int MAX_COMMON_STRING_16 = 16; // 通用字符串长度16 + public static final int MAX_COMMON_STRING_32 = 32; // 通用字符串长度32 + public static final int MAX_COMMON_STRING_64 = 64; // 通用字符串长度64 + public static final int MAX_COMMON_STRING_128 = 128; // 通用字符串长度128 + public static final int MAX_USER_NAME_LEN = 128; // 最大用户名长度 + public static final int MAX_ROOMNUM_COUNT = 32; // 房间最大个数 + public static final int MAX_FACE_COUTN = 20; // 人脸模板数据最大个数 + public static final int MAX_WINDOWS_COUNT = 16; // 诱导屏最大窗口个数 + + public static final int CFG_COMMON_STRING_16 = 16; // 通用字符串长度16 + public static final int CFG_COMMON_STRING_32 = 32; // 通用字符串长度16 + public static final int CFG_COMMON_STRING_256 = 256; // 通用字符串长度256 + + public static final int MAX_COILCONFIG = 3; // 智能交通车检器线圈配置上限 + public static final int MAX_DETECTOR = 6; // 智能交通车检器配置上限 + public static final int MAX_VIOLATIONCODE = 16; // 智能交通违章代码长度上限 + public static final int MAX_LANE_CONFIG_NUMBER = 32; // 车道最大个数 + public static final int MAX_VIOLATIONCODE_DESCRIPT = 64; // 智能交通违章代码长度上限 + public static final int MAX_ROADWAYNO = 128; // 道路编号 由32个数字和字母构成 + public static final int MAX_PRIORITY_NUMBER = 256; // 违章优先级包含违章最大个数 + public static final int MAX_DRIVINGDIRECTION = 256; // 行驶方向字符串长度 + + public static final int MAX_OSD_CUSTOM_SORT_NUM = 8; + public static final int MAX_OSD_CUSTOM_SORT_ELEM_NUM = 8; + public static final int MAX_OSD_CUSTOM_GENERAL_NUM = 8; + public static final int MAX_OSD_ITEM_ATTR_NUM = 8; + public static final int MAX_PRE_POX_STR_LEN = 32; + public static final int MAX_OSD_CUSTOM_NAME_LEN = 32; + public static final int MAX_OSD_CUSTOM_VALUE_LEN = 256; + public static final int MAX_CONF_CHAR = 256; + public static final int MAX_IVS_EVENT_NUM = 256; + public static final int MAX_QUERY_USER_NUM = 4; // 最大查询用户个数 + public static final int MAX_DEVICE_ADDRESS = 256; // TrafficSnapshot智能交通设备地址 + public static final int MAX_STORAGE_NUM = 8; // 存储设备最大个数 + public static final int MAX_PARTITION_NUM = 8; // 最大分区个数 + public static final int MAX_SCADA_POINT_LIST_INFO_NUM = 256; // 最大点位表路径个数 + public static final int MAX_SCADA_POINT_LIST_ALARM_INFO_NUM = 256; // 最大点位表报警个数 + public static final int MAX_LABEL_ARRAY = 1024; + + public static final int MAX_DELIVERY_FILE_NUM = 128; // 最大投放文件数量 + public static final int DELIVERY_FILE_URL_LEN = 128; // 投放文件的URL长度 + + public static final int MAX_COMMON_STRING_512 = 512; // 通用字符串长度512 + public static final int MAX_RFIDELETAG_CARDID_LEN = 16; // RFID 电子车牌标签信息中卡号最大长度 + public static final int MAX_RFIDELETAG_DATE_LEN = 16; // RFID 电子车牌标签信息中时间最大长度 + public static final int MAX_REPEATENTERROUTE_NUM = 12; //反潜路径个数 + public static final int ECK_SCREEN_NUM_MAX = 8; // 智能停车系统出入口机最大屏数量 + + public static final int NET_COUNTRY_LENGTH = 3; // 国家缩写长度 + + // 矩阵子卡类型, 多种类型可以组合 + public static final int NET_MATRIX_CARD_MAIN = 0x10000000; // 主卡 + public static final int NET_MATRIX_CARD_INPUT = 0x00000001; // 输入卡 + public static final int NET_MATRIX_CARD_OUTPUT = 0x00000002; // 输出卡 + public static final int NET_MATRIX_CARD_ENCODE = 0x00000004; // 编码卡 + public static final int NET_MATRIX_CARD_DECODE = 0x00000008; // 解码卡 + public static final int NET_MATRIX_CARD_CASCADE = 0x00000010; // 级联卡 + public static final int NET_MATRIX_CARD_INTELLIGENT = 0x00000020; // 智能卡 + public static final int NET_MATRIX_CARD_ALARM = 0x00000040; // 报警卡 + public static final int NET_MATRIX_CARD_RAID = 0x00000080; // 硬Raid卡 + public static final int NET_MATRIX_CARD_NET_DECODE = 0x00000100; // 网络解码卡 + + public static final int RESERVED_TYPE_FOR_INTEL_BOX = 0x00000001; + public static final int RESERVED_TYPE_FOR_COMMON = 0x00000010; + + /************************************************************************ + ** 结构体 + ***********************************************************************/ + // 设置登入时的相关参数 + public static class NET_PARAM extends Structure + { + public int nWaittime; // 等待超时时间(毫秒为单位),为0默认5000ms + public int nConnectTime; // 连接超时时间(毫秒为单位),为0默认1500ms + public int nConnectTryNum; // 连接尝试次数,为0默认1次 + public int nSubConnectSpaceTime; // 子连接之间的等待时间(毫秒为单位),为0默认10ms + public int nGetDevInfoTime; // 获取设备信息超时时间,为0默认1000ms + public int nConnectBufSize; // 每个连接接收数据缓冲大小(字节为单位),为0默认250*1024 + public int nGetConnInfoTime; // 获取子连接信息超时时间(毫秒为单位),为0默认1000ms + public int nSearchRecordTime; // 按时间查询录像文件的超时时间(毫秒为单位),为0默认为3000ms + public int nsubDisconnetTime; // 检测子链接断线等待时间(毫秒为单位),为0默认为60000ms + public byte byNetType; // 网络类型, 0-LAN, 1-WAN + public byte byPlaybackBufSize; // 回放数据接收缓冲大小(M为单位),为0默认为4M + public byte bDetectDisconnTime; // 心跳检测断线时间(单位为秒),为0默认为60s,最小时间为2s + public byte bKeepLifeInterval; // 心跳包发送间隔(单位为秒),为0默认为10s,最小间隔为2s + public int nPicBufSize; // 实时图片接收缓冲大小(字节为单位),为0默认为2*1024*1024 + public byte[] bReserved = new byte[4]; // 保留字段字段 + } + + // 设备信息 + public static class NET_DEVICEINFO extends Structure { + public byte[] sSerialNumber = new byte[NET_SERIALNO_LEN]; // 序列号 + public byte byAlarmInPortNum; // DVR报警输入个数 + public byte byAlarmOutPortNum; // DVR报警输出个数 + public byte byDiskNum; // DVR硬盘个数 + public byte byDVRType; // DVR类型, 见枚举NET_DEV_DEVICE_TYPE + public union union = new union(); + public static class union extends Union { + public byte byChanNum; // DVR通道个数 + public byte byLeftLogTimes; // 当登陆失败原因为密码错误时,通过此参数通知用户,剩余登陆次数,为0时表示此参数无效 + } + } + + // 设备信息扩展/////////////////////////////////////////////////// + public static class NET_DEVICEINFO_Ex extends Structure { + public byte[] sSerialNumber = new byte[NET_SERIALNO_LEN]; // 序列号 + public int byAlarmInPortNum; // DVR报警输入个数 + public int byAlarmOutPortNum; // DVR报警输出个数 + public int byDiskNum; // DVR硬盘个数 + public int byDVRType; // DVR类型,见枚举NET_DEVICE_TYPE + public int byChanNum; // DVR通道个数 + public byte byLimitLoginTime; // 在线超时时间,为0表示不限制登陆,非0表示限制的分钟数 + public byte byLeftLogTimes; // 当登陆失败原因为密码错误时,通过此参数通知用户,剩余登陆次数,为0时表示此参数无效 + public byte[] bReserved = new byte[2]; // 保留字节,字节对齐 + public int byLockLeftTime; // 当登陆失败,用户解锁剩余时间(秒数), -1表示设备未设置该参数 + public byte[] Reserved = new byte[24]; // 保留 + } + + // 对应接口 CLIENT_LoginEx2///////////////////////////////////////////////////////// + public static class EM_LOGIN_SPAC_CAP_TYPE extends Structure { + public static final int EM_LOGIN_SPEC_CAP_TCP = 0; // TCP登陆, 默认方式 + public static final int EM_LOGIN_SPEC_CAP_ANY = 1; // 无条件登陆 + public static final int EM_LOGIN_SPEC_CAP_SERVER_CONN = 2; // 主动注册的登入 + public static final int EM_LOGIN_SPEC_CAP_MULTICAST = 3; // 组播登陆 + public static final int EM_LOGIN_SPEC_CAP_UDP = 4; // UDP方式下的登入 + public static final int EM_LOGIN_SPEC_CAP_MAIN_CONN_ONLY = 6; // 只建主连接下的登入 + public static final int EM_LOGIN_SPEC_CAP_SSL = 7; // SSL加密方式登陆 + + public static final int EM_LOGIN_SPEC_CAP_INTELLIGENT_BOX = 9; // 登录智能盒远程设备 + public static final int EM_LOGIN_SPEC_CAP_NO_CONFIG = 10; // 登录设备后不做取配置操作 + public static final int EM_LOGIN_SPEC_CAP_U_LOGIN = 11; // 用U盾设备的登入 + public static final int EM_LOGIN_SPEC_CAP_LDAP = 12; // LDAP方式登录 + public static final int EM_LOGIN_SPEC_CAP_AD = 13; // AD(ActiveDirectory)登录方式 + public static final int EM_LOGIN_SPEC_CAP_RADIUS = 14; // Radius 登录方式 + public static final int EM_LOGIN_SPEC_CAP_SOCKET_5 = 15; // Socks5登陆方式 + public static final int EM_LOGIN_SPEC_CAP_CLOUD = 16; // 云登陆方式 + public static final int EM_LOGIN_SPEC_CAP_AUTH_TWICE = 17; // 二次鉴权登陆方式 + public static final int EM_LOGIN_SPEC_CAP_TS = 18; // TS码流客户端登陆方式 + public static final int EM_LOGIN_SPEC_CAP_P2P = 19; // 为P2P登陆方式 + public static final int EM_LOGIN_SPEC_CAP_MOBILE = 20; // 手机客户端登陆 + } + + // 时间 + public static class NET_TIME extends Structure { + public int dwYear; // 年 + public int dwMonth; // 月 + public int dwDay; // 日 + public int dwHour; // 时 + public int dwMinute; // 分 + public int dwSecond; // 秒 + + public NET_TIME() { + this.dwYear = 0; + this.dwMonth = 0; + this.dwDay = 0; + this.dwHour = 0; + this.dwMinute = 0; + this.dwSecond = 0; + } + + public void setTime(int year, int month, int day, int hour, int minute, int second) { + this.dwYear = year; + this.dwMonth= month; + this.dwDay= day; + this.dwHour=hour; + this.dwMinute=minute; + this.dwSecond=second; + } + + public NET_TIME(NET_TIME other) { + this.dwYear = other.dwYear; + this.dwMonth = other.dwMonth; + this.dwDay = other.dwDay; + this.dwHour = other.dwHour; + this.dwMinute = other.dwMinute; + this.dwSecond = other.dwSecond; + } + + //用于列表中显示 + public String toStringTime() { + return String.format("%02d/%02d/%02d %02d:%02d:%02d", dwYear, dwMonth, dwDay, dwHour, dwMinute, dwSecond); + } + + public String toString() { + return String.format("%02d%02d%02d%02d%02d%02d", dwYear, dwMonth, dwDay, dwHour, dwMinute, dwSecond); + } + } + + public static class NET_TIME_EX extends Structure + { + public int dwYear; // 年 + public int dwMonth; // 月 + public int dwDay; // 日 + public int dwHour; // 时 + public int dwMinute; // 分 + public int dwSecond; // 秒 + public int dwMillisecond; // 毫秒 + public int[] dwReserved = new int[2]; // 保留字段 + + public String toString() { + return dwYear + "/" + dwMonth + "/" + dwDay + " " + dwHour + ":" + dwMinute + ":" + 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_CFG_Rect extends Structure + { + public int nStructSize; + public int nLeft; + public int nTop; + public int nRight; + public int nBottom; + + public NET_CFG_Rect() + { + this.nStructSize = this.size(); + } + } + + // 颜色 + public static class NET_CFG_Color extends Structure + { + public int nStructSize; + public int nRed; // 红 + public int nGreen; // 绿 + public int nBlue; // 蓝 + public int nAlpha; // 透明 + + public NET_CFG_Color() + { + this.nStructSize = this.size(); + } + } + + // 编码物件-通道标题 + public static class NET_CFG_VideoWidgetChannelTitle extends Structure + { + public int nStructSize; + public int bEncodeBlend; // 叠加到主码流, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra1; // 叠加到辅码流1, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra2; // 叠加到辅码流2, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra3; // 叠加到辅码流3, 类型为BOOL, 取值0或者1 + public int bEncodeBlendSnapshot; // 叠加到抓图, 类型为BOOL, 取值0或者1 + public NET_CFG_Color stuFrontColor = new NET_CFG_Color(); // 前景色 + public NET_CFG_Color stuBackColor = new NET_CFG_Color(); // 背景色 + public NET_CFG_Rect stuRect = new NET_CFG_Rect(); // 区域, 坐标取值0~8191, 仅使用left和top值, 点(left,top)应和(right,bottom)设置成同样的点 + public int bPreviewBlend; // 叠加到预览视频, 类型为BOOL, 取值0或者1 + + public NET_CFG_VideoWidgetChannelTitle() + { + this.nStructSize = this.size(); + } + } + + // 编码物件-时间标题 + public static class NET_CFG_VideoWidgetTimeTitle extends Structure + { + public int nStructSize; + public int bEncodeBlend; // 叠加到主码流, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra1; // 叠加到辅码流1, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra2; // 叠加到辅码流2, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra3; // 叠加到辅码流3, 类型为BOOL, 取值0或者1 + public int bEncodeBlendSnapshot; // 叠加到抓图, 类型为BOOL, 取值0或者1 + public NET_CFG_Color stuFrontColor = new NET_CFG_Color(); // 前景色 + public NET_CFG_Color stuBackColor = new NET_CFG_Color(); // 背景色 + public NET_CFG_Rect stuRect = new NET_CFG_Rect(); // 区域, 坐标取值0~8191, 仅使用left和top值, 点(left,top)应和(right,bottom)设置成同样的点 + public int bShowWeek; // 是否显示星期, 类型为BOOL, 取值0或者1 + public int bPreviewBlend; // 叠加到预览视频, 类型为BOOL, 取值0或者1 + + public NET_CFG_VideoWidgetTimeTitle() + { + this.nStructSize = this.size(); + } + } + + // 编码物件-区域覆盖配置 + public static class NET_CFG_VideoWidgetCover extends Structure + { + public int nStructSize; + public int bEncodeBlend; // 叠加到主码流, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra1; // 叠加到辅码流1, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra2; // 叠加到辅码流2, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra3; // 叠加到辅码流3, 类型为BOOL, 取值0或者1 + public int bEncodeBlendSnapshot; // 叠加到抓图, 类型为BOOL, 取值0或者1 + public NET_CFG_Color stuFrontColor = new NET_CFG_Color(); // 前景色 + public NET_CFG_Color stuBackColor = new NET_CFG_Color(); // 背景色 + public NET_CFG_Rect stuRect = new NET_CFG_Rect(); // 区域, 坐标取值0~8191 + public int bPreviewBlend; // 叠加到预览视频, 类型为BOOL, 取值0或者1 + + public NET_CFG_VideoWidgetCover() + { + this.nStructSize = this.size(); + } + } + + public class EM_TITLE_TEXT_ALIGN + { + public static final int EM_TEXT_ALIGN_INVALID = 0; // 无效的对齐方式 + public static final int EM_TEXT_ALIGN_LEFT = 1; // 左对齐 + public static final int EM_TEXT_ALIGN_XCENTER = 2; // X坐标中对齐 + public static final int EM_TEXT_ALIGN_YCENTER = 3; // Y坐标中对齐 + public static final int EM_TEXT_ALIGN_CENTER = 4; // 居中 + public static final int EM_TEXT_ALIGN_RIGHT = 5; // 右对齐 + public static final int EM_TEXT_ALIGN_TOP = 6; // 按照顶部对齐 + public static final int EM_TEXT_ALIGN_BOTTOM = 7; // 按照底部对齐 + public static final int EM_TEXT_ALIGN_LEFTTOP = 8; // 按照左上角对齐 + public static final int EM_TEXT_ALIGN_CHANGELINE = 9; // 换行对齐 + } + + // 编码物件-自定义标题 + public static class NET_CFG_VideoWidgetCustomTitle extends Structure + { + public int nStructSize; + public int bEncodeBlend; // 叠加到主码流, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra1; // 叠加到辅码流1, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra2; // 叠加到辅码流2, 类型为BOOL, 取值0或者1 + public int bEncodeBlendExtra3; // 叠加到辅码流3, 类型为BOOL, 取值0或者1 + public int bEncodeBlendSnapshot; // 叠加到抓图, 类型为BOOL, 取值0或者1 + public NET_CFG_Color stuFrontColor = new NET_CFG_Color(); // 前景色 + public NET_CFG_Color stuBackColor = new NET_CFG_Color(); // 背景色 + public NET_CFG_Rect stuRect = new NET_CFG_Rect(); // 区域, 坐标取值0~8191, 仅使用left和top值, 点(left,top)应和(right,bottom)设置成同样的点 + public byte[] szText = new byte[NET_CFG_Custom_Title_Len];// 标题内容 + public int bPreviewBlend; // 叠加到预览视频, 类型为BOOL, 取值0或者1 + public byte[] szType = new byte[NET_CFG_Custom_TitleType_Len];// 标题类型 "Rtinfo" 实时刻录信息 "Custom" 自定义叠加、温湿度叠加 "Title" :片头信息 "Check" 校验码 + // 地理信息 "Geography" ATM卡号信息 "ATMCardInfo" 摄像机编号 "CameraID" + public int emTextAlign; // 标题对齐方式 (参见EM_TITLE_TEXT_ALIGN) + + public NET_CFG_VideoWidgetCustomTitle() + { + this.nStructSize = this.size(); + } + } + + // 编码物件-叠加传感器信息-叠加内容描述 + public static class NET_CFG_VideoWidgetSensorInfo_Description extends Structure + { + public int nStructSize; + public int nSensorID; // 需要描述的传感器的ID(即模拟量报警通道号) + public byte[] szDevID = new byte[CFG_COMMON_STRING_32]; // 设备ID + public byte[] szPointID = new byte[CFG_COMMON_STRING_32];// 测点ID + public byte[] szText = new byte[CFG_COMMON_STRING_256]; // 需要叠加的内容 + public NET_CFG_VideoWidgetSensorInfo_Description() + { + this.nStructSize = this.size(); + } + } + + // 编码物件-叠加传感器信息 + public static class NET_CFG_VideoWidgetSensorInfo extends Structure + { + public int nStructSize; + public int bPreviewBlend; // 叠加到预览视频, 类型为BOOL, 取值0或者1 + public int bEncodeBlend; // 叠加到主码流视频编码, 类型为BOOL, 取值0或者1 + public NET_CFG_Rect stuRect = new NET_CFG_Rect(); // 区域, 坐标取值0~8191 + public int nDescriptionNum; // 叠加区域描述数目 + public NET_CFG_VideoWidgetSensorInfo_Description[] stuDescription = (NET_CFG_VideoWidgetSensorInfo_Description[])new NET_CFG_VideoWidgetSensorInfo_Description().toArray(NET_CFG_Max_Description_Num);// 叠加区域描述信息 + + public NET_CFG_VideoWidgetSensorInfo() + { + this.nStructSize = this.size(); + } + } + + // 视频编码物件配置 + public static class NET_CFG_VideoWidget extends Structure + { + public int nStructSize; + public NET_CFG_VideoWidgetChannelTitle stuChannelTitle = new NET_CFG_VideoWidgetChannelTitle(); // 通道标题 + public NET_CFG_VideoWidgetTimeTitle stuTimeTitle = new NET_CFG_VideoWidgetTimeTitle(); // 时间标题 + public int nConverNum; // 区域覆盖数量 + public NET_CFG_VideoWidgetCover[] stuCovers = new NET_CFG_VideoWidgetCover[NET_CFG_Max_Video_Widget_Cover]; // 覆盖区域 + public int nCustomTitleNum; // 自定义标题数量 + public NET_CFG_VideoWidgetCustomTitle[] stuCustomTitle = new NET_CFG_VideoWidgetCustomTitle[NET_CFG_Max_Video_Widget_Custom_Title]; // 自定义标题 + public int nSensorInfo; // 传感器信息叠加区域数目 + public NET_CFG_VideoWidgetSensorInfo[] stuSensorInfo = new NET_CFG_VideoWidgetSensorInfo[NET_CFG_Max_Video_Widget_Sensor_Info]; // 传感器信息叠加区域信息 + public double fFontSizeScale; //叠加字体大小放大比例 + //当fFontSizeScale≠0时,nFontSize不起作用 + //当fFontSizeScale=0时,nFontSize起作用 + //设备默认fFontSizeScale=1.0 + //如果需要修改倍数,修改该值 + //如果需要按照像素设置,则置该值为0,nFontSize的值生效 + public int nFontSize; //叠加到主码流上的全局字体大小,单位 px. + //和fFontSizeScale共同作用 + public int nFontSizeExtra1; //叠加到辅码流1上的全局字体大小,单位 px + public int nFontSizeExtra2; //叠加到辅码流2上的全局字体大小,单位 px + public int nFontSizeExtra3; //叠加到辅码流3上的全局字体大小,单位 px + public int nFontSizeSnapshot; //叠加到抓图流上的全局字体大小, 单位 px + public int nFontSizeMergeSnapshot; //叠加到抓图流上合成图片的字体大小,单位 px + + public NET_CFG_VideoWidget() + { + this.nStructSize = this.size(); + for (int i = 0; i < stuCustomTitle.length; i++) { + stuCustomTitle[i] = new NET_CFG_VideoWidgetCustomTitle(); + } + + for (int i = 0; i < stuCovers.length; i++) { + stuCovers[i] = new NET_CFG_VideoWidgetCover(); + } + + for (int i = 0; i < stuSensorInfo.length; i++) { + stuSensorInfo[i] = new NET_CFG_VideoWidgetSensorInfo(); + } + } + } + + // 报警事件类型 NET_EVENT_VIDEOABNORMALDETECTION 对应的数据描述信息 + public static class ALARM_VIDEOABNORMAL_DETECTION_INFO extends Structure + { + public int dwSize; + public int nChannelID; // 通道号 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public int nType; // 检测类型,0-视频丢失, 1-视频遮挡, 2-画面冻结, 3-过亮, 4-过暗, 5-场景变化 + // 6-条纹检测 , 7-噪声检测 , 8-偏色检测 , 9-视频模糊检测 , 10-对比度异常检测 + // 11-视频运动, 12-视频闪烁, 13-视频颜色, 14-虚焦检测, 15-过曝检测 + public int nValue; // 检测值,值越高表示视频质量越差, GB30147定义 + public int nOccurrenceCount; // 规则被触发生次数 + + public ALARM_VIDEOABNORMAL_DETECTION_INFO() + { + this.dwSize = this.size(); + } + } + + // 停车发卡刷卡类型 + public static class NET_PARKING_CARD_TYPE extends Structure + { + public static final int NET_PARKING_CARD_TYPE_UNKNOWN = 0; + public static final int NET_PARKING_CARD_TYPE_SEND = 1; // 发卡 + public static final int NET_PARKING_CARD_TYPE_DETECT = 2; // 刷卡 + } + + // 报警事件类型 NET_ALARM_PARKING_CARD (停车刷卡事件)对应的数据描述信息 + public static class ALARM_PARKING_CARD extends Structure { + public int dwSize; + public int emType; // 类型, 参考 NET_PARKING_CARD_TYPE + public int dwCardNo; // 卡号 + public byte[] szPlate = new byte[NET_COMMON_STRING_16]; // 车牌 + + public ALARM_PARKING_CARD() { + this.dwSize = this.size(); + } + } + + // 报警事件类型 NET_ALARM_NEW_FILE 对应的数据描述信息 + public static class ALARM_NEW_FILE_INFO extends Structure + { + public int dwSize; + public int nChannel; // 抓图通道号 + public int nEventID; // 事件ID + public int dwEvent; // 事件类型 + public int FileSize; // 文件大小,单位是字节 + public int nIndex; // 事件源通道 + public int dwStorPoint; // 存储点 + public byte[] szFileName = new byte[128]; // 文件名 + + public ALARM_NEW_FILE_INFO() + { + this.dwSize = this.size(); + } + } + + // 人数越上限类型 + public static class EM_UPPER_LIMIT_TYPE extends Structure + { + public static final int EM_UPPER_LIMIT_TYPE_UNKNOWN = 0; + public static final int EM_UPPER_LIMIT_TYPE_ENTER_OVER = 1; // 进入越上限 + public static final int EM_UPPER_LIMIT_TYPE_EXIT_OVER = 2; // 出来越上限 + public static final int EM_UPPER_LIMIT_TYPE_INSIDE_OVER = 3; // 内部越上限 + } + + + // 事件类型 NET_ALARM_HUMAM_NUMBER_STATISTIC (人数量/客流量统计事件NumberStat对应的数据描述信息) + public static class ALARM_HUMAN_NUMBER_STATISTIC_INFO extends Structure + { + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventAction; // 事件动作,0-事件持续, 1-表示事件开始, 2-表示事件结束; + public int nNumber; // 区域内物体的个数 + public int nEnteredNumber; // 进入区域或者出入口内的物体个数 + public int nExitedNumber; // 出来区域或者出入口内的物体个数 + public int emUpperLimitType; // 人数越上限类型,参见EM_UPPER_LIMIT_TYPE定义 + public byte[] reserved = new byte[512]; // 预留 + } + + /////////////////////////////////智能支持///////////////////////////////// + //物体对应图片文件信息 + public static class NET_PIC_INFO extends Structure + { + public int dwOffSet; //文件在二进制数据块中的偏移位置,单位:字节 + public int dwFileLenth; //文件大小,单位:字节 + public short wWidth; //图片宽度,单位:像素 + public short wHeight; //图片高度,单位:像素 + public Pointer pszFilePath; //鉴于历史原因,该成员只在事件上报时有效, char * + // 文件路径 + // 用户使用该字段时需要自行申请空间进行拷贝保存 + public byte bIsDetected; //图片是否算法检测出来的检测过的提交识别服务器时, + //则不需要再时检测定位抠图,1:检测过的,0:没有检测过 + public byte[] bReserved = new byte[7];//12<--16 + public NET_POINT stuPoint; // 小图左上角在大图的位置,使用绝对坐标系 + } + + // 人员类型 + public static class EM_PERSON_TYPE extends Structure + { + public static final int PERSON_TYPE_UNKNOWN = 0; + public static final int PERSON_TYPE_NORMAL = 1; //普通人员 + public static final int PERSON_TYPE_SUSPICION = 2; //嫌疑人员 + } + + // 证件类型 + public static class EM_CERTIFICATE_TYPE extends Structure + { + public static final int CERTIFICATE_TYPE_UNKNOWN = 0; + public static final int CERTIFICATE_TYPE_IC = 1; //身份证 + public static final int CERTIFICATE_TYPE_PASSPORT = 2; //护照 + } + + //人员信息 + public static class FACERECOGNITION_PERSON_INFO extends Structure + { + public byte[] szPersonName = new byte[NET_MAX_NAME_LEN]; // 姓名,此参数作废 + public short wYear; // 出生年,作为查询条件时,此参数填0,则表示此参数无效 + public byte byMonth; // 出生月,作为查询条件时,此参数填0,则表示此参数无效 + public byte byDay; // 出生日,作为查询条件时,此参数填0,则表示此参数无效 + public byte[] szID = new byte[NET_MAX_PERSON_ID_LEN]; // 人员唯一标示(身份证号码,工号,或其他编号) + public byte bImportantRank; // 人员重要等级,1~10,数值越高越重要,作为查询条件时,此参数填0,则表示此参数无效 + public byte bySex; // 性别,1-男,2-女,作为查询条件时,此参数填0,则表示此参数无效 + public short wFacePicNum; // 图片张数 + public NET_PIC_INFO[] szFacePicInfo = (NET_PIC_INFO[])new NET_PIC_INFO().toArray(NET_MAX_PERSON_IMAGE_NUM);//当前人员对应的图片信息 + public byte byType; // 人员类型,详见 EM_PERSON_TYPE + public byte byIDType; // 证件类型,详见EM_CERTIFICATE_TYPE + public byte[] bReserved1 = new byte[2]; // 字节对齐 + public byte[] szProvince = new byte[NET_MAX_PROVINCE_NAME_LEN]; // 省份 + public byte[] szCity = new byte[NET_MAX_CITY_NAME_LEN]; // 城市 + public byte[] szPersonNameEx = new byte[NET_MAX_PERSON_NAME_LEN]; // 姓名,因存在姓名过长,16字节无法存放问题,故增加此参数, + public byte[] szUID = new byte[NET_MAX_PERSON_ID_LEN]; // 人员唯一标识符,首次由服务端生成,区别于ID字段 + // 修改,删除操作时必填 + public byte[] szCountry = new byte[NET_COUNTRY_LENGTH]; // 国籍,符合ISO3166规范 + public byte byIsCustomType; // 人员类型是否为自定义: 0 使用Type规定的类型 1 自定义,使用szPersonName字段 + public Pointer pszComment; // 备注信息 + public Pointer pszGroupID; // 人员所属组ID + public Pointer pszGroupName; // 人员所属组名 + public Pointer pszFeatureValue; // 人脸特征 + public byte bGroupIdLen; // pszGroupID的长度 + public byte bGroupNameLen; // pszGroupName的长度 + public byte bFeatureValueLen; // pszFeatureValue的长度 + public byte[] bReserved = new byte[5]; + } + + ///////////////////////////////////人脸识别模块相关结构体/////////////////////////////////////// + public static class NET_UID_CHAR extends Structure + { + public byte[] szUID = new byte[NET_MAX_PERSON_ID_LEN]; //UID内容 + } + + //人脸识别数据库操作 + public static class EM_OPERATE_FACERECONGNITIONDB_TYPE + { + public static final int NET_FACERECONGNITIONDB_UNKOWN = 0; + public static final int NET_FACERECONGNITIONDB_ADD = 1; // 添加人员信息和人脸样本,如果人员已经存在,图片数据和原来的数据合并 + public static final int NET_FACERECONGNITIONDB_DELETE = 2; // 删除人员信息和人脸样本 + public static final int NET_FACERECONGNITIONDB_MODIFY = 3; // 修改人员信息和人脸样本,人员的UID标识必填 + public static final int NET_FACERECONGNITIONDB_DELETE_BY_UID = 4; // 通过UID删除人员信息和人脸样本 + } + + //CLIENT_OperateFaceRecognitionDB接口输入参数 + public static class NET_IN_OPERATE_FACERECONGNITIONDB extends Structure + { + public int dwSize; + public int emOperateType; // 操作类型, 取 EM_OPERATE_FACERECONGNITIONDB_TYPE 中的值 + public FACERECOGNITION_PERSON_INFO stPersonInfo; // 人员信息 + // emOperateType 操作类型为 ET_FACERECONGNITIONDB_DELETE_BY_UID 时使用,stPeronInfo字段无效 + public int nUIDNum; // UID个数 + public Pointer stuUIDs; // 人员唯一标识符,首次由服务端生成,区别于ID字段, NET_UID_CHAR * + + // 图片二进制数据 + public Pointer pBuffer; // 缓冲地址, char * + public int nBufferLen; // 缓冲数据长度 + + public NET_IN_OPERATE_FACERECONGNITIONDB() + { + this.dwSize = this.size(); + } + } + + //CLIENT_OperateFaceRecognitionDB 接口输出参数 + public static class NET_OUT_OPERATE_FACERECONGNITIONDB extends Structure + { + public int dwSize; + + public NET_OUT_OPERATE_FACERECONGNITIONDB() + { + this.dwSize = this.size(); + } + } + + //人脸对比模式 + public static class EM_FACE_COMPARE_MODE extends Structure + { + public static final int NET_FACE_COMPARE_MODE_UNKOWN = 0; + public static final int NET_FACE_COMPARE_MODE_NORMAL = 1; //正常 + public static final int NET_FACE_COMPARE_MODE_AREA = 2; //指定人脸区域组合区域 + public static final int NET_FACE_COMPARE_MODE_AUTO = 3; //智能模式,算法根据人脸各个区域情况自动选取组合 + } + + //人脸区域 + public static class EM_FACE_AREA_TYPE extends Structure + { + public static final int NET_FACE_AREA_TYPE_UNKOWN = 0; + public static final int NET_FACE_AREA_TYPE_EYEBROW = 1; //眉毛 + public static final int NET_FACE_AREA_TYPE_EYE = 2; //眼睛 + public static final int NET_FACE_AREA_TYPE_NOSE= 3; //鼻子 + public static final int NET_FACE_AREA_TYPE_MOUTH = 4; //嘴巴 + public static final int NET_FACE_AREA_TYPE_CHEEK =5; //脸颊 + } + + public static class NET_FACE_MATCH_OPTIONS extends Structure + { + public int dwSize; + public int nMatchImportant;//人员重要等级1~10,数值越高越重要,(查询重要等级大于等于此等级的人员), 类型为unsigned int + public int emMode;//人脸比对模式,详见EM_FACE_COMPARE_MODE, 取EM_FACE_COMPARE_MODE中的值 + public int nAreaNum;//人脸区域个数 + public int[] szAreas= new int[MAX_FACE_AREA_NUM];//人脸区域组合,emMode为NET_FACE_COMPARE_MODE_AREA时有效, 数组元素取EM_FACE_AREA_TYPE中的值 + public int nAccuracy;//识别精度(取值1~10,随着值增大,检测精度提高,检测速度下降。最小值为1表示检测速度优先,最大值为10表示检测精度优先。暂时只对人脸检测有效) + public int nSimilarity;//相似度(必须大于该相识度才报告;百分比表示,1~100) + public int nMaxCandidate;//报告的最大候选个数(根据相似度进行排序,取相似度最大的候选人数报告) + + public NET_FACE_MATCH_OPTIONS() + { + this.dwSize = this.size(); + } + } + + //人脸识别人脸类型 + public static class EM_FACERECOGNITION_FACE_TYPE extends Structure + { + public static final int EM_FACERECOGNITION_FACE_TYPE_UNKOWN = 0; + public static final int EM_FACERECOGNITION_FACE_TYPE_ALL = 1; //所有人脸 + public static final int EM_FACERECOGNITION_FACE_TYPE_REC_SUCCESS= 2;//识别成功 + public static final int EM_FACERECOGNITION_FACE_TYPE_REC_FAIL = 3;//识别失败 + } + + public static class NET_FACE_FILTER_CONDTION extends Structure + { + public int dwSize; + public NET_TIME stStartTime;//开始时间 + public NET_TIME stEndTime;//结束时间 + public byte[] szMachineAddress = new byte[MAX_PATH];//地点,支持模糊匹配 + public int nRangeNum;//实际数据库个数 + public byte[] szRange = new byte[MAX_FACE_DB_NUM];//待查询数据库类型,详见EM_FACE_DB_TYPE + public int emFaceType;//待查询人脸类型,详见EM_FACERECOGNITION_FACE_TYPE, 取EM_FACERECOGNITION_FACE_TYPE中的值 + public int nGroupIdNum;//人员组数 + public byte[] szGroupId = new byte[MAX_GOURP_NUM*NET_COMMON_STRING_64];//人员组ID + public NET_TIME stBirthdayRangeStart; // 生日起始时间 + public NET_TIME stBirthdayRangeEnd; // 生日结束时间 + + public NET_FACE_FILTER_CONDTION() + { + this.dwSize = this.size(); + } + } + + //CLIENT_StartFindFaceRecognition 接口输入参数 + public static class NET_IN_STARTFIND_FACERECONGNITION extends Structure + { + public int dwSize; + public int bPersonEnable; // 人员信息查询条件是否有效, BOOL类型,取值0或1 + public FACERECOGNITION_PERSON_INFO stPerson; // 人员信息查询条件 + public NET_FACE_MATCH_OPTIONS stMatchOptions; // 人脸匹配选项 + public NET_FACE_FILTER_CONDTION stFilterInfo; // 查询过滤条件 + + // 图片二进制数据 + public Pointer pBuffer; // 缓冲地址, char * + public int nBufferLen; // 缓冲数据长度 + public int nChannelID; // 通道号 + + public NET_IN_STARTFIND_FACERECONGNITION() + { + this.dwSize = this.size(); + } + } + + //CLIENT_StartFindFaceRecognition 接口输出参数 + public static class NET_OUT_STARTFIND_FACERECONGNITION extends Structure + { + public int dwSize; + public int nTotalCount; // 返回的符合查询条件的记录个数 + // -1表示总条数未生成,要推迟获取 + // 使用 CLIENT_AttachFaceFindState 接口状态 + public LLong lFindHandle; // 查询句柄 + public int nToken; // 获取到的查询令牌 + + public NET_OUT_STARTFIND_FACERECONGNITION() + { + this.dwSize = this.size(); + } + } + + //CLIENT_DoFindFaceRecognition 接口输入参数 + public static class NET_IN_DOFIND_FACERECONGNITION extends Structure + { + public int dwSize; + public LLong lFindHandle; // 查询句柄 + public int nBeginNum; // 查询起始序号 + public int nCount; // 当前想查询的记录条数 + public int emDataType; // 指定查询结果返回图片的格式. 参考 EM_NEEDED_PIC_RETURN_TYPE + + public NET_IN_DOFIND_FACERECONGNITION() + { + this.dwSize = this.size(); + } + } + + // 查询结果返回图片的格式 + public static class EM_NEEDED_PIC_RETURN_TYPE extends Structure + { + public static final int EM_NEEDED_PIC_TYPE_UNKOWN = 0; // 未知类型 + public static final int EM_NEEDED_PIC_TYPE_HTTP_URL = 1; // 返回图片HTTP链接 + public static final int EM_NEEDED_PIC_TYPE_BINARY_DATA = 2; // 返回图片二进制数据 + public static final int EM_NEEDED_PIC_TYPE_HTTP_AND_BINARY = 3; // 返回二进制和HTTP链接 + } + + //候选人员信息 + public static class CANDIDATE_INFO extends Structure + { + public FACERECOGNITION_PERSON_INFO stPersonInfo; // 人员信息 + // 布控(黑名单)库,指布控库中人员信息; + // 历史库,指历史库中人员信息 + // 报警库,指布控库的人员信息 + public byte bySimilarity; // 和查询图片的相似度,百分比表示,1~100 + public byte byRange; // 人员所属数据库范围,详见 EM_FACE_DB_TYPE + public byte[] byReserved1 = new byte[2]; + public NET_TIME stTime; // 当byRange为历史数据库时有效,表示查询人员出现的时间 + public byte[] szAddress = new byte[MAX_PATH]; //当byRange为历史数据库时有效,表示查询人员出现的地点 + public int bIsHit; // BOOL类型,是否有识别结果,指这个检测出的人脸在库中有没有比对结果 + public NET_PIC_INFO_EX3 stuSceneImage; // 人脸全景图 + public int nChannelID; // 通道号 + public byte[] byReserved = new byte[32]; // 保留字节 + } + + // 物体对应图片文件信息(包含图片路径) + public static class NET_PIC_INFO_EX3 extends Structure + { + public int dwOffSet; // 文件在二进制数据块中的偏移位置, 单位:字节 + public int dwFileLenth; // 文件大小, 单位:字节 + public short wWidth; // 图片宽度, 单位:像素 + public short wHeight; // 图片高度, 单位:像素 + public byte[] szFilePath = new byte[64]; // 文件路径 + public byte bIsDetected; // 图片是否算法检测出来的检测过的提交识别服务器时, + // 则不需要再时检测定位抠图,1:检测过的,0:没有检测过 + public byte[] bReserved = new byte[11]; // 保留 + } + + //CLIENT_DoFindFaceRecognition接口输出参数 + public static class NET_OUT_DOFIND_FACERECONGNITION extends Structure + { + public int dwSize; + public int nCadidateNum; //实际返回的候选信息结构体个数 + public CANDIDATE_INFO[] stCadidateInfo = (CANDIDATE_INFO[])new CANDIDATE_INFO().toArray(MAX_FIND_COUNT);//候选信息数组 + + // 图片二进制数据 + public Pointer pBuffer; //缓冲地址, char * + public int nBufferLen; //缓冲数据长度 + + public NET_OUT_DOFIND_FACERECONGNITION() + { + this.dwSize = this.size(); + } + } + + /////////////////////////////////智能支持///////////////////////////////// + //CLIENT_DetectFace接口输入参数 + public static class NET_IN_DETECT_FACE extends Structure + { + public int dwSize; + public NET_PIC_INFO stPicInfo;//大图信息 + // 图片二进制数据 + public Pointer pBuffer;//缓冲地址, char * + public int nBufferLen;//缓冲数据长度 + + public NET_IN_DETECT_FACE() + { + this.dwSize = this.size(); + } + } + + //CLIENT_DetectFace接口输出参数 + public static class NET_OUT_DETECT_FACE extends Structure + { + public int dwSize; + public Pointer pPicInfo;//检测出的人脸图片信息,由用户申请空间, NET_PIC_INFO* + public int nMaxPicNum;//最大人脸图片信息个数 + public int nRetPicNum;//实际返回的人脸图片个数 + // 图片二进制数据 + public Pointer pBuffer;//缓冲地址,由用户申请空间,存放检测出的人脸图片数据, char * + public int nBufferLen;//缓冲数据长度 + + public NET_OUT_DETECT_FACE() + { + this.dwSize = this.size(); + } + } + + // 人脸识别事件类型 + public static class EM_FACERECOGNITION_ALARM_TYPE extends Structure + { + public static final int NET_FACERECOGNITION_ALARM_TYPE_UNKOWN = 0; + public static final int NET_FACERECOGNITION_ALARM_TYPE_ALL = 1; //黑白名单 + public static final int NET_FACERECOGNITION_ALARM_TYPE_BLACKLIST = 2; //黑名单 + public static final int NET_FACERECOGNITION_ALARM_TYPE_WHITELIST = 3; //白名单 + } + + //NET_FILE_QUERY_FACE对应的人脸识别服务查询参数 + public static class MEDIAFILE_FACERECOGNITION_PARAM extends Structure + { + public int dwSize;//结构体大小 + // 查询过滤条件 + public NET_TIME stStartTime;//开始时间 + public NET_TIME stEndTime;//结束时间 + public byte[] szMachineAddress = new byte[MAX_PATH];//地点,支持模糊匹配 + public int nAlarmType;//待查询报警类型,详见EM_FACERECOGNITION_ALARM_TYPE + public int abPersonInfo;//人员信息是否有效, BOOL类型,取值0或1 + public FACERECOGNITION_PERSON_INFO stPersonInfo;//人员信息 + public int nChannelId;//通道号 + public int nGroupIdNum;//人员组数 + public byte[] szGroupId = new byte[MAX_GOURP_NUM*NET_COMMON_STRING_64];//人员组ID + + public MEDIAFILE_FACERECOGNITION_PARAM() + { + this.dwSize = this.size(); + } + } + + // DH_MEDIA_QUERY_TRAFFICCAR对应的查询条件 + public static class MEDIA_QUERY_TRAFFICCAR_PARAM extends Structure + { + public int nChannelID; // 通道号从0开始,-1表示查询所有通道 + public NET_TIME StartTime; // 开始时间 + public NET_TIME EndTime; // 结束时间 + public int nMediaType; // 文件类型,0:任意类型, 1:jpg图片, 2:dav文件 + public int nEventType; // 事件类型,详见"智能分析事件类型", 0:表示查询任意事件,此参数废弃,请使用pEventTypes + public byte[] szPlateNumber = new byte[32]; // 车牌号, "\0"则表示查询任意车牌号 + public int nSpeedUpperLimit; // 查询的车速范围; 速度上限 单位: km/h + public int nSpeedLowerLimit; // 查询的车速范围; 速度下限 单位: km/h + public int bSpeedLimit; // 是否按速度查询; TRUE:按速度查询,nSpeedUpperLimit和nSpeedLowerLimit有效。 + public int dwBreakingRule; // 违章类型: + // 当事件类型为 EVENT_IVS_TRAFFICGATE时 + // 第一位:逆行; 第二位:压线行驶; 第三位:超速行驶; + // 第四位:欠速行驶; 第五位:闯红灯; + // 当事件类型为 EVENT_IVS_TRAFFICJUNCTION + // 第一位:闯红灯; 第二位:不按规定车道行驶; + // 第三位:逆行; 第四位:违章掉头; + // 第五位:压线行驶; + + public byte[] szPlateType=new byte[32]; // 车牌类型,"Unknown" 未知,"Normal" 蓝牌黑牌,"Yellow" 黄牌,"DoubleYellow" 双层黄尾牌,"Police" 警牌"Armed" 武警牌, + // "Military" 部队号牌,"DoubleMilitary" 部队双层,"SAR" 港澳特区号牌,"Trainning" 教练车号牌 + // "Personal" 个性号牌,"Agri" 农用牌,"Embassy" 使馆号牌,"Moto" 摩托车号牌,"Tractor" 拖拉机号牌,"Other" 其他号牌 + public byte[] szPlateColor = new byte[16]; // 车牌颜色, "Blue"蓝色,"Yellow"黄色, "White"白色,"Black"黑色 + public byte[] szVehicleColor = new byte[16]; // 车身颜色:"White"白色, "Black"黑色, "Red"红色, "Yellow"黄色, "Gray"灰色, "Blue"蓝色,"Green"绿色 + public byte[] szVehicleSize = new byte[16]; // 车辆大小类型:"Light-duty":小型车;"Medium":中型车; "Oversize":大型车; "Unknown": 未知 + public int nGroupID; // 事件组编号(此值>=0时有效) + public short byLane; // 车道号(此值>=0时表示具体车道,-1表示所有车道,即不下发此字段) + public byte byFileFlag; // 文件标志, 0xFF-使用nFileFlagEx, 0-表示所有录像, 1-定时文件, 2-手动文件, 3-事件文件, 4-重要文件, 5-合成文件 + public byte byRandomAccess; // 是否需要在查询过程中随意跳转,0-不需要,1-需要 + public int nFileFlagEx; // 文件标志, 按位表示: bit0-定时文件, bit1-手动文件, bit2-事件文件, bit3-重要文件, bit4-合成文件, bit5-黑名单图片 0xFFFFFFFF-所有录像 + public int nDirection; // 车道方向(车开往的方向) 0-北 1-东北 2-东 3-东南 4-南 5-西南 6-西 7-西北 8-未知 -1-所有方向 + public Pointer szDirs; // 工作目录列表,一次可查询多个目录,为空表示查询所有目录。目录之间以分号分隔,如“/mnt/dvr/sda0;/mnt/dvr/sda1”,szDirs==null 或"" 表示查询所有 + public Pointer pEventTypes; // 待查询的事件类型数组指针,事件类型,详见"智能分析事件类型",若为NULL则认为查询所有事件(缓冲需由用户申请) + public int nEventTypeNum; // 事件类型数组大小 + public Pointer pszDeviceAddress; // 设备地址, NULL表示该字段不起作用 + public Pointer pszMachineAddress; // 机器部署地点, NULL表示该字段不起作用 + public Pointer pszVehicleSign; // 车辆标识, 例如 "Unknown"-未知, "Audi"-奥迪, "Honda"-本田... NULL表示该字段不起作用 + public short wVehicleSubBrand; // 车辆子品牌 需要通过映射表得到真正的子品牌 映射表详见开发手册 + public short wVehicleYearModel; // 车辆品牌年款 需要通过映射表得到真正的年款 映射表详见开发手册 + public int[] bReserved = new int[28]; // 保留字段 + } + + // DH_MEDIA_QUERY_TRAFFICCAR_EX对应的查询条件 + public static class MEDIA_QUERY_TRAFFICCAR_PARAM_EX extends Structure + { + public int dwSize; + public MEDIA_QUERY_TRAFFICCAR_PARAM stuParam; // 基本查询参数 + + public MEDIA_QUERY_TRAFFICCAR_PARAM_EX() { + this.dwSize = this.size(); + } + } + + // DH_MEDIA_QUERY_TRAFFICCAR查询出来的media文件信息 + public static class MEDIAFILE_TRAFFICCAR_INFO extends Structure + { + public int ch; // 通道号 + public byte[] szFilePath = new byte[128]; // 文件路径 + public int size; // 文件长度 + public NET_TIME starttime; // 开始时间 + public NET_TIME endtime; // 结束时间 + public int nWorkDirSN; // 工作目录编号 + public byte nFileType; // 文件类型 1:jpg图片 + public byte bHint; // 文件定位索引 + public byte bDriveNo; // 磁盘号 + public byte bReserved2; + public int nCluster; // 簇号 + public byte byPictureType; // 图片类型, 0-普通, 1-合成, 2-抠图 + public byte[] bReserved = new byte[3]; // 保留字段 + + //以下是交通车辆信息 + public byte[] szPlateNumber = new byte[32]; // 车牌号码 + public byte[] szPlateType = new byte[32]; // 号牌类型"Unknown" 未知; "Normal" 蓝牌黑牌; "Yellow" 黄牌; "DoubleYellow" 双层黄尾牌 + // "Police" 警牌; "Armed" 武警牌; "Military" 部队号牌; "DoubleMilitary" 部队双层 + // "SAR" 港澳特区号牌; "Trainning" 教练车号牌; "Personal" 个性号牌; "Agri" 农用牌 + // "Embassy" 使馆号牌; "Moto" 摩托车号牌; "Tractor" 拖拉机号牌; "Other" 其他号牌 + public byte[] szPlateColor = new byte[16]; // 车牌颜色:"Blue","Yellow", "White","Black" + public byte[] szVehicleColor = new byte[16]; // 车身颜色:"White", "Black", "Red", "Yellow", "Gray", "Blue","Green" + public int nSpeed; // 车速,单位 Km/H + public int nEventsNum; // 关联的事件个数 + public int[] nEvents = new int[32]; // 关联的事件列表,数组值表示相应的事件,详见"智能分析事件类型" + public int dwBreakingRule; // 具体违章类型掩码,第一位:闯红灯; 第二位:不按规定车道行驶; + // 第三位:逆行; 第四位:违章掉头;否则默认为:交通路口事件 + public byte[] szVehicleSize = new byte[16]; // 车辆大小类型:"Light-duty":小型车;"Medium":中型车; "Oversize":大型车 + public byte[] szChannelName = new byte[NET_CHAN_NAME_LEN]; // 本地或远程的通道名称 + public byte[] szMachineName = new byte[NET_MAX_NAME_LEN]; // 本地或远程设备名称 + + public int nSpeedUpperLimit; // 速度上限 单位: km/h + public int nSpeedLowerLimit; // 速度下限 单位: km/h + public int nGroupID; // 事件里的组编号 + public byte byCountInGroup; // 一个事件组内的抓拍张数 + public byte byIndexInGroup; // 一个事件组内的抓拍序号 + public byte byLane; // 车道,参见MEDIA_QUERY_TRAFFICCAR_PARAM + public byte[] bReserved1 = new byte[21]; // 保留 + public NET_TIME stSnapTime; // 抓拍时间 + public int nDirection; // 车道方向,参见MEDIA_QUERY_TRAFFICCAR_PARAM + public byte[] szMachineAddress = new byte[MAX_PATH]; // 机器部署地点 + } + + // DH_MEDIA_QUERY_TRAFFICCAR_EX查询出来的文件信息 + public static class MEDIAFILE_TRAFFICCAR_INFO_EX extends Structure + { + public int dwSize; + public MEDIAFILE_TRAFFICCAR_INFO stuInfo; // 基本信息 + public byte[] szDeviceAddr = new byte[NET_COMMON_STRING_256]; // 设备地址 + public byte[] szVehicleSign = new byte[NET_COMMON_STRING_32]; // 车辆标识, 例如 "Unknown"-未知, "Audi"-奥迪, "Honda"-本田... + public byte[] szCustomParkNo = new byte[NET_COMMON_STRING_64]; // 自定义车位号(停车场用) + public short wVehicleSubBrand; // 车辆子品牌,需要通过映射表得到真正的子品牌 + public short wVehicleYearModel; // 车辆年款,需要通过映射表得到真正的年款 + public NET_TIME stuEleTagInfoUTC; // 对应电子车牌标签信息中的过车时间(ThroughTime) + public int[] emFalgLists = new int[EM_RECORD_SNAP_FLAG_TYPE.FLAG_TYPE_MAX]; // 录像或抓图文件标志, 参考 EM_RECORD_SNAP_FLAG_TYPE + public int nFalgCount; // 标志总数 + + public MEDIAFILE_TRAFFICCAR_INFO_EX() { + this.dwSize = this.size(); + } + } + + public static class NET_PIC_INFO_EX extends Structure + { + public int dwSize;//结构体大小 + public int dwFileLenth;//文件大小,单位:字节 + public byte[] szFilePath = new byte[MAX_PATH];//文件路径 + + public NET_PIC_INFO_EX() + { + this.dwSize = this.size(); + } + } + + //区域;各边距按整长8192的比例 + public static class NET_RECT extends Structure + { + public int left; + public int top; + public int right; + public int bottom; + } + + + // 时间段结构 + public static class NET_TSECT extends Structure + { + public int bEnable; // 当表示录像时间段时,按位表示四个使能,从低位到高位分别表示动检录象、报警录象、普通录象、动检和报警同时发生才录像 + public int iBeginHour; + public int iBeginMin; + public int iBeginSec; + public int iEndHour; + public int iEndMin; + public int iEndSec; + } + + + public static class DH_RECT extends Structure + { + public NativeLong left; + public NativeLong top; + public NativeLong right; + public NativeLong bottom; + } + + //二维空间点 + public static class NET_POINT extends Structure + { + public short nx; + public short ny; + } + + public static class NET_CANDIDAT_PIC_PATHS extends Structure + { + public int dwSize;//结构体大小 + public int nFileCount;//实际文件个数 + public NET_PIC_INFO_EX[] stFiles = (NET_PIC_INFO_EX[])new NET_PIC_INFO_EX().toArray(NET_MAX_PERSON_IMAGE_NUM);//文件信息 + + public NET_CANDIDAT_PIC_PATHS() + { + this.dwSize = this.size(); + } + } + + //颜色类型 + public static class EM_COLOR_TYPE extends Structure + { + public static final int NET_COLOR_TYPE_RED = 0;//红色 + public static final int NET_COLOR_TYPE_YELLOW = 1;//黄色 + public static final int NET_COLOR_TYPE_GREEN = 2; //绿色 + public static final int NET_COLOR_TYPE_CYAN = 3; //青色 + public static final int NET_COLOR_TYPE_BLUE = 4; //蓝色 + public static final int NET_COLOR_TYPE_PURPLE = 5; //紫色 + public static final int NET_COLOR_TYPE_BLACK = 6; //黑色 + public static final int NET_COLOR_TYPE_WHITE = 7; //白色 + public static final int NET_COLOR_TYPE_MAX = 8; + } + + //视频分析物体信息结构体 + public static class NET_MSG_OBJECT extends Structure + { + public int nObjectID;//物体ID,每个ID表示一个唯一的物体 + public byte[] szObjectType = new byte[128];//物体类型 + public int nConfidence;//置信度(0~255),值越大表示置信度越高 + public int nAction;//物体动作:1:Appear2:Move3:Stay + public DH_RECT BoundingBox;//包围盒 + public NET_POINT Center;//物体型心 + public int nPolygonNum;//多边形顶点个数 + public NET_POINT[] Contour = (NET_POINT[])new NET_POINT().toArray(NET_MAX_POLYGON_NUM);//较精确的轮廓多边形 + public int rgbaMainColor;//表示车牌、车身等物体主要颜色;按字节表示,分别为红、绿、蓝和透明度,例如:RGB值为(0,255,0),透明度为0时,其值为0x00ff0000. + public byte[] szText = new byte[128];//物体上相关的带0结束符文本,比如车牌,集装箱号等等 + // "ObjectType"为"Vehicle"或者"Logo"时(尽量使用Logo。Vehicle是为了兼容老产品)表示车标,支持: + // "Unknown"未知 + // "Audi" 奥迪 + // "Honda" 本田 + // "Buick" 别克 + // "Volkswagen" 大众 + // "Toyota" 丰田 + // "BMW" 宝马 + // "Peugeot" 标致 + // "Ford" 福特 + // "Mazda" 马自达 + // "Nissan" 尼桑 + // "Hyundai" 现代 + // "Suzuki" 铃木 + // "Citroen" 雪铁龙 + // "Benz" 奔驰 + // "BYD" 比亚迪 + // "Geely" 吉利 + // "Lexus" 雷克萨斯 + // "Chevrolet" 雪佛兰 + // "Chery" 奇瑞 + // "Kia" 起亚 + // "Charade" 夏利 + // "DF" 东风 + // "Naveco" 依维柯 + // "SGMW" 五菱 + // "Jinbei" 金杯 + // "JAC" 江淮 + // "Emgrand" 帝豪 + // "ChangAn" 长安 + // "Great Wall" 长城 + // "Skoda" 斯柯达 + // "BaoJun" 宝骏 + // "Subaru" 斯巴鲁 + // "LandWind" 陆风 + // "Luxgen" 纳智捷 + // "Renault" 雷诺 + // "Mitsubishi" 三菱 + // "Roewe" 荣威 + // "Cadillac" 凯迪拉克 + // "MG" 名爵 + // "Zotye" 众泰 + // "ZhongHua" 中华 + // "Foton" 福田 + // "SongHuaJiang" 松花江 + // "Opel" 欧宝 + // "HongQi" 一汽红旗 + // "Fiat" 菲亚特 + // "Jaguar" 捷豹 + // "Volvo" 沃尔沃 + // "Acura" 讴歌 + // "Porsche" 保时捷 + // "Jeep" 吉普 + // "Bentley" 宾利 + // "Bugatti" 布加迪 + // "ChuanQi" 传祺 + // "Daewoo" 大宇 + // "DongNan" 东南 + // "Ferrari" 法拉利 + // "Fudi" 福迪 + // "Huapu" 华普 + // "HawTai" 华泰 + // "JMC" 江铃 + // "JingLong" 金龙客车 + // "JoyLong" 九龙 + // "Karry" 开瑞 + // "Chrysler" 克莱斯勒 + // "Lamborghini" 兰博基尼 + // "RollsRoyce" 劳斯莱斯 + // "Linian" 理念 + // "LiFan" 力帆 + // "LieBao" 猎豹 + // "Lincoln" 林肯 + // "LandRover" 路虎 + // "Lotus" 路特斯 + // "Maserati" 玛莎拉蒂 + // "Maybach" 迈巴赫 + // "Mclaren" 迈凯轮 + // "Youngman" 青年客车 + // "Tesla" 特斯拉 + // "Rely" 威麟 + // "Lsuzu" 五十铃 + // "Yiqi" 一汽 + // "Infiniti" 英菲尼迪 + // "YuTong" 宇通客车 + // "AnKai" 安凯客车 + // "Canghe" 昌河 + // "HaiMa" 海马 + // "Crown" 丰田皇冠 + // "HuangHai" 黄海 + // "JinLv" 金旅客车 + // "JinNing" 精灵 + // "KuBo" 酷博 + // "Europestar" 莲花 + // "MINI" 迷你 + // "Gleagle" 全球鹰 + // "ShiDai" 时代 + // "ShuangHuan" 双环 + // "TianYe" 田野 + // "WeiZi" 威姿 + // "Englon" 英伦 + // "ZhongTong" 中通客车 + // "Changan" 长安轿车 + // "Yuejin" 跃进 + // "Taurus" 金牛星 + // "Alto" 奥拓 + // "Weiwang" 威旺 + // "Chenglong" 乘龙 + // "Haige" 海格 + // "Shaolin" 少林客车 + // "Beifang" 北方客车 + // "Beijing" 北京汽车 + // "Hafu" 哈弗 + public byte[] szObjectSubType = new byte[64];//物体子类别,根据不同的物体类型,可以取以下子类型: + // Vehicle Category:"Unknown" 未知,"Motor" 机动车,"Non-Motor":非机动车,"Bus": 公交车,"Bicycle" 自行车,"Motorcycle":摩托车,"PassengerCar":客车, + // "LargeTruck":大货车, "MidTruck":中货车,"SaloonCar":轿车,"Microbus":面包车,"MicroTruck":小货车,"Tricycle":三轮车, "Passerby":行人 + // Plate Category:"Unknown" 未知,"Normal" 蓝牌黑牌,"Yellow" 黄牌,"DoubleYellow" 双层黄尾牌,"Police" 警牌"Armed" 武警牌, + // "Military" 部队号牌,"DoubleMilitary" 部队双层,"SAR" 港澳特区号牌,"Trainning" 教练车号牌 + // "Personal" 个性号牌,"Agri" 农用牌,"Embassy" 使馆号牌,"Moto" 摩托车号牌,"Tractor" 拖拉机号牌,"Other" 其他号牌 + // HumanFace Category:"Normal" 普通人脸,"HideEye" 眼部遮挡,"HideNose" 鼻子遮挡,"HideMouth" 嘴部遮挡 + public short wSubBrand; // 车辆子品牌 需要通过映射表得到真正的子品牌 映射表详见开发手册 + public byte byReserved1; + public byte bPicEnble;//是否有物体对应图片文件信息, 类型小bool, 取值0或者1 + public NET_PIC_INFO stPicInfo;//物体对应图片信息 + public byte bShotFrame;//是否是抓拍张的识别结果, 类型小bool, 取值0或者1 + public byte bColor;//物体颜色(rgbaMainColor)是否可用, 类型小bool, 取值0或者1 + public byte byReserved2; + public byte byTimeType;//时间表示类型,详见EM_TIME_TYPE说明 + public NET_TIME_EX stuCurrentTime;//针对视频浓缩,当前时间戳(物体抓拍或识别时,会将此识别智能帧附在一个视频帧或jpeg图片中,此帧所在原始视频中的出现时间) + public NET_TIME_EX stuStartTime;//开始时间戳(物体开始出现时) + public NET_TIME_EX stuEndTime;//结束时间戳(物体最后出现时) + public DH_RECT stuOriginalBoundingBox;//包围盒(绝对坐标) + public DH_RECT stuSignBoundingBox;//车标坐标包围盒 + public int dwCurrentSequence;//当前帧序号(抓下这个物体时的帧) + public int dwBeginSequence;//开始帧序号(物体开始出现时的帧序号) + public int dwEndSequence;//结束帧序号(物体消逝时的帧序号) + public long nBeginFileOffse;//开始时文件偏移,单位:字(物体开始出现时,视频帧在原始视频文件中相对于文件起始处的偏移) + public long nEndFileOffset;//结束时文件偏移,单位:字节(物体消逝时,视频帧在原始视频文件中相对于文件起始处的偏移) + public byte[] byColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//物体颜色相似度,取值范围:0-100,数组下标值代表某种颜色,详见 EM_COLOR_TYPE + public byte[] byUpperBodyColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//上半身物体颜色相似度(物体类型为人时有效) + public byte[] byLowerBodyColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//下半身物体颜色相似度(物体类型为人时有效) + public int nRelativeID;//相关物体ID + public byte[] szSubText = new byte[20];//"ObjectType"为"Vehicle"或者"Logo"时,表示车标下的某一车系,比如奥迪A6L,由于车系较多,SDK实现时透传此字段,设备如实填写。 + public short wBrandYear; // 车辆品牌年款 需要通过映射表得到真正的年款 映射表详见开发手册 + + public NET_MSG_OBJECT() + { + /*if(Utils.getOsName().equals("win")) { + // 强制采用最大四字节对其 + setAlignType(ALIGN_GNUC); + }*/ + } + } + + //NET_FILE_QUERY_FACE对应的人脸识别服务FINDNEXT查询返回参数 + public static class MEDIAFILE_FACERECOGNITION_INFO extends Structure + { + public int dwSize;//结构体大小 + public int bGlobalScenePic;//全景图是否存在, BOOL类型,取值0或1 + public NET_PIC_INFO_EX stGlobalScenePic;//全景图片文件路径 + public NET_MSG_OBJECT stuObject;//目标人脸物体信息 + public NET_PIC_INFO_EX stObjectPic;//目标人脸文件路径 + public int nCandidateNum;//当前人脸匹配到的候选对象数量 + public CANDIDATE_INFO[] stuCandidates = (CANDIDATE_INFO[])new CANDIDATE_INFO().toArray(NET_MAX_CANDIDATE_NUM);//当前人脸匹配到的候选对象信息 + public NET_CANDIDAT_PIC_PATHS[] stuCandidatesPic = (NET_CANDIDAT_PIC_PATHS[])new NET_CANDIDAT_PIC_PATHS().toArray(NET_MAX_CANDIDATE_NUM);//当前人脸匹配到的候选对象图片文件路径 + public NET_TIME stTime;//报警发生时间 + public byte[] szAddress = new byte[MAX_PATH];//报警发生地点 + public int nChannelId;//通道号 + + public MEDIAFILE_FACERECOGNITION_INFO() + { + this.dwSize = this.size(); + } + } + + //每个视频输入通道对应的所有事件规则:缓冲区pRuleBuf填充多个事件规则信息,每个事件规则信息内容为CFG_RULE_INFO+"事件类型对应的规则配置结构体"。 + public static class CFG_ANALYSERULES_INFO extends Structure + { + public int nRuleCount;//事件规则个数 + public Pointer pRuleBuf;//每个视频输入通道对应的视频分析事件规则配置缓冲, char * + public int nRuleLen;//缓冲大小 + } + + // 规则通用信息 + public static class CFG_RULE_COMM_INFO extends Structure + { + public byte bRuleId; // 规则编号 + public int emClassType; // 规则所属的场景, EM_SCENE_TYPE + public byte[] bReserved = new byte[512]; // 保留字节 + } + + public static class CFG_RULE_INFO extends Structure + { + public int dwRuleType;//事件类型,详见dhnetsdk.h中"智能分析事件类型" + public int nRuleSize;//该事件类型规则配置结构体大小 + public CFG_RULE_COMM_INFO stuRuleCommInfo; // 规则通用信息 + } + + //区域顶点信息 + public static class CFG_POLYGON extends Structure + { + public int nX;//0~8191 + public int nY; + } + + //区域信息 + public static class CFG_REGION extends Structure + { + public int nPointNum; + public CFG_POLYGON[] stuPolygon = (CFG_POLYGON[])new CFG_POLYGON().toArray(MAX_POLYGON_NUM); + } + + public static class CFG_SIZE_Attribute extends Union + { + public float nWidth;//宽 + public float nArea;//面积 + } + + //Size + public static class CFG_SIZE extends Structure + { + public CFG_SIZE_Attribute attr; + public float nHeight;//高 + } + + //校准框信息 + public static class CFG_CALIBRATEBOX_INFO extends Structure + { + public CFG_POLYGON stuCenterPoint;//校准框中心点坐标(点的坐标归一化到[0,8191]区间) + public float fRatio;//相对基准校准框的比率(比如1表示基准框大小,0.5表示基准框大小的一半) + } + + //尺寸过滤器 + public static class CFG_SIZEFILTER_INFO extends Structure + { + public int nCalibrateBoxNum;//校准框个数 + public CFG_CALIBRATEBOX_INFO[] stuCalibrateBoxs = (CFG_CALIBRATEBOX_INFO[])new CFG_CALIBRATEBOX_INFO().toArray(MAX_CALIBRATEBOX_NUM);//校准框(远端近端标定模式下有效) + public byte bMeasureModeEnable;//计量方式参数是否有效, 类型bool, 取值0或1 + public byte bMeasureMode;//计量方式,0-像素,不需要远端、近端标定,1-实际长度,单位:米,2-远端近端标定后的像素 + public byte bFilterTypeEnable;//过滤类型参数是否有效, 类型bool, 取值0或1 + // ByArea,ByRatio仅作兼容,使用独立的ByArea和ByRatio选项代替 2012/03/06 + public byte bFilterType;//过滤类型:0:"ByLength",1:"ByArea",2"ByWidthHeight" + public byte[] bReserved = new byte[2];//保留字段 + public byte bFilterMinSizeEnable;//物体最小尺寸参数是否有效, 类型bool, 取值0或1 + public byte bFilterMaxSizeEnable;//物体最大尺寸参数是否有效, 类型bool, 取值0或1 + public CFG_SIZE stuFilterMinSize;//物体最小尺寸"ByLength"模式下表示宽高的尺寸,"ByArea"模式下宽表示面积,高无效(远端近端标定模式下表示基准框的宽高尺寸)。 + public CFG_SIZE stuFilterMaxSize;//物体最大尺寸"ByLength"模式下表示宽高的尺寸,"ByArea"模式下宽表示面积,高无效(远端近端标定模式下表示基准框的宽高尺寸)。 + public byte abByArea;//类型bool, 取值0或1 + public byte abMinArea;//类型bool, 取值0或1 + public byte abMaxArea;//类型bool, 取值0或1 + public byte abMinAreaSize;//类型bool, 取值0或1 + public byte abMaxAreaSize;//类型bool, 取值0或1 + public byte bByArea;//是否按面积过滤通过能力ComplexSizeFilter判断是否可用, 类型bool, 取值0或1 + public byte[] bReserved1 = new byte[2]; + public float nMinArea;//最小面积 + public float nMaxArea;//最大面积 + public CFG_SIZE stuMinAreaSize;//最小面积矩形框尺寸"计量方式"为"像素"时,表示最小面积矩形框的宽高尺寸;"计量方式"为"远端近端标定模式"时,表示基准框的最小宽高尺寸; + public CFG_SIZE stuMaxAreaSize;//最大面积矩形框尺寸,同上 + public byte abByRatio;//类型bool, 取值0或1 + public byte abMinRatio;//类型bool, 取值0或1 + public byte abMaxRatio;//类型bool, 取值0或1 + public byte abMinRatioSize;//类型bool, 取值0或1 + public byte abMaxRatioSize;//类型bool, 取值0或1 + public byte bByRatio;//是否按宽高比过滤通过能力ComplexSizeFilter判断是否可用, 类型bool, 取值0或1 + public byte[] bReserved2 = new byte[2]; + public double dMinRatio;//最小宽高比 + public double dMaxRatio;//最大宽高比 + public CFG_SIZE stuMinRatioSize;//最小宽高比矩形框尺寸,最小宽高比对应矩形框的宽高尺寸。 + public CFG_SIZE stuMaxRatioSize;//最大宽高比矩形框尺寸,同上 + public int nAreaCalibrateBoxNum;//面积校准框个数 + public CFG_CALIBRATEBOX_INFO[] stuAreaCalibrateBoxs = (CFG_CALIBRATEBOX_INFO[])new CFG_CALIBRATEBOX_INFO().toArray(MAX_CALIBRATEBOX_NUM);//面积校准框 + public int nRatioCalibrateBoxs;//宽高校准框个数 + public CFG_CALIBRATEBOX_INFO[] stuRatioCalibrateBoxs = (CFG_CALIBRATEBOX_INFO[])new CFG_CALIBRATEBOX_INFO().toArray(MAX_CALIBRATEBOX_NUM);//宽高校准框 + public byte abBySize;//长宽过滤使能参数是否有效, 类型bool, 取值0或1 + public byte bBySize;//长宽过滤使能, 类型bool, 取值0或1 + } + + //各种物体特定的过滤器 + public static class CFG_OBJECT_SIZEFILTER_INFO extends Structure + { + public byte[] szObjectType = new byte[MAX_NAME_LEN];//物体类型 + public CFG_SIZEFILTER_INFO stSizeFilter;//对应的尺寸过滤器 + } + + //特殊区域的属性类型 + public static class EM_SEPCIALREGION_PROPERTY_TYPE extends Structure + { + public static final int EM_SEPCIALREGION_PROPERTY_TYPE_HIGHLIGHT = 1;//高亮,键盘检测区域具有此特性 + public static final int EM_SEPCIALREGION_PROPERTY_TYPE_REGULARBLINK = 2; //规律的闪烁,插卡区域具有此特性 + public static final int EM_SEPCIALREGION_PROPERTY_TYPE_IREGULARBLINK = 3; //不规律的闪烁,屏幕区域具有此特性 + public static final int EM_SEPCIALREGION_PROPERTY_TYPE_NUM = 4; + } + + //特殊检测区,是指从检测区中区分出来,有特殊检测属性的区域 + public static class CFG_SPECIALDETECT_INFO extends Structure + { + public int nDetectNum;//检测区域顶点数 + public CFG_POLYGON[] stDetectRegion = (CFG_POLYGON[])new CFG_POLYGON().toArray(MAX_POLYGON_NUM);//检测区域 + public int nPropertyNum;//特殊检测区属性个数 + public int[] nPropertys = new int[EM_SEPCIALREGION_PROPERTY_TYPE.EM_SEPCIALREGION_PROPERTY_TYPE_NUM];//特殊检测区属性 + } + + //各类物体的子类型 + public static class CFG_CATEGORY_TYPE extends Structure + { + public static final int CFG_CATEGORY_TYPE_UNKNOW = 0; //未知类型 + //车型相关子类别 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MOTOR = 1; //"Motor"机动车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_NON_MOTOR = 2; //"Non-Motor"非机动车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_BUS = 3; //"Bus"公交车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_BICYCLE = 4; //"Bicycle"自行车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MOTORCYCLE = 5; //"Motorcycle"摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_UNLICENSEDMOTOR = 6; //"UnlicensedMotor":无牌机动车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_LARGECAR = 7; //"LargeCar"大型汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MICROCAR = 8; //"MicroCar"小型汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_EMBASSYCAR = 9; //"EmbassyCar"使馆汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MARGINALCAR = 10; //"MarginalCar"领馆汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_AREAOUTCAR = 11; //"AreaoutCar"境外汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_FOREIGNCAR = 12; //"ForeignCar"外籍汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_DUALTRIWHEELMOTORCYCLE = 13; //"DualTriWheelMotorcycle"两、三轮摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_LIGHTMOTORCYCLE = 14; //"LightMotorcycle"轻便摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_EMBASSYMOTORCYCLE = 15 ; //"EmbassyMotorcycle"使馆摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MARGINALMOTORCYCLE = 16; //"MarginalMotorcycle"领馆摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_AREAOUTMOTORCYCLE = 17; //"AreaoutMotorcycle"境外摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_FOREIGNMOTORCYCLE = 18; //"ForeignMotorcycle"外籍摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_FARMTRANSMITCAR = 19; //"FarmTransmitCar"农用运输车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TRACTOR = 20; //"Tractor"拖拉机 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TRAILER = 21; //"Trailer"挂车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_COACHCAR = 22; //"CoachCar"教练汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_COACHMOTORCYCLE = 23; //"CoachMotorcycle"教练摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TRIALCAR = 24; //"TrialCar"试验汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TRIALMOTORCYCLE = 25; //"TrialMotorcycle"试验摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TEMPORARYENTRYCAR = 26; //"TemporaryEntryCar"临时入境汽车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TEMPORARYENTRYMOTORCYCLE = 27; //"TemporaryEntryMotorcycle"临时入境摩托车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TEMPORARYSTEERCAR = 28; //"TemporarySteerCar"临时行驶车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_PASSENGERCAR = 29; //"PassengerCar"客车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_LARGETRUCK = 30; //"LargeTruck"大货车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MIDTRUCK =31 ; //"MidTruck"中货车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_SALOONCAR = 32; //"SaloonCar"轿车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MICROBUS = 33; //"Microbus"面包车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_MICROTRUCK = 34; //"MicroTruck"小货车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_TRICYCLE = 35; //"Tricycle"三轮车 + public static final int CFG_CATEGORY_VEHICLE_TYPE_PASSERBY = 36; //"Passerby"行人 + //车牌相关子类别 + public static final int CFG_CATEGORY_PLATE_TYPE_NORMAL = 37; //"Normal"蓝牌黑字 + public static final int CFG_CATEGORY_PLATE_TYPE_YELLOW = 38; //"Yellow"黄牌 + public static final int CFG_CATEGORY_PLATE_TYPE_DOUBLEYELLOW = 39; //"DoubleYellow"双层黄尾牌 + public static final int CFG_CATEGORY_PLATE_TYPE_POLICE = 40; //"Police"警牌 + public static final int CFG_CATEGORY_PLATE_TYPE_ARMED = 41; //"Armed"武警牌 + public static final int CFG_CATEGORY_PLATE_TYPE_MILITARY = 42; //"Military"部队号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_DOUBLEMILITARY = 43; //"DoubleMilitary"部队双层 + public static final int CFG_CATEGORY_PLATE_TYPE_SAR = 44; //"SAR"港澳特区号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_TRAINNING = 45; //"Trainning"教练车号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_PERSONAL = 46; //"Personal"个性号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_AGRI = 47; //"Agri"农用牌 + public static final int CFG_CATEGORY_PLATE_TYPE_EMBASSY = 48; //"Embassy"使馆号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_MOTO = 49; //"Moto"摩托车号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_TRACTOR = 50; //"Tractor"拖拉机号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_OFFICIALCAR = 51; //"OfficialCar"公务车 + public static final int CFG_CATEGORY_PLATE_TYPE_PERSONALCAR = 52; //"PersonalCar"私家车 + public static final int CFG_CATEGORY_PLATE_TYPE_WARCAR = 53; //"WarCar"军用 + public static final int CFG_CATEGORY_PLATE_TYPE_OTHER = 54; //"Other"其他号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_CIVILAVIATION = 55; //"Civilaviation"民航号牌 + public static final int CFG_CATEGORY_PLATE_TYPE_BLACK = 56; //"Black"黑牌 + } + + //不同区域各种类型物体的检测模块配置 + public static class CFG_MODULE_INFO extends Structure + { + // 信息 + public byte[] szObjectType = new byte[MAX_NAME_LEN];//默认物体类型,详见"支持的检测物体类型列表" + public byte bSnapShot;//是否对识别物体抓图,类型bool,取值0或1 + public byte bSensitivity;//灵敏度,取值1-10,值越小灵敏度越低 + public byte bMeasureModeEnable;//计量方式参数是否有效,类型bool,取值0或1 + public byte bMeasureMode;//计量方式,0-像素,不需要远端、近端标定,1-实际长度,单位:米,2-远端近端标定后的像素 + public int nDetectRegionPoint;//检测区域顶点数 + public CFG_POLYGON[] stuDetectRegion = (CFG_POLYGON[])new CFG_POLYGON().toArray(MAX_POLYGON_NUM);//检测区域 + public int nTrackRegionPoint;//跟踪区域顶点数 + public CFG_POLYGON[] stuTrackRegion = (CFG_POLYGON[])new CFG_POLYGON().toArray(MAX_POLYGON_NUM);//跟踪区域 + public byte bFilterTypeEnable;//过滤类型参数是否有效,类型bool,取值0或1 + // ByArea,ByRatio仅作兼容使枚懒⒌腂yArea和ByRatio选项代替 2012/03/06 + public byte nFilterType;//过滤类型:0:"ByLength",1:"ByArea",2:"ByWidthHeight",3:"ByRatio": + public byte bBackgroudEnable;//区域的背景类型参数是否有效,类型bool,取值0或1 + public byte bBackgroud;//区域的背景类型,0-普通类型,1-高光类型 + public byte abBySize;//长宽过滤使能参数是否有效,类型bool,取值0或1 + public byte bBySize;//长宽过滤使能,类型bool,取值0或1 + public byte bFilterMinSizeEnable;//物体最小尺寸参数是否有效,类型bool,取值0或1 + public byte bFilterMaxSizeEnable;//物体最大尺寸参数是否有效,类型bool,取值0或1 + public CFG_SIZE stuFilterMinSize;//物体最小尺寸"ByLength"模式下表示宽高的尺寸,"ByArea"模式下宽表示面积,高无效。 + public CFG_SIZE stuFilterMaxSize;//物体最大尺寸"ByLength"模式下表示宽高的尺寸,"ByArea"模式下宽表示面积,高无效。 + public int nExcludeRegionNum;//排除区域数 + public CFG_REGION[] stuExcludeRegion = (CFG_REGION[])new CFG_REGION().toArray(MAX_EXCLUDEREGION_NUM);//排除区域 + public int nCalibrateBoxNum;//校准框个数 + public CFG_CALIBRATEBOX_INFO[] stuCalibrateBoxs = (CFG_CALIBRATEBOX_INFO[])new CFG_CALIBRATEBOX_INFO().toArray(MAX_CALIBRATEBOX_NUM);//校准框(远端近端标定模式下有效) + public byte bAccuracy;//检测精度是否有效,类型bool,取值0或1 + public byte byAccuracy;//检测精度 + public byte bMovingStep;//算法移动步长是否有效,类型bool,取值0或1 + public byte byMovingStep;//算法移动步长 + public byte bScalingFactor;//算法缩放因子是否有效,类型bool,取值0或1 + public byte byScalingFactor;//算法缩放因子 + public byte[] bReserved2 = new byte[1];//保留字段 + public byte abDetectBalance;//漏检和误检平衡参数是否有效,类型bool,取值0或1 + public int nDetectBalance;//漏检和误检平衡0-折中模式(默认)1-漏检更少2-误检更少 + public byte abByRatio;//类型bool,取值0或1 + public byte abMinRatio;;//类型bool,取值0或1 + public byte abMaxRatio;;//类型bool,取值0或1 + public byte abMinAreaSize;;//类型bool,取值0或1 + public byte abMaxAreaSize;;//类型bool,取值0或1 + public byte bByRatio;//是否按宽高比过滤通过能力ComplexSizeFilter判断是否可用可以和nFilterType复用,类型bool,取值0或1 + public byte[] bReserved1 = new byte[2]; + public double dMinRatio;//最小宽高比 + public double dMaxRatio;//最大宽高比 + public CFG_SIZE stuMinAreaSize;//最小面积矩形框尺寸"计量方式"为"像素"时,表示最小面积矩形框的宽高尺寸;"计量方式"为"远端近端标定模式"时,表示基准框的最小宽高尺寸; + public CFG_SIZE stuMaxAreaSize;//最大面积矩形框尺寸,同上 + public byte abByArea;//类型bool,取值0或1 + public byte abMinArea;//类型bool,取值0或1 + public byte abMaxArea;//类型bool,取值0或1 + public byte abMinRatioSize;//类型bool,取值0或1 + public byte abMaxRatioSize;//类型bool,取值0或1 + public byte bByArea;//是否按面积过滤通过能力ComplexSizeFilter判断是否可用可以和nFilterType复用,类型bool,取值0或1 + public byte[] bReserved3 = new byte[2]; + public float nMinArea;//最小面积 + public float nMaxArea;//最大面积 + public CFG_SIZE stuMinRatioSize;//最小宽高比矩形框尺寸,最小宽高比对应矩形框的宽高尺寸。 + public CFG_SIZE stuMaxRatioSize;//最大宽高比矩形框尺寸,同上 + public int nAreaCalibrateBoxNum;//面积校准框个数 + public CFG_CALIBRATEBOX_INFO[] stuAreaCalibrateBoxs = (CFG_CALIBRATEBOX_INFO[])new CFG_CALIBRATEBOX_INFO().toArray(MAX_CALIBRATEBOX_NUM);//面积校准框 + public int nRatioCalibrateBoxs;//比例校准框个数 + public CFG_CALIBRATEBOX_INFO[] stuRatioCalibrateBoxs = (CFG_CALIBRATEBOX_INFO[])new CFG_CALIBRATEBOX_INFO().toArray(MAX_CALIBRATEBOX_NUM);//比例校准框个数 + public byte bAntiDisturbance;//是否开启去扰动模块,类型bool,取值0或1 + public byte bBacklight;//是否有逆光,类型bool,取值0或1 + public byte bShadow;//是否有阴影,类型bool,取值0或1 + public byte bContourAssistantTrack;//是否开启轮廓辅助跟踪,例:在人脸识别时可以通过跟踪人体来辅助识别脸,类型bool,取值0或1 + public int nPtzPresetId;//云台预置点,0~255,0表示固定场景,忽略预置点。大于0表示在此预置点时模块有效 + public int nObjectFilterNum;//物体特定的过滤器个数 + public CFG_OBJECT_SIZEFILTER_INFO[] stObjectFilter= (CFG_OBJECT_SIZEFILTER_INFO[])new CFG_OBJECT_SIZEFILTER_INFO().toArray(MAX_OBJECT_LIST_SIZE);//物体特定的过滤器信息 + public int abObjectImageSize; //BOOL类型,取值0或1 + public CFG_SIZE stObjectImageSize;//保证物体图像尺寸相同,单位是像素,不支持小数,取值:>=0,0表示自动调整大小 + public int nSpecailDetectNum;//特殊检测区域个数 + public CFG_SPECIALDETECT_INFO[] stSpecialDetectRegions= (CFG_SPECIALDETECT_INFO[])new CFG_SPECIALDETECT_INFO().toArray(MAX_SPECIALDETECT_NUM);//特殊检测区信息 + public int nAttribute;//需要识别物体的属性个数, 类型为unsigned int + public byte[] szAttributes = new byte[MAX_OBJECT_ATTRIBUTES_SIZE*MAX_NAME_LEN];//需要识别物体的属性列表,“Category” + public int abPlateAnalyseMode;//nPlateAnalyseMode是否有效, BOOL类型,取值0或1 + public int nPlateAnalyseMode;//车牌识别模式,0-只识别车头牌照1-只识别车尾牌照2-车头牌照优先(场景中大部分车均是车头牌照)3-车尾牌照优先(场景中大部分车均是车尾牌照) + //szAttributes属性存在"Category"时生效 + public int nCategoryNum;//需要识别物体的子类型总数 + public int[] emCategoryType= new int[MAX_CATEGORY_TYPE_NUMBER];//子类型信息, 元素取CFG_CATEGORY_TYPE中的值 + public byte[] szSceneType = new byte[CFG_COMMON_STRING_16]; // 检测区参数用于的场景类型 + } + + public static class CFG_ANALYSEMODULES_INFO extends Structure + { + public int nMoudlesNum;//检测模块数 + public CFG_MODULE_INFO[] stuModuleInfo= (CFG_MODULE_INFO[])new CFG_MODULE_INFO().toArray(MAX_ANALYSE_MODULE_NUM);//每个视频输入通道对应的各种类型物体的检测模块配置 + } + + // CLIENT_FindGroupInfo接口输入参数 + public static class NET_IN_FIND_GROUP_INFO extends Structure + { + public int dwSize; + public byte[] szGroupId = new byte[NET_COMMON_STRING_64]; //人员组ID,唯一标识一组人员,为空表示查询全部人员组信息 + + public NET_IN_FIND_GROUP_INFO() + { + this.dwSize = this.size(); + } + } + + // 人脸数据类型 + public static class EM_FACE_DB_TYPE extends Structure + { + public static final int NET_FACE_DB_TYPE_UNKOWN = 0; + public static final int NET_FACE_DB_TYPE_HISTORY = 1; //历史数据库,存放的是检测出的人脸信息,一般没有包含人脸对应人员信息 + public static final int NET_FACE_DB_TYPE_BLACKLIST = 2; //黑名单数据库 + public static final int NET_FACE_DB_TYPE_WHITELIST = 3; //白名单数据库,废弃 + public static final int NET_FACE_DB_TYPE_ALARM = 4; //报警库 + } + + // 人员组信息 + public static class NET_FACERECONGNITION_GROUP_INFO extends Structure + { + public int dwSize; + public int emFaceDBType; // 人员组类型,详见 EM_FACE_DB_TYPE, 取值为EM_FACE_DB_TYPE中的值 + public byte[] szGroupId = new byte[NET_COMMON_STRING_64]; // 人员组ID,唯一标识一组人员(不可修改,添加操作时无效) + public byte[] szGroupName = new byte[NET_COMMON_STRING_128]; // 人员组名称 + public byte[] szGroupRemarks = new byte[NET_COMMON_STRING_256]; // 人员组备注信息 + public int nGroupSize; // 当前组内人员数 + public int nSimilarity; // 库相似度阈值,人脸比对高于阈值认为匹配成功 + public int nRetChnCount; // 实际返回的通道号个数 + public int[] nChannel = new int[NET_MAX_CAMERA_CHANNEL_NUM]; // 当前组绑定到的视频通道号列表 + + public NET_FACERECONGNITION_GROUP_INFO() + { + this.dwSize = this.size(); + } + } + + // CLIENT_FindGroupInfo接口输出参数 + public static class NET_OUT_FIND_GROUP_INFO extends Structure + { + public int dwSize; + public Pointer pGroupInfos; //人员组信息,由用户申请空间, 指向 NET_FACERECONGNITION_GROUP_INFO 的指针 + public int nMaxGroupNum; //当前申请的数组大小 + public int nRetGroupNum; //设备返回的人员组个数 + + public NET_OUT_FIND_GROUP_INFO() + { + this.dwSize = this.size(); + } + } + + // 人员组操作枚举 + public static class EM_OPERATE_FACERECONGNITION_GROUP_TYPE extends Structure + { + public static final int NET_FACERECONGNITION_GROUP_UNKOWN = 0; + public static final int NET_FACERECONGNITION_GROUP_ADD = 1; // 添加人员组信息, 对应结构体为 NET_ADD_FACERECONGNITION_GROUP_INFO + public static final int NET_FACERECONGNITION_GROUP_MODIFY = 2; // 修改人员组信息, 对应结构体为 NET_MODIFY_FACERECONGNITION_GROUP_INFO + public static final int NET_FACERECONGNITION_GROUP_DELETE = 3; // 删除人员组信息, 对应结构体为 NET_DELETE_FACERECONGNITION_GROUP_INFO + } + + // CLIENT_OperateFaceRecognitionGroup 接口输入参数 + public static class NET_IN_OPERATE_FACERECONGNITION_GROUP extends Structure + { + public int dwSize; + public int emOperateType; // 操作类型, 取值为 EM_OPERATE_FACERECONGNITION_GROUP_TYPE 中的值 + public Pointer pOPerateInfo; // 相关操作信息,指向void * + + public NET_IN_OPERATE_FACERECONGNITION_GROUP() + { + this.dwSize = this.size(); + } + } + + // CLIENT_OperateFaceRecognitionGroup接口输出参数 + public static class NET_OUT_OPERATE_FACERECONGNITION_GROUP extends Structure + { + public int dwSize; + public byte[] szGroupId = new byte[NET_COMMON_STRING_64]; // 新增记录的人员组ID,唯一标识一组人员 + + public NET_OUT_OPERATE_FACERECONGNITION_GROUP() + { + this.dwSize = this.size(); + } + } + + // 添加人员组信息 + public static class NET_ADD_FACERECONGNITION_GROUP_INFO extends Structure + { + public int dwSize; + public NET_FACERECONGNITION_GROUP_INFO stuGroupInfo; // 人员组信息 + + public NET_ADD_FACERECONGNITION_GROUP_INFO() { + this.dwSize = this.size(); + } + } + + // 修改人员组信息 + public static class NET_MODIFY_FACERECONGNITION_GROUP_INFO extends Structure + { + public int dwSize; + public NET_FACERECONGNITION_GROUP_INFO stuGroupInfo; // 人员组信息 + + public NET_MODIFY_FACERECONGNITION_GROUP_INFO() { + this.dwSize = this.size(); + } + } + + // 删除人员组信息 + public static class NET_DELETE_FACERECONGNITION_GROUP_INFO extends Structure + { + public int dwSize; + public byte[] szGroupId = new byte[NET_COMMON_STRING_64]; // 人员组ID,唯一标识一组人员 + + public NET_DELETE_FACERECONGNITION_GROUP_INFO() { + this.dwSize = this.size(); + } + } + + // CLIENT_SetGroupInfoForChannel接口输入参数 + public static class NET_IN_SET_GROUPINFO_FOR_CHANNEL extends Structure + { + public int dwSize; + public int nChannelID;//通道号 + public int nGroupIdNum;//人员组数 + public byte[] szGroupId = new byte[MAX_GOURP_NUM*NET_COMMON_STRING_64];//人员组ID + + public NET_IN_SET_GROUPINFO_FOR_CHANNEL() + { + this.dwSize = this.size(); + } + } + + // CLIENT_SetGroupInfoForChannel接口输出参数 + public static class NET_OUT_SET_GROUPINFO_FOR_CHANNEL extends Structure + { + public int dwSize; + + public NET_OUT_SET_GROUPINFO_FOR_CHANNEL() + { + this.dwSize = this.size(); + } + } + + // 人脸查询状态信息回调函数, lAttachHandle是CLIENT_AttachFaceFindState的返回值 + public static class NET_CB_FACE_FIND_STATE extends Structure + { + public int dwSize; + public int nToken;//视频浓缩任务数据库主键ID + public int nProgress;//正常取值范围:0-100,-1,表示查询token不存在(当订阅一个不存在或结束的查询时) + public int nCurrentCount;//目前符合查询条件的人脸数量 + + public NET_CB_FACE_FIND_STATE() + { + this.dwSize = this.size(); + } + } + + //CLIENT_AttachFaceFindState接口输入参数 + public static class NET_IN_FACE_FIND_STATE extends Structure + { + public int dwSize;//结构体大小,必须填写 + public int nTokenNum;//查询令牌数,为0时,表示订阅所有的查询任务 + public Pointer nTokens;//查询令牌, 指向int的指针 + public StdCallCallback cbFaceFindState; //回调函数 fFaceFindState 回调 + public LLong dwUser;//用户数据 + + public NET_IN_FACE_FIND_STATE() + { + this.dwSize = this.size(); + } + } + + //CLIENT_AttachFaceFindState接口输入参数 + public static class NET_OUT_FACE_FIND_STATE extends Structure + { + public int dwSize; + + public NET_OUT_FACE_FIND_STATE() + { + this.dwSize = this.size(); + } + } + + // SDK全局日志打印信息 + public static class LOG_SET_PRINT_INFO extends Structure + { + public int dwSize; + public int bSetFilePath;//是否重设日志路径, BOOL类型,取值0或1 + public byte[] szLogFilePath = new byte[MAX_LOG_PATH_LEN];//日志路径(默认"./sdk_log/sdk_log.log") + public int bSetFileSize;//是否重设日志文件大小, BOOL类型,取值0或1 + public int nFileSize;//每个日志文件的大小(默认大小10240),单位:比特, 类型为unsigned int + public int bSetFileNum;//是否重设日志文件个数, BOOL类型,取值0或1 + public int nFileNum;//绕接日志文件个数(默认大小10), 类型为unsigned int + public int bSetPrintStrategy;//是否重设日志打印输出策略, BOOL类型,取值0或1 + public int nPrintStrategy;//日志输出策略,0:输出到文件(默认); 1:输出到窗口, 类型为unsigned int + + public LOG_SET_PRINT_INFO() + { + this.dwSize = this.size(); + } + } + + // media文件查询条件 + public static class EM_FILE_QUERY_TYPE extends Structure + { + public static final int NET_FILE_QUERY_TRAFFICCAR = 0; //交通车辆信息 + public static final int NET_FILE_QUERY_ATM = 1; //ATM信息 + public static final int NET_FILE_QUERY_ATMTXN = 2; //ATM交易信息 + public static final int NET_FILE_QUERY_FACE = 3; //人脸信息 MEDIAFILE_FACERECOGNITION_PARAM和MEDIAFILE_FACERECOGNITION_INFO + public static final int NET_FILE_QUERY_FILE = 4; //文件信息对应 NET_IN_MEDIA_QUERY_FILE 和 NET_OUT_MEDIA_QUERY_FILE + public static final int NET_FILE_QUERY_TRAFFICCAR_EX = 5; //交通车辆信息,扩展NET_FILE_QUERY_TRAFFICCAR,支持更多的字段 + public static final int NET_FILE_QUERY_FACE_DETECTION = 6; //人脸检测事件信息MEDIAFILE_FACE_DETECTION_PARAM和 MEDIAFILE_FACE_DETECTION_INFO + } + + // 查询跳转条件 + public static class NET_FINDING_JUMP_OPTION_INFO extends Structure + { + public int dwSize; + public int nOffset;//查询结果偏移量,是相对于当前查询的第一条查询结果的位置偏移 + + public NET_FINDING_JUMP_OPTION_INFO() + { + this.dwSize = this.size(); + } + } + + // 云台联动类型 + public static class CFG_LINK_TYPE extends Structure + { + public static final int LINK_TYPE_NONE = 0; //无联动 + public static final int LINK_TYPE_PRESET = 1; //联动预置点 + public static final int LINK_TYPE_TOUR = 2; //联动巡航 + public static final int LINK_TYPE_PATTERN = 3; //联动轨迹 + } + + // 联动云台信息 + public static class CFG_PTZ_LINK extends Structure + { + public int emType;//联动类型, 取值为CFG_LINK_TYPE中的值 + public int nValue;//联动取值分别对应预置点号,巡航号等等 + } + + // 联动云台信息扩展 + public static class CFG_PTZ_LINK_EX extends Structure + { + public int emType;//联动类型, 取值为CFG_LINK_TYPE中的值 + public int nParam1;//联动参数1 + public int nParam2;//联动参数2 + public int nParam3;//联动参数3 + public int nChannelID;//所联动云台通道 + } + + // RGBA信息 + public static class CFG_RGBA extends Structure + { + public int nRed; + public int nGreen; + public int nBlue; + public int nAlpha; + } + + // 事件标题内容结构体 + public static class CFG_EVENT_TITLE extends Structure + { + public byte[] szText = new byte[MAX_CHANNELNAME_LEN]; + public CFG_POLYGON stuPoint;//标题左上角坐标,采用0-8191相对坐标系 + public CFG_SIZE stuSize;//标题的宽度和高度,采用0-8191相对坐标系,某项或者两项为0表示按照字体自适应宽高 + public CFG_RGBA stuFrontColor;//前景颜色 + public CFG_RGBA stuBackColor;//背景颜色 + } + + // 邮件附件类型 + public static class CFG_ATTACHMENT_TYPE extends Structure + { + public static final int ATTACHMENT_TYPE_PIC = 0; //图片附件 + public static final int ATTACHMENT_TYPE_VIDEO = 1; //视频附件 + public static final int ATTACHMENT_TYPE_NUM = 2; //附件类型总数 + } + + // 分割模式 + public static class CFG_SPLITMODE extends Structure + { + public static final int SPLITMODE_1 =1;//1画面 + public static final int SPLITMODE_2 =2;//2画面 + public static final int SPLITMODE_4 =4;//4画面 + public static final int SPLITMODE_6 =6;//6画面 + public static final int SPLITMODE_8 =8;//8画面 + public static final int SPLITMODE_9 =9;//9画面 + public static final int SPLITMODE_12 =12;//12画面 + public static final int SPLITMODE_16 =16;//16画面 + public static final int SPLITMODE_20 =20;//20画面 + public static final int SPLITMODE_25 =25;//25画面 + public static final int SPLITMODE_36 =36;//36画面 + public static final int SPLITMODE_64 =64;//64画面 + public static final int SPLITMODE_144 =144;//144画面 + public static final int SPLITMODE_PIP =1000;//画中画分割模式基础值 + public static final int SPLITMODE_PIP1 =SPLITMODE_PIP+1;//画中画模式, 1个全屏大画面+1个小画面窗口 + public static final int SPLITMODE_PIP3 =SPLITMODE_PIP+3;//画中画模式, 1个全屏大画面+3个小画面窗口 + public static final int SPLITMODE_FREE =SPLITMODE_PIP*2;//自由开窗模式,可以自由创建、关闭窗口,自由设置窗口位置和Z轴次序 + public static final int SPLITMODE_COMPOSITE_1 = SPLITMODE_PIP * 3 + 1; // 融合屏成员1分割 + public static final int SPLITMODE_COMPOSITE_4 = SPLITMODE_PIP * 3 + 4; // 融合屏成员4分割 + public static final int SPLITMODE_EOF = SPLITMODE_COMPOSITE_4+1; //结束标识 + } + + // 轮巡联动配置 + public static class CFG_TOURLINK extends Structure + { + public int bEnable;//轮巡使能, BOOL类型,取值0或1 + public int emSplitMode;//轮巡时的分割模式,取值范围为CFG_SPLITMODE中的值 + public int[] nChannels = new int[MAX_VIDEO_CHANNEL_NUM];//轮巡通道号列表 + public int nChannelCount;//轮巡通道数量 + } + + // 门禁操作类型 + public static class EM_CFG_ACCESSCONTROLTYPE extends Structure + { + public static final int EM_CFG_ACCESSCONTROLTYPE_NULL = 0;//不做操作 + public static final int EM_CFG_ACCESSCONTROLTYPE_AUTO = 1; //自动 + public static final int EM_CFG_ACCESSCONTROLTYPE_OPEN = 2; //开门 + public static final int EM_CFG_ACCESSCONTROLTYPE_CLOSE = 3; //关门 + public static final int EM_CFG_ACCESSCONTROLTYPE_OPENALWAYS = 4; //永远开启 + public static final int EM_CFG_ACCESSCONTROLTYPE_CLOSEALWAYS = 5; //永远关闭 + } + + // 邮件详细内容 + public static class CFG_MAIL_DETAIL extends Structure + { + public int emAttachType;//附件类型, 取值范围为CFG_ATTACHMENT_TYPE中的值 + public int nMaxSize;//文件大小上限,单位kB + public int nMaxTimeLength;//最大录像时间长度,单位秒,对video有效 + } + + // 语音呼叫发起方 + public static class EM_CALLER_TYPE extends Structure + { + public static final int EM_CALLER_DEVICE = 0;//设备发起 + } + + //获取测温项温度的条件 + public static class NET_RADIOMETRY_CONDITION extends Structure + { + public int nPresetId; // 预置点编号 + public int nRuleId; // 规则编号 + public int nMeterType; // 测温项类别,见NET_RADIOMETRY_METERTYPE + public byte[] szName = new byte[64]; // 测温项的名称,从测温配置规则名字中选取 + public int nChannel; // 通道号 + public byte[] reserved = new byte[256]; + } + + // CLIENT_QueryDevInfo 接口 NET_QUERY_DEV_RADIOMETRY_TEMPER 命令入参 + public static class NET_IN_RADIOMETRY_GETTEMPER extends Structure + { + public int dwSize; + public NET_RADIOMETRY_CONDITION stCondition; // 获取测温项温度的条件 + public NET_IN_RADIOMETRY_GETTEMPER() + { + this.dwSize = this.size(); + } + } + //获取测温项温度的条件 + public static class NET_RADIOMETRYINFO extends Structure + { + public int nMeterType; // 返回测温类型,见NET_RADIOMETRY_METERTYPE + public int nTemperUnit; // 温度单位(当前配置的温度单位),见 NET_TEMPERATURE_UNIT + public float fTemperAver; // 点的温度或者平均温度 点的时候 只返回此字段 + public float fTemperMax; // 最高温度 + public float fTemperMin; // 最低温度 + public float fTemperMid; // 中间温度值 + public float fTemperStd; // 标准方差值 + public byte[] reserved= new byte[64]; + } + // CLIENT_QueryDevInfo 接口 NET_QUERY_DEV_RADIOMETRY_TEMPER 命令出参 + public static class NET_OUT_RADIOMETRY_GETTEMPER extends Structure + { + public int dwSize; + public NET_RADIOMETRYINFO stTempInfo; // 获取测温参数值 + public NET_OUT_RADIOMETRY_GETTEMPER() + { + this.dwSize = this.size(); + } + } + // 呼叫协议 + public static class EM_CALLER_PROTOCOL_TYPE extends Structure + { + public static final int EM_CALLER_PROTOCOL_CELLULAR = 0;//手机方式 + } + + // 语音呼叫联动信息 + public static class CFG_TALKBACK_INFO extends Structure + { + public int bCallEnable;//语音呼叫使能, BOOL类型,取值0或1 + public int emCallerType;//语音呼叫发起方, 取值范围为EM_CALLER_TYPE中的值 + public int emCallerProtocol;//语音呼叫协议, 取值范围为EM_CALLER_PROTOCOL_TYPE中的值 + } + + // 电话报警中心联动信息 + public static class CFG_PSTN_ALARM_SERVER extends Structure + { + public int bNeedReport;//是否上报至电话报警中心, BOOL类型,取值0或1 + public int nServerCount;//电话报警服务器个数 + public byte[] byDestination = new byte[MAX_PSTN_SERVER_NUM];//上报的报警中心下标,详见配置CFG_PSTN_ALARM_CENTER_INFO + } + + // 时间表信息 + public static class CFG_TIME_SCHEDULE extends Structure + { + public int bEnableHoliday;//是否支持节假日配置,默认为不支持,除非获取配置后返回为TRUE,不要使能假日配置, BOOL类型,取值0或1 + public CFG_TIME_SECTION[] stuTimeSection = (CFG_TIME_SECTION[])new CFG_TIME_SECTION().toArray(MAX_TIME_SCHEDULE_NUM*MAX_REC_TSECT);//第一维前7个元素对应每周7天,第8个元素对应节假日,每天最多6个时间段 + } + + // 报警联动信息 + public static class CFG_ALARM_MSG_HANDLE extends Structure + { + //能力 + public byte abRecordMask;//类型bool, 取值0或者1 + public byte abRecordEnable;//类型bool, 取值0或者1 + public byte abRecordLatch;//类型bool, 取值0或者1 + public byte abAlarmOutMask;//类型bool, 取值0或者1 + public byte abAlarmOutEn;//类型bool, 取值0或者1 + public byte abAlarmOutLatch;//类型bool, 取值0或者1 + public byte abExAlarmOutMask;//类型bool, 取值0或者1 + public byte abExAlarmOutEn;//类型bool, 取值0或者1 + public byte abPtzLinkEn;//类型bool, 取值0或者1 + public byte abTourMask;//类型bool, 取值0或者1 + public byte abTourEnable;//类型bool, 取值0或者1 + public byte abSnapshot;//类型bool, 取值0或者1 + public byte abSnapshotEn;//类型bool, 取值0或者1 + public byte abSnapshotPeriod;//类型bool, 取值0或者1 + public byte abSnapshotTimes;//类型bool, 取值0或者1 + public byte abTipEnable;//类型bool, 取值0或者1 + public byte abMailEnable;//类型bool, 取值0或者1 + public byte abMessageEnable;//类型bool, 取值0或者1 + public byte abBeepEnable;//类型bool, 取值0或者1 + public byte abVoiceEnable;//类型bool, 取值0或者1 + public byte abMatrixMask;//类型bool, 取值0或者1 + public byte abMatrixEnable;//类型bool, 取值0或者1 + public byte abEventLatch;//类型bool, 取值0或者1 + public byte abLogEnable;//类型bool, 取值0或者1 + public byte abDelay;//类型bool, 取值0或者1 + public byte abVideoMessageEn;//类型bool, 取值0或者1 + public byte abMMSEnable;//类型bool, 取值0或者1 + public byte abMessageToNetEn;//类型bool, 取值0或者1 + public byte abTourSplit;//类型bool, 取值0或者1 + public byte abSnapshotTitleEn;//类型bool, 取值0或者1 + public byte abChannelCount;//类型bool, 取值0或者1 + public byte abAlarmOutCount;//类型bool, 取值0或者1 + public byte abPtzLinkEx;//类型bool, 取值0或者1 + public byte abSnapshotTitle;//类型bool, 取值0或者1 + public byte abMailDetail;//类型bool, 取值0或者1 + public byte abVideoTitleEn;//类型bool, 取值0或者1 + public byte abVideoTitle;//类型bool, 取值0或者1 + public byte abTour;//类型bool, 取值0或者1 + public byte abDBKeys;//类型bool, 取值0或者1 + public byte abJpegSummary;//类型bool, 取值0或者1 + public byte abFlashEn;//类型bool, 取值0或者1 + public byte abFlashLatch;//类型bool, 取值0或者1 + //信息 + public int nChannelCount;//设备的视频通道数 + public int nAlarmOutCount;//设备的报警输出个数 + public int[] dwRecordMask = new int[MAX_CHANNEL_COUNT];//录像通道掩码(按位) + public int bRecordEnable;//录像使能, BOOL类型,取值0或1 + public int nRecordLatch;//录像延时时间(秒) + public int[] dwAlarmOutMask = new int[MAX_CHANNEL_COUNT];//报警输出通道掩码 + public int bAlarmOutEn;//报警输出使能, BOOL类型,取值0或1 + public int nAlarmOutLatch;//报警输出延时时间(秒) + public int[] dwExAlarmOutMask = new int[MAX_CHANNEL_COUNT];//扩展报警输出通道掩码 + public int bExAlarmOutEn;//扩展报警输出使能, BOOL类型,取值0或1 + public CFG_PTZ_LINK [] stuPtzLink = (CFG_PTZ_LINK [])new CFG_PTZ_LINK().toArray(MAX_VIDEO_CHANNEL_NUM);//云台联动项 + public int bPtzLinkEn;//云台联动使能, BOOL类型,取值0或1 + public int[] dwTourMask = new int[MAX_CHANNEL_COUNT];//轮询通道掩码 + public int bTourEnable;//轮询使能, BOOL类型,取值0或1 + public int[] dwSnapshot = new int[MAX_CHANNEL_COUNT];//快照通道号掩码 + public int bSnapshotEn;//快照使能, BOOL类型,取值0或1 + public int nSnapshotPeriod;//连拍周期(秒) + public int nSnapshotTimes;//连拍次数 + public int bTipEnable;//本地消息框提示, BOOL类型,取值0或1 + public int bMailEnable;//发送邮件,如果有图片,作为附件, BOOL类型,取值0或1 + public int bMessageEnable;//上传到报警服务器, BOOL类型,取值0或1 + public int bBeepEnable;//蜂鸣, BOOL类型,取值0或1 + public int bVoiceEnable;//语音提示, BOOL类型,取值0或1 + public int[] dwMatrixMask = new int[MAX_CHANNEL_COUNT];//联动视频矩阵通道掩码 + public int bMatrixEnable;//联动视频矩阵, BOOL类型,取值0或1 + public int nEventLatch;//联动开始延时时间(秒),0-15 + public int bLogEnable;//是否记录日志, BOOL类型,取值0或1 + public int nDelay;//设置时先延时再生效,单位为秒 + public int bVideoMessageEn;//叠加提示字幕到视频。叠加的字幕包括事件类型,通道号,秒计时。BOOL类型,取值0或1 + public int bMMSEnable;//发送彩信使能, BOOL类型,取值0或1 + public int bMessageToNetEn;//消息上传给网络使能, BOOL类型,取值0或1 + public int nTourSplit;//轮巡时的分割模式0:1画面; + public int bSnapshotTitleEn;//是否叠加图片标题, BOOL类型,取值0或1 + public int nPtzLinkExNum;//云台配置数 + public CFG_PTZ_LINK_EX[] stuPtzLinkEx = (CFG_PTZ_LINK_EX[])new CFG_PTZ_LINK_EX().toArray(MAX_VIDEO_CHANNEL_NUM);//扩展云台信息 + public int nSnapTitleNum;//图片标题内容数 + public CFG_EVENT_TITLE[] stuSnapshotTitle = (CFG_EVENT_TITLE[])new CFG_EVENT_TITLE().toArray(MAX_VIDEO_CHANNEL_NUM);//图片标题内容 + public CFG_MAIL_DETAIL stuMailDetail;//邮件详细内容 + public int bVideoTitleEn;//是否叠加视频标题,主要指主码流, BOOL类型,取值0或1 + public int nVideoTitleNum;//视频标题内容数目 + public CFG_EVENT_TITLE[] stuVideoTitle = (CFG_EVENT_TITLE[])new CFG_EVENT_TITLE().toArray(MAX_VIDEO_CHANNEL_NUM);//视频标题内容 + public int nTourNum;//轮询联动数目 + public CFG_TOURLINK[] stuTour = (CFG_TOURLINK[])new CFG_TOURLINK().toArray(MAX_VIDEO_CHANNEL_NUM);//轮询联动配置 + public int nDBKeysNum;//指定数据库关键字的有效数 + public byte[] szDBKeys = new byte[MAX_DBKEY_NUM*MAX_CHANNELNAME_LEN];//指定事件详细信息里需要写到数据库的关键字 + public byte[] byJpegSummary = new byte[MAX_SUMMARY_LEN];//叠加到JPEG图片的摘要信息 + public int bFlashEnable;//是否使能补光灯, BOOL类型,取值0或1 + public int nFlashLatch;//补光灯延时时间(秒),延时时间范围:10,300] + public byte abAudioFileName;//bool类型,取值0或1 + public byte abAlarmBellEn;//bool类型,取值0或1 + public byte abAccessControlEn;//bool类型,取值0或1 + public byte abAccessControl;//bool类型,取值0或1 + public byte[] szAudioFileName = new byte[MAX_PATH];//联动语音文件绝对路径 + public int bAlarmBellEn;//警号使能, BOOL类型,取值0或1 + public int bAccessControlEn;//门禁使能, BOOL类型,取值0或1 + public int dwAccessControl;//门禁组数 + public int[] emAccessControlType = new int[MAX_ACCESSCONTROL_NUM];//门禁联动操作信息, 元素取值范围为EM_CFG_ACCESSCONTROLTYPE中的值 + public byte abTalkBack;//bool类型,取值0或1 + public CFG_TALKBACK_INFO stuTalkback;//语音呼叫联动信息 + public byte abPSTNAlarmServer;//bool类型,取值0或1 + public CFG_PSTN_ALARM_SERVER stuPSTNAlarmServer;//电话报警中心联动信息 + public CFG_TIME_SCHEDULE stuTimeSection;//事件响应时间表 + public byte abAlarmBellLatch;//bool类型,取值0或1 + public int nAlarmBellLatch;//警号输出延时时间(10-300秒) + } + + // 时间段信息 + public static class CFG_TIME_SECTION extends Structure + { + public int dwRecordMask;//录像掩码,按位分别为动态检测录像、报警录像、定时录像、Bit3~Bit15保留、Bit16动态检测抓图、Bit17报警抓图、Bit18定时抓图 + public int nBeginHour; + public int nBeginMin; + public int nBeginSec; + public int nEndHour; + public int nEndMin; + public int nEndSec; + } + + // 事件类型EVENT_IVS_FACERECOGNITION(人脸识别)对应的规则配置 + public static class CFG_FACERECOGNITION_INFO extends Structure + { + // 信息 + public byte[] szRuleName = new byte[MAX_NAME_LEN];//规则名称,不同规则不能重名 + public byte bRuleEnable;//规则使能,bool类型,取值0或1 + public byte[] bReserved = new byte[2];//保留字段 + public int nObjectTypeNum;//相应物体类型个数 + public byte[] szObjectTypes = new byte[MAX_OBJECT_LIST_SIZE*MAX_NAME_LEN];//相应物体类型列表 + public int nPtzPresetId;//云台预置点编号0~65535 + public byte bySimilarity;//相似度,必须大于该相识度才报告(1~100) + public byte byAccuracy;//识别精度(取值1~10,随着值增大,检测精度提高,检测速度下降。最小值为1表示检测速度优先,最大值为10表示检测精度优先) + public byte byMode;//对比模式,0-正常,1-指定人脸区域组合, + public byte byImportantRank;//查询重要等级大于等于此等级的人员(1~10,数值越高越重要) + public int nAreaNum;//区域数 + public byte[] byAreas = new byte[8];//人脸区域组合,0-眉毛,1-眼睛,2-鼻子,3-嘴巴,4-脸颊(此参数在对比模式为1时有效) + public int nMaxCandidate;//报告的最大匹配图片个数 + public CFG_ALARM_MSG_HANDLE stuEventHandler;//报警联动 + public CFG_TIME_SECTION[] stuTimeSection = (CFG_TIME_SECTION[])new CFG_TIME_SECTION().toArray(WEEK_DAY_NUM*MAX_REC_TSECT_EX);//事件响应时间段 + } + + // 大类业务方案 + public static class EM_CLASS_TYPE extends Structure + { + public static final int EM_CLASS_UNKNOWN =0;//未知业务 + public static final int EM_CLASS_VIDEO_SYNOPSIS =1;//视频浓缩 + public static final int EM_CLASS_TRAFFIV_GATE =2;//卡口 + public static final int EM_CLASS_ELECTRONIC_POLICE =3;//电警 + public static final int EM_CLASS_SINGLE_PTZ_PARKING =4;//单球违停 + public static final int EM_CLASS_PTZ_PARKINBG =5;//主从违停 + public static final int EM_CLASS_TRAFFIC =6;//交通事件"Traffic" + public static final int EM_CLASS_NORMAL =7;//通用行为分析"Normal" + public static final int EM_CLASS_PRISON =8;//监所行为分析"Prison" + public static final int EM_CLASS_ATM =9;//金融行为分析"ATM" + public static final int EM_CLASS_METRO =10;//地铁行为分析 + public static final int EM_CLASS_FACE_DETECTION =11;//人脸检测"FaceDetection" + public static final int EM_CLASS_FACE_RECOGNITION =12;//人脸识别"FaceRecognition" + public static final int EM_CLASS_NUMBER_STAT =13;//人数统计"NumberStat" + public static final int EM_CLASS_HEAT_MAP =14;//热度图"HeatMap" + public static final int EM_CLASS_VIDEO_DIAGNOSIS =15;//视频诊断"VideoDiagnosis" + public static final int EM_CLASS_VIDEO_ENHANCE =16;//视频增强 + public static final int EM_CLASS_SMOKEFIRE_DETECT =17;//烟火检测 + public static final int EM_CLASS_VEHICLE_ANALYSE =18;//车辆特征识别"VehicleAnalyse" + public static final int EM_CLASS_PERSON_FEATURE =19;//人员特征识别 + } + + // 智能报警事件公共信息 + public static class EVENT_INTELLI_COMM_INFO extends Structure + { + public int emClassType; // 智能事件所属大类, 取值为 EM_CLASS_TYPE 中的值 + public int nPresetID; // 该事件触发的预置点,对应该设置规则的预置点 + public byte[] bReserved = new byte[124]; // 保留字节,留待扩展. + } + + // 事件类型EVENT_IVS_FACERECOGNITION(人脸识别)对应的数据块描述信息 + public static class DEV_EVENT_FACERECOGNITION_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public int nEventID; // 事件ID + public NET_TIME_EX UTC; // 事件发生的时间 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public int nCandidateNum; // 当前人脸匹配到的候选对象数量 + public CANDIDATE_INFO[] stuCandidates = (CANDIDATE_INFO[])new CANDIDATE_INFO().toArray(NET_MAX_CANDIDATE_NUM);// 当前人脸匹配到的候选对象信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte byImageIndex; // 图片的序号,同一时间内(精确到秒)可能有多张图片,从0开始 + public byte[] byReserved1 = new byte[2]; // 对齐 + public int bGlobalScenePic; // 全景图是否存在, 类型为BOOL, 取值为0或者1 + public NET_PIC_INFO stuGlobalScenePicInfo; // 全景图片信息 + public byte[] szSnapDevAddress = new byte[MAX_PATH];//抓拍当前人脸的设备地址,如:滨康路37号 + public int nOccurrenceCount; // 事件触发累计次数, 类型为unsigned int + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public NET_FACE_DATA stuFaceData; // 人脸数据 + public byte[] bReserved = new byte[300]; // 保留字节,留待扩展. + } + + // 人脸数据 + public static class NET_FACE_DATA extends Structure + { + public int emSex; // 性别, 参考 EM_DEV_EVENT_FACEDETECT_SEX_TYPE + public int nAge; // 年龄,-1表示该字段数据无效 + public int nFeatureValidNum; // 人脸特征数组有效个数,与 emFeature 结合使用 + public int[] emFeature = new int[NET_MAX_FACEDETECT_FEATURE_NUM]; // 人脸特征数组,与 nFeatureValidNum 结合使用, 参考 EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE + public int emRace; // 种族, 参考 EM_RACE_TYPE + public int emEye; // 眼睛状态, 参考 EM_EYE_STATE_TYPE + public int emMouth; // 嘴巴状态, 参考 EM_MOUTH_STATE_TYPE + public int emMask; // 口罩状态, 参考 EM_MASK_STATE_TYPE + public int emBeard; // 胡子状态, 参考 EM_BEARD_STATE_TYPE + public int nAttractive; // 魅力值, -1表示无效, 0未识别,识别时范围1-100,得分高魅力高 + public byte[] bReserved = new byte[128]; // 保留字节,留待扩展. + } + + //人脸检测对应性别类型 + public static class EM_DEV_EVENT_FACEDETECT_SEX_TYPE extends Structure + { + public static final int EM_DEV_EVENT_FACEDETECT_SEX_TYPE_UNKNOWN = 0; //未知 + public static final int EM_DEV_EVENT_FACEDETECT_SEX_TYPE_MAN = 1; //男性 + public static final int EM_DEV_EVENT_FACEDETECT_SEX_TYPE_WOMAN = 2; //女性 + } + + //人脸检测对应人脸特征类型 + public static class EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE extends Structure + { + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_UNKNOWN = 0; //未知 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_WEAR_GLASSES = 1; //戴眼镜 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_SMILE = 2; //微笑 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_ANGER = 3; //愤怒 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_SADNESS = 4; //悲伤 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_DISGUST = 5; //厌恶 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_FEAR = 6; //害怕 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_SURPRISE = 7; //惊讶 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_NEUTRAL = 8; //正常 + public static final int EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE_LAUGH = 9; //大笑 + } + + // 种族类型 + public static class EM_RACE_TYPE extends Structure + { + public static final int EM_RACE_UNKNOWN = 0; // 未知 + public static final int EM_RACE_NODISTI = 1; // 未识别 + public static final int EM_RACE_YELLOW = 2; // 黄种人 + public static final int EM_RACE_BLACK = 3; // 黑人 + public static final int EM_RACE_WHITE = 4; // 白人 + } + + // 眼睛状态 + public static class EM_EYE_STATE_TYPE extends Structure + { + public static final int EM_EYE_STATE_UNKNOWN = 0; // 未知 + public static final int EM_EYE_STATE_NODISTI = 1; // 未识别 + public static final int EM_EYE_STATE_CLOSE = 2; // 闭眼 + public static final int EM_EYE_STATE_OPEN = 3; // 睁眼 + } + + // 嘴巴状态 + public static class EM_MOUTH_STATE_TYPE extends Structure + { + public static final int EM_MOUTH_STATE_UNKNOWN = 0; // 未知 + public static final int EM_MOUTH_STATE_NODISTI = 1; // 未识别 + public static final int EM_MOUTH_STATE_CLOSE = 2; // 闭嘴 + public static final int EM_MOUTH_STATE_OPEN = 3; // 张嘴 + } + + // 口罩状态 + public static class EM_MASK_STATE_TYPE extends Structure + { + public static final int EM_MASK_STATE_UNKNOWN = 0; // 未知 + public static final int EM_MASK_STATE_NODISTI = 1; // 未识别 + public static final int EM_MASK_STATE_NOMASK = 2; // 没戴口罩 + public static final int EM_MASK_STATE_WEAR = 3; // 戴口罩 + } + + // 胡子状态 + public static class EM_BEARD_STATE_TYPE extends Structure + { + public static final int EM_BEARD_STATE_UNKNOWN = 0; // 未知 + public static final int EM_BEARD_STATE__NODISTI = 1; // 未识别 + public static final int EM_BEARD_STATE_NOBEARD = 2; // 没胡子 + public static final int EM_BEARD_STATE_HAVEBEARD = 3; // 有胡子 + } + + // 事件文件的文件标签类型 + public static class EM_EVENT_FILETAG extends Structure + { + public static final int NET_ATMBEFOREPASTE = 1; //ATM贴条前 + public static final int NET_ATMAFTERPASTE = 2; //ATM贴条后 + } + + // 事件对应文件信息 + public static class NET_EVENT_FILE_INFO extends Structure + { + public byte bCount;//当前文件所在文件组中的文件总数 + public byte bIndex;//当前文件在文件组中的文件编号(编号1开始) + public byte bFileTag;//文件标签,具体说明见枚举类型 EM_EVENT_FILETAG + public byte bFileType;//文件类型,0-普通1-合成2-抠图 + public NET_TIME_EX stuFileTime;//文件时间 + public int nGroupId;//同一组抓拍文件的唯一标识 + } + + // 多人脸检测信息 + public static class NET_FACE_INFO extends Structure + { + public int nObjectID;//物体ID,每个ID表示一个唯一的物体 + public byte[] szObjectType = new byte[128];//物体类型 + public int nRelativeID;//Relative与另一张图片ID相同,表示这张人脸抠图是从大图中取出的 + public DH_RECT BoundingBox;//包围盒 + public NET_POINT Center;//物体型心 + } + + //事件类型EVENT_IVS_FACEDETECT(人脸检测事件)对应的数据块描述信息 + public static class DEV_EVENT_FACEDETECT_INFO extends Structure + { + public int nChannelID;//通道号 + public byte[] szName = new byte[128];//事件名称 + public byte[] bReserved1 = new byte[4];//字节对齐 + public double PTS;//时间戳(单位是毫秒) + public NET_TIME_EX UTC;//事件发生的时间 + public int nEventID;//事件ID + public NET_MSG_OBJECT stuObject;//检测到的物体 + public NET_EVENT_FILE_INFO stuFileInfo;//事件对应文件信息 + public byte bEventAction;//事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] reserved = new byte[2];//保留字节 + public byte byImageIndex;//图片的序号,同一时间内(精确到秒)可能有多张图片,从0开始 + public int nDetectRegionNum;//规则检测区域顶点数 + public NET_POINT[] DetectRegion = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM);//规则检测区域 + public int dwSnapFlagMask;//抓图标志(按位),具体见NET_RESERVED_COMMON + public byte[] szSnapDevAddress = new byte[MAX_PATH];//抓拍当前人脸的设备地址,如:滨康路37号 + public int nOccurrenceCount;//事件触发累计次数, 类型为unsigned int + public int emSex;//性别, 取值为EM_DEV_EVENT_FACEDETECT_SEX_TYPE中的值 + public int nAge;//年龄,-1表示该字段数据无效 + public int nFeatureValidNum;//人脸特征数组有效个数,与emFeature结合使用, 类型为unsigned int + public int[] emFeature = new int[NET_MAX_FACEDETECT_FEATURE_NUM];//人脸特征数组,与nFeatureValidNum, 取值为EM_DEV_EVENT_FACEDETECT_FEATURE_TYPE中的值 + public int nFacesNum;//指示stuFaces有效数量 + public NET_FACE_INFO[] stuFaces = (NET_FACE_INFO[])new NET_FACE_INFO().toArray(10);//多张人脸时使用,此时没有Object + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo;//智能事件公共信息 + public byte[] bReserved = new byte[892];//保留字节,留待扩展 + } + + // 事件类型EVENT_IVS_TRAFFICJAM(交通拥堵事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFICJAM_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte bJamLenght; // 表示拥堵长度(总车道长度百分比)0-100 + public byte reserved; // 保留字节 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public NET_TIME_EX stuStartJamTime; // 开始停车时间 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束(bEventAction=2时此参数有效) + public int nAlarmIntervalTime; // 报警时间间隔,单位:秒。(此事件为连续性事件,在收到第一个此事件之后,若在超过间隔时间后未收到此事件的后续事件,则认为此事件异常结束了) + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public int nJamRealLength; // 表实际的拥堵长度,单位米 + public byte[] bReserved = new byte[1008]; // 保留字节,留待扩展. + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 车辆行驶方向 + public static class NET_FLOWSTAT_DIRECTION extends Structure + { + public static final int DRIVING_DIR_UNKNOW = 0 ; //兼容之前 + public static final int DRIVING_DIR_APPROACH = 1 ; //上行,即车辆离设备部署点越来越近 + public static final int DRIVING_DIR_LEAVE = 2 ; //下行,即车辆离设备部署点越来越远 + } + + //车辆流量统计车辆行驶方向信息 + public static class NET_TRAFFIC_FLOWSTAT_INFO_DIR extends Structure + { + public int emDrivingDir; //行驶方向 (参见NET_FLOWSTAT_DIRECTION) + public byte[] szUpGoing = new byte[FLOWSTAT_ADDR_NAME]; //上行地点 + public byte[] szDownGoing = new byte[FLOWSTAT_ADDR_NAME]; //下行地点 + public byte[] reserved= new byte[32]; //保留字节 + + } + + public static class NET_TRAFFIC_JAM_STATUS extends Structure + { + public static final int JAM_STATUS_UNKNOW = 0; //未知 + public static final int JAM_STATUS_CLEAR = 1; //通畅 + public static final int JAM_STATUS_JAMMED = 2; //拥堵 + } + + + public static class NET_TRAFFIC_FLOW_STATE extends Structure + { + public int nLane; // 车道号 + public int dwState; // 状态值 + // 1- 流量过大 + // 2- 流量过大恢复 + // 3- 正常 + // 4- 流量过小 + // 5- 流量过小恢复 + public int dwFlow; // 流量值, 单位: 辆 + public int dwPeriod; // 流量值对应的统计时间 + public NET_TRAFFIC_FLOWSTAT_INFO_DIR stTrafficFlowDir; // 车道方向信息 + public int nVehicles; // 通过车辆总数 + public float fAverageSpeed; // 平均车速,单位km/h + public float fAverageLength; // 平均车长,单位米 + public float fTimeOccupyRatio; // 时间占有率,即单位时间内通过断面的车辆所用时间的总和占单位时间的比例 + public float fSpaceOccupyRatio; // 空间占有率,即按百分率计量的车辆长度总和除以时间间隔内车辆平均行驶距离 + public float fSpaceHeadway; // 车头间距,相邻车辆之间的距离,单位米/辆 + public float fTimeHeadway; // 车头时距,单位秒/辆 + public float fDensity; // 车辆密度,每公里的车辆数,单位辆/km + public int nOverSpeedVehicles; // 超速车辆数 + public int nUnderSpeedVehicles; // 低速车辆数 + public int nLargeVehicles; // 大车交通量(9米<车长<12米),辆/单位时间 + public int nMediumVehicles; // 中型车交通量(6米<车长<9米),辆/单位时间 + public int nSmallVehicles; // 小车交通量(4米<车长<6米),辆/单位时间, + public int nMotoVehicles; // 摩托交通量(微型车,车长<4米),辆/单位时间, + public int nLongVehicles; // 超长交通量(车长>=12米),辆/单位时间, + public int nVolume; // 交通量, 辆/单位时间, 某时间间隔通过车道、道路或其他通道上一点的车辆数,常以1小时计, + public int nFlowRate; // 流率小车当量,辆/小时, 车辆通过车道、道路某一断面或某一路段的当量小时流量 + public int nBackOfQueue; // 排队长度,单位:米, 从信号交叉口停车线到上游排队车辆末端之间的距离 + public int nTravelTime; // 旅行时间,单位:秒, 车辆通过某一条道路所用时间。包括所有停车延误 + public int nDelay; // 延误,单位:秒,驾驶员、乘客或行人花费的额外的行程时间 + public byte[] byDirection = new byte[MAX_DRIVING_DIR_NUM]; // 车道方向,详见NET_ROAD_DIRECTION + public byte byDirectionNum; // 车道行驶方向个数 + public byte[] reserved1 = new byte[3]; // 字节对齐 + public int emJamState; // 道路拥挤状况 (参见 NET_TRAFFIC_JAM_STATUS ) + // 按车辆类型统计交通量 + public int nPassengerCarVehicles; // 客车交通量(辆/单位时间) + public int nLargeTruckVehicles; // 大货车交通量(辆/单位时间) + public int nMidTruckVehicles; // 中货车交通量(辆/单位时间) + public int nSaloonCarVehicles; // 轿车交通量(辆/单位时间) + public int nMicrobusVehicles; // 面包车交通量(辆/单位时间) + public int nMicroTruckVehicles; // 小货车交通量(辆/单位时间) + public int nTricycleVehicles; // 三轮车交通量(辆/单位时间) + public int nMotorcycleVehicles; // 摩托车交通量(辆/单位时间) + public int nPasserbyVehicles; // 行人交通量(辆/单位时间) + public int emRank; // 道路等级, 参考 NET_TRAFFIC_ROAD_RANK + public int nState; // 流量状态 + // 1- 流量过大(拥堵) + // 2- 流量过大恢复(略堵) + // 3- 正常 + // 4- 流量过小(通畅) + // 5- 流量过小恢复(良好) + public int bOccupyHeadCoil; // 车头虚拟线圈是否被占用 TURE表示占用,FALSE表示未占用 + public int bOccupyTailCoil; // 车尾虚拟线圈是否被占用 TURE表示占用,FALSE表示未占用 + public int bStatistics; // 流量数据是否有效 TURE表示有效,FALSE表示无效 + + public int nLeftVehicles; // 左转车辆总数,单位:分钟 + public int nRightVehicles; // 右转车辆总数,单位:分钟 + public int nStraightVehicles; // 直行车辆总数,单位:分钟 + public int nUTurnVehicles; // 掉头车辆总数,单位:分钟 + public NET_POINT stQueueEnd; // 每个车道的最后一辆车坐标,采用8192坐标系 + public double dBackOfQueue; // 排队长度,单位:米, 从信号交叉口停车线到上游排队车辆末端之间的距离 + public int dwPeriodByMili; // 流量值的毫秒时间,值不超过60000,和dwPeriod一起使用,流量值总时间:dwPeriod*60*1000+dwPeriodByMili(单位:毫秒) + public int nBusVehicles; // 公交车交通量(辆/单位时间) + public int nMPVVehicles; // MPV交通量(辆/单位时间) + public int nMidPassengerCarVehicles; // 中客车交通量(辆/单位时间) + public int nMiniCarriageVehicles; // 微型轿车交通量(辆/单位时间) + public int nOilTankTruckVehicles; // 油罐车交通量(辆/单位时间) + public int nPickupVehicles; // 皮卡车交通量(辆/单位时间) + public int nSUVVehicles; // SUV交通量(辆/单位时间) + public int nSUVorMPVVehicles; // SUV或者MPV交通量(辆/单位时间) + public int nTankCarVehicles; // 槽罐车交通量(辆/单位时间) + public int nUnknownVehicles; // 未知车辆交通量(辆/单位时间) + public byte[] reserved = new byte[724]; // 保留字节 + } + + //事件类型 EVENT_IVS_TRAFFIC_FLOWSTATE(交通流量事件)对应数据块描述信息 + public static class DEV_EVENT_TRAFFIC_FLOW_STATE extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] bReserved1 = new byte[8]; // 字节对齐 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nSequence; // 序号 + public int nStateNum; // 流量状态数量 + public NET_TRAFFIC_FLOW_STATE[] stuStates = (NET_TRAFFIC_FLOW_STATE[])new NET_TRAFFIC_FLOW_STATE().toArray(NET_MAX_LANE_NUM); // 流量状态, 每个车道对应数组中一个元素 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[892]; // 保留字节 + } + + // 图片分辨率 + public static class NET_RESOLUTION_INFO extends Structure + { + public short snWidth;//宽 + public short snHight;//高 + } + + public static class EM_COMMON_SEAT_TYPE extends Structure + { + public static final int COMMON_SEAT_TYPE_UNKNOWN = 0;//未识别 + public static final int COMMON_SEAT_TYPE_MAIN = 1;//主驾驶 + public static final int COMMON_SEAT_TYPE_SLAVE = 2;//副驾驶 + } + + // 违规状态 + public static class EVENT_COMM_STATUS extends Structure + { + public byte bySmoking;//是否抽烟 + public byte byCalling;//是否打电话 + public byte[] szReserved = new byte[14];//预留字段 + } + + public static class NET_SAFEBELT_STATE extends Structure + { + public static final int SS_NUKNOW = 0;//未知 + public static final int SS_WITH_SAFE_BELT = 1;//已系安全带 + public static final int SS_WITHOUT_SAFE_BELT = 2;//未系安全带 + } + + //遮阳板状态 + public static class NET_SUNSHADE_STATE extends Structure + { + public static final int SS_NUKNOW_SUN_SHADE = 0;//未知 + public static final int SS_WITH_SUN_SHADE = 1;//有遮阳板 + public static final int SS_WITHOUT_SUN_SHADE = 2;//无遮阳板 + } + + // 驾驶位违规信息 + public static class EVENT_COMM_SEAT extends Structure + { + public int bEnable;//是否检测到座驾信息, 类型BOOL, 取值0或者1 + public int emSeatType;//座驾类型,0:未识别;1:主驾驶; 取值为EM_COMMON_SEAT_TYPE中的值 + public EVENT_COMM_STATUS stStatus;//违规状态 + public int emSafeBeltStatus;//安全带状态, 取值为NET_SAFEBELT_STATE中的值 + public int emSunShadeStatus;//遮阳板状态, 取值为NET_SUNSHADE_STATE中的值 + public byte[] szReserved = new byte[24];//预留字节 + } + + public static class EM_COMM_ATTACHMENT_TYPE extends Structure + { + public static final int COMM_ATTACHMENT_TYPE_UNKNOWN = 0;// 未知类型 + public static final int COMM_ATTACHMENT_TYPE_FURNITURE = 1;// 摆件 + public static final int COMM_ATTACHMENT_TYPE_PENDANT = 2;// 挂件 + public static final int COMM_ATTACHMENT_TYPE_TISSUEBOX = 3;// 纸巾盒 + public static final int COMM_ATTACHMENT_TYPE_DANGER = 4;// 危险品 + } + + // 车辆物件 + public static class EVENT_COMM_ATTACHMENT extends Structure + { + public int emAttachmentType;//物件类型, 取值为EM_COMM_ATTACHMENT_TYPE中的值 + public NET_RECT stuRect;//坐标 + public byte[] bReserved = new byte[20];//预留字节 + } + + //NTP校时状态 + public static class EM_NTP_STATUS extends Structure + { + public static final int NET_NTP_STATUS_UNKNOWN = 0; + public static final int NET_NTP_STATUS_DISABLE = 1; + public static final int NET_NTP_STATUS_SUCCESSFUL = 2; + public static final int NET_NTP_STATUS_FAILED = 3; + } + + // 交通抓图图片信息 + public static class EVENT_PIC_INFO extends Structure + { + public int nOffset; // 原始图片偏移,单位字节 + public int nLength; // 原始图片长度,单位字节 + } + + public static class EVENT_COMM_INFO extends Structure + { + public int emNTPStatus;//NTP校时状态, 取值为EM_NTP_STATUS中的值 + public int nDriversNum;//驾驶员信息数 + public Pointer pstDriversInfo;//驾驶员信息数据,类型为 NET_MSG_OBJECT_EX* + public Pointer pszFilePath;//本地硬盘或者sd卡成功写入路径,为NULL时,路径不存在, 类型为char * + public Pointer pszFTPPath;//设备成功写到ftp服务器的路径, 类型为char * + public Pointer pszVideoPath;//当前接入需要获取当前违章的关联视频的FTP上传路径, 类型为char * + public EVENT_COMM_SEAT[] stCommSeat = (EVENT_COMM_SEAT[])new EVENT_COMM_SEAT().toArray(COMMON_SEAT_MAX_NUMBER);//驾驶位信息 + public int nAttachmentNum;//车辆物件个数 + public EVENT_COMM_ATTACHMENT[] stuAttachment = (EVENT_COMM_ATTACHMENT[])new EVENT_COMM_ATTACHMENT().toArray(NET_MAX_ATTACHMENT_NUM);//车辆物件信息 + public int nAnnualInspectionNum;//年检标志个数 + public NET_RECT[] stuAnnualInspection = (NET_RECT[])new NET_RECT().toArray(NET_MAX_ANNUUALINSPECTION_NUM);//年检标志 + public float fHCRatio; // HC所占比例,单位:% + public float fNORatio; // NO所占比例,单位:% + public float fCOPercent; // CO所占百分比,单位:% 取值0~100 + public float fCO2Percent; // CO2所占百分比,单位:% 取值0~100 + public float fLightObscuration; // 不透光度,单位:% 取值0~100 + public int nPictureNum;// 原始图片张数 + public EVENT_PIC_INFO[] stuPicInfos = (EVENT_PIC_INFO[])new EVENT_PIC_INFO().toArray(NET_MAX_EVENT_PIC_NUM);// 原始图片信息 + public float fTemperature; // 温度值,单位摄氏度 + public int nHumidity; // 相对湿度百分比值 + public float fPressure; // 气压值,单位Kpa + public float fWindForce; // 风力值,单位m/s + public int nWindDirection; // 风向,单位度,范围:[0,360] + public float fRoadGradient; // 道路坡度值,单位度 + public float fAcceleration; // 加速度值,单位:m/s2 + public NET_RFIDELETAG_INFO stuRFIDEleTagInfo; // RFID 电子车牌标签信息 + public byte[] bReserved = new byte[704];//预留字节 + public byte[] szCountry = new byte[20];//国家 + } + + // RFID 电子车牌标签信息 + public static class NET_RFIDELETAG_INFO extends Structure + { + public byte[] szCardID = new byte[MAX_RFIDELETAG_CARDID_LEN]; // 卡号 + public int nCardType; // 卡号类型, 0:交通管理机关发行卡, 1:新车出厂预装卡 + public int emCardPrivince; // 卡号省份, 对应 EM_CARD_PROVINCE + public byte[] szPlateNumber = new byte[NET_MAX_PLATE_NUMBER_LEN]; // 车牌号码 + public byte[] szProductionDate = new byte[MAX_RFIDELETAG_DATE_LEN]; // 出厂日期 + public int emCarType; // 车辆类型, 对应 EM_CAR_TYPE + public int nPower; // 功率,单位:千瓦时,功率值范围0~254;255表示该车功率大于可存储的最大功率值 + public int nDisplacement; // 排量,单位:百毫升,排量值范围0~254;255表示该车排量大于可存储的最大排量值 + public int nAntennaID; // 天线ID,取值范围:1~4 + public int emPlateType; // 号牌种类, 对应 EM_PLATE_TYPE + public byte[] szInspectionValidity = new byte[MAX_RFIDELETAG_DATE_LEN]; // 检验有效期,年-月 + public int nInspectionFlag; // 逾期未年检标志, 0:已年检, 1:逾期未年检 + public int nMandatoryRetirement; // 强制报废期,从检验有效期开始,距离强制报废期的年数 + public int emCarColor; // 车身颜色, 对应 EM_CAR_COLOR_TYPE + public int nApprovedCapacity; // 核定载客量,该值<0时:无效;此值表示核定载客,单位为人 + public int nApprovedTotalQuality; // 此值表示总质量,单位为百千克;该值<0时:无效;该值的有效范围为0~0x3FF,0x3FF(1023)表示数据值超过了可存储的最大值 + public NET_TIME_EX stuThroughTime; // 过车时间 + public int emUseProperty; // 使用性质, 对应 EM_USE_PROPERTY_TYPE + public byte[] szPlateCode = new byte[MAX_COMMON_STRING_8]; // 发牌代号,UTF-8编码 + public byte[] szPlateSN = new byte[MAX_COMMON_STRING_16]; // 号牌号码序号,UTF-8编码 + public byte[] bReserved = new byte[104]; // 保留字节,留待扩展. + } + + // 车检器冗余信息 + public static class NET_SIG_CARWAY_INFO_EX extends Structure + { + public byte[] byRedundance = new byte[8];//由车检器产生抓拍信号冗余信息 + public byte[] bReserved = new byte[120];//保留字段 + } + + // 颜色RGBA + public static class NET_COLOR_RGBA extends Structure + { + public int nRed;//红 + public int nGreen;//绿 + public int nBlue;//蓝 + public int nAlpha;//透明 + } + + // TrafficCar 交通车辆信息 + public static class DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO extends Structure + { + public byte[] szPlateNumber = new byte[32];//车牌号码 + public byte[] szPlateType = new byte[32];//号牌类型参见VideoAnalyseRule中车牌类型定义 + public byte[] szPlateColor = new byte[32];//车牌颜色"Blue","Yellow", + public byte[] szVehicleColor = new byte[32];//车身颜色"White", + public int nSpeed;//速度单位Km/H + public byte[] szEvent = new byte[64];//触发的相关事件参见事件列表Event + public byte[] szViolationCode = new byte[32];//违章代码详见TrafficGlobal.ViolationCode + public byte[] szViolationDesc = new byte[64];//违章描述 + public int nLowerSpeedLimit;//速度下限 + public int nUpperSpeedLimit;//速度上限 + public int nOverSpeedMargin;//限高速宽限值单位:km/h + public int nUnderSpeedMargin;//限低速宽限值单位:km/h + public int nLane;//车道参见事件列表EventList中卡口和路口事件。 + public int nVehicleSize;//车辆大小,-1表示未知,否则按位 + // 第0位:"Light-duty", 小型车 + // 第1位:"Medium", 中型车 + // 第2位:"Oversize", 大型车 + // 第3位:"Minisize", 微型车 + // 第4位:"Largesize", 长车 + public float fVehicleLength;//车辆长度单位米 + public int nSnapshotMode;//抓拍方式0-未分类,1-全景,2-近景,4-同向抓拍,8-反向抓拍,16-号牌图像 + public byte[] szChannelName = new byte[32];//本地或远程的通道名称,可以是地点信息来源于通道标题配置ChannelTitle.Name + public byte[] szMachineName = new byte[256];//本地或远程设备名称来源于普通配置General.MachineName + public byte[] szMachineGroup = new byte[256];//机器分组或叫设备所属单位默认为空,用户可以将不同的设备编为一组,便于管理,可重复。 + public byte[] szRoadwayNo = new byte[64];//道路编号 + public byte[] szDrivingDirection = new byte[3*NET_MAX_DRIVINGDIRECTION];// + // 行驶方向 , "DrivingDirection" : ["Approach", "上海", "杭州"], + // "Approach"-上行,即车辆离设备部署点越来越近;"Leave"-下行, + // 即车辆离设备部署点越来越远,第二和第三个参数分别代表上行和 + // 下行的两个地点 + public Pointer szDeviceAddress;//设备地址,OSD叠加到图片上的,来源于配 置TrafficSnapshot.DeviceAddress,'\0'结束 + public byte[] szVehicleSign = new byte[32];//车辆标识,例如 + public NET_SIG_CARWAY_INFO_EX stuSigInfo;//由车检器产生抓拍信号冗余信息 + public Pointer szMachineAddr;//设备部署地点 + public float fActualShutter;//当前图片曝光时间,单位为毫秒 + public byte byActualGain;//当前图片增益,范围为0~100 + public byte byDirection;//车道方向,0-南向北1-西南向东北2-西向东 + public byte[] byReserved = new byte[2]; + public Pointer szDetailedAddress;//详细地址,作为szDeviceAddress的补充 + public byte[] szDefendCode = new byte[NET_COMMON_STRING_64];//图片防伪码 + public int nTrafficBlackListID;//关联黑名单数据库记录默认主键ID,0,无效;>0,黑名单数据记录 + public NET_COLOR_RGBA stuRGBA;//车身颜色RGBA + public NET_TIME stSnapTime;//抓拍时间 + public int nRecNo;//记录编号 + public byte[] szCustomParkNo= new byte[NET_COMMON_STRING_32+1];// 自定义车位号(停车场用) + public byte[] byReserved1 = new byte[3]; + public int nDeckNo;//车板位号 + public int nFreeDeckCount;//空闲车板数量 + public int nFullDeckCount;//占用车板数量 + public int nTotalDeckCount;//总共车板数量 + public byte[] szViolationName = new byte[64];//违章名称 + public int nWeight;//车重(单位Kg), 类型为unsigned int + + public byte[] szCustomRoadwayDirection = new byte[32]; // 自定义车道方向,byDirection为9时有效 + public byte byPhysicalLane; // 物理车道号,取值0到5 + public byte[] byReserved2 = new byte[3]; + public int emMovingDirection; // 车辆行驶方向 EM_TRAFFICCAR_MOVE_DIRECTION + public NET_TIME stuEleTagInfoUTC; // 对应电子车牌标签信息中的过车时间(ThroughTime) + public byte[] bReserved = new byte[552]; // 保留字节,留待扩展. + } + + // 事件类型EVENT_IVS_TRAFFIC_PARKING(交通违章停车事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_PARKING_INFO extends Structure + { + public int nChannelID;//通道号 + public byte[] szName = new byte[128];//事件名称 + public byte[] bReserved1 = new byte[4];//字节对齐 + public double PTS;//时间戳(单位是毫秒) + public NET_TIME_EX UTC;//事件发生的时间 + public int nEventID;//事件ID + public NET_MSG_OBJECT stuObject;//检测到的物体 + public NET_MSG_OBJECT stuVehicle;//车身信息 + public int nLane;//对应车道号 + public NET_EVENT_FILE_INFO stuFileInfo;//事件对应文件信息 + public byte bEventAction;//事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] reserved = new byte[2];//保留字节 + public byte byImageIndex;//图片的序号,同一时间内(精确到秒)可能有多张图片,从0开始 + public NET_TIME_EX stuStartParkingTime;//开始停车时间 + public int nSequence;//表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束(bEventAction=2时此参数有效) + public int nAlarmIntervalTime;//报警时间间隔,单位:秒。(此事件为连续性事件,在收到第一个此事件之后,若在超过间隔时间后未收到此事件的后续事件,则认为此事件异常结束了) + public int nParkingAllowedTime;//允许停车时长,单位:秒。 + public int nDetectRegionNum;//规则检测区域顶点数 + public NET_POINT[] DetectRegion = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM);//规则检测区域 + public int dwSnapFlagMask;//抓图标志(按位),具体见NET_RESERVED_COMMON + public NET_RESOLUTION_INFO stuResolution;//对应图片的分辨率 + public int bIsExistAlarmRecord;//true:有对应的报警录像;false:无对应的报警录像, 类型为BOOL, 取值为0或1 + public int dwAlarmRecordSize;//录像大小 + public byte[] szAlarmRecordPath = new byte[NET_COMMON_STRING_256];//录像路径 + public byte[] szFTPPath = new byte[NET_COMMON_STRING_256];//FTP路径 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo;//智能事件公共信息 + public byte byPreAlarm; // 是否为违章预警图片,0 违章停车事件1 预警事件(预警触发后一定时间,车辆还没有离开,才判定为违章)由于此字段会导致事件含义改变,必须和在平台识别预警事件后,才能有此字段, + public byte[] bReserved2 = new byte[3]; // 保留字节,留待扩展. + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[228];//保留字节,留待扩展. + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar;//交通车辆信息 + public EVENT_COMM_INFO stCommInfo;//公共信息 + } + + //停车场信息 + public static class DEV_TRAFFIC_PARKING_INFO extends Structure + { + public int nFeaturePicAreaPointNum; // 特征图片区点个数 + public NET_POINT[] stFeaturePicArea = (NET_POINT[])new NET_POINT().toArray(NET_MAX_POLYGON_NUM); // 特征图片区信息 + public byte[] bReserved = new byte[572]; // 保留字节 + } + + //事件类型 EVENT_IVS_TRAFFIC_PARKINGSPACEPARKING(车位有车事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_PARKINGSPACEPARKING_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] bReserved1 = new byte[8]; // 字节对齐 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public int nParkingSpaceStatus; // 车位状态,0-占用,1-空闲,2-压线 + public DEV_TRAFFIC_PARKING_INFO stTrafficParingInfo; // 停车场信息 + public byte byPlateTextSource; // 车牌识别来源, 0:本地算法识别,1:后端服务器算法识别 + public byte[] bReserved = new byte[379]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 事件类型 EVENT_IVS_TRAFFIC_PARKINGSPACENOPARKING(车位无车事件)对应的数据块描述信息 + // 由于历史原因,如果要处理卡口事件,DEV_EVENT_TRAFFICJUNCTION_INFO和EVENT_IVS_TRAFFICGATE要一起处理,以防止有视频电警和线圈电警同时接入平台的情况发生 + // 另外EVENT_IVS_TRAFFIC_TOLLGATE只支持新卡口事件的配置 + public static class DEV_EVENT_TRAFFIC_PARKINGSPACENOPARKING_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] bReserved1 = new byte[8]; // 字节对齐 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见 NET_RESERVED_COMMON + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public DEV_TRAFFIC_PARKING_INFO stTrafficParingInfo; // 停车场信息 + public byte byPlateTextSource; // 车牌识别来源, 0:本地算法识别,1:后端服务器算法识别 + public byte[] bReserved = new byte[383]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型 EVENT_IVS_TRAFFIC_PEDESTRAIN(交通行人事件)对应数据块描述信息 + public static class DEV_EVENT_TRAFFIC_PEDESTRAIN_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] bReserved1 = new byte[8]; // 字节对齐 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public int dwSnapFlagMask; // 抓图标志(按位),0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] bReserved2 = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[892]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型 EVENT_IVS_TRAFFIC_THROW(交通抛洒物品事件)对应数据块描述信息 + public static class DEV_EVENT_TRAFFIC_THROW_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] bReserved1 = new byte[8]; // 字节对齐 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public int dwSnapFlagMask; // 抓图标志(按位),0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] bReserved2 = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public EVENT_TRAFFIC_CAR_PART_INFO stuTrafficCarPartInfo; // 交通车辆部分信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[340]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 交通车辆部分信息 + public class EVENT_TRAFFIC_CAR_PART_INFO extends Structure + { + public byte[] szMachineName = new byte[128]; // 本地或远程设备名称 来源于普通配置General.MachineName + public byte[] szRoadwayNo = new byte[32]; // 道路编号 + public byte[] bReserved = new byte[352]; // 保留字节 + } + + // 事件上报携带卡片信息 + public static class EVENT_CARD_INFO extends Structure + { + public byte[] szCardNumber = new byte[NET_EVENT_CARD_LEN];// 卡片序号字符串 + public byte[] bReserved = new byte[32]; // 保留字节,留待扩展. + } + + // 车辆方向信息 + public static class EM_VEHICLE_DIRECTION extends Structure + { + public static final int NET_VEHICLE_DIRECTION_UNKOWN = 0; // 未知 + public static final int NET_VEHICLE_DIRECTION_HEAD = 1; // 车头 + public static final int NET_VEHICLE_DIRECTION_TAIL = 2; // 车尾 + } + + // 开闸状态 + public static class EM_OPEN_STROBE_STATE extends Structure + { + public static final int NET_OPEN_STROBE_STATE_UNKOWN = 0; // 未知状态 + public static final int NET_OPEN_STROBE_STATE_CLOSE = 1; // 关闸 + public static final int NET_OPEN_STROBE_STATE_AUTO = 2; // 自动开闸 + public static final int NET_OPEN_STROBE_STATE_MANUAL = 3; // 手动开闸 + } + + public static class RESERVED_PARA extends Structure + { + public int dwType; //pData的数据类型 + //当[dwType]为 RESERVED_TYPE_FOR_INTEL_BOX 时,pData 对应为结构体 RESERVED_DATA_INTEL_BOX 的地址 + //当[dwType]为 RESERVED_TYPE_FOR_COMMON 时,[pData]对应为结构体 NET_RESERVED_COMMON 的结构体地址 + //当[dwType]为 RESERVED_TYPE_FOR_PATH 时,[pData]对应结构体NET_RESERVED_PATH的结构体地址 + public Pointer pData; //数据,由用户申请内存,大小参考对应的结构体 + } + + public static class NET_RESERVED_COMMON extends Structure + { + public int dwStructSize; + public Pointer pIntelBox; // 对应 结构体 RESERVED_DATA_INTEL_BOX*, 兼容 RESERVED_TYPE_FOR_INTEL_BOX + public int dwSnapFlagMask; // 抓图标志(按位),0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + + public NET_RESERVED_COMMON() { + this.dwStructSize = this.size(); + } + } + + // 事件类型 EVENT_IVS_TRAFFICJUNCTION 交通路口老规则事件/视频电警上的交通卡口老规则事件对应的数据块描述信息 + // 由于历史原因,如果要处理卡口事件,DEV_EVENT_TRAFFICJUNCTION_INFO 和 EVENT_IVS_TRAFFICGATE要一起处理 + // 以防止有视频电警和线圈电警同时接入平台的情况发生, 另外EVENT_IVS_TRAFFIC_TOLLGATE只支持新卡口事件的配置 + public static class DEV_EVENT_TRAFFICJUNCTION_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte byMainSeatBelt; // 主驾驶座,系安全带状态,1-系安全带,2-未系安全带 + public byte bySlaveSeatBelt; // 副驾驶座,系安全带状态,1-系安全带,2-未系安全带 + public byte byVehicleDirection; // 当前被抓拍到的车辆是车头还是车尾,具体请见 EM_VEHICLE_DIRECTION + public byte byOpenStrobeState; // 开闸状态,具体请见 EM_OPEN_STROBE_STATE + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public int nLane; // 对应车道号 + public int dwBreakingRule; // 违反规则掩码,第一位:闯红灯; + // 第二位:不按规定车道行驶; + // 第三位:逆行; 第四位:违章掉头; + // 第五位:交通堵塞; 第六位:交通异常空闲 + // 第七位:压线行驶; 否则默认为:交通路口事件 + public NET_TIME_EX RedLightUTC; // 红灯开始UTC时间 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public int nSpeed; // 车辆实际速度Km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte byDirection; // 路口方向,1-表示正向,2-表示反向 + public byte byLightState; // LightState表示红绿灯状态:0 未知,1 绿灯,2 红灯,3 黄灯 + public byte byReserved; // 保留字节 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public int dwSnapFlagMask; // 抓图标志(按位),具体见 NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte[] szRecordFile = new byte[NET_COMMON_STRING_128];// 报警对应的原始录像文件信息 + public EVENT_JUNCTION_CUSTOM_INFO stuCustomInfo; // 自定义信息 + public byte byPlateTextSource; // 车牌识别来源, 0:本地算法识别,1:后端服务器算法识别 + public byte[] bReserved1 = new byte[3]; // 保留字节,留待扩展. + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[196]; // 保留字节,留待扩展. + public int nTriggerType; // TriggerType:触发类型,0车检器,1雷达,2视频 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public int dwRetCardNumber; // 卡片个数 + public EVENT_CARD_INFO[] stuCardInfo = (EVENT_CARD_INFO[])new EVENT_CARD_INFO().toArray(NET_EVENT_MAX_CARD_NUM);// 卡片信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //卡口事件专用定制上报内容,定制需求增加到Custom下 + public class EVENT_JUNCTION_CUSTOM_INFO extends Structure + { + public EVENT_CUSTOM_WEIGHT_INFO stuWeightInfo; // 原始图片信息 + public byte[] bReserved = new byte[60]; // 预留字节 + } + + //建委地磅定制称重信息 + public static class EVENT_CUSTOM_WEIGHT_INFO extends Structure + { + public int dwRoughWeight; // 毛重,车辆满载货物重量。单位KG + public int dwTareWeight; // 皮重,空车重量。单位KG + public int dwNetWeight; // 净重,载货重量。单位KG + public byte[] bReserved = new byte[28]; // 预留字节 + } + + // 事件类型 EVENT_IVS_TRAFFICGATE(交通卡口老规则事件/线圈电警上的交通卡口老规则事件)对应的数据块描述信息 + // 由于历史原因,如果要处理卡口事件,DEV_EVENT_TRAFFICJUNCTION_INFO和EVENT_IVS_TRAFFICGATE要一起处理,以防止有视频电警和线圈电警同时接入平台的情况发生 + // 另外 EVENT_IVS_TRAFFIC_TOLLGATE 只支持新卡口事件的配置 + public static class DEV_EVENT_TRAFFICGATE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte byOpenStrobeState; // 开闸状态,具体请见EM_OPEN_STROBE_STATE + public byte bReserved1[] = new byte[3]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public int nLane; // 对应车道号 + public int nSpeed; // 车辆实际速度Km/h + public int nSpeedUpperLimit; // 速度上限 单位:km/h + public int nSpeedLowerLimit; // 速度下限 单位:km/h + public int dwBreakingRule; // 违反规则掩码,第一位:逆行; + // 第二位:压线行驶; 第三位:超速行驶; + // 第四位:欠速行驶; 第五位:闯红灯;第六位:穿过路口(卡口事件) + // 第七位: 压黄线; 第八位: 有车占道; 第九位: 黄牌占道;否则默认为:交通卡口事件 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public byte szManualSnapNo[] = new byte[64]; // 手动抓拍序号 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[3]; // 保留字节 + public byte[] szSnapFlag = new byte[16]; // 设备产生的抓拍标识 + public byte bySnapMode; // 抓拍方式,0-未分类 1-全景 2-近景 4-同向抓拍 8-反向抓拍 16-号牌图像 + public byte byOverSpeedPercentage; // 超速百分比 + public byte byUnderSpeedingPercentage; // 欠速百分比 + public byte byRedLightMargin; // 红灯容许间隔时间,单位:秒 + public byte byDriveDirection; // 行驶方向,0-上行(即车辆离设备部署点越来越近),1-下行(即车辆离设备部署点越来越远) + public byte[] szRoadwayNo = new byte[32]; // 道路编号 + public byte[] szViolationCode = new byte[16]; // 违章代码 + public byte[] szViolationDesc = new byte[128]; // 违章描述 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte[] szVehicleType= new byte[32]; // 车辆大小类型 Minisize"微型车,"Light-duty"小型车,"Medium"中型车, + // "Oversize"大型车,"Huge"超大车,"Largesize"长车 "Unknown"未知 + public byte byVehicleLenth; // 车辆长度, 单位米 + public byte byLightState; // LightState表示红绿灯状态:0 未知,1 绿灯,2 红灯,3 黄灯 + public byte byReserved1; // 保留字节,留待扩展 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nOverSpeedMargin; // 限高速宽限值 单位:km/h + public int nUnderSpeedMargin; // 限低速宽限值 单位:km/h + public byte[] szDrivingDirection = new byte[3*NET_MAX_DRIVINGDIRECTION]; // + // "DrivingDirection" : ["Approach", "上海", "杭州"],行驶方向 + // "Approach"-上行,即车辆离设备部署点越来越近;"Leave"-下行, + // 即车辆离设备部署点越来越远,第二和第三个参数分别代表上行和 + // 下行的两个地点,UTF-8编码 + public byte[] szMachineName = new byte[256]; // 本地或远程设备名称 + public byte[] szMachineAddress = new byte[256]; // 机器部署地点、道路编码 + public byte[] szMachineGroup = new byte[256]; // 机器分组、设备所属单位 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_SIG_CARWAY_INFO_EX stuSigInfo; // 由车检器产生抓拍信号冗余信息 + public byte[] szFilePath = new byte[MAX_PATH]; // 文件路径 + public NET_TIME_EX RedLightUTC; // 红灯开始UTC时间 + public Pointer szDeviceAddress; // 设备地址,OSD叠加到图片上的,来源于配置TrafficSnapshot.DeviceAddress,'\0'结束 + public float fActualShutter; // 当前图片曝光时间,单位为毫秒 + public byte byActualGain; // 当前图片增益,范围为0~100 + public byte byDirection; // 0-南向北 1-西南向东北 2-西向东 3-西北向东南 4-北向南 5-东北向西南 6-东向西 7-东南向西北 8-未知 + public byte bReserve; // 保留字节, 字节对齐 + public byte bRetCardNumber; // 卡片个数 + public EVENT_CARD_INFO[] stuCardInfo = (EVENT_CARD_INFO[])new EVENT_CARD_INFO().toArray(NET_EVENT_MAX_CARD_NUM);// 卡片信息 + public byte[] szDefendCode = new byte[NET_COMMON_STRING_64]; // 图片防伪码 + public int nTrafficBlackListID; // 关联黑名单数据库记录默认主键ID, 0,无效;> 0,黑名单数据记录 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + public byte[] bReserved = new byte[452]; // 保留字节,留待扩展. + } + + //事件类型EVENT_IVS_TRAFFIC_RUNREDLIGHT(交通-闯红灯事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_RUNREDLIGHT_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nLightState; // 红绿灯状态 0:未知 1:绿灯 2:红灯 3:黄灯 + public int nSpeed; // 车速,km/h + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_TIME_EX stRedLightUTC; // 红灯开始时间 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte byRedLightMargin; // 红灯容许间隔时间,单位:秒 + public byte[] byAlignment = new byte[3]; // 字节对齐 + public int nRedLightPeriod; // 表示红灯周期时间,单位毫秒 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[928]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型EVENT_IVS_TRAFFIC_OVERLINE(交通-压线事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_OVERLINE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public int nSpeed; // 车辆实际速度,Km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[968]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 事件类型EVENT_IVS_TRAFFIC_RETROGRADE(交通-逆行事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_RETROGRADE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public int nSpeed; // 车辆实际速度,Km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public int bIsExistAlarmRecord; // rue:有对应的报警录像; false:无对应的报警录像 + public int dwAlarmRecordSize; // 录像大小 + public byte[] szAlarmRecordPath = new byte[NET_COMMON_STRING_256]; // 录像路径 + public EVENT_INTELLI_COMM_INFO intelliCommInfo; // 智能事件公共信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[484]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public int nDetectNum; // 规则检测区域顶点数 + public NET_POINT[] DetectRegion = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM); // 规则检测区域 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型EVENT_IVS_TRAFFIC_OVERSPEED(交通超速事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_OVERSPEED_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSpeed; // 车辆实际速度Km/h + public int nSpeedUpperLimit; // 速度上限 单位:km/h + public int nSpeedLowerLimit; // 速度下限 单位:km/h + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte[] szFilePath = new byte[MAX_PATH]; // 文件路径 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[576]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型EVENT_IVS_TRAFFIC_UNDERSPEED(交通欠速事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_UNDERSPEED_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved2 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSpeed; // 车辆实际速度Km/h + public int nSpeedUpperLimit; // 速度上限 单位:km/h + public int nSpeedLowerLimit; // 速度下限 单位:km/h + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] bReserved1 = new byte[2]; // 对齐 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nUnderSpeedingPercentage; // 欠速百分比 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[832]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型EVENT_IVS_TRAFFIC_WRONGROUTE(交通违章-不按车道行驶)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_WRONGROUTE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public int nLane; // 对应车道号 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nSpeed; // 车辆实际速度,km/h + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[972]; // 保留字节,留待扩展. + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 事件类型 EVENT_IVS_TRAFFIC_TURNLEFT(交通-违章左转)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_TURNLEFT_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC ; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public int nSpeed; // 车辆实际速度,Km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见 NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[968]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 事件类型 EVENT_IVS_TRAFFIC_TURNRIGHT (交通-违章右转)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_TURNRIGHT_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public int nSpeed; // 车辆实际速度,Km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见 NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[968]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 事件类型EVENT_IVS_TRAFFIC_UTURN(违章调头事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_UTURN_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public int nSpeed; // 车辆实际速度,Km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见 NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[968]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型 EVENT_IVS_TRAFFIC_RUNYELLOWLIGHT(交通违章-闯黄灯事件)对应数据块描述信息 + public static class DEV_EVENT_TRAFFIC_RUNYELLOWLIGHT_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nLightState; // 红绿灯状态 0:未知 1:绿灯 2:红灯 3:黄灯 + public int nSpeed; // 车速,km/h + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见 NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_TIME_EX stYellowLightUTC; // 黄灯开始时间 + public int nYellowLightPeriod; // 黄灯周期间隔时间,单位秒 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte byRedLightMargin; // 黄灯容许间隔时间,单位:秒 + public byte[] szSourceDevice = new byte[MAX_PATH]; // 事件源设备唯一标识,字段不存在或者为空表示本地设备 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public byte[] bReserved = new byte[1024]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + + } + + //事件类型EVENT_IVS_TRAFFIC_OVERYELLOWLINE(交通违章-压黄线)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_OVERYELLOWLINE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public int nLane; // 对应车道号 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nSpeed; // 车辆实际速度,km/h + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public int bIsExistAlarmRecord; // bool 类型: 1:有对应的报警录像; 0:无对应的报警录像 + public int dwAlarmRecordSize; // 录像大小 + public byte[] szAlarmRecordPath = new byte[NET_COMMON_STRING_256]; // 录像路径 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[532]; // 保留字节,留待扩展. + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + + public int nDetectNum; // 规则检测区域顶点数 + public NET_POINT[] DetectRegion = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM); // 规则检测区域 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型EVENT_IVS_TRAFFIC_YELLOWPLATEINLANE(交通违章-黄牌车占道事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_YELLOWPLATEINLANE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public int nLane; // 对应车道号 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nSpeed; // 车辆实际速度,km/h + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte[] bReserved = new byte[1016]; // 保留字节,留待扩展. + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型 EVENT_IVS_TRAFFIC_VEHICLEINROUTE(有车占道事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_VEHICLEINROUTE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public int nLane; // 对应车道号 + public int nSequence; // 抓拍序号,如3-2-1/0,1表示抓拍正常结束,0表示抓拍异常结束 + public int nSpeed; // 车速 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 表示交通车辆的数据库记录 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved0 = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] byReserved = new byte[884]; + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型EVENT_IVS_TRAFFIC_CROSSLANE(交通违章-违章变道)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_CROSSLANE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public int nLane; // 对应车道号 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nSpeed; // 车辆实际速度,km/h + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[836]; // 保留字节,留待扩展.留待扩展. + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stuTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 事件类型EVENT_IVS_TRAFFIC_NOPASSING(交通违章-禁止通行事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_NOPASSING_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public int nTriggerType; // TriggerType:触发类型,0车检器,1雷达,2视频 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int UTCMS; // + public int nMark; // 底层产生的触发抓拍帧标记 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public byte[] byReserved1 = new byte[3]; + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public int nFrameSequence; // 视频分析帧序号 + public int nSource; // 视频分析的数据源地址 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] byReserved = new byte[984]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + //事件类型 EVENT_IVS_TRAFFIC_PEDESTRAINPRIORITY(斑马线行人优先事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_PEDESTRAINPRIORITY_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nLane; // 对应车道号 + public double dInitialUTC; // 事件初始UTC时间 UTC为事件的UTC (1970-1-1 00:00:00)秒数。 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 表示交通车辆的数据库记录 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[984]; // 保留字节,留待扩展. + public EVENT_COMM_INFO stCommInfo; // 公共信息 + + } + + //事件类型 EVENT_IVS_TRAFFIC_VEHICLEINBUSROUTE(占用公交车道事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_VEHICLEINBUSROUTE_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nLane; // 对应车道号 + public int nSequence; // 抓拍序号,如3-2-1/0,1表示抓拍正常结束,0表示抓拍异常结束 + public int nSpeed; // 车速,km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 表示交通车辆的数据库记录 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[980]; // 保留字节,留待扩展. + public EVENT_COMM_INFO stCommInfo; // 公共信息 + + } + + //事件类型 EVENT_IVS_TRAFFIC_BACKING(违章倒车事件)对应的数据块描述信息 + public static class DEV_EVENT_IVS_TRAFFIC_BACKING_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nLane; // 对应车道号 + public int nSequence; // 抓拍序号,如3-2-1/0,1表示抓拍正常结束,0表示抓拍异常结束 + public int nSpeed; // 车速,km/h + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 表示交通车辆的数据库记录 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[848]; // 保留字节,留待扩展. + public EVENT_COMM_INFO stCommInfo; // 公共信息 + + } + + // GPS信息 + public static class NET_GPS_INFO extends Structure + { + public int nLongitude; // 经度(单位是百万分之一度) + // 西经:0 - 180000000 实际值应为: 180*1000000 – dwLongitude + // 东经:180000000 - 360000000 实际值应为: dwLongitude – 180*1000000 + // 如: 300168866应为(300168866 - 180*1000000)/1000000 即东经120.168866度 + public int nLatidude; // 纬度(单位是百万分之一度) + // 南纬:0 - 90000000 实际值应为: 90*1000000 – dwLatidude + // 北纬:90000000 – 180000000 实际值应为: dwLatidude – 90*1000000 + // 如: 120186268应为 (120186268 - 90*1000000)/1000000 即北纬30. 186268度 + public double dbAltitude; // 高度,单位为米 + public double dbSpeed; // 速度,单位km/H + public double dbBearing; // 方向角,单位° + public byte[] bReserved = new byte[8]; // 保留字段 + + public NET_GPS_INFO() + { + /*if(Utils.getOsName().equals("win")) { + // 强制采用最大四字节对齐 + setAlignType(ALIGN_GNUC); + }*/ + } + } + + // 事件类型 EVENT_IVS_TRAFFIC_OVERSTOPLINE (压停车线事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_OVERSTOPLINE extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public int nTriggerType; // TriggerType:触发类型,0车检器,1雷达,2视频 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte byEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public byte[] byReserved1 = new byte[2]; + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nMark; // 底层产生的触发抓拍帧标记 + public int nFrameSequence; // 视频分析帧序号 + public int nSource; // 视频分析的数据源地址 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stuTrafficCar; // 交通车辆信息 + public int nSpeed; // 车辆实际速度,Km/h + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] byReserved = new byte[984]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + + } + + //事件类型 EVENT_IVS_TRAFFIC_PARKINGONYELLOWBOX(黄网格线抓拍事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_PARKINGONYELLOWBOX_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[8]; // 字节对齐 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + + public int nInterval1; // 第二张和第一张的延时时间,单位秒 + public int nInterval2; // 第三张和第二张的延时时间,单位秒 + public int nFollowTime; // 跟随时间,如果一辆车与前一辆车进入黄网格的时间差小于此值,就认为是跟车进入,跟车进入情况下如果停车则不算违章 + + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[984]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + + } + + // 事件类型EVENT_IVS_TRAFFIC_WITHOUT_SAFEBELT(交通未系安全带事件事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_WITHOUT_SAFEBELT extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public int nTriggerType; // TriggerType:触发类型,0车检器,1雷达,2视频 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte byEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; public byte byReserved1[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public byte[] byReserved1 = new byte[2]; + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nLane; // 对应车道号 + public int nMark; // 底层产生的触发抓拍帧标记 + public int nFrameSequence; // 视频分析帧序号 + public int nSource; // 视频分析的数据源地址 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stuTrafficCar; // 交通车辆信息 + public int nSpeed; // 车辆实际速度,Km/h + public int emMainSeat; // 主驾驶座位安全带状态 参考 NET_SAFEBELT_STATE + public int emSlaveSeat; // 副驾驶座位安全带状态 参考 NET_SAFEBELT_STATE + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON , 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] byReserved = new byte[984]; // 保留字节 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + + } + + //事件类型EVENT_IVS_TRAFFIC_JAM_FORBID_INTO(交通拥堵禁入事件)对应的数据块描述信息 + public static class DEV_EVENT_ALARM_JAMFORBIDINTO_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public int PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEveID; // 事件ID + ///////////////////////////////以上为公共字段////////////////////////////// + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nMark; // 底层产生的触发抓拍帧标记 + public int nSource; // 视频分析的数据源地址 + public int nSequence; // 表示抓拍序号,如3-2-1/0,1表示抓拍正常结束,0表示抓拍异常结束 + public int nFrameSequence; // 帧序号 + public int nLane; // 车道号 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[984]; // 保留字节 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stuTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + } + + //事件类型EVENT_IVS_TRAFFIC_PASSNOTINORDER(交通-未按规定依次通过)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_PASSNOTINORDER_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public NET_MSG_OBJECT stuObject; // 车牌信息 + public NET_MSG_OBJECT stuVehicle; // 车身信息 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nSequence; // 表示抓拍序号,如3,2,1,1表示抓拍结束,0表示异常结束 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON , 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 交通车辆信息 + public EVENT_COMM_INFO stCommInfo; // 公共信息 + public NET_GPS_INFO stuGPSInfo; // GPS信息 车载定制 + public byte[] bReserved = new byte[984]; // 保留字节 + } + + //事件类型EVENT_IVS_TRAFFIC_MANUALSNAP(交通手动抓拍事件)对应的数据块描述信息 + public static class DEV_EVENT_TRAFFIC_MANUALSNAP_INFO extends Structure + { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nLane; // 对应车道号 + public byte[] szManualSnapNo = new byte[64]; // 手动抓拍序号 + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_MSG_OBJECT stuVehicle; // 检测到的车身信息 + public DEV_EVENT_TRAFFIC_TRAFFICCAR_INFO stTrafficCar; // 表示交通车辆的数据库记录 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte byOpenStrobeState; // 开闸状态, 具体请见 EM_OPEN_STROBE_STATE + public byte[] byReserved = new byte[1]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON , 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte[] bReserved = new byte[1016]; // 保留字节,留待扩展. + public EVENT_COMM_INFO stCommInfo; // 公共信息 + } + + // 事件类型 EVENT_IVS_CROSSLINEDETECTION(警戒线事件)对应的数据块描述信息 + public static class DEV_EVENT_CROSSLINE_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public NET_POINT[] DetectLine = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_LINE_NUM);// 规则检测线 + public int nDetectLineNum; // 规则检测线顶点数 + public NET_POINT[] TrackLine = (NET_POINT[])new NET_POINT().toArray(NET_MAX_TRACK_LINE_NUM); // 物体运动轨迹 + public int nTrackLineNum; // 物体运动轨迹顶点数 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte bDirection; // 表示入侵方向, 0-由左至右, 1-由右至左 + public byte byReserved; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见 NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public int nSourceIndex; // 事件源设备上的index,-1表示数据无效,-1表示数据无效 + public byte[] szSourceDevice = new byte[MAX_PATH]; // 事件源设备唯一标识,字段不存在或者为空表示本地设备 + public int nOccurrenceCount; // 事件触发累计次数, 类型为unsigned int + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[476]; // 保留字节,留待扩展. + } + + // 事件类型 EVENT_IVS_CROSSREGIONDETECTION(警戒区事件)对应的数据块描述信息 + public static class DEV_EVENT_CROSSREGION_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public NET_POINT[] DetectRegion = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM); // 规则检测区域 + public int nDetectRegionNum; // 规则检测区域顶点数 + public NET_POINT[] TrackLine = (NET_POINT[])new NET_POINT().toArray(NET_MAX_TRACK_LINE_NUM); // 物体运动轨迹 + public int nTrackLineNum; // 物体运动轨迹顶点数 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte bDirection; // 表示入侵方向, 0-进入, 1-离开,2-出现,3-消失 + public byte bActionType; // 表示检测动作类型,0-出现 1-消失 2-在区域内 3-穿越区域 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON , 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public int nSourceIndex; // 事件源设备上的index,-1表示数据无效 + public byte[] szSourceDevice = new byte[MAX_PATH];// 事件源设备唯一标识,字段不存在或者为空表示本地设备 + public int nOccurrenceCount; // 事件触发累计次数, unsigned int 类型 + public byte[] bReserved = new byte[536]; // 保留字节,留待扩展. + public int nObjectNum; // 检测到的物体个数 + public NET_MSG_OBJECT[] stuObjectIDs = (NET_MSG_OBJECT[]) new NET_MSG_OBJECT().toArray(NET_MAX_OBJECT_LIST); // 检测到的物体 + public int nTrackNum; // 轨迹数(与检测到的物体个数 nObjectNum 对应) + public NET_POLY_POINTS[] stuTrackInfo = (NET_POLY_POINTS[]) new NET_POLY_POINTS().toArray(NET_MAX_OBJECT_LIST); // 轨迹信息(与检测到的物体对应) + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + } + + // 事件类型 EVENT_IVS_WANDERDETECTION(徘徊事件)对应的数据块描述信息 + public static class DEV_EVENT_WANDER_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; // 保留字节 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nObjectNum; // 检测到的物体个数 + public NET_MSG_OBJECT[] stuObjectIDs = (NET_MSG_OBJECT[]) new NET_MSG_OBJECT().toArray(NET_MAX_OBJECT_LIST); // 检测到的物体 + public int nTrackNum; // 轨迹数(与检测到的物体个数对应) + public NET_POLY_POINTS[] stuTrackInfo = (NET_POLY_POINTS[]) new NET_POLY_POINTS().toArray(NET_MAX_OBJECT_LIST); // 轨迹信息(与检测到的物体对应) + public int nDetectRegionNum; // 规则检测区域顶点数 + public NET_POINT[] DetectRegion = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM); // 规则检测区域 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON , 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public int nSourceIndex; // 事件源设备上的index,-1表示数据无效 + public byte[] szSourceDevice = new byte[MAX_PATH]; // 事件源设备唯一标识,字段不存在或者为空表示本地设备 + public int nOccurrenceCount; // 事件触发累计次数, unsigned int 类型 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[624]; // 保留字节,留待扩展. + } + + //事件类型 EVENT_IVS_LEAVEDETECTION(离岗检测事件)对应数据块描述信息 + public static class DEV_EVENT_IVS_LEAVE_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public int nDetectRegionNum; // 规则检测区域顶点数 + public NET_POINT[] DetectRegion = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM);// 规则检测区域 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[894]; // 保留字节 + } + + //事件类型 EVENT_IVS_AUDIO_ABNORMALDETECTION(声音异常检测)对应数据块描述信息 + public static class DEV_EVENT_IVS_AUDIO_ABNORMALDETECTION_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public int nDecibel; // 声音强度 + public int nFrequency; // 声音频率 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public byte[] bReserved = new byte[1024]; // 保留字节,留待扩展. + } + + //事件类型 EVENT_IVS_CLIMBDETECTION(攀高检测事件)对应数据块描述信息 + public static class DEV_EVENT_IVS_CLIMB_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public NET_MSG_OBJECT stuObject; // 检测到的物体 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public NET_RESOLUTION_INFO stuResolution; // 对应图片的分辨率 + public int nDetectLineNum; // 规则检测线顶点数 + public NET_POINT[] DetectLine = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_LINE_NUM); // 规则检测线 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nOccurrenceCount; // 事件触发累计次数, unsigned int + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[890]; // 保留字节 + } + + // 事件类型 EVENT_IVS_FIGHTDETECTION(斗殴事件)对应的数据块描述信息 + public static class DEV_EVENT_FIGHT_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[128]; // 事件名称 + public byte[] bReserved1 = new byte[4]; // 字节对齐 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + public int nObjectNum; // 检测到的物体个数 + public NET_MSG_OBJECT[] stuObjectIDs = (NET_MSG_OBJECT[])new NET_MSG_OBJECT().toArray(NET_MAX_OBJECT_LIST); // 检测到的物体列表 + public NET_EVENT_FILE_INFO stuFileInfo; // 事件对应文件信息 + public byte bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public byte[] byReserved = new byte[2]; // 保留字节 + public byte byImageIndex; // 图片的序号, 同一时间内(精确到秒)可能有多张图片, 从0开始 + public int nDetectRegionNum; // 规则检测区域顶点数 + public NET_POINT[] DetectRegion = (NET_POINT[]) new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM); // 规则检测区域 + + public int dwSnapFlagMask; // 抓图标志(按位),具体见NET_RESERVED_COMMON, 0位:"*",1位:"Timing",2位:"Manual",3位:"Marked",4位:"Event",5位:"Mosaic",6位:"Cutout" + public int nSourceIndex; // 事件源设备上的index,-1表示数据无效 + public byte[] szSourceDevice = new byte[MAX_PATH]; // 事件源设备唯一标识,字段不存在或者为空表示本地设备 + public int nOccurrenceCount; // 事件触发累计次数, unsigned int 类型 + public EVENT_INTELLI_COMM_INFO stuIntelliCommInfo; // 智能事件公共信息 + public byte[] bReserved = new byte[492]; // 保留字节,留待扩展. + } + + // 加油类型 + public static class EM_REFUEL_TYPE extends Structure { + public static final int EM_REFUEL_TYPE_UNKNOWN = 0; // unknown + public static final int EM_REFUEL_TYPE_NINETY_EIGHT = 1; // "98#" + public static final int EM_REFUEL_TYPE_NINETY_SEVEN = 2; // "97#" + public static final int EM_REFUEL_TYPE_NINETY_FIVE = 3; // "95#" + public static final int EM_REFUEL_TYPE_NINETY_THREE = 4; // "93#" + public static final int EM_REFUEL_TYPE_NINETY = 5; // "90#" + public static final int EM_REFUEL_TYPE_TEN = 6; // "10#" + public static final int EM_REFUEL_TYPE_FIVE = 7; // "5#" + public static final int EM_REFUEL_TYPE_ZERO = 8; // "0#" + public static final int EM_REFUEL_TYPE_NEGATIVE_TEN = 9; // "-10#" + public static final int EM_REFUEL_TYPE_NEGATIVE_TWENTY = 10; // "-20#" + public static final int EM_REFUEL_TYPE_NEGATIVE_THIRTY_FIVE = 11; // "-35#" + public static final int EM_REFUEL_TYPE_NEGATIVE_FIFTY = 12; // "-50#" + } + + // 车辆抓拍图片信息 + public static class DEV_EVENT_TRAFFIC_FCC_IMAGE extends Structure { + public int dwOffSet; // 图片文件在二进制数据块中的偏移位置, 单位:字节 + public int dwLength; // 图片大小, 单位:字节 + public short wWidth; // 图片宽度, 单位:像素 + public short wHeight; // 图片高度, 单位:像素 + } + + // 车辆抓图信息 + public static class DEV_EVENT_TRAFFIC_FCC_OBJECT extends Structure { + public DEV_EVENT_TRAFFIC_FCC_IMAGE stuImage; // 车辆抓拍图片信息 + } + + // 事件类型 EVENT_IVS_TRAFFIC_FCC 加油站提枪、挂枪事件 + public static class DEV_EVENT_TRAFFIC_FCC_INFO extends Structure { + public int nChannelID; // 通道号 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public int nTriggerID; // 触发类型: 1表示提枪, 2表示挂枪 + public double PTS; // 时间戳(单位是毫秒) + public NET_TIME_EX UTC; // 事件发生的时间 + public int nEventID; // 事件ID + ///////////////////////////////以上为公共字段////////////////////////////// + + public int nNum; // 加油枪号 + public int nLitre; // 加油升数,单位 0.01升 + public int emType; // 加油类型: 取值范围{"90#","93#","10#","-20#"}, 具体参考 EM_REFUEL_TYPE + public int dwMoney; // 加油金额,单位 0.01元 + public byte[] szText = new byte[NET_COMMON_STRING_16]; // 车牌号 + public byte[] szTime = new byte[NET_COMMON_STRING_32]; // 事件发生时间: "2016-05-23 10:31:17" + public DEV_EVENT_TRAFFIC_FCC_OBJECT stuObject; // 车辆抓图信息 + public byte[] bReserved = new byte[1024]; // 保留字节,留待扩展 + } + + // 区域或曲线顶点信息 + public static class NET_POLY_POINTS extends Structure + { + public int nPointNum; // 顶点数 + public NET_POINT[] stuPoints = (NET_POINT[])new NET_POINT().toArray(NET_MAX_DETECT_REGION_NUM); // 顶点信息 + } + + + // 抓图参数结构体 + public static class SNAP_PARAMS extends Structure + { + public int Channel; // 抓图的通道 + public int Quality; // 画质;1~6 + public int ImageSize; // 画面大小;0:QCIF,1:CIF,2:D1 + public int mode; // 抓图模式;-1:表示停止抓图, 0:表示请求一帧, 1:表示定时发送请求, 2:表示连续请求 + public int InterSnap; // 时间单位秒;若mode=1表示定时发送请求时 + // 只有部分特殊设备(如:车载设备)支持通过该字段实现定时抓图时间间隔的配置 + // 建议通过 CFG_CMD_ENCODE 配置的stuSnapFormat[nSnapMode].stuVideoFormat.nFrameRate字段实现相关功能 + public int CmdSerial; // 请求序列号,有效值范围 0~65535,超过范围会被截断为 unsigned short + public int[] Reserved = new int[4]; + } + + // 对应CLIENT_StartSearchDevices接口 + public static class DEVICE_NET_INFO_EX extends Structure + { + public int iIPVersion;//4 for IPV4, 6 for IPV6 + public byte[] szIP = new byte[64];//IPIPV4形如"192.168.0.1" + public int nPort;//tcp端口 + public byte[] szSubmask = new byte[64];//子网掩码IPV6无子网掩码 + public byte[] szGateway = new byte[64];//网关 + public byte[] szMac = new byte[NET_MACADDR_LEN];//MAC地址 + public byte[] szDeviceType = new byte[NET_DEV_TYPE_LEN];//设备类型 + public byte byManuFactory;//目标设备的生产厂商,具体参考EM_IPC_TYPE类 + public byte byDefinition;//1-标清2-高清 + public byte bDhcpEn;//Dhcp使能状态,true-开,false-关, 类型为bool, 取值0或者1 + public byte byReserved1;//字节对齐 + public byte[] verifyData = new byte[88];//校验数据通过异步搜索回调获取(在修改设备IP时会用此信息进行校验) + public byte[] szSerialNo = new byte[NET_DEV_SERIALNO_LEN];//序列号 + public byte[] szDevSoftVersion = new byte[NET_MAX_URL_LEN];//设备软件版本号 + public byte[] szDetailType = new byte[NET_DEV_TYPE_LEN];//设备型号 + public byte[] szVendor = new byte[NET_MAX_STRING_LEN];//OEM客户类型 + public byte[] szDevName = new byte[NET_MACHINE_NAME_NUM];//设备名称 + public byte[] szUserName = new byte[NET_USER_NAME_LENGTH_EX];//登陆设备用户名(在修改设备IP时需要填写) + public byte[] szPassWord = new byte[NET_USER_NAME_LENGTH_EX];//登陆设备密码(在修改设备IP时需要填写) + public short nHttpPort;//HTTP服务端口号, unsigned short类型 + public short wVideoInputCh;//视频输入通道数 + public short wRemoteVideoInputCh;//远程视频输入通道数 + public short wVideoOutputCh;//视频输出通道数 + public short wAlarmInputCh;//报警输入通道数 + public short wAlarmOutputCh;//报警输出通道数 + public int bNewWordLen; // TRUE使用新密码字段szNewPassWord, BOOL类型 + public byte[] szNewPassWord = new byte[NET_COMMON_STRING_64]; // 登陆设备密码(在修改设备IP时需要填写) + public byte byInitStatus; // 设备初始化状态,按位确定初始化状态 + // bit0~1:0-老设备,没有初始化功能 1-未初始化账号 2-已初始化账户 + // bit2~3:0-老设备,保留 1-公网接入未使能 2-公网接入已使能 + // bit4~5:0-老设备,保留 1-手机直连未使能 2-手机直连使能 + + public byte byPwdResetWay; // 支持密码重置方式:按位确定密码重置方式,只在设备有初始化账号时有意义 + // bit0-支持预置手机号 bit1-支持预置邮箱 bit2-支持文件导出 + public byte bySpecialAbility; // 设备初始化能力,按位确定初始化能力 + public byte[] szNewDetailType = new byte[NET_COMMON_STRING_64]; // 设备型号 + public int bNewUserName; // TRUE表示使用新用户名(szNewUserName)字段. BOOL类型 + public byte[] szNewUserName = new byte[NET_COMMON_STRING_64]; // 登陆设备用户名(在修改设备IP时需要填写) + public byte[] cReserved = new byte[41]; + } + + // 视频输入通道信息 + public static class NET_VIDEO_INPUTS extends Structure { + public int dwSize; + public byte[] szChnName = new byte[64]; // 通道名称 + public int bEnable; // 使能 + public byte[] szControlID = new byte[128]; // 控制ID + public byte[] szMainStreamUrl = new byte[MAX_PATH]; // 主码流url地址 + public byte[] szExtraStreamUrl = new byte[MAX_PATH]; // 辅码流url地址 + public int nOptionalMainUrlCount; // 备用主码流地址数量 + public byte[] szOptionalMainUrls = new byte[8*MAX_PATH]; // 备用主码流地址列表 + public int nOptionalExtraUrlCount; // 备用辅码流地址数量 + public byte[] szOptionalExtraUrls = new byte[8*MAX_PATH]; // 备用辅码流地址列表 + + public NET_VIDEO_INPUTS() + { + this.dwSize = this.size(); + } + } + + // 远程设备信息 + public static class NET_REMOTE_DEVICE extends Structure { + public int dwSize; + public int bEnable; // 使能 + public byte[] szIp = new byte[16]; // IP + public byte[] szUser = new byte[8]; // 用户名, 建议使用szUserEx + public byte[] szPwd = new byte[8]; // 密码, 建议使用szPwdEx + public int nPort; // 端口 + public int nDefinition; // 清晰度, 0-标清, 1-高清 + public int emProtocol; // 协议类型 NET_DEVICE_PROTOCOL + public byte[] szDevName = new byte[64]; // 设备名称 + public int nVideoInputChannels; // 视频输入通道数 + public int nAudioInputChannels; // 音频输入通道数 + public byte[] szDevClass = new byte[32]; // 设备类型, 如IPC, DVR, NVR等 + public byte[] szDevType = new byte[32]; // 设备具体型号, 如IPC-HF3300 + public int nHttpPort; // Http端口 + public int nMaxVideoInputCount; // 视频输入通道最大数 + public int nRetVideoInputCount; // 返回实际通道个数 + public Pointer pstuVideoInputs; // 视频输入通道信息 NET_VIDEO_INPUTS* + public byte[] szMachineAddress = new byte[256]; // 设备部署地 + public byte[] szSerialNo = new byte[48]; // 设备序列号 + public int nRtspPort; // Rtsp端口 + + /*以下用于新平台扩展*/ + public byte[] szUserEx = new byte[32]; // 用户名 + public byte[] szPwdEx = new byte[32]; // 密码 + + public NET_REMOTE_DEVICE() + { + this.dwSize = this.size(); + } + } + + // 可用的显示源信息 + public static class NET_MATRIX_CAMERA_INFO extends Structure + { + public int dwSize; + public byte szName[] = new byte[128]; // 名称 + public byte szDevID[] = new byte[128]; // 设备ID + public byte szszControlID[] = new byte[128]; // 控制ID + public int nChannelID; // 通道号, DeviceID设备内唯一 + public int nUniqueChannel; // 设备内统一编号的唯一通道号 + public int bRemoteDevice; // 是否远程设备 + public NET_REMOTE_DEVICE stuRemoteDevice; // 远程设备信息 + public int emStreamType; // 视频码流类型 NET_STREAM_TYPE + public int emChannelType; // 通道类型应 NET_LOGIC_CHN_TYPE + + public NET_MATRIX_CAMERA_INFO() { + this.dwSize = this.size(); + stuRemoteDevice = new NET_REMOTE_DEVICE(); + } + } + + // CLIENT_MatrixGetCameras接口的输入参数 + public static class NET_IN_MATRIX_GET_CAMERAS extends Structure { + public int dwSize; + + public NET_IN_MATRIX_GET_CAMERAS() { + this.dwSize = this.size(); + } + } + + // CLIENT_MatrixGetCameras接口的输出参数 + public static class NET_OUT_MATRIX_GET_CAMERAS extends Structure { + public int dwSize; + public Pointer pstuCameras; // 显示源信息数组, 用户分配内存 NET_MATRIX_CAMERA_INFO + public int nMaxCameraCount; // 显示源数组大小 + public int nRetCameraCount; // 返回的显示源数量 + + public NET_OUT_MATRIX_GET_CAMERAS() { + this.dwSize = this.size(); + } + } + + // CLIENT_SnapPictureToFile 接口输入参数 + public static class NET_IN_SNAP_PIC_TO_FILE_PARAM extends Structure { + public int dwSize; // 结构体大小 + public SNAP_PARAMS stuParam; // 抓图参数, 其中mode字段仅一次性抓图, 不支持定时或持续抓图; 除了车载DVR, 其他设备仅支持每秒一张的抓图频率 + + public byte[] szFilePath = new byte[MAX_PATH];// 写入文件的地址 + + public NET_IN_SNAP_PIC_TO_FILE_PARAM() { + this.dwSize = this.size(); + this.stuParam = new SNAP_PARAMS(); + } + } + + // CLIENT_SnapPictureToFile 接口输出参数 + public static class NET_OUT_SNAP_PIC_TO_FILE_PARAM extends Structure { + public int dwSize; + public Pointer szPicBuf; // 图片内容,用户分配内存 + public int dwPicBufLen; // 图片内容内存大小, 单位:字节 + public int dwPicBufRetLen; // 返回的图片大小, 单位:字节 + + public NET_OUT_SNAP_PIC_TO_FILE_PARAM() { + this.dwSize = this.size(); + } + + public NET_OUT_SNAP_PIC_TO_FILE_PARAM(int nMaxBuf) { + this.dwSize = this.size(); + this.dwPicBufLen = nMaxBuf; + Memory mem = new Memory(nMaxBuf); + mem.clear(); + this.szPicBuf = mem; + } + } + + // 录像文件信息 + public static class NET_RECORDFILE_INFO extends Structure { + public int ch; // 通道号 + public byte[] filename = new byte[124]; // 文件名 + public int framenum; // 文件总帧数 + public int size; // 文件长度 + public NET_TIME starttime = new NET_TIME(); // 开始时间 + public NET_TIME endtime = new NET_TIME(); // 结束时间 + public int driveno; // 磁盘号(区分网络录像和本地录像的类型,0-127表示本地录像,其中64表示光盘1,128表示网络录像) + public int startcluster; // 起始簇号 + public byte nRecordFileType; // 录象文件类型 0:普通录象;1:报警录象;2:移动检测;3:卡号录象;4:图片, 5: 智能录像,255:所有录像 + public byte bImportantRecID; // 0:普通录像 1:重要录像 + public byte bHint; // 文件定位索引(nRecordFileType==4<图片>时,bImportantRecID<<8 +bHint ,组成图片定位索引 ) + public byte bRecType; // 0-主码流录像 1-辅码1流录像 2-辅码流2 3-辅码流3录像 + + public static class ByValue extends NET_RECORDFILE_INFO implements Structure.ByValue { } + public static class ByReference extends NET_RECORDFILE_INFO implements Structure.ByReference { } + } + + // 录像查询类型 + public static class EM_QUERY_RECORD_TYPE extends Structure { + public static final int EM_RECORD_TYPE_ALL = 0; // 所有录像 + public static final int EM_RECORD_TYPE_ALARM = 1; // 外部报警录像 + public static final int EM_RECORD_TYPE_MOTION_DETECT = 2; // 动态检测报警录像 + public static final int EM_RECORD_TYPE_ALARM_ALL = 3; // 所有报警录像 + public static final int EM_RECORD_TYPE_CARD = 4; // 卡号查询 + public static final int EM_RECORD_TYPE_CONDITION = 5; // 按条件查询 + public static final int EM_RECORD_TYPE_JOIN = 6; // 组合查询 + public static final int EM_RECORD_TYPE_CARD_PICTURE = 8; // 按卡号查询图片,HB-U、NVS等使用 + public static final int EM_RECORD_TYPE_PICTURE = 9; // 查询图片,HB-U、NVS等使用 + public static final int EM_RECORD_TYPE_FIELD = 10; // 按字段查询 + public static final int EM_RECORD_TYPE_INTELLI_VIDEO = 11; // 智能录像查询 + public static final int EM_RECORD_TYPE_NET_DATA = 15; // 查询网络数据,金桥网吧等使用 + public static final int EM_RECORD_TYPE_TRANS_DATA = 16; // 查询透明串口数据录像 + public static final int EM_RECORD_TYPE_IMPORTANT = 17; // 查询重要录像 + public static final int EM_RECORD_TYPE_TALK_DATA = 18; // 查询录音文件 + + public static final int EM_RECORD_TYPE_INVALID = 256; // 无效的查询类型 + } + + // 语言种类 + public static class NET_LANGUAGE_TYPE extends Structure + { + public static final int NET_LANGUAGE_ENGLISH = 0; //英文 + public static final int NET_LANGUAGE_CHINESE_SIMPLIFIED = NET_LANGUAGE_ENGLISH+1; //简体中文 + public static final int NET_LANGUAGE_CHINESE_TRADITIONAL = NET_LANGUAGE_CHINESE_SIMPLIFIED+1; //繁体中文 + public static final int NET_LANGUAGE_ITALIAN = NET_LANGUAGE_CHINESE_TRADITIONAL+1; //意大利文 + public static final int NET_LANGUAGE_SPANISH = NET_LANGUAGE_ITALIAN+1; //西班牙文 + public static final int NET_LANGUAGE_JAPANESE = NET_LANGUAGE_SPANISH+1; //日文版 + public static final int NET_LANGUAGE_RUSSIAN = NET_LANGUAGE_JAPANESE+1; //俄文版 + public static final int NET_LANGUAGE_FRENCH = NET_LANGUAGE_RUSSIAN+1; //法文版 + public static final int NET_LANGUAGE_GERMAN = NET_LANGUAGE_FRENCH+1; //德文版 + public static final int NET_LANGUAGE_PORTUGUESE = NET_LANGUAGE_GERMAN+1; //葡萄牙语 + public static final int NET_LANGUAGE_TURKEY = NET_LANGUAGE_PORTUGUESE+1; //土尔其语 + public static final int NET_LANGUAGE_POLISH = NET_LANGUAGE_TURKEY+1; //波兰语 + public static final int NET_LANGUAGE_ROMANIAN = NET_LANGUAGE_POLISH+1; //罗马尼亚 + public static final int NET_LANGUAGE_HUNGARIAN = NET_LANGUAGE_ROMANIAN+1; //匈牙利语 + public static final int NET_LANGUAGE_FINNISH = NET_LANGUAGE_HUNGARIAN+1; //芬兰语 + public static final int NET_LANGUAGE_ESTONIAN = NET_LANGUAGE_FINNISH+1; //爱沙尼亚语 + public static final int NET_LANGUAGE_KOREAN = NET_LANGUAGE_ESTONIAN+1; //韩语 + public static final int NET_LANGUAGE_FARSI = NET_LANGUAGE_KOREAN+1; //波斯语 + public static final int NET_LANGUAGE_DANSK = NET_LANGUAGE_FARSI+1; //丹麦语 + public static final int NET_LANGUAGE_CZECHISH = NET_LANGUAGE_DANSK+1; //捷克文 + public static final int NET_LANGUAGE_BULGARIA = NET_LANGUAGE_CZECHISH+1; //保加利亚文 + public static final int NET_LANGUAGE_SLOVAKIAN = NET_LANGUAGE_BULGARIA+1; //斯洛伐克语 + public static final int NET_LANGUAGE_SLOVENIA = NET_LANGUAGE_SLOVAKIAN+1; //斯洛文尼亚文 + public static final int NET_LANGUAGE_CROATIAN = NET_LANGUAGE_SLOVENIA+1; //克罗地亚语 + public static final int NET_LANGUAGE_DUTCH = NET_LANGUAGE_CROATIAN+1; //荷兰语 + public static final int NET_LANGUAGE_GREEK = NET_LANGUAGE_DUTCH+1; //希腊语 + public static final int NET_LANGUAGE_UKRAINIAN = NET_LANGUAGE_GREEK+1; //乌克兰语 + public static final int NET_LANGUAGE_SWEDISH = NET_LANGUAGE_UKRAINIAN+1; //瑞典语 + public static final int NET_LANGUAGE_SERBIAN = NET_LANGUAGE_SWEDISH+1; //塞尔维亚语 + public static final int NET_LANGUAGE_VIETNAMESE = NET_LANGUAGE_SERBIAN+1; //越南语 + public static final int NET_LANGUAGE_LITHUANIAN = NET_LANGUAGE_VIETNAMESE+1; //立陶宛语 + public static final int NET_LANGUAGE_FILIPINO = NET_LANGUAGE_LITHUANIAN+1; //菲律宾语 + public static final int NET_LANGUAGE_ARABIC = NET_LANGUAGE_FILIPINO+1; //阿拉伯语 + public static final int NET_LANGUAGE_CATALAN = NET_LANGUAGE_ARABIC+1; //加泰罗尼亚语 + public static final int NET_LANGUAGE_LATVIAN = NET_LANGUAGE_CATALAN+1; //拉脱维亚语 + public static final int NET_LANGUAGE_THAI = NET_LANGUAGE_LATVIAN+1; //泰语 + public static final int NET_LANGUAGE_HEBREW = NET_LANGUAGE_THAI+1; //希伯来语 + public static final int NET_LANGUAGE_Bosnian = NET_LANGUAGE_HEBREW+1; //波斯尼亚文 + } + + // 区域信息 + public static class CFG_RECT extends Structure + { + public int nLeft; + public int nTop; + public int nRight; + public int nBottom; + } + + // 视频输入夜晚特殊配置选项,在晚上光线较暗时自动切换到夜晚的配置参数 + public static class CFG_VIDEO_IN_NIGHT_OPTIONS extends Structure + { + public byte bySwitchMode;//已废弃,使用CFG_VIDEO_IN_OPTIONS里面的bySwitchMode + //0-不切换,总是使用白天配置;1-根据亮度切换;2-根据时间切换;3-不切换,总是使用夜晚配置;4-使用普通配置 + public byte byProfile;//当前使用的配置文件. + // 0-白天 + // 1-晚上 + // 2-Normal + // 0,1,2都为临时配置,使图像生效,便于查看图像调试效果,不点击确定,离开页面不保存至设备。 + ///3-非临时配置,点击确定后保存至设备,与SwitchMode结合使用,根据SwitchMode决定最终生效的配置。 + // SwitchMode=0,Profile=3,设置白天配置到设备; + // SwitchMode=1,Profile=3,则设置夜晚配置到设备 + // SwitchMode=2,Profile=3,根据日出日落时间段切换,白天时间段使用白天配置,夜晚时间段使用夜晚配置,保存至设备; + // SwitchMode=4,Profile=3;使用普通配置,保存至设备 + public byte byBrightnessThreshold;//亮度阈值0~100 + public byte bySunriseHour;//大致日出和日落时间,日落之后日出之前,将采用夜晚特殊的配置。 + public byte bySunriseMinute;//00:00:00 ~ 23:59:59 + public byte bySunriseSecond; + public byte bySunsetHour; + public byte bySunsetMinute; + public byte bySunsetSecond; + public byte byGainRed;//红色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainBlue;//绿色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainGreen;//蓝色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byExposure;//曝光模式;取值范围取决于设备能力集:0-自动曝光,1-曝光等级1,2-曝光等级2…n-1最大曝光等级数n带时间上下限的自动曝光n+1自定义时间手动曝光 (n==byExposureEn) + public float fExposureValue1;//自动曝光时间下限或者手动曝光自定义时间,毫秒为单位,取值0.1ms~80ms + public float fExposureValue2;//自动曝光时间上限,毫秒为单位,取值0.1ms~80ms + public byte byWhiteBalance;//白平衡,0-"Disable", 1-"Auto", 2-"Custom", 3-"Sunny", 4-"Cloudy", 5-"Home", 6-"Office", 7-"Night", 8-"HighColorTemperature", 9-"LowColorTemperature", 10-"AutoColorTemperature", 11-"CustomColorTemperature" + public byte byGain;//0~100,GainAuto为true时表示自动增益的上限,否则表示固定的增益值 + public byte bGainAuto;//自动增益, 类型为bool, 取值0或1 + public byte bIrisAuto;//自动光圈, 类型为bool, 取值0或1 + public float fExternalSyncPhase;//外同步的相位设置0~360 + public byte byGainMin;//增益下限 + public byte byGainMax;//增益上限 + public byte byBacklight;//背光补偿:取值范围取决于设备能力集:0-关闭1-启用2-指定区域背光补偿 + public byte byAntiFlicker;//防闪烁模式0-Outdoor1-50Hz防闪烁 2-60Hz防闪烁 + public byte byDayNightColor;//日/夜模式;0-总是彩色,1-根据亮度自动切换,2-总是黑白 + public byte byExposureMode;//曝光模式调节曝光等级为自动曝光时有效,取值:0-默认自动,1-增益优先,2-快门优先 + public byte byRotate90;//0-不旋转,1-顺时针90°,2-逆时针90° + public byte bMirror;//镜像, 类型为bool, 取值0或1 + public byte byWideDynamicRange;//宽动态值0-关闭,1~100-为真实范围值 + public byte byGlareInhibition;//强光抑制0-关闭,1~100为范围值 + public CFG_RECT stuBacklightRegion = new CFG_RECT();//背光补偿区域 + public byte byFocusMode;//0-关闭,1-辅助聚焦,2-自动聚焦 + public byte bFlip;//翻转, 类型为bool, 取值0或1 + public byte[] reserved = new byte[74];//保留 + } + + // 闪光灯配置 + public static class CFG_FLASH_CONTROL extends Structure + { + public byte byMode;//工作模式,0-禁止闪光,1-始终闪光,2-自动闪光 + public byte byValue;//工作值,0-0us,1-64us, 2-128us, 3-192...15-960us + public byte byPole;//触发模式,0-低电平1-高电平 2-上升沿 3-下降沿 + public byte byPreValue;//亮度预设值区间0~100 + public byte byDutyCycle;//占空比,0~100 + public byte byFreqMultiple;//倍频,0~10 + public byte[] reserved = new byte[122];//保留 + } + + // 抓拍参数特殊配置 + public static class CFG_VIDEO_IN_SNAPSHOT_OPTIONS extends Structure + { + public byte byGainRed;//红色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainBlue;//绿色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainGreen;//蓝色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byExposure;//曝光模式;取值范围取决于设备能力集:0-自动曝光,1-曝光等级1,2-曝光等级2…n-1最大曝光等级数n带时间上下限的自动曝光n+1自定义时间手动曝光 (n==byExposureEn) + public float fExposureValue1;//自动曝光时间下限或者手动曝光自定义时间,毫秒为单位,取值0.1ms~80ms + public float fExposureValue2;//自动曝光时间上限,毫秒为单位,取值0.1ms~80ms + public byte byWhiteBalance;//白平衡,0-"Disable", 1-"Auto", 2-"Custom", 3-"Sunny", 4-"Cloudy", 5-"Home", 6-"Office", 7-"Night", 8-"HighColorTemperature", 9-"LowColorTemperature", 10-"AutoColorTemperature", 11-"CustomColorTemperature" + public byte byColorTemperature;//色温等级,白平衡为"CustomColorTemperature"模式下有效 + public byte bGainAuto;//自动增益, 类型为bool, 取值0或1 + public byte byGain;//增益调节,GainAuto为true时表示自动增益的上限,否则表示固定的增益值 + public byte[] reversed = new byte[112];//保留 + } + + // 鱼眼镜头配置 + public static class CFG_FISH_EYE extends Structure + { + public CFG_POLYGON stuCenterPoint;//鱼眼圆心坐标,范围[0,8192] + public int nRadius;//鱼眼半径大小,范围[0,8192], 类型为unsigned int + public float fDirection;//镜头旋转方向,旋转角度[0,360.0] + public byte byPlaceHolder;//镜头安装方式1顶装,2壁装;3地装,默认1 + public byte byCalibrateMode;//鱼眼矫正模式,详见CFG_CALIBRATE_MODE枚举值 + public byte[] reversed = new byte[31];//保留 + } + + public static class CFG_VIDEO_IN_NORMAL_OPTIONS extends Structure + { + public byte byGainRed;//红色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainBlue;//绿色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainGreen;//蓝色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byExposure;//曝光模式;取值范围取决于设备能力集:0-自动曝光,1-曝光等级1,2-曝光等级2…n-1最大曝光等级数n带时间上下限的自动曝光n+1自定义时间手动曝光 (n==byExposureEn) + public float fExposureValue1;//自动曝光时间下限或者手动曝光自定义时间,毫秒为单位,取值0.1ms~80ms + public float fExposureValue2;//自动曝光时间上限,毫秒为单位,取值0.1ms~80ms + public byte byWhiteBalance;//白平衡,0-"Disable", 1-"Auto", 2-"Custom", 3-"Sunny", 4-"Cloudy", 5-"Home", 6-"Office", 7-"Night", 8-"HighColorTemperature", 9-"LowColorTemperature", 10-"AutoColorTemperature", 11-"CustomColorTemperature" + public byte byGain;//0~100,GainAuto为true时表示自动增益的上限,否则表示固定的增益值 + public byte bGainAuto;//自动增益, 类型为bool, 取值0或1 + public byte bIrisAuto;//自动光圈, 类型为bool, 取值0或1 + public float fExternalSyncPhase;//外同步的相位设置0~360 + public byte byGainMin;//增益下限 + public byte byGainMax;//增益上限 + public byte byBacklight;//背光补偿:取值范围取决于设备能力集:0-关闭1-启用2-指定区域背光补偿 + public byte byAntiFlicker;//防闪烁模式0-Outdoor1-50Hz防闪烁 2-60Hz防闪烁 + public byte byDayNightColor;//日/夜模式;0-总是彩色,1-根据亮度自动切换,2-总是黑白 + public byte byExposureMode;//曝光模式调节曝光等级为自动曝光时有效,取值:0-默认自动,1-增益优先,2-快门优先 + public byte byRotate90;//0-不旋转,1-顺时针90°,2-逆时针90° + public byte bMirror;//镜像, 类型为bool, 取值0或1 + public byte byWideDynamicRange;//宽动态值0-关闭,1~100-为真实范围值 + public byte byGlareInhibition;//强光抑制0-关闭,1~100为范围值 + public CFG_RECT stuBacklightRegion;//背光补偿区域 + public byte byFocusMode;//0-关闭,1-辅助聚焦,2-自动聚焦 + public byte bFlip;//翻转, 类型为bool, 取值0或1 + public byte[] reserved = new byte[74];//保留 + } + + // 视频输入前端选项 + public static class CFG_VIDEO_IN_OPTIONS extends Structure + { + public byte byBacklight;//背光补偿:取值范围取决于设备能力集:0-关闭1-启用2-指定区域背光补偿 + public byte byDayNightColor;//日/夜模式;0-总是彩色,1-根据亮度自动切换,2-总是黑白 + public byte byWhiteBalance;//白平衡,0-"Disable", 1-"Auto", 2-"Custom", 3-"Sunny", 4-"Cloudy", 5-"Home", 6-"Office", 7-"Night", 8-"HighColorTemperature", 9-"LowColorTemperature", 10-"AutoColorTemperature", 11-"CustomColorTemperature" + public byte byColorTemperature;//色温等级,白平衡为"CustomColorTemperature"模式下有效 + public byte bMirror;//镜像, 类型为bool, 取值0或1 + public byte bFlip;//翻转, 类型为bool, 取值0或1 + public byte bIrisAuto;//自动光圈, 类型为bool, 取值0或1 + public byte bInfraRed;//根据环境光自动开启红外补偿灯, 类型为bool, 取值0或1 + public byte byGainRed;//红色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainBlue;//绿色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byGainGreen;//蓝色增益调节,白平衡为"Custom"模式下有效0~100 + public byte byExposure;//曝光模式;取值范围取决于设备能力集:0-自动曝光,1-曝光等级1,2-曝光等级2…n-1最大曝光等级数n带时间上下限的自动曝光n+1自定义时间手动曝光 (n==byExposureEn) + public float fExposureValue1;//自动曝光时间下限或者手动曝光自定义时间,毫秒为单位,取值0.1ms~80ms + public float fExposureValue2;//自动曝光时间上限,毫秒为单位,取值0.1ms~80ms + public byte bGainAuto;//自动增益, 类型为bool, 取值0或1 + public byte byGain;//增益调节,GainAuto为true时表示自动增益的上限,否则表示固定的增益值 + public byte bySignalFormat;//信号格式,0-Inside(内部输入)1-BT656 2-720p 3-1080p 4-1080i 5-1080sF + public byte byRotate90;//0-不旋转,1-顺时针90°,2-逆时针90° + public float fExternalSyncPhase;//外同步的相位设置 0~360 + public byte byExternalSync;//外部同步信号输入,0-内部同步 1-外部同步 + public byte bySwitchMode;//0-不切换,总是使用白天配置;1-根据亮度切换;2-根据时间切换;3-不切换,总是使用夜晚配置;4-使用普通配置 + public byte byDoubleExposure;//双快门,0-不启用,1-双快门全帧率,即图像和视频只有快门参数不同,2-双快门半帧率,即图像和视频快门及白平衡参数均不同 + public byte byWideDynamicRange;//宽动态值 + public CFG_VIDEO_IN_NIGHT_OPTIONS stuNightOptions;//夜晚参数 + public CFG_FLASH_CONTROL stuFlash;//闪光灯配置 + public CFG_VIDEO_IN_SNAPSHOT_OPTIONS stuSnapshot;//抓拍参数,双快门时有效 + public CFG_FISH_EYE stuFishEye;//鱼眼镜头 + public byte byFocusMode;//0-关闭,1-辅助聚焦,2-自动聚焦 + public byte[] reserved = new byte[28];//保留 + public byte byGainMin;//增益下限 + public byte byGainMax;//增益上限 + public byte byAntiFlicker;//防闪烁模式 0-Outdoor 1-50Hz防闪烁 2-60Hz防闪烁 + public byte byExposureMode;//曝光模式调节曝光等级为自动曝光时有效,取值:0-默认自动,1-增益优先,2-快门优先,4-手动 + public byte byGlareInhibition;//强光抑制0-关闭,1~100为范围值 + public CFG_RECT stuBacklightRegion;//背光补偿区域 + public CFG_VIDEO_IN_NORMAL_OPTIONS stuNormalOptions;//普通参数 + } + + // 通用云台控制命令 + public static class NET_PTZ_ControlType extends Structure + { + public static final int NET_PTZ_UP_CONTROL = 0;//上 + public static final int NET_PTZ_DOWN_CONTROL = NET_PTZ_UP_CONTROL+1; //下 + public static final int NET_PTZ_LEFT_CONTROL = NET_PTZ_DOWN_CONTROL+1; //左 + public static final int NET_PTZ_RIGHT_CONTROL = NET_PTZ_LEFT_CONTROL+1; //右 + public static final int NET_PTZ_ZOOM_ADD_CONTROL = NET_PTZ_RIGHT_CONTROL+1; //变倍+ + public static final int NET_PTZ_ZOOM_DEC_CONTROL = NET_PTZ_ZOOM_ADD_CONTROL+1; //变倍- + public static final int NET_PTZ_FOCUS_ADD_CONTROL = NET_PTZ_ZOOM_DEC_CONTROL+1; //调焦+ + public static final int NET_PTZ_FOCUS_DEC_CONTROL = NET_PTZ_FOCUS_ADD_CONTROL+1; //调焦- + public static final int NET_PTZ_APERTURE_ADD_CONTROL = NET_PTZ_FOCUS_DEC_CONTROL+1; //光圈+ + public static final int NET_PTZ_APERTURE_DEC_CONTROL = NET_PTZ_APERTURE_ADD_CONTROL+1; //光圈- + public static final int NET_PTZ_POINT_MOVE_CONTROL = NET_PTZ_APERTURE_DEC_CONTROL+1; //转至预置点 + public static final int NET_PTZ_POINT_SET_CONTROL = NET_PTZ_POINT_MOVE_CONTROL+1; //设置 + public static final int NET_PTZ_POINT_DEL_CONTROL = NET_PTZ_POINT_SET_CONTROL+1; //删除 + public static final int NET_PTZ_POINT_LOOP_CONTROL = NET_PTZ_POINT_DEL_CONTROL+1; //点间巡航 + public static final int NET_PTZ_LAMP_CONTROL = NET_PTZ_POINT_LOOP_CONTROL+1; //灯光雨刷 + } + + // 云台控制扩展命令 + public static class NET_EXTPTZ_ControlType extends Structure + { + public static final int NET_EXTPTZ_LEFTTOP = 0x20;//左上 + public static final int NET_EXTPTZ_RIGHTTOP = NET_EXTPTZ_LEFTTOP+1; //右上 + public static final int NET_EXTPTZ_LEFTDOWN = NET_EXTPTZ_RIGHTTOP+1; //左下 + public static final int NET_EXTPTZ_RIGHTDOWN = NET_EXTPTZ_LEFTDOWN+1; //右下 + public static final int NET_EXTPTZ_ADDTOLOOP = NET_EXTPTZ_RIGHTDOWN+1; //加入预置点到巡航巡航线路预置点值 + public static final int NET_EXTPTZ_DELFROMLOOP = NET_EXTPTZ_ADDTOLOOP+1; //删除巡航中预置点巡航线路预置点值 + public static final int NET_EXTPTZ_CLOSELOOP = NET_EXTPTZ_DELFROMLOOP+1; //清除巡航巡航线路 + public static final int NET_EXTPTZ_STARTPANCRUISE = NET_EXTPTZ_CLOSELOOP+1; //开始水平旋转 + public static final int NET_EXTPTZ_STOPPANCRUISE = NET_EXTPTZ_STARTPANCRUISE+1; //停止水平旋转 + public static final int NET_EXTPTZ_SETLEFTBORDER = NET_EXTPTZ_STOPPANCRUISE+1; //设置左边界 + public static final int NET_EXTPTZ_SETRIGHTBORDER = NET_EXTPTZ_SETLEFTBORDER+1; //设置右边界 + public static final int NET_EXTPTZ_STARTLINESCAN = NET_EXTPTZ_SETRIGHTBORDER+1; //开始线扫 + public static final int NET_EXTPTZ_CLOSELINESCAN = NET_EXTPTZ_STARTLINESCAN+1; //停止线扫 + public static final int NET_EXTPTZ_SETMODESTART = NET_EXTPTZ_CLOSELINESCAN+1; //设置模式开始模式线路 + public static final int NET_EXTPTZ_SETMODESTOP = NET_EXTPTZ_SETMODESTART+1; //设置模式结束模式线路 + public static final int NET_EXTPTZ_RUNMODE = NET_EXTPTZ_SETMODESTOP+1; //运行模式模式线路 + public static final int NET_EXTPTZ_STOPMODE = NET_EXTPTZ_RUNMODE+1; //停止模式模式线路 + public static final int NET_EXTPTZ_DELETEMODE = NET_EXTPTZ_STOPMODE+1; //清除模式模式线路 + public static final int NET_EXTPTZ_REVERSECOMM = NET_EXTPTZ_DELETEMODE+1; //翻转命令 + public static final int NET_EXTPTZ_FASTGOTO = NET_EXTPTZ_REVERSECOMM+1; //快速定位水平坐标(8192)垂直坐标(8192)变倍(4) + public static final int NET_EXTPTZ_AUXIOPEN = NET_EXTPTZ_FASTGOTO+1; //辅助开关开辅助点 + public static final int NET_EXTPTZ_AUXICLOSE = NET_EXTPTZ_AUXIOPEN+1; //辅助开关关辅助点 + public static final int NET_EXTPTZ_OPENMENU = 0x36;//打开球机菜单 + public static final int NET_EXTPTZ_CLOSEMENU = NET_EXTPTZ_OPENMENU+1; //关闭菜单 + public static final int NET_EXTPTZ_MENUOK = NET_EXTPTZ_CLOSEMENU+1; //菜单确定 + public static final int NET_EXTPTZ_MENUCANCEL = NET_EXTPTZ_MENUOK+1; //菜单取消 + public static final int NET_EXTPTZ_MENUUP = NET_EXTPTZ_MENUCANCEL+1; //菜单上 + public static final int NET_EXTPTZ_MENUDOWN = NET_EXTPTZ_MENUUP+1; //菜单下 + public static final int NET_EXTPTZ_MENULEFT = NET_EXTPTZ_MENUDOWN+1; //菜单左 + public static final int NET_EXTPTZ_MENURIGHT = NET_EXTPTZ_MENULEFT+1; //菜单右 + public static final int NET_EXTPTZ_ALARMHANDLE = 0x40;//报警联动云台parm1:报警输入通道;parm2:报警联动类型1-预置点2-线扫3-巡航;parm3:联动值,如预置点号 + public static final int NET_EXTPTZ_MATRIXSWITCH = 0x41;//矩阵切换parm1:监视器号(视频输出号);parm2:视频输入号;parm3:矩阵号 + public static final int NET_EXTPTZ_LIGHTCONTROL= NET_EXTPTZ_MATRIXSWITCH+1; //灯光控制器 + public static final int NET_EXTPTZ_EXACTGOTO = NET_EXTPTZ_LIGHTCONTROL+1; //三维精确定位parm1:水平角度(0~3600);parm2:垂直坐标(0~900);parm3:变倍(1~128) + public static final int NET_EXTPTZ_RESETZERO = NET_EXTPTZ_EXACTGOTO+1; //三维定位重设零位 + public static final int NET_EXTPTZ_MOVE_ABSOLUTELY = NET_EXTPTZ_RESETZERO+1; //绝对移动控制命令,param4对应结构PTZ_CONTROL_ABSOLUTELY + public static final int NET_EXTPTZ_MOVE_CONTINUOUSLY = NET_EXTPTZ_MOVE_ABSOLUTELY+1; //持续移动控制命令,param4对应结构PTZ_CONTROL_CONTINUOUSLY + public static final int NET_EXTPTZ_GOTOPRESET = NET_EXTPTZ_MOVE_CONTINUOUSLY+1; //云台控制命令,以一定速度转到预置位点,parm4对应结构PTZ_CONTROL_GOTOPRESET + public static final int NET_EXTPTZ_SET_VIEW_RANGE = 0x49;//设置可视域(param4对应结构PTZ_VIEW_RANGE_INFO) + public static final int NET_EXTPTZ_FOCUS_ABSOLUTELY = 0x4A;//绝对聚焦(param4对应结构PTZ_FOCUS_ABSOLUTELY) + public static final int NET_EXTPTZ_HORSECTORSCAN = 0x4B;//水平扇扫(param4对应PTZ_CONTROL_SECTORSCAN,param1、param2、param3无效) + public static final int NET_EXTPTZ_VERSECTORSCAN = 0x4C;//垂直扇扫(param4对应PTZ_CONTROL_SECTORSCAN,param1、param2、param3无效) + public static final int NET_EXTPTZ_SET_ABS_ZOOMFOCUS = 0x4D;//设定绝对焦距、聚焦值,param1为焦距,范围:0,255],param2为聚焦,范围:[0,255],param3、param4无效 + public static final int NET_EXTPTZ_SET_FISHEYE_EPTZ = 0x4E;//控制鱼眼电子云台,param4对应结构PTZ_CONTROL_SET_FISHEYE_EPTZ + public static final int NET_EXTPTZ_UP_TELE = 0x70; //上 + TELE param1=速度(1-8),下同 + public static final int NET_EXTPTZ_DOWN_TELE = NET_EXTPTZ_UP_TELE+1; //下 + TELE + public static final int NET_EXTPTZ_LEFT_TELE = NET_EXTPTZ_DOWN_TELE+1; //左 + TELE + public static final int NET_EXTPTZ_RIGHT_TELE = NET_EXTPTZ_LEFT_TELE+1; //右 + TELE + public static final int NET_EXTPTZ_LEFTUP_TELE = NET_EXTPTZ_RIGHT_TELE+1; //左上 + TELE + public static final int NET_EXTPTZ_LEFTDOWN_TELE = NET_EXTPTZ_LEFTUP_TELE+1; //左下 + TELE + public static final int NET_EXTPTZ_TIGHTUP_TELE = NET_EXTPTZ_LEFTDOWN_TELE+1; //右上 + TELE + public static final int NET_EXTPTZ_RIGHTDOWN_TELE = NET_EXTPTZ_TIGHTUP_TELE+1; //右下 + TELE + public static final int NET_EXTPTZ_UP_WIDE = NET_EXTPTZ_RIGHTDOWN_TELE+1; // 上 + WIDEparam1=速度(1-8),下同 + public static final int NET_EXTPTZ_DOWN_WIDE = NET_EXTPTZ_UP_WIDE+1; //下 + WIDE + public static final int NET_EXTPTZ_LEFT_WIDE = NET_EXTPTZ_DOWN_WIDE+1; //左 + WIDE + public static final int NET_EXTPTZ_RIGHT_WIDE = NET_EXTPTZ_LEFT_WIDE+1; //右 + WIDE + public static final int NET_EXTPTZ_LEFTUP_WIDE = NET_EXTPTZ_RIGHT_WIDE+1; //左上 + WIDE + public static final int NET_EXTPTZ_LEFTDOWN_WIDE = NET_EXTPTZ_LEFTUP_WIDE+1; //左下 + WIDE + public static final int NET_EXTPTZ_TIGHTUP_WIDE = NET_EXTPTZ_LEFTDOWN_WIDE+1; //右上 + WIDE + public static final int NET_EXTPTZ_RIGHTDOWN_WIDE = NET_EXTPTZ_TIGHTUP_WIDE+1; //右下 + WIDE + public static final int NET_EXTPTZ_TOTAL = NET_EXTPTZ_RIGHTDOWN_WIDE+1; //最大命令值 + } + + // 雨刷工作模式 + public static class EM_CFG_RAINBRUSHMODE_MODE extends Structure + { + public static final int EM_CFG_RAINBRUSHMODE_MODE_UNKNOWN = 0; //未知 + public static final int EM_CFG_RAINBRUSHMODE_MODE_MANUAL = EM_CFG_RAINBRUSHMODE_MODE_UNKNOWN+1; //手动模式 + public static final int EM_CFG_RAINBRUSHMODE_MODE_TIMING = EM_CFG_RAINBRUSHMODE_MODE_MANUAL+1; //定时模式 + } + + // 雨刷使能电平模式 + public static class EM_CFG_RAINBRUSHMODE_ENABLEMODE extends Structure + { + public static final int EM_CFG_RAINBRUSHMODE_ENABLEMODE_UNKNOWN = 0; //未知 + public static final int EM_CFG_RAINBRUSHMODE_ENABLEMODE_LOW = EM_CFG_RAINBRUSHMODE_ENABLEMODE_UNKNOWN+1; //低电平有效(常闭) + public static final int EM_CFG_RAINBRUSHMODE_ENABLEMODE_HIGH = EM_CFG_RAINBRUSHMODE_ENABLEMODE_LOW+1; //高电平有效(常开) + } + + // 雨刷模式相关配置(对应 CFG_RAINBRUSHMODE_INFO 命令) + public static class CFG_RAINBRUSHMODE_INFO extends Structure + { + public int emMode;//雨刷工作模式, 取值为EM_CFG_RAINBRUSHMODE_MODE中的值 + public int emEnableMode;//雨刷使能电平模式, 取值为EM_CFG_RAINBRUSHMODE_ENABLEMODE中的值 + public int nPort;//雨刷使用的IO端口,-1表示未接入设备,-2表示该字段无效(设备未传送该字段) + } + + public static class CFG_RAINBRUSH_INFO extends Structure + { + public byte bEnable;//雨刷使能, 类型为bool, 取值0或1 + public byte bSpeedRate;//雨刷速度,1:快速;2:中速;3:慢速 + public byte[] bReserved = new byte[2];//保留对齐 + public CFG_TIME_SECTION[] stuTimeSection = (CFG_TIME_SECTION[])new CFG_TIME_SECTION().toArray(WEEK_DAY_NUM*MAX_REC_TSECT);// 事件响应时间段 + } + + // 控制类型,对应CLIENT_ControlDevice接口 + public static class CtrlType extends Structure + { + public static final int CTRLTYPE_CTRL_REBOOT = 0;//重启设备 + public static final int CTRLTYPE_CTRL_SHUTDOWN = CTRLTYPE_CTRL_REBOOT+1; //关闭设备 + public static final int CTRLTYPE_CTRL_DISK = CTRLTYPE_CTRL_SHUTDOWN+1; //硬盘管理 + public static final int CTRLTYPE_KEYBOARD_POWER =3;//网络键盘 + public static final int CTRLTYPE_KEYBOARD_ENTER = CTRLTYPE_KEYBOARD_POWER+1; + public static final int CTRLTYPE_KEYBOARD_ESC = CTRLTYPE_KEYBOARD_ENTER+1; + public static final int CTRLTYPE_KEYBOARD_UP = CTRLTYPE_KEYBOARD_ESC+1; + public static final int CTRLTYPE_KEYBOARD_DOWN = CTRLTYPE_KEYBOARD_UP+1; + public static final int CTRLTYPE_KEYBOARD_LEFT = CTRLTYPE_KEYBOARD_DOWN+1; + public static final int CTRLTYPE_KEYBOARD_RIGHT = CTRLTYPE_KEYBOARD_LEFT+1; + public static final int CTRLTYPE_KEYBOARD_BTN0 = CTRLTYPE_KEYBOARD_RIGHT+1; + public static final int CTRLTYPE_KEYBOARD_BTN1 = CTRLTYPE_KEYBOARD_BTN0+1; + public static final int CTRLTYPE_KEYBOARD_BTN2 = CTRLTYPE_KEYBOARD_BTN1+1; + public static final int CTRLTYPE_KEYBOARD_BTN3 = CTRLTYPE_KEYBOARD_BTN2+1; + public static final int CTRLTYPE_KEYBOARD_BTN4 = CTRLTYPE_KEYBOARD_BTN3+1; + public static final int CTRLTYPE_KEYBOARD_BTN5 = CTRLTYPE_KEYBOARD_BTN4+1; + public static final int CTRLTYPE_KEYBOARD_BTN6 = CTRLTYPE_KEYBOARD_BTN5+1; + public static final int CTRLTYPE_KEYBOARD_BTN7 = CTRLTYPE_KEYBOARD_BTN6+1; + public static final int CTRLTYPE_KEYBOARD_BTN8 = CTRLTYPE_KEYBOARD_BTN7+1; + public static final int CTRLTYPE_KEYBOARD_BTN9 = CTRLTYPE_KEYBOARD_BTN8+1; + public static final int CTRLTYPE_KEYBOARD_BTN10 = CTRLTYPE_KEYBOARD_BTN9+1; + public static final int CTRLTYPE_KEYBOARD_BTN11 = CTRLTYPE_KEYBOARD_BTN10+1; + public static final int CTRLTYPE_KEYBOARD_BTN12 = CTRLTYPE_KEYBOARD_BTN11+1; + public static final int CTRLTYPE_KEYBOARD_BTN13 = CTRLTYPE_KEYBOARD_BTN12+1; + public static final int CTRLTYPE_KEYBOARD_BTN14 = CTRLTYPE_KEYBOARD_BTN13+1; + public static final int CTRLTYPE_KEYBOARD_BTN15 = CTRLTYPE_KEYBOARD_BTN14+1; + public static final int CTRLTYPE_KEYBOARD_BTN16 = CTRLTYPE_KEYBOARD_BTN15+1; + public static final int CTRLTYPE_KEYBOARD_SPLIT = CTRLTYPE_KEYBOARD_BTN16+1; + public static final int CTRLTYPE_KEYBOARD_ONE = CTRLTYPE_KEYBOARD_SPLIT+1; + public static final int CTRLTYPE_KEYBOARD_NINE = CTRLTYPE_KEYBOARD_ONE+1; + public static final int CTRLTYPE_KEYBOARD_ADDR = CTRLTYPE_KEYBOARD_NINE+1; + public static final int CTRLTYPE_KEYBOARD_INFO = CTRLTYPE_KEYBOARD_ADDR+1; + public static final int CTRLTYPE_KEYBOARD_REC = CTRLTYPE_KEYBOARD_INFO+1; + public static final int CTRLTYPE_KEYBOARD_FN1 = CTRLTYPE_KEYBOARD_REC+1; + public static final int CTRLTYPE_KEYBOARD_FN2 = CTRLTYPE_KEYBOARD_FN1+1; + public static final int CTRLTYPE_KEYBOARD_PLAY = CTRLTYPE_KEYBOARD_FN2+1; + public static final int CTRLTYPE_KEYBOARD_STOP = CTRLTYPE_KEYBOARD_PLAY+1; + public static final int CTRLTYPE_KEYBOARD_SLOW = CTRLTYPE_KEYBOARD_STOP+1; + public static final int CTRLTYPE_KEYBOARD_FAST = CTRLTYPE_KEYBOARD_SLOW+1; + public static final int CTRLTYPE_KEYBOARD_PREW = CTRLTYPE_KEYBOARD_FAST+1; + public static final int CTRLTYPE_KEYBOARD_NEXT = CTRLTYPE_KEYBOARD_PREW+1; + public static final int CTRLTYPE_KEYBOARD_JMPDOWN = CTRLTYPE_KEYBOARD_NEXT+1; + public static final int CTRLTYPE_KEYBOARD_JMPUP = CTRLTYPE_KEYBOARD_JMPDOWN+1; + public static final int CTRLTYPE_KEYBOARD_10PLUS = CTRLTYPE_KEYBOARD_JMPUP+1; + public static final int CTRLTYPE_KEYBOARD_SHIFT = CTRLTYPE_KEYBOARD_10PLUS+1; + public static final int CTRLTYPE_KEYBOARD_BACK = CTRLTYPE_KEYBOARD_SHIFT+1; + public static final int CTRLTYPE_KEYBOARD_LOGIN = CTRLTYPE_KEYBOARD_BACK+1;//新网络键盘功能 + public static final int CTRLTYPE_KEYBOARD_CHNNEL = CTRLTYPE_KEYBOARD_LOGIN+1;//切换视频通道 + public static final int CTRLTYPE_TRIGGER_ALARM_IN =100;//触发报警输入 + public static final int CTRLTYPE_TRIGGER_ALARM_OUT = CTRLTYPE_TRIGGER_ALARM_IN+1; //触发报警输出 + public static final int CTRLTYPE_CTRL_MATRIX = CTRLTYPE_TRIGGER_ALARM_OUT+1; //矩阵控制 + public static final int CTRLTYPE_CTRL_SDCARD = CTRLTYPE_CTRL_MATRIX+1; //SD卡控制(IPC产品)参数同硬盘控制 + public static final int CTRLTYPE_BURNING_START = CTRLTYPE_CTRL_SDCARD+1; //刻录机控制,开始刻录 + public static final int CTRLTYPE_BURNING_STOP = CTRLTYPE_BURNING_START+1; //刻录机控制,结束刻录 + public static final int CTRLTYPE_BURNING_ADDPWD = CTRLTYPE_BURNING_STOP+1; //刻录机控制,叠加密码(以'\0'为结尾的字符串,最大长度8位) + public static final int CTRLTYPE_BURNING_ADDHEAD = CTRLTYPE_BURNING_ADDPWD+1; //刻录机控制,叠加片头(以'\0'为结尾的字符串,最大长度1024字节,支持分行,行分隔符'\n') + public static final int CTRLTYPE_BURNING_ADDSIGN = CTRLTYPE_BURNING_ADDHEAD+1; //刻录机控制,叠加打点到刻录信息(参数无) + public static final int CTRLTYPE_BURNING_ADDCURSTOMINFO = CTRLTYPE_BURNING_ADDSIGN+1; //刻录机控制,自定义叠加(以'\0'为结尾的字符串,最大长度1024字节,支持分行,行分隔符'\n') + public static final int CTRLTYPE_CTRL_RESTOREDEFAULT = CTRLTYPE_BURNING_ADDCURSTOMINFO+1; //恢复设备的默认设置 + public static final int CTRLTYPE_CTRL_CAPTURE_START = CTRLTYPE_CTRL_RESTOREDEFAULT+1; //触发设备抓图 + public static final int CTRLTYPE_CTRL_CLEARLOG = CTRLTYPE_CTRL_CAPTURE_START+1; //清除日志 + public static final int CTRLTYPE_TRIGGER_ALARM_WIRELESS =200;//触发无线报警(IPC产品) + public static final int CTRLTYPE_MARK_IMPORTANT_RECORD = CTRLTYPE_TRIGGER_ALARM_WIRELESS+1; //标识重要录像文件 + public static final int CTRLTYPE_CTRL_DISK_SUBAREA = CTRLTYPE_MARK_IMPORTANT_RECORD+1; //网络硬盘分区 + public static final int CTRLTYPE_BURNING_ATTACH = CTRLTYPE_CTRL_DISK_SUBAREA+1; //刻录机控制,附件刻录. + public static final int CTRLTYPE_BURNING_PAUSE = CTRLTYPE_BURNING_ATTACH+1; //刻录暂停 + public static final int CTRLTYPE_BURNING_CONTINUE = CTRLTYPE_BURNING_PAUSE+1; //刻录继续 + public static final int CTRLTYPE_BURNING_POSTPONE = CTRLTYPE_BURNING_CONTINUE+1; //刻录顺延 + public static final int CTRLTYPE_CTRL_OEMCTRL = CTRLTYPE_BURNING_POSTPONE+1; //报停控制 + public static final int CTRLTYPE_BACKUP_START = CTRLTYPE_CTRL_OEMCTRL+1; //设备备份开始 + public static final int CTRLTYPE_BACKUP_STOP = CTRLTYPE_BACKUP_START+1; //设备备份停止 + public static final int CTRLTYPE_VIHICLE_WIFI_ADD = CTRLTYPE_BACKUP_STOP+1; //车载手动增加WIFI配置 + public static final int CTRLTYPE_VIHICLE_WIFI_DEC = CTRLTYPE_VIHICLE_WIFI_ADD+1; //车载手动删除WIFI配置 + public static final int CTRLTYPE_BUZZER_START = CTRLTYPE_VIHICLE_WIFI_DEC+1; //蜂鸣器控制开始 + public static final int CTRLTYPE_BUZZER_STOP = CTRLTYPE_BUZZER_START+1; //蜂鸣器控制结束 + public static final int CTRLTYPE_REJECT_USER = CTRLTYPE_BUZZER_STOP+1; //剔除用户 + public static final int CTRLTYPE_SHIELD_USER = CTRLTYPE_REJECT_USER+1; //屏蔽用户 + public static final int CTRLTYPE_RAINBRUSH = CTRLTYPE_SHIELD_USER+1; //智能交通,雨刷控制 + public static final int CTRLTYPE_MANUAL_SNAP = CTRLTYPE_RAINBRUSH+1; //智能交通,手动抓拍(对应结构体MANUAL_SNAP_PARAMETER) + public static final int CTRLTYPE_MANUAL_NTP_TIMEADJUST = CTRLTYPE_MANUAL_SNAP+1; //手动NTP校时 + public static final int CTRLTYPE_NAVIGATION_SMS = CTRLTYPE_MANUAL_NTP_TIMEADJUST+1; //导航信息和短消息 + public static final int CTRLTYPE_CTRL_ROUTE_CROSSING = CTRLTYPE_NAVIGATION_SMS+1; //路线点位信息 + public static final int CTRLTYPE_BACKUP_FORMAT = CTRLTYPE_CTRL_ROUTE_CROSSING+1; //格式化备份设备 + public static final int CTRLTYPE_DEVICE_LOCALPREVIEW_SLIPT = CTRLTYPE_BACKUP_FORMAT+1; //控制设备端本地预览分割(对应结构体DEVICE_LOCALPREVIEW_SLIPT_PARAMETER) + public static final int CTRLTYPE_CTRL_INIT_RAID = CTRLTYPE_DEVICE_LOCALPREVIEW_SLIPT+1; //RAID初始化 + public static final int CTRLTYPE_CTRL_RAID = CTRLTYPE_CTRL_INIT_RAID+1; //RAID操作 + public static final int CTRLTYPE_CTRL_SAPREDISK = CTRLTYPE_CTRL_RAID+1; //热备盘操作 + public static final int CTRLTYPE_WIFI_CONNECT = CTRLTYPE_CTRL_SAPREDISK+1; //手动发起WIFI连接(对应结构体WIFI_CONNECT) + public static final int CTRLTYPE_WIFI_DISCONNECT = CTRLTYPE_WIFI_CONNECT+1; //手动断开WIFI连接(对应结构体WIFI_CONNECT) + public static final int CTRLTYPE_CTRL_ARMED = CTRLTYPE_WIFI_DISCONNECT+1; //布撤防操作 + public static final int CTRLTYPE_CTRL_IP_MODIFY = CTRLTYPE_CTRL_ARMED+1; //修改前端IP(对应结构体 NET_CTRL_IPMODIFY_PARAM) + public static final int CTRLTYPE_CTRL_WIFI_BY_WPS = CTRLTYPE_CTRL_IP_MODIFY+1; //wps连接wifi(对应结构体NET_CTRL_CONNECT_WIFI_BYWPS) + public static final int CTRLTYPE_CTRL_FORMAT_PATITION = CTRLTYPE_CTRL_WIFI_BY_WPS+1; //格式化分区(对应结构体NET_FORMAT_PATITION) + public static final int CTRLTYPE_CTRL_EJECT_STORAGE = CTRLTYPE_CTRL_FORMAT_PATITION+1; //手动卸载设备(对应结构体NET_EJECT_STORAGE_DEVICE) + public static final int CTRLTYPE_CTRL_LOAD_STORAGE = CTRLTYPE_CTRL_EJECT_STORAGE+1; //手动装载设备(对应结构体NET_LOAD_STORAGE_DEVICE) + public static final int CTRLTYPE_CTRL_CLOSE_BURNER = CTRLTYPE_CTRL_LOAD_STORAGE+1; //关闭刻录机光驱门(对应结构体NET_CTRL_BURNERDOOR)一般需要等6 + public static final int CTRLTYPE_CTRL_EJECT_BURNER = CTRLTYPE_CTRL_CLOSE_BURNER+1; //弹出刻录机光驱门(对应结构体NET_CTRL_BURNERDOOR)一般需要等4秒 + public static final int CTRLTYPE_CTRL_CLEAR_ALARM = CTRLTYPE_CTRL_EJECT_BURNER+1; //消警(对应结构体NET_CTRL_CLEAR_ALARM) + public static final int CTRLTYPE_CTRL_MONITORWALL_TVINFO = CTRLTYPE_CTRL_CLEAR_ALARM+1; //电视墙信息显示(对应结构体NET_CTRL_MONITORWALL_TVINFO) + public static final int CTRLTYPE_CTRL_START_VIDEO_ANALYSE = CTRLTYPE_CTRL_MONITORWALL_TVINFO+1; //开始视频智能分析(对应结构体NET_CTRL_START_VIDEO_ANALYSE) + public static final int CTRLTYPE_CTRL_STOP_VIDEO_ANALYSE = CTRLTYPE_CTRL_START_VIDEO_ANALYSE+1; //停止视频智能分析(对应结构体NET_CTRL_STOP_VIDEO_ANALYSE) + public static final int CTRLTYPE_CTRL_UPGRADE_DEVICE = CTRLTYPE_CTRL_STOP_VIDEO_ANALYSE+1; //控制启动设备升级,由设备独立完成升级过程,不需要传输升级文件 + public static final int CTRLTYPE_CTRL_MULTIPLAYBACK_CHANNALES = CTRLTYPE_CTRL_UPGRADE_DEVICE+1; //切换多通道预览回放的通道(对应结构体NET_CTRL_MULTIPLAYBACK_CHANNALES) + public static final int CTRLTYPE_CTRL_SEQPOWER_OPEN = CTRLTYPE_CTRL_MULTIPLAYBACK_CHANNALES+1; //电源时序器打开开关量输出口(对应NET_CTRL_SEQPOWER_PARAM) + public static final int CTRLTYPE_CTRL_SEQPOWER_CLOSE = CTRLTYPE_CTRL_SEQPOWER_OPEN+1; //电源时序器关闭开关量输出口(对应NET_CTRL_SEQPOWER_PARAM) + public static final int CTRLTYPE_CTRL_SEQPOWER_OPEN_ALL = CTRLTYPE_CTRL_SEQPOWER_CLOSE+1; //电源时序器打开开关量输出口组(对应NET_CTRL_SEQPOWER_PARAM) + public static final int CTRLTYPE_CTRL_SEQPOWER_CLOSE_ALL = CTRLTYPE_CTRL_SEQPOWER_OPEN_ALL+1; //电源时序器关闭开关量输出口组(对应NET_CTRL_SEQPOWER_PARAM) + public static final int CTRLTYPE_CTRL_PROJECTOR_RISE = CTRLTYPE_CTRL_SEQPOWER_CLOSE_ALL+1; //投影仪上升(对应NET_CTRL_PROJECTOR_PARAM) + public static final int CTRLTYPE_CTRL_PROJECTOR_FALL = CTRLTYPE_CTRL_PROJECTOR_RISE+1; //投影仪下降(对应NET_CTRL_PROJECTOR_PARAM) + public static final int CTRLTYPE_CTRL_PROJECTOR_STOP = CTRLTYPE_CTRL_PROJECTOR_FALL+1; //投影仪停止(对应NET_CTRL_PROJECTOR_PARAM) + public static final int CTRLTYPE_CTRL_INFRARED_KEY = CTRLTYPE_CTRL_PROJECTOR_STOP+1; //红外按键(对应NET_CTRL_INFRARED_KEY_PARAM) + public static final int CTRLTYPE_CTRL_START_PLAYAUDIO = CTRLTYPE_CTRL_INFRARED_KEY+1; //设备开始播放音频文件(对应结构体NET_CTRL_START_PLAYAUDIO) + public static final int CTRLTYPE_CTRL_STOP_PLAYAUDIO = CTRLTYPE_CTRL_START_PLAYAUDIO+1; //设备停止播放音频文件 + public static final int CTRLTYPE_CTRL_START_ALARMBELL = CTRLTYPE_CTRL_STOP_PLAYAUDIO+1; //开启警号(对应结构体 NET_CTRL_ALARMBELL ) + public static final int CTRLTYPE_CTRL_STOP_ALARMBELL = CTRLTYPE_CTRL_START_ALARMBELL+1; //关闭警号(对应结构体 NET_CTRL_ALARMBELL ) + public static final int CTRLTYPE_CTRL_ACCESS_OPEN = CTRLTYPE_CTRL_STOP_ALARMBELL+1; //门禁控制-开门(对应结构体 NET_CTRL_ACCESS_OPEN) + public static final int CTRLTYPE_CTRL_SET_BYPASS = CTRLTYPE_CTRL_ACCESS_OPEN+1; //设置旁路功能(对应结构体NET_CTRL_SET_BYPASS) + public static final int CTRLTYPE_CTRL_RECORDSET_INSERT = CTRLTYPE_CTRL_SET_BYPASS+1; //添加记录,获得记录集编号(对应NET_CTRL_RECORDSET_INSERT_PARAM) + public static final int CTRLTYPE_CTRL_RECORDSET_UPDATE = CTRLTYPE_CTRL_RECORDSET_INSERT+1; //更新某记录集编号的记录(对应NET_CTRL_RECORDSET_PARAM) + public static final int CTRLTYPE_CTRL_RECORDSET_REMOVE = CTRLTYPE_CTRL_RECORDSET_UPDATE+1; //根据记录集编号删除某记录(对应NET_CTRL_RECORDSET_PARAM) + public static final int CTRLTYPE_CTRL_RECORDSET_CLEAR = CTRLTYPE_CTRL_RECORDSET_REMOVE+1; //清除所有记录集信息(对应NET_CTRL_RECORDSET_PARAM) + public static final int CTRLTYPE_CTRL_ACCESS_CLOSE = CTRLTYPE_CTRL_RECORDSET_CLEAR+1; //门禁控制-关门(对应结构体NET_CTRL_ACCESS_CLOSE) + public static final int CTRLTYPE_CTRL_ALARM_SUBSYSTEM_ACTIVE_SET = CTRLTYPE_CTRL_ACCESS_CLOSE+1; //报警子系统激活设置(对应结构体NET_CTRL_ALARM_SUBSYSTEM_SETACTIVE) + public static final int CTRLTYPE_CTRL_FORBID_OPEN_STROBE = CTRLTYPE_CTRL_ALARM_SUBSYSTEM_ACTIVE_SET+1; //禁止设备端开闸(对应结构体NET_CTRL_FORBID_OPEN_STROBE) + public static final int CTRLTYPE_CTRL_OPEN_STROBE = CTRLTYPE_CTRL_FORBID_OPEN_STROBE+1; //开启道闸(对应结构体 NET_CTRL_OPEN_STROBE) + public static final int CTRLTYPE_CTRL_TALKING_REFUSE = CTRLTYPE_CTRL_OPEN_STROBE+1; //对讲拒绝接听(对应结构体NET_CTRL_TALKING_REFUSE) + public static final int CTRLTYPE_CTRL_ARMED_EX = CTRLTYPE_CTRL_TALKING_REFUSE+1; //布撤防操作(对应结构体CTRL_ARM_DISARM_PARAM_EX),对CTRL_ARM_DISARM_PARAM升级,建议用这个 + public static final int CTRLTYPE_CTRL_NET_KEYBOARD =400;//网络键盘控制(对应结构体NET_CTRL_NET_KEYBOARD) + public static final int CTRLTYPE_CTRL_AIRCONDITION_OPEN = CTRLTYPE_CTRL_NET_KEYBOARD+1; //打开空调(对应结构体NET_CTRL_OPEN_AIRCONDITION) + public static final int CTRLTYPE_CTRL_AIRCONDITION_CLOSE = CTRLTYPE_CTRL_AIRCONDITION_OPEN+1; //关闭空调(对应结构体NET_CTRL_CLOSE_AIRCONDITION) + public static final int CTRLTYPE_CTRL_AIRCONDITION_SET_TEMPERATURE = CTRLTYPE_CTRL_AIRCONDITION_CLOSE+1; //设定空调温度(对应结构体NET_CTRL_SET_TEMPERATURE) + public static final int CTRLTYPE_CTRL_AIRCONDITION_ADJUST_TEMPERATURE = CTRLTYPE_CTRL_AIRCONDITION_SET_TEMPERATURE+1; //调节空调温度(对应结构体NET_CTRL_ADJUST_TEMPERATURE) + public static final int CTRLTYPE_CTRL_AIRCONDITION_SETMODE = CTRLTYPE_CTRL_AIRCONDITION_ADJUST_TEMPERATURE+1; //设置空调工作模式(对应结构体NET_CTRL_ADJUST_TEMPERATURE) + public static final int CTRLTYPE_CTRL_AIRCONDITION_SETWINDMODE = CTRLTYPE_CTRL_AIRCONDITION_SETMODE+1; //设置空调送风模式(对应结构体NET_CTRL_AIRCONDITION_SETMODE) + public static final int CTRLTYPE_CTRL_RESTOREDEFAULT_EX = CTRLTYPE_CTRL_AIRCONDITION_SETWINDMODE+1;//恢复设备的默认设置新协议(对应结构体NET_CTRL_RESTORE_DEFAULT) + // 恢复配置优先使用该枚举,如果接口失败, + // 且CLIENT_GetLastError返回NET_UNSUPPORTED,再尝试使用NET_CTRL_RESTOREDEFAULT恢复配置 + public static final int CTRLTYPE_CTRL_NOTIFY_EVENT = CTRLTYPE_CTRL_RESTOREDEFAULT_EX+1; //向设备发送事件(对应结构体NET_NOTIFY_EVENT_DATA) + public static final int CTRLTYPE_CTRL_SILENT_ALARM_SET = CTRLTYPE_CTRL_NOTIFY_EVENT+1; //无声报警设置 + public static final int CTRLTYPE_CTRL_START_PLAYAUDIOEX = CTRLTYPE_CTRL_SILENT_ALARM_SET+1; //设备开始语音播报(对应结构体NET_CTRL_START_PLAYAUDIOEX) + public static final int CTRLTYPE_CTRL_STOP_PLAYAUDIOEX = CTRLTYPE_CTRL_START_PLAYAUDIOEX+1; //设备停止语音播报 + public static final int CTRLTYPE_CTRL_CLOSE_STROBE = CTRLTYPE_CTRL_STOP_PLAYAUDIOEX+1; //关闭道闸(对应结构体 NET_CTRL_CLOSE_STROBE) + public static final int CTRLTYPE_CTRL_SET_ORDER_STATE = CTRLTYPE_CTRL_CLOSE_STROBE+1; //设置车位预定状态(对应结构体NET_CTRL_SET_ORDER_STATE) + public static final int CTRLTYPE_CTRL_RECORDSET_INSERTEX = CTRLTYPE_CTRL_SET_ORDER_STATE+1; //添加记录,获得记录集编号(对应NET_CTRL_RECORDSET_INSERT_PARAM) + public static final int CTRLTYPE_CTRL_RECORDSET_UPDATEEX = CTRLTYPE_CTRL_RECORDSET_INSERTEX+1; //更新某记录集编号的记录(对应NET_CTRL_RECORDSET_PARAM) + public static final int CTRLTYPE_CTRL_CAPTURE_FINGER_PRINT = CTRLTYPE_CTRL_RECORDSET_UPDATEEX+1; //指纹采集(对应结构体NET_CTRL_CAPTURE_FINGER_PRINT) + public static final int CTRLTYPE_CTRL_ECK_LED_SET = CTRLTYPE_CTRL_CAPTURE_FINGER_PRINT+1; //停车场出入口控制器LED设置(对应结构体NET_CTRL_ECK_LED_SET_PARAM) + public static final int CTRLTYPE_CTRL_ECK_IC_CARD_IMPORT = CTRLTYPE_CTRL_ECK_LED_SET+1; //智能停车系统出入口机IC卡信息导入(对应结构体NET_CTRL_ECK_IC_CARD_IMPORT_PARAM) + public static final int CTRLTYPE_CTRL_ECK_SYNC_IC_CARD = CTRLTYPE_CTRL_ECK_IC_CARD_IMPORT+1; //智能停车系统出入口机IC卡信息同步指令,收到此指令后,设备删除原有IC卡信息(对应结构体NET_CTRL_ECK_SYNC_IC_CARD_PARAM) + public static final int CTRLTYPE_CTRL_LOWRATEWPAN_REMOVE = CTRLTYPE_CTRL_ECK_SYNC_IC_CARD+1; //删除指定无线设备(对应结构体NET_CTRL_LOWRATEWPAN_REMOVE) + public static final int CTRLTYPE_CTRL_LOWRATEWPAN_MODIFY = CTRLTYPE_CTRL_LOWRATEWPAN_REMOVE+1; //修改无线设备信息(对应结构体NET_CTRL_LOWRATEWPAN_MODIFY) + public static final int CTRLTYPE_CTRL_ECK_SET_PARK_INFO = CTRLTYPE_CTRL_LOWRATEWPAN_MODIFY+1; //智能停车系统出入口机设置车位信息(对应结构体NET_CTRL_ECK_SET_PARK_INFO_PARAM) + public static final int CTRLTYPE_CTRL_VTP_DISCONNECT = CTRLTYPE_CTRL_ECK_SET_PARK_INFO+1; //挂断视频电话(对应结构体NET_CTRL_VTP_DISCONNECT) + public static final int CTRLTYPE_CTRL_UPDATE_FILES = CTRLTYPE_CTRL_VTP_DISCONNECT+1; //远程投放多媒体文件更新(对应结构体NET_CTRL_UPDATE_FILES) + public static final int CTRLTYPE_CTRL_MATRIX_SAVE_SWITCH = CTRLTYPE_CTRL_UPDATE_FILES+1; //保存上下位矩阵输出关系(对应结构体NET_CTRL_MATRIX_SAVE_SWITCH) + public static final int CTRLTYPE_CTRL_MATRIX_RESTORE_SWITCH = CTRLTYPE_CTRL_MATRIX_SAVE_SWITCH+1; //恢复上下位矩阵输出关系(对应结构体NET_CTRL_MATRIX_RESTORE_SWITCH) + public static final int CTRLTYPE_CTRL_VTP_DIVERTACK = CTRLTYPE_CTRL_MATRIX_RESTORE_SWITCH+1; //呼叫转发响应(对应结构体NET_CTRL_VTP_DIVERTACK) + public static final int CTRLTYPE_CTRL_RAINBRUSH_MOVEONCE = CTRLTYPE_CTRL_VTP_DIVERTACK+1; //雨刷来回刷一次,雨刷模式配置为手动模式时有效(对应结构体NET_CTRL_RAINBRUSH_MOVEONCE) + public static final int CTRLTYPE_CTRL_RAINBRUSH_MOVECONTINUOUSLY = CTRLTYPE_CTRL_RAINBRUSH_MOVEONCE+1; //雨刷来回循环刷,雨刷模式配置为手动模式时有效(对应结构体NET_CTRL_RAINBRUSH_MOVECONTINUOUSLY) + public static final int CTRLTYPE_CTRL_RAINBRUSH_STOPMOVE = CTRLTYPE_CTRL_RAINBRUSH_MOVECONTINUOUSLY+1; //雨刷停止刷,雨刷模式配置为手动模式时有效(对应结构体NET_CTRL_RAINBRUSH_STOPMOVE) + public static final int CTRLTYPE_CTRL_ALARM_ACK = CTRLTYPE_CTRL_RAINBRUSH_STOPMOVE+1; //报警事件确认(对应结构体NET_CTRL_ALARM_ACK) + // NET_CTRL_ALARM_ACK 该操作切勿在报警回调接口中调用 + public static final int CTRLTYPE_CTRL_RECORDSET_IMPORT = CTRLTYPE_CTRL_ALARM_ACK + 1; // 批量导入记录集信息(对应 NET_CTRL_RECORDSET_PARAM ) + public static final int CTRLTYPE_CTRL_DELIVERY_FILE = CTRLTYPE_CTRL_RECORDSET_IMPORT + 1; // 向视频输出口投放视频和图片文件, 楼宇对讲使用,同一时间投放(对应 NET_CTRL_DELIVERY_FILE ) + // 以下命令只在 CLIENT_ControlDeviceEx 上有效 + public static final int CTRLTYPE_CTRL_THERMO_GRAPHY_ENSHUTTER = 0x10000;//设置热成像快门启用/禁用,pInBuf= NET_IN_THERMO_EN_SHUTTER*, pOutBuf= NET_OUT_THERMO_EN_SHUTTER * + public static final int CTRLTYPE_CTRL_RADIOMETRY_SETOSDMARK = CTRLTYPE_CTRL_THERMO_GRAPHY_ENSHUTTER+1; //设置测温项的osd为高亮,pInBuf=NET_IN_RADIOMETRY_SETOSDMARK*,pOutBuf= NET_OUT_RADIOMETRY_SETOSDMARK * + public static final int CTRLTYPE_CTRL_AUDIO_REC_START_NAME = CTRLTYPE_CTRL_RADIOMETRY_SETOSDMARK+1; //开启音频录音并得到录音名,pInBuf = NET_IN_AUDIO_REC_MNG_NAME *, pOutBuf = NET_OUT_AUDIO_REC_MNG_NAME * + public static final int CTRLTYPE_CTRL_AUDIO_REC_STOP_NAME = CTRLTYPE_CTRL_AUDIO_REC_START_NAME+1; //关闭音频录音并返回文件名称,pInBuf = NET_IN_AUDIO_REC_MNG_NAME *, pOutBuf = NET_OUT_AUDIO_REC_MNG_NAME * + public static final int CTRLTYPE_CTRL_SNAP_MNG_SNAP_SHOT = CTRLTYPE_CTRL_AUDIO_REC_STOP_NAME+1; //即时抓图(又名手动抓图),pInBuf =NET_IN_SNAP_MNG_SHOT *, pOutBuf = NET_OUT_SNAP_MNG_SHOT * + public static final int CTRLTYPE_CTRL_LOG_STOP = CTRLTYPE_CTRL_SNAP_MNG_SNAP_SHOT+1; //强制同步缓存数据到数据库并关闭数据库,pInBuf = NET_IN_LOG_MNG_CTRL *, pOutBuf = NET_OUT_LOG_MNG_CTRL * + public static final int CTRLTYPE_CTRL_LOG_RESUME = CTRLTYPE_CTRL_LOG_STOP+1; //恢复数据库,pInBuf = NET_IN_LOG_MNG_CTRL *, pOutBuf = NET_OUT_LOG_MNG_CTRL * + } + + // 视频压缩格式 + public static class CFG_VIDEO_COMPRESSION extends Structure + { + public static final int VIDEO_FORMAT_MPEG4 = 0; //MPEG4 + public static final int VIDEO_FORMAT_MS_MPEG4 = VIDEO_FORMAT_MPEG4+1; //MS-MPEG4 + public static final int VIDEO_FORMAT_MPEG2 = VIDEO_FORMAT_MS_MPEG4+1; //MPEG2 + public static final int VIDEO_FORMAT_MPEG1 = VIDEO_FORMAT_MPEG2+1; //MPEG1 + public static final int VIDEO_FORMAT_H263 = VIDEO_FORMAT_MPEG1+1; //H.263 + public static final int VIDEO_FORMAT_MJPG = VIDEO_FORMAT_H263+1; //MJPG + public static final int VIDEO_FORMAT_FCC_MPEG4 = VIDEO_FORMAT_MJPG+1; //FCC-MPEG4 + public static final int VIDEO_FORMAT_H264 = VIDEO_FORMAT_FCC_MPEG4+1; //H.264 + public static final int VIDEO_FORMAT_H265 = VIDEO_FORMAT_H264+1; //H.265 + } + + // 码流控制模式 + public static class CFG_BITRATE_CONTROL extends Structure + { + public static final int BITRATE_CBR = 0; //固定码流 + public static final int BITRATE_VBR = BITRATE_CBR+1; //可变码流 + } + + // H264 编码级别 + public static class CFG_H264_PROFILE_RANK extends Structure + { + public static final int PROFILE_BASELINE = 1;//提供I/P帧,仅支持progressive(逐行扫描)和CAVLC + public static final int PROFILE_MAIN = PROFILE_BASELINE+1; //提供I/P/B帧,支持progressiv和interlaced,提供CAVLC或CABAC + public static final int PROFILE_EXTENDED = PROFILE_MAIN+1; //提供I/P/B/SP/SI帧,仅支持progressive(逐行扫描)和CAVLC + public static final int PROFILE_HIGH = PROFILE_EXTENDED+1; //即FRExt,Main_Profile基础上新增:8x8intraprediction(8x8帧内预测), custom + // quant(自定义量化), lossless video coding(无损视频编码), 更多的yuv格式 + } + + // 画质 + public static class CFG_IMAGE_QUALITY extends Structure + { + public static final int IMAGE_QUALITY_Q10 = 1;//图像质量10% + public static final int IMAGE_QUALITY_Q30 = IMAGE_QUALITY_Q10+1; //图像质量30% + public static final int IMAGE_QUALITY_Q50 = IMAGE_QUALITY_Q30+1; //图像质量50% + public static final int IMAGE_QUALITY_Q60 = IMAGE_QUALITY_Q50+1; //图像质量60% + public static final int IMAGE_QUALITY_Q80 = IMAGE_QUALITY_Q60+1; //图像质量80% + public static final int IMAGE_QUALITY_Q100 = IMAGE_QUALITY_Q80+1; //图像质量100% + } + + // 视频格式 + public static class CFG_VIDEO_FORMAT extends Structure + { + // 能力 + public byte abCompression;// 类型为bool, 取值0或1 + public byte abWidth;// 类型为bool, 取值0或1 + public byte abHeight;// 类型为bool, 取值0或1 + public byte abBitRateControl;// 类型为bool, 取值0或1 + public byte abBitRate;// 类型为bool, 取值0或1 + public byte abFrameRate;// 类型为bool, 取值0或1 + public byte abIFrameInterval;// 类型为bool, 取值0或1 + public byte abImageQuality;// 类型为bool, 取值0或1 + public byte abFrameType;// 类型为bool, 取值0或1 + public byte abProfile;// 类型为bool, 取值0或1 + // 信息 + public int emCompression;//视频压缩格式, 取值为CFG_VIDEO_COMPRESSION中的值 + public int nWidth;//视频宽度 + public int nHeight;//视频高度 + public int emBitRateControl;//码流控制模式, 取值为CFG_BITRATE_CONTROL中的值 + public int nBitRate;//视频码流(kbps) + public float nFrameRate;//视频帧率 + public int nIFrameInterval;//I帧间隔(1-100),比如50表示每49个B帧或P帧,设置一个I帧。 + public int emImageQuality;//图像质量, 取值为CFG_IMAGE_QUALITY中的值 + public int nFrameType;//打包模式,0-DHAV,1-"PS" + public int emProfile;//H.264编码级别, 取值为CFG_H264_PROFILE_RANK中的值 + } + + // 音频编码模式 + public static class CFG_AUDIO_FORMAT extends Structure + { + public static final int AUDIO_FORMAT_G711A = 0; //G711a + public static final int AUDIO_FORMAT_PCM = AUDIO_FORMAT_G711A+1; //PCM + public static final int AUDIO_FORMAT_G711U = AUDIO_FORMAT_PCM+1; //G711u + public static final int AUDIO_FORMAT_AMR = AUDIO_FORMAT_G711U+1; //AMR + public static final int AUDIO_FORMAT_AAC = AUDIO_FORMAT_AMR+1; //AAC + } + + // 音频格式 + public static class CFG_AUDIO_ENCODE_FORMAT extends Structure + { + // 能力 + public byte abCompression;// 类型为bool, 取值0或1 + public byte abDepth;// 类型为bool, 取值0或1 + public byte abFrequency;// 类型为bool, 取值0或1 + public byte abMode;// 类型为bool, 取值0或1 + public byte abFrameType;// 类型为bool, 取值0或1 + public byte abPacketPeriod;// 类型为bool, 取值0或1 + // 信息 + public int emCompression;//音频压缩模式,取值为CFG_AUDIO_FORMAT中的值 + public int nDepth;//音频采样深度 + public int nFrequency;//音频采样频率 + public int nMode;//音频编码模式 + public int nFrameType;//音频打包模式,0-DHAV,1-PS + public int nPacketPeriod;//音频打包周期,ms + } + + // 视频编码参数 + public static class CFG_VIDEOENC_OPT extends Structure + { + // 能力 + public byte abVideoEnable;// 类型为bool, 取值0或1 + public byte abAudioEnable;// 类型为bool, 取值0或1 + public byte abSnapEnable;// 类型为bool, 取值0或1 + public byte abAudioAdd;//音频叠加能力, 类型为bool, 取值0或1 + public byte abAudioFormat;// 类型为bool, 取值0或1 + // 信息 + public int bVideoEnable;//视频使能, 类型为BOOL, 取值0或者1 + public CFG_VIDEO_FORMAT stuVideoFormat;//视频格式 + public int bAudioEnable;//音频使能, 类型为BOOL, 取值0或者1 + public int bSnapEnable;//定时抓图使能, 类型为BOOL, 取值0或者1 + public int bAudioAddEnable;//音频叠加使能, 类型为BOOL, 取值0或者1 + public CFG_AUDIO_ENCODE_FORMAT stuAudioFormat;//音频格式 + } + + // 遮挡信息 + public static class CFG_COVER_INFO extends Structure + { + // 能力 + public byte abBlockType;// 类型为bool, 取值0或1 + public byte abEncodeBlend;// 类型为bool, 取值0或1 + public byte abPreviewBlend;// 类型为bool, 取值0或1 + // 信息 + public CFG_RECT stuRect = new CFG_RECT();//覆盖的区域坐标 + public CFG_RGBA stuColor = new CFG_RGBA();//覆盖的颜色 + public int nBlockType;//覆盖方式;0-黑块,1-马赛克 + public int nEncodeBlend;//编码级遮挡;1-生效,0-不生效 + public int nPreviewBlend;//预览遮挡;1-生效,0-不生效 + } + + // 多区域遮挡配置 + public static class CFG_VIDEO_COVER extends Structure + { + public int nTotalBlocks;//支持的遮挡块数 + public int nCurBlocks;//已设置的块数 + public CFG_COVER_INFO[] stuCoverBlock = (CFG_COVER_INFO[])new CFG_COVER_INFO().toArray(MAX_VIDEO_COVER_NUM);// 覆盖的区域 + } + + // OSD信息 + public static class CFG_OSD_INFO extends Structure + { + // 能力 + public byte abShowEnable;// 类型为bool, 取值0或1 + // 信息 + public CFG_RGBA stuFrontColor = new CFG_RGBA();//前景颜色 + public CFG_RGBA stuBackColor = new CFG_RGBA();//背景颜色 + public CFG_RECT stuRect = new CFG_RECT();//矩形区域 + public int bShowEnable;//显示使能, 类型为BOOL, 取值0或者1 + } + + // 画面颜色属性 + public static class CFG_COLOR_INFO extends Structure + { + public int nBrightness;//亮度(0-100) + public int nContrast;//对比度(0-100) + public int nSaturation;//饱和度(0-100) + public int nHue;//色度(0-100) + public int nGain;//增益(0-100) + public int bGainEn;//增益使能, 类型为BOOL, 取值0或者1 + } + + // 图像通道属性信息 + public static class CFG_ENCODE_INFO extends Structure + { + public int nChannelID;//通道号(0开始),获取时,该字段有效;设置时,该字段无效 + public byte[] szChnName = new byte[MAX_CHANNELNAME_LEN];//无效字段 + public CFG_VIDEOENC_OPT[] stuMainStream = (CFG_VIDEOENC_OPT[])new CFG_VIDEOENC_OPT().toArray(MAX_VIDEOSTREAM_NUM); // 主码流,0-普通录像,1-动检录像,2-报警录像 + public int nValidCountMainStream; // 主码流数组中有效的个数 + public CFG_VIDEOENC_OPT[] stuExtraStream = (CFG_VIDEOENC_OPT[])new CFG_VIDEOENC_OPT().toArray(MAX_VIDEOSTREAM_NUM); // 辅码流,0-辅码流1,1-辅码流2,2-辅码流3 + public int nValidCountExtraStream; // 辅码流数组中有效的个数 + public CFG_VIDEOENC_OPT[] stuSnapFormat = (CFG_VIDEOENC_OPT[])new CFG_VIDEOENC_OPT().toArray(MAX_VIDEOSTREAM_NUM); // 抓图,0-普通抓图,1-动检抓图,2-报警抓图 + public int nValidCountSnapFormat; // 抓图数组中有效的个数 + public int dwCoverAbilityMask;//无效字段 + public int dwCoverEnableMask;//无效字段 + public CFG_VIDEO_COVER stuVideoCover;//无效字段 + public CFG_OSD_INFO stuChnTitle;//无效字段 + public CFG_OSD_INFO stuTimeTitle;//无效字段 + public CFG_COLOR_INFO stuVideoColor;//无效字段 + public int emAudioFormat;//无效字段, 取值为CFG_AUDIO_FORMAT中的值 + public int nProtocolVer;//协议版本号,只读,获取时,该字段有效;设置时,该字段无效 + } + + // 设备软件版本信息,高16位表示主版本号,低16位表示次版本号 + public static class NET_VERSION_INFO extends Structure + { + public int dwSoftwareVersion; + public int dwSoftwareBuildDate; + public int dwDspSoftwareVersion; + public int dwDspSoftwareBuildDate; + public int dwPanelVersion; + public int dwPanelSoftwareBuildDate; + public int dwHardwareVersion; + public int dwHardwareDate; + public int dwWebVersion; + public int dwWebBuildDate; + } + + // 设备软件版本信息,对应CLIENT_QueryDevState接口 + public static class NETDEV_VERSION_INFO extends Structure + { + public byte[] szDevSerialNo = new byte[NET_DEV_SERIALNO_LEN]; // 序列号 + public int byDevType; // 设备类型,见枚举 NET_DEVICE_TYPE + public byte[] szDevType = new byte[NET_DEV_TYPE_LEN]; // 设备详细型号,字符串格式,可能为空 + public int nProtocalVer; // 协议版本号 + public byte[] szSoftWareVersion = new byte[NET_MAX_URL_LEN]; + public int dwSoftwareBuildDate; + public byte[] szPeripheralSoftwareVersion = new byte[NET_MAX_URL_LEN];// 从片版本信息,字符串格式,可能为空 + public int dwPeripheralSoftwareBuildDate; + public byte[] szGeographySoftwareVersion = new byte[NET_MAX_URL_LEN]; // 地理信息定位芯片版本信息,字符串格式,可能为空 + public int dwGeographySoftwareBuildDate; + public byte[] szHardwareVersion = new byte[NET_MAX_URL_LEN]; + public int dwHardwareDate; + public byte[] szWebVersion = new byte[NET_MAX_URL_LEN]; + public int dwWebBuildDate; + public byte[] reserved = new byte[256]; + } + + // 设备类型 + public static class NET_DEVICE_TYPE extends Structure + { + public static final int NET_PRODUCT_NONE = 0; + public static final int NET_DVR_NONREALTIME_MACE = 1; // 非实时MACE + public static final int NET_DVR_NONREALTIME = 2; // 非实时 + public static final int NET_NVS_MPEG1 = 3; // 网络视频服务器 + public static final int NET_DVR_MPEG1_2 = 4; // MPEG1二路录像机 + public static final int NET_DVR_MPEG1_8 = 5; // MPEG1八路录像机 + public static final int NET_DVR_MPEG4_8 = 6; // MPEG4八路录像机 + public static final int NET_DVR_MPEG4_16 = 7; // MPEG4十六路录像机 + public static final int NET_DVR_MPEG4_SX2 = 8; // LB系列录像机 + public static final int NET_DVR_MEPG4_ST2 = 9; // GB系列录像机 + public static final int NET_DVR_MEPG4_SH2 = 10; // HB系列录像机 10 + public static final int NET_DVR_MPEG4_GBE = 11; // GBE系列录像机 + public static final int NET_DVR_MPEG4_NVSII = 12; // II代网络视频服务器 + public static final int NET_DVR_STD_NEW = 13; // 新标准配置协议 + public static final int NET_DVR_DDNS = 14; // DDNS服务器 + public static final int NET_DVR_ATM = 15; // ATM机 + public static final int NET_NB_SERIAL = 16; // 二代非实时NB系列机器 + public static final int NET_LN_SERIAL = 17; // LN系列产品 + public static final int NET_BAV_SERIAL = 18; // BAV系列产品 + public static final int NET_SDIP_SERIAL = 19; // SDIP系列产品 + public static final int NET_IPC_SERIAL = 20; // IPC系列产品 20 + public static final int NET_NVS_B = 21; // NVS B系列 + public static final int NET_NVS_C = 22; // NVS H系列 + public static final int NET_NVS_S = 23; // NVS S系列 + public static final int NET_NVS_E = 24; // NVS E系列 + public static final int NET_DVR_NEW_PROTOCOL = 25; // 从QueryDevState中查询设备类型,以字符串格式 + public static final int NET_NVD_SERIAL = 26; // 解码器 + public static final int NET_DVR_N5 = 27; // N5 + public static final int NET_DVR_MIX_DVR = 28; // 混合DVR + public static final int NET_SVR_SERIAL = 29; // SVR系列 + public static final int NET_SVR_BS = 30; // SVR-BS 30 + public static final int NET_NVR_SERIAL = 31; // NVR系列 + public static final int NET_DVR_N51 = 32; // N51 + public static final int NET_ITSE_SERIAL = 33; // ITSE 智能分析盒 + public static final int NET_ITC_SERIAL = 34; // 智能交通像机设备 + public static final int NET_HWS_SERIAL = 35; // 雷达测速仪HWS + public static final int NET_PVR_SERIAL = 36; // 便携式音视频录像机 + public static final int NET_IVS_SERIAL = 37; // IVS(智能视频服务器系列) + public static final int NET_IVS_B = 38; // 通用智能视频侦测服务器 + public static final int NET_IVS_F = 39; // 人脸识别服务器 + public static final int NET_IVS_V = 40; // 视频质量诊断服务器 40 + public static final int NET_MATRIX_SERIAL = 41; // 矩阵 + public static final int NET_DVR_N52 = 42; // N52 + public static final int NET_DVR_N56 = 43; // N56 + public static final int NET_ESS_SERIAL = 44; // ESS + public static final int NET_IVS_PC = 45; // 人数统计服务器 + public static final int NET_PC_NVR = 46; // pc-nvr + public static final int NET_DSCON = 47; // 大屏控制器 + public static final int NET_EVS = 48; // 网络视频存储服务器 + public static final int NET_EIVS = 49; // 嵌入式智能分析视频系统 + public static final int NET_DVR_N6 = 50; // DVR-N6 50 + public static final int NET_UDS = 51; // 万能解码器 + public static final int NET_AF6016 = 52; // 银行报警主机 + public static final int NET_AS5008 = 53; // 视频网络报警主机 + public static final int NET_AH2008 = 54; // 网络报警主机 + public static final int NET_A_SERIAL = 55; // 报警主机系列 + public static final int NET_BSC_SERIAL = 56; // 门禁系列产品 + public static final int NET_NVS_SERIAL = 57; // NVS系列产品 + public static final int NET_VTO_SERIAL = 58; // VTO系列产品 + public static final int NET_VTNC_SERIAL = 59; // VTNC系列产品 + public static final int NET_TPC_SERIAL = 60; // TPC系列产品, 即热成像设备 60 + public static final int NET_ASM_SERIAL = 61; // 无线中继设备 + public static final int NET_VTS_SERIAL = 62; // 管理机 + } + + // DSP能力描述,对应CLIENT_GetDevConfig接口 + public static class NET_DSP_ENCODECAP extends Structure + { + public int dwVideoStandardMask;//视频制式掩码,按位表示设备能够支持的视频制式 + public int dwImageSizeMask;//分辨率掩码,按位表示设备能够支持的分辨率设置 + public int dwEncodeModeMask;//编码模式掩码,按位表示设备能够支持的编码模式设置 + public int dwStreamCap; // 按位表示设备支持的多媒体功能, + // 第一位表示支持主码流 + // 第二位表示支持辅码流1 + // 第三位表示支持辅码流2 + // 第五位表示支持jpg抓图 + public int[] dwImageSizeMask_Assi = new int[8];//表示主码流为各分辨率时,支持的辅码流分辨率掩码。 + public int dwMaxEncodePower;//DSP支持的最高编码能力 + public short wMaxSupportChannel;//每块DSP支持最多输入视频通道数 + public short wChannelMaxSetSync;//DSP每通道的最大编码设置是否同步;0:不同步,1:同步 + } + + // 系统信息 + public static class NET_DEV_SYSTEM_ATTR_CFG extends Structure + { + public int dwSize; + /* 下面是设备的只读部分 */ + public NET_VERSION_INFO stVersion; + public NET_DSP_ENCODECAP stDspEncodeCap;//DSP能力描述 + public byte[] szDevSerialNo = new byte[NET_DEV_SERIALNO_LEN];//序列号 + public byte byDevType;//设备类型,见枚举NET_DEVICE_TYPE + public byte[] szDevType = new byte[NET_DEV_TYPE_LEN];//设备详细型号,字符串格式,可能为空 + public byte byVideoCaptureNum;//视频口数量 + public byte byAudioCaptureNum;//音频口数量 + public byte byTalkInChanNum;//对讲输入接口数量 + public byte byTalkOutChanNum;//对讲输出接口数量 + public byte byDecodeChanNum;//NSP + public byte byAlarmInNum;//报警输入口数 + public byte byAlarmOutNum;//报警输出口数 + public byte byNetIONum;//网络口数 + public byte byUsbIONum;//USB口数量 + public byte byIdeIONum;//IDE数量 + public byte byComIONum;//串口数量 + public byte byLPTIONum;//并口数量 + public byte byVgaIONum;//NSP + public byte byIdeControlNum;//NSP + public byte byIdeControlType;//NSP + public byte byCapability;//NSP,扩展描述 + public byte byMatrixOutNum;//视频矩阵输出口数 + /* 下面是设备的可写部分 */ + public byte byOverWrite;//硬盘满处理方式(覆盖、停止) + public byte byRecordLen;//录象打包长度 + public byte byDSTEnable;//是否实行夏令时1-实行0-不实行 + public short wDevNo;//设备编号,用于遥控 + public byte byVideoStandard;//视频制式:0-PAL,1-NTSC + public byte byDateFormat;//日期格式 + public byte byDateSprtr;//日期分割符(0:".",1:"-",2:"/") + public byte byTimeFmt;//时间格式(0-24小时,1-12小时) + public byte byLanguage;//枚举值详见NET_LANGUAGE_TYPE + + public NET_DEV_SYSTEM_ATTR_CFG() + { + this.dwSize = this.size(); + } + } + + // 入侵方向 + public static class EM_MSG_OBJ_PERSON_DIRECTION extends Structure + { + public static final int EM_MSG_OBJ_PERSON_DIRECTION_UNKOWN = 0; //未知方向 + public static final int EM_MSG_OBJ_PERSON_DIRECTION_LEFT_TO_RIGHT = EM_MSG_OBJ_PERSON_DIRECTION_UNKOWN+1; //从左向右 + public static final int EM_MSG_OBJ_PERSON_DIRECTION_RIGHT_TO_LEFT = EM_MSG_OBJ_PERSON_DIRECTION_LEFT_TO_RIGHT+1; //从右向左 + } + + // 视频分析物体信息扩展结构体 + public static class NET_MSG_OBJECT_EX extends Structure + { + public int dwSize; + public int nObjectID;//物体ID,每个ID表示一个唯一的物体 + public byte[] szObjectType = new byte[128];//物体类型 + public int nConfidence;//置信度(0~255),值越大表示置信度越高 + public int nAction;//物体动作:1:Appear2:Move3:Stay 4:Remove 5:Disappear 6:Split 7:Merge 8:Rename + public DH_RECT BoundingBox;//包围盒 + public NET_POINT Center;//物体型心 + public int nPolygonNum;//多边形顶点个数 + public NET_POINT[] Contour = (NET_POINT[])new NET_POINT().toArray(NET_MAX_POLYGON_NUM);// 较精确的轮廓多边形 + public int rgbaMainColor;//表示车牌、车身等物体主要颜色;按字节表示,分别为红、绿、蓝和透明度,例如:RGB值为(0,255,0),透明度为0时,其值为0x00ff0000. + public byte[] szText = new byte[128];//同NET_MSG_OBJECT相应字段 + public byte[] szObjectSubType = new byte[64];//物体子类别,根据不同的物体类型,可以取以下子类型: + // 同NET_MSG_OBJECT相应字段 + public byte[] byReserved1 = new byte[3]; + public byte bPicEnble;//是否有物体对应图片文件信息, 类型为bool, 取值0或1 + public NET_PIC_INFO stPicInfo;//物体对应图片信息 + public byte bShotFrame;//是否是抓拍张的识别结果, 类型为bool, 取值0或1 + public byte bColor;//物体颜色(rgbaMainColor)是否可用, 类型为bool, 取值0或1 + public byte bLowerBodyColor;//下半身颜色(rgbaLowerBodyColor)是否可用 + public byte byTimeType;//时间表示类型,详见EM_TIME_TYPE说明 + public NET_TIME_EX stuCurrentTime;//针对视频浓缩,当前时间戳(物体抓拍或识别时,会将此识别智能帧附在一个视频帧或jpeg图片中,此帧所在原始视频中的出现时间) + public NET_TIME_EX stuStartTime;//开始时间戳(物体开始出现时) + public NET_TIME_EX stuEndTime;//结束时间戳(物体最后出现时) + public DH_RECT stuOriginalBoundingBox;//包围盒(绝对坐标) + public DH_RECT stuSignBoundingBox;//车标坐标包围盒 + public int dwCurrentSequence;//当前帧序号(抓下这个物体时的帧) + public int dwBeginSequence;//开始帧序号(物体开始出现时的帧序号) + public int dwEndSequence;//结束帧序号(物体消逝时的帧序号) + public long nBeginFileOffset;//开始时文件偏移,单位:字节(物体开始出现时,视频帧在原始视频文件中相对于文件起始处的偏移) + public long nEndFileOffset;//结束时文件偏移,单位:字节(物体消逝时,视频帧在原始视频文件中相对于文件起始处的偏移) + public byte[] byColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//物体颜色相似度,取值范围:0-100,数组下标值代表某种颜色,详见EM_COLOR_TYPE + public byte[] byUpperBodyColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//上半身物体颜色相似度(物体类型为人时有效) + public byte[] byLowerBodyColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//下半身物体颜色相似度(物体类型为人时有效) + public int nRelativeID;//相关物体ID + public byte[] szSubText = new byte[20];//"ObjectType"为"Vehicle"或者"Logo"时,表示车标下的某一车系,比如奥迪A6L,由于车系较多,SDK实现时透传此字段,设备如实填写。 + public int nPersonStature;//入侵人员身高,单位cm + public int emPersonDirection;//人员入侵方向, 取值为EM_MSG_OBJ_PERSON_DIRECTION中的值 + public int rgbaLowerBodyColor;//使用方法同rgbaMainColor,物体类型为人时有效 + + public NET_MSG_OBJECT_EX() + { + this.dwSize = this.size(); + + /*if(Utils.getOsName().equals("win")) { + // 强制采用最大四字节对其 + setAlignType(ALIGN_GNUC); + }*/ + } + } + + // 视频分析物体信息扩展结构体,扩展版本2 + public static class NET_MSG_OBJECT_EX2 extends Structure + { + public int dwSize; + public int nObjectID;//物体ID,每个ID表示一个唯一的物体 + public byte[] szObjectType = new byte[128];//物体类型 + public int nConfidence;//置信度(0~255),值越大表示置信度越高 + public int nAction;//物体动作:1:Appear2:Move3:Stay 4:Remove 5:Disappear 6:Split 7:Merge 8:Rename + public DH_RECT BoundingBox;//包围盒 + public NET_POINT Center;//物体型心 + public int nPolygonNum;//多边形顶点个数 + public NET_POINT[] Contour = (NET_POINT[])new NET_POINT().toArray(NET_MAX_POLYGON_NUM);//较精确的轮廓多边形 + public int rgbaMainColor;//表示车牌、车身等物体主要颜色;按字节表示,分别为红、绿、蓝和透明度,例如:RGB值为(0,255,0),透明度为0时,其值为0x00ff0000. + public byte[] szText = new byte[128];//同NET_MSG_OBJECT相应字段 + public byte[] szObjectSubType = new byte[64];//物体子类别,根据不同的物体类型,可以取以下子类型: + // 同NET_MSG_OBJECT相应字段 + public byte[] byReserved1 = new byte[3]; + public byte bPicEnble;//是否有物体对应图片文件信息, 类型为bool, 取值0或者1 + public NET_PIC_INFO stPicInfo;//物体对应图片信息 + public byte bShotFrame;//是否是抓拍张的识别结果, 类型为bool, 取值0或者1 + public byte bColor;//物体颜色(rgbaMainColor)是否可用, 类型为bool, 取值0或者1 + public byte bLowerBodyColor;//下半身颜色(rgbaLowerBodyColor)是否可用 + public byte byTimeType;//时间表示类型,详见EM_TIME_TYPE说明 + public NET_TIME_EX stuCurrentTime;//针对视频浓缩,当前时间戳(物体抓拍或识别时,会将此识别智能帧附在一个视频帧或jpeg图片中,此帧所在原始视频中的出现时间) + public NET_TIME_EX stuStartTime;//开始时间戳(物体开始出现时) + public NET_TIME_EX stuEndTime;//结束时间戳(物体最后出现时) + public DH_RECT stuOriginalBoundingBox;//包围盒(绝对坐标) + public DH_RECT stuSignBoundingBox;//车标坐标包围盒 + public int dwCurrentSequence;//当前帧序号(抓下这个物体时的帧) + public int dwBeginSequence;//开始帧序号(物体开始出现时的帧序号) + public int dwEndSequence;//结束帧序号(物体消逝时的帧序号) + public long nBeginFileOffset;//开始时文件偏移,单位:字节(物体开始出现时,视频帧在原始视频文件中相对于文件起始处的偏移) + public long nEndFileOffset;//结束时文件偏移,单位:字节(物体消逝时,视频帧在原始视频文件中相对于文件起始处的偏移) + public byte[] byColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//物体颜色相似度,取值范围:0-100,数组下标值代表某种颜色,详见EM_COLOR_TYPE + public byte[] byUpperBodyColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//上半身物体颜色相似度(物体类型为人时有效) + public byte[] byLowerBodyColorSimilar = new byte[EM_COLOR_TYPE.NET_COLOR_TYPE_MAX];//下半身物体颜色相似度(物体类型为人时有效) + public int nRelativeID;//相关物体ID + public byte[] szSubText = new byte[20];//"ObjectType"为"Vehicle"或者"Logo"时,表示车标下的某一车系,比如奥迪A6L,由于车系较多,SDK实现时透传此字段,设备如实填写。 + public int nPersonStature;//入侵人员身高,单位cm + public int emPersonDirection;//人员入侵方向, 取值为EM_MSG_OBJ_PERSON_DIRECTION中的值 + public int rgbaLowerBodyColor;//使用方法同rgbaMainColor,物体类型为人时有效 + //视频浓缩额外信息 + public int nSynopsisSpeed;//浓缩速度域值,共分1~10共十个档位,5表示浓缩后只保留5以上速度的物体。是个相对单位 + // 为0时,该字段无效 + public int nSynopsisSize;//浓缩尺寸域值,共分1~10共十个档位,3表示浓缩后只保留3以上大小的物体。是个相对单位 + // 为0时,该字段无效 + public int bEnableDirection;//为True时,对物体运动方向做过滤, 类型为BOOL, 取值0或者1 + // 为False时,不对物体运动方向做过滤, + public NET_POINT stuSynopsisStartLocation;//浓缩运动方向,起始坐标点,点的坐标归一化到[0,8192)区间,bEnableDirection为True时有效 + public NET_POINT stuSynopsisEndLocation;//浓缩运动方向,终止坐标点,点的坐标归一化到[0,8192)区间,bEnableDirection为True时有效 + public byte[] byReserved = new byte[2048];//扩展字节 + + public NET_MSG_OBJECT_EX2() + { + this.dwSize = this.size(); + + /*if(Utils.getOsName().equals("win")) { + // 强制采用最大四字节对其 + setAlignType(ALIGN_GNUC); + }*/ + } + } + + // 设备协议类型 + public static class NET_DEVICE_PROTOCOL extends Structure + { + public static final int NET_PROTOCOL_PRIVATE2 = 0; //私有2代协议 + public static final int NET_PROTOCOL_PRIVATE3 = NET_PROTOCOL_PRIVATE2+1; //私有3代协议 + public static final int NET_PROTOCOL_ONVIF = NET_PROTOCOL_PRIVATE3+1; //Onvif + public static final int NET_PROTOCOL_VNC = NET_PROTOCOL_ONVIF+1; //虚拟网络计算机 + public static final int NET_PROTOCOL_TS = NET_PROTOCOL_VNC+1; //标准TS + public static final int NET_PROTOCOL_PRIVATE = 100;//私有协议 + public static final int NET_PROTOCOL_AEBELL = NET_PROTOCOL_PRIVATE+1; //美电贝尔 + public static final int NET_PROTOCOL_PANASONIC = NET_PROTOCOL_AEBELL+1; //松下 + public static final int NET_PROTOCOL_SONY = NET_PROTOCOL_PANASONIC+1; //索尼 + public static final int NET_PROTOCOL_DYNACOLOR = NET_PROTOCOL_SONY+1; //Dynacolor + public static final int NET_PROTOCOL_TCWS = NET_PROTOCOL_DYNACOLOR+1; //天城威视 + public static final int NET_PROTOCOL_SAMSUNG = NET_PROTOCOL_TCWS+1; //三星 + public static final int NET_PROTOCOL_YOKO = NET_PROTOCOL_SAMSUNG+1; //YOKO + public static final int NET_PROTOCOL_AXIS = NET_PROTOCOL_YOKO+1; //安讯视 + public static final int NET_PROTOCOL_SANYO = NET_PROTOCOL_AXIS+1; //三洋 + public static final int NET_PROTOCOL_BOSH = NET_PROTOCOL_SANYO+1; //Bosch + public static final int NET_PROTOCOL_PECLO = NET_PROTOCOL_BOSH+1; //Peclo + public static final int NET_PROTOCOL_PROVIDEO = NET_PROTOCOL_PECLO+1; //Provideo + public static final int NET_PROTOCOL_ACTI = NET_PROTOCOL_PROVIDEO+1; //ACTi + public static final int NET_PROTOCOL_VIVOTEK = NET_PROTOCOL_ACTI+1; //Vivotek + public static final int NET_PROTOCOL_ARECONT = NET_PROTOCOL_VIVOTEK+1; //Arecont + public static final int NET_PROTOCOL_PRIVATEEH = NET_PROTOCOL_ARECONT+1; //PrivateEH + public static final int NET_PROTOCOL_IMATEK = NET_PROTOCOL_PRIVATEEH+1; //IMatek + public static final int NET_PROTOCOL_SHANY = NET_PROTOCOL_IMATEK+1; //Shany + public static final int NET_PROTOCOL_VIDEOTREC = NET_PROTOCOL_SHANY+1; //动力盈科 + public static final int NET_PROTOCOL_URA = NET_PROTOCOL_VIDEOTREC+1; //Ura + public static final int NET_PROTOCOL_BITICINO = NET_PROTOCOL_URA+1; //Bticino + public static final int NET_PROTOCOL_ONVIF2 = NET_PROTOCOL_BITICINO+1; //Onvif协议类型,同NET_PROTOCOL_ONVIF + public static final int NET_PROTOCOL_SHEPHERD = NET_PROTOCOL_ONVIF2+1; //视霸 + public static final int NET_PROTOCOL_YAAN = NET_PROTOCOL_SHEPHERD+1; //亚安 + public static final int NET_PROTOCOL_AIRPOINT = NET_PROTOCOL_YAAN+1; //Airpop + public static final int NET_PROTOCOL_TYCO = NET_PROTOCOL_AIRPOINT+1; //TYCO + public static final int NET_PROTOCOL_XUNMEI = NET_PROTOCOL_TYCO+1; //讯美 + public static final int NET_PROTOCOL_HIKVISION = NET_PROTOCOL_XUNMEI+1; //海康 + public static final int NET_PROTOCOL_LG = NET_PROTOCOL_HIKVISION+1; //LG + public static final int NET_PROTOCOL_AOQIMAN = NET_PROTOCOL_LG+1; //奥奇曼 + public static final int NET_PROTOCOL_BAOKANG = NET_PROTOCOL_AOQIMAN+1; //宝康 + public static final int NET_PROTOCOL_WATCHNET = NET_PROTOCOL_BAOKANG+1; //Watchnet + public static final int NET_PROTOCOL_XVISION = NET_PROTOCOL_WATCHNET+1; //Xvision + public static final int NET_PROTOCOL_FUSITSU = NET_PROTOCOL_XVISION+1; //富士通 + public static final int NET_PROTOCOL_CANON = NET_PROTOCOL_FUSITSU+1; //Canon + public static final int NET_PROTOCOL_GE = NET_PROTOCOL_CANON+1; //GE + public static final int NET_PROTOCOL_Basler = NET_PROTOCOL_GE+1; //巴斯勒 + public static final int NET_PROTOCOL_Patro = NET_PROTOCOL_Basler+1; //帕特罗 + public static final int NET_PROTOCOL_CPKNC = NET_PROTOCOL_Patro+1; //CPPLUSK系列 + public static final int NET_PROTOCOL_CPRNC = NET_PROTOCOL_CPKNC+1; //CPPLUSR系列 + public static final int NET_PROTOCOL_CPUNC = NET_PROTOCOL_CPRNC+1; //CPPLUSU系列 + public static final int NET_PROTOCOL_CPPLUS = NET_PROTOCOL_CPUNC+1; //CPPLUSIPC + public static final int NET_PROTOCOL_XunmeiS = NET_PROTOCOL_CPPLUS+1; //讯美s,实际协议为Onvif + public static final int NET_PROTOCOL_GDDW = NET_PROTOCOL_XunmeiS+1; //广东电网 + public static final int NET_PROTOCOL_PSIA = NET_PROTOCOL_GDDW+1; //PSIA + public static final int NET_PROTOCOL_GB2818 = NET_PROTOCOL_PSIA+1; //GB2818 + public static final int NET_PROTOCOL_GDYX = NET_PROTOCOL_GB2818+1; //GDYX + public static final int NET_PROTOCOL_OTHER = NET_PROTOCOL_GDYX+1; //由用户自定义 + } + + // 雨刷来回循环刷,雨刷模式配置为手动模式时有效(对应命令 CTRLTYPE_CTRL_RAINBRUSH_MOVECONTINUOUSLY) + public static class NET_CTRL_RAINBRUSH_MOVECONTINUOUSLY extends Structure + { + public int dwSize; + public int nChannel;//表示雨刷的索引 + public int nInterval;//雨刷间隔 + + public NET_CTRL_RAINBRUSH_MOVECONTINUOUSLY() + { + this.dwSize = this.size(); + } + } + + // 雨刷停止刷,雨刷模式配置为手动模式时有效(对应命令 CTRLTYPE_CTRL_RAINBRUSH_STOPMOVE) + public static class NET_CTRL_RAINBRUSH_STOPMOVE extends Structure + { + public int dwSize; + public int nChannel;//表示雨刷的索引 + + public NET_CTRL_RAINBRUSH_STOPMOVE() + { + this.dwSize = this.size(); + } + } + + // 雨刷来回刷一次,雨刷模式配置为手动模式时有效(对应命令 CTRLTYPE_CTRL_RAINBRUSH_MOVEONCE) + public static class NET_CTRL_RAINBRUSH_MOVEONCE extends Structure + { + public int dwSize; + public int nChannel;//表示雨刷的索引 + + public NET_CTRL_RAINBRUSH_MOVEONCE() + { + this.dwSize = this.size(); + } + } + + // DSP能力描述,扩展类型,对应CLIENT_QueryDevState接口 + public static class NET_DEV_DSP_ENCODECAP extends Structure + { + public int dwVideoStandardMask; //视频制式掩码,按位表示设备能够支持的视频制式 + public int dwImageSizeMask; //分辨率掩码,按位表示设备能够支持的分辨率 + public int dwEncodeModeMask; //编码模式掩码,按位表示设备能够支持的编码模式 + public int dwStreamCap; //按位表示设备支持的多媒体功能, + // 第一位表示支持主码流 + // 第二位表示支持辅码流1 + // 第三位表示支持辅码流2 + // 第五位表示支持jpg抓图 + public int[] dwImageSizeMask_Assi = new int[32];//表示主码流为各分辨率时,支持的辅码流分辨率掩码。 + public int dwMaxEncodePower; //DSP支持的最高编码能力 + public short wMaxSupportChannel;//每块DSP支持最多输入视频通道数 + public short wChannelMaxSetSync;//DSP每通道的最大编码设置是否同步;0:不同步,1:同步 + public byte[] bMaxFrameOfImageSize = new byte[32];//不同分辨率下的最大采集帧率,与dwVideoStandardMask按位对应 + public byte bEncodeCap; //标志,配置时要求符合下面条件,否则配置不能生效; + // 0:主码流的编码能力+辅码流的编码能力 <= 设备的编码能力, + // 1:主码流的编码能力+辅码流的编码能力 <= 设备的编码能力, + // 辅码流的编码能力 <= 主码流的编码能力, + // 辅码流的分辨率 <= 主码流的分辨率, + // 主码流和辅码流的帧率 <= 前端视频采集帧率 + // 2:N5的计算方法 + // 辅码流的分辨率 <= 主码流的分辨率 + // 查询支持的分辨率和相应最大帧率 + public byte[] reserved = new byte[95]; + } + + //云台控制坐标单元 + public static class PTZ_SPACE_UNIT extends Structure + { + public int nPositionX;//云台水平运动位置,有效范围:0,3600] + public int nPositionY;//云台垂直运动位置,有效范围:-1800,1800] + public int nZoom;//云台光圈变动位置,有效范围:0,128] + public byte[] szReserve = new byte[32];//预留32字节 + } + + //云台控制速度单元 + public static class PTZ_SPEED_UNIT extends Structure + { + public float fPositionX;//云台水平方向速率,归一化到-1~1 + public float fPositionY;//云台垂直方向速率,归一化到-1~1 + public float fZoom;//云台光圈放大倍率,归一化到0~1 + public byte[] szReserve = new byte[32];//预留32字节 + } + + //持续控制云台对应结构 + public static class PTZ_CONTROL_CONTINUOUSLY extends Structure + { + public PTZ_SPEED_UNIT stuSpeed; //云台运行速度 + public int nTimeOut; //连续移动超时时间,单位为秒 + public byte[] szReserve = new byte[64]; //预留64字节 + } + + //绝对控制云台对应结构 + public static class PTZ_CONTROL_ABSOLUTELY extends Structure + { + public PTZ_SPACE_UNIT stuPosition; //云台绝对移动位置 + public PTZ_SPEED_UNIT stuSpeed; //云台运行速度 + public byte[] szReserve = new byte[64]; //预留64字节 + } + + //带速度转动到预置位点云台控制对应结构 + public static class PTZ_CONTROL_GOTOPRESET extends Structure + { + public int nPresetIndex; //预置位索引 + public PTZ_SPEED_UNIT stuSpeed; //云台运行速度 + public byte[] szReserve = new byte[64]; //预留64字节 + } + + //设置云台可视域信息 + public static class PTZ_VIEW_RANGE_INFO extends Structure + { + public int nStructSize; + public int nAzimuthH; //水平方位角度,0~3600,单位:度 + + public PTZ_VIEW_RANGE_INFO() + { + this.nStructSize = this.size(); + } + } + + //云台绝对聚焦对应结构 + public static class PTZ_FOCUS_ABSOLUTELY extends Structure + { + public int dwValue; //云台聚焦位置,取值范围(0~8191) + public int dwSpeed; //云台聚焦速度,取值范围(0~7) + public byte[] szReserve = new byte[64]; //预留64字节 + } + + // 云台控制-扇扫对应结构 + public static class PTZ_CONTROL_SECTORSCAN extends Structure + { + public int nBeginAngle; //起始角度,范围:-180,180] + public int nEndAngle; //结束角度,范围:-180,180] + public int nSpeed; //速度,范围:0,255] + public byte[] szReserve = new byte[64]; //预留64字节 + } + + // 控制鱼眼电子云台信息 + public static class PTZ_CONTROL_SET_FISHEYE_EPTZ extends Structure + { + public int dwSize; //结构体大小 + public int dwWindowID; //进行EPtz控制的窗口编号 + public int dwCommand; //电子云台命令 + public int dwParam1; //命令对应参数1 + public int dwParam2; //命令对应参数2 + public int dwParam3; //命令对应参数3 + public int dwParam4; //命令对应参数4 + } + + // 变倍设置基本信息单元 + public static class CFG_VIDEO_IN_ZOOM_UNIT extends Structure + { + public int nSpeed;//变倍速率(0~7) + public int bDigitalZoom;//是否数字变倍, 类型为BOOL, 取值0或者1 + public int nZoomLimit;//当前速率下最大变倍上限(0~13)。 + } + + // 单通道变倍设置基本信息 + public static class CFG_VIDEO_IN_ZOOM extends Structure + { + public int nChannelIndex;//通道号 + public int nVideoInZoomRealNum;//配置使用个数 + public CFG_VIDEO_IN_ZOOM_UNIT[] stVideoInZoomUnit = (CFG_VIDEO_IN_ZOOM_UNIT[])new CFG_VIDEO_IN_ZOOM_UNIT().toArray(MAX_VIDEO_IN_ZOOM);//通道变速配置单元信息 + } + + // 设备状态 + public static class CFG_TRAFFIC_DEVICE_STATUS extends Structure + { + public byte[] szType = new byte[MAX_PATH]; // 设备类型 支持:"Radar","Detector","SigDetector","StroboscopicLamp"," FlashLamp" + public byte[] szSerialNo = new byte[MAX_PATH]; // 设备编号 + public byte[] szVendor = new byte[MAX_PATH]; // 生产厂商 + public int nWokingState; // 工作状态 0-故障,1-正常工作 + public byte byLightState; // RS485灯的亮灭状态,Type 为"DhrsStroboscopicLamp"或者"DhrsSteadyLamp"时有效 + // 0-未知, 1-灯亮, 2-灯灭 + public byte[] byReserved = new byte[3]; // 预留字节 + } + + // 获取设备工作状态是否正常 (对应命令 CFG_CAP_CMD_DEVICE_STATE ) + public static class CFG_CAP_TRAFFIC_DEVICE_STATUS extends Structure + { + public int nStatus; // stuStatus 实际个数 + public CFG_TRAFFIC_DEVICE_STATUS[] stuStatus = (CFG_TRAFFIC_DEVICE_STATUS[]) new CFG_TRAFFIC_DEVICE_STATUS().toArray(MAX_STATUS_NUM); + } + + // 视频输入通道 + public static class CFG_RemoteDeviceVideoInput extends Structure + { + public int bEnable; + public byte[] szName = new byte[MAX_DEVICE_NAME_LEN]; + public byte[] szControlID = new byte[MAX_DEV_ID_LEN_EX]; + public byte[] szMainUrl = new byte[MAX_PATH]; // 主码流url地址 + public byte[] szExtraUrl = new byte[MAX_PATH]; // 辅码流url地址 + public int nServiceType; // 服务类型, 0-TCP, 1-UDP, 2-MCAST, -1-AUTO + } + + // 远程设备 + public static class AV_CFG_RemoteDevice extends Structure + { + public int nStructSize; + public int bEnable; // 使能 + public byte[] szID = new byte[AV_CFG_Device_ID_Len]; // 设备ID + public byte[] szIP = new byte[AV_CFG_IP_Address_Len];// 设备IP + public int nPort; // 端口 + public byte[] szProtocol = new byte[AV_CFG_Protocol_Len]; // 协议类型 + public byte[] szUser = new byte[AV_CFG_User_Name_Len]; // 用户名 + public byte[] szPassword = new byte[AV_CFG_Password_Len]; // 密码 + public byte[] szSerial = new byte[AV_CFG_Serial_Len]; // 设备序列号 + public byte[] szDevClass = new byte[AV_CFG_Device_Class_Len]; // 设备类型 + public byte[] szDevType = new byte[AV_CFG_Device_Type_Len]; // 设备型号 + public byte[] szName = new byte[AV_CFG_Device_Name_Len]; // 机器名称 + public byte[] szAddress = new byte[AV_CFG_Address_Len]; // 机器部署地点 + public byte[] szGroup = new byte[AV_CFG_Group_Name_Len]; // 机器分组 + public int nDefinition; // 清晰度, 0-标清, 1-高清 + public int nVideoChannel; // 视频输入通道数 + public int nAudioChannel; // 音频输入通道数 + public int nRtspPort; // Rtsp端口号 + public byte[] szVendor = new byte[MAX_PATH]; // 设备接入类型 + public Pointer pVideoInput; // 视频输入通道,用户申请nMaxVideoInputs个CFG_RemoteDeviceVideoInput空间 + public int nMaxVideoInputs; + public int nRetVideoInputs; + public int nHttpPort; // http端口号 + + /* 以下3项为国际接入方式相关 */ + public int bGB28181; // 是否有国际接入方式 + public int nDevLocalPort; // 设备本地端口 + public byte[] szDeviceNo = new byte[AV_CFG_DeviceNo_Len]; // 设备编号 + + public AV_CFG_RemoteDevice() { + this.nStructSize = this.size(); + } + } + + // 录像模式 + public static class AV_CFG_RecordMode extends Structure + { + public int nStructSize; + public int nMode; // 录像模式, 0-自动录像,1-手动录像,2-关闭录像 + public int nModeExtra1; // 辅码流录像模式, 0-自动录像,1-手动录像,2-关闭录像 + public int nModeExtra2; // 辅码流2录像模式, 0-自动录像,1-手动录像,2-关闭录像 + + public AV_CFG_RecordMode() { + this.nStructSize = this.size(); + } + } + + // 视频分析资源类型 + public static class CFG_VIDEO_SOURCE_TYPE extends Structure { + public static final int CFG_VIDEO_SOURCE_REALSTREAM = 0; // 实时流 + public static final int CFG_VIDEO_SOURCE_FILESTREAM = 1; // 文件流 + } + + // 分析源文件类型 + public static class CFG_SOURCE_FILE_TYPE extends Structure { + public static final int CFG_SOURCE_FILE_UNKNOWN = 0; // 未知类型 + public static final int CFG_SOURCE_FILE_RECORD = 1; // 录像文件 + public static final int CFG_SOURCE_FILE_PICTURE = 2; // 图片文件 + } + + // 视频分析源文件信息 + public static class CFG_SOURCE_FILE_INFO extends Structure { + public byte[] szFilePath = new byte[MAX_PATH];// 文件路径 + public int emFileType; // 文件类型,详见 CFG_SOURCE_FILE_TYPE + } + + // 每个视频输入通道对应的视频分析资源配置信息 + public static class CFG_ANALYSESOURCE_INFO extends Structure { + public byte bEnable; // 视频分析使能 1-使能, 0-禁用 + public int nChannelID; // 智能分析的前端视频通道号 + public int nStreamType;// 智能分析的前端视频码流类型,0:抓图码流; 1:主码流; 2:子码流1; 3:子码流2; 4:子码流3; 5:物体流 + public byte[] szRemoteDevice = new byte[MAX_NAME_LEN];// 设备名 + public byte abDeviceInfo; // 设备信息是否有效 ; 1-有效,0-无效 + public AV_CFG_RemoteDevice stuDeviceInfo; // 设备信息 + public int emSourceType; // 视频分析源类型,详见 CFG_VIDEO_SOURCE_TYPE + public CFG_SOURCE_FILE_INFO stuSourceFile; // 当视频分析源类型为 CFG_VIDEO_SOURCE_FILESTREAM 时,有效 + } + + public static class CFG_OVERSPEED_INFO extends Structure { + public int[] nSpeedingPercentage = new int[2]; // 超速百分比区间要求区间不能重叠。有效值为0,正数,-1,-1表示无穷大值 + // 如果是欠速:要求区间不能重叠。有效值为0,正数,-1,-1表示无穷大值,欠速百分比的计算方式:限低速-实际车速/限低速 + public byte[] szCode = new byte[MAX_VIOLATIONCODE]; // 违章代码 + public byte[] szDescription = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述 + } + + // 违章代码配置表 + public static class VIOLATIONCODE_INFO extends Structure { + public byte[] szRetrograde = new byte[MAX_VIOLATIONCODE]; // 逆行 + public byte[] szRetrogradeDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + public byte[] szRetrogradeShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 显示名称 + + public byte[] szRetrogradeHighway = new byte[MAX_VIOLATIONCODE]; // 逆行-高速公路 + public byte[] szRetrogradeHighwayDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + + public byte[] szRunRedLight = new byte[MAX_VIOLATIONCODE]; // 闯红灯 + public byte[] szRunRedLightDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + + public byte[] szCrossLane = new byte[MAX_VIOLATIONCODE]; // 违章变道 + public byte[] szCrossLaneDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + public byte[] szCrossLaneShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章变道显示名称 + + public byte[] szTurnLeft = new byte[MAX_VIOLATIONCODE]; // 违章左转 + public byte[] szTurnLeftDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + + public byte[] szTurnRight = new byte[MAX_VIOLATIONCODE]; // 违章右转 + public byte[] szTurnRightDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + + public byte[] szU_Turn = new byte[MAX_VIOLATIONCODE]; // 违章掉头 + public byte[] szU_TurnDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + public byte[] szU_TurnShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 显示信息 + + public byte[] szJam = new byte[MAX_VIOLATIONCODE]; // 交通拥堵 + public byte[] szJamDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + + public byte[] szParking = new byte[MAX_VIOLATIONCODE]; // 违章停车 + public byte[] szParkingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + public byte[] szParkingShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章停车显示名称 + + // 超速 和 超速比例 只需且必须有一个配置 + public byte[] szOverSpeed = new byte[MAX_VIOLATIONCODE]; // 超速 + public byte[] szOverSpeedDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + public CFG_OVERSPEED_INFO[] stOverSpeedConfig = (CFG_OVERSPEED_INFO[])new CFG_OVERSPEED_INFO().toArray(5); // 超速比例代码 + + // 超速(高速公路) 和 超速比例(高速公路) 只需且必须有一个配置 + public byte[] szOverSpeedHighway = new byte[MAX_VIOLATIONCODE]; // 超速-高速公路 + public byte[] szOverSpeedHighwayDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 超速-违章描述信息 + public CFG_OVERSPEED_INFO[] stOverSpeedHighwayConfig = (CFG_OVERSPEED_INFO[])new CFG_OVERSPEED_INFO().toArray(5); // 超速比例代码 + + // 欠速 和 欠速比例 只需且必须有一个配置 + public byte[] szUnderSpeed = new byte[MAX_VIOLATIONCODE]; // 欠速 + public byte[] szUnderSpeedDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + public CFG_OVERSPEED_INFO[] stUnderSpeedConfig = (CFG_OVERSPEED_INFO[]) new CFG_OVERSPEED_INFO().toArray(5); // 欠速配置信息是一个数组,不同的欠速比违章代码不同,为空表示违章代码不区分超速比 + + public byte[] szOverLine = new byte[MAX_VIOLATIONCODE]; // 压线 + public byte[] szOverLineDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + public byte[] szOverLineShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 压线显示名称 + + public byte[] szOverYellowLine = new byte[MAX_VIOLATIONCODE]; // 压黄线 + public byte[] szOverYellowLineDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章描述信息 + + public byte[] szYellowInRoute = new byte[MAX_VIOLATIONCODE]; // 黄牌占道 + public byte[] szYellowInRouteDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 黄牌占道违章描述信息 + + public byte[] szWrongRoute = new byte[MAX_VIOLATIONCODE]; // 不按车道行驶 + public byte[] szWrongRouteDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 不按车道行驶违章描述信息 + + public byte[] szDrivingOnShoulder = new byte[MAX_VIOLATIONCODE]; // 路肩行驶 + public byte[] szDrivingOnShoulderDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 路肩行驶违章描述信息 + + public byte[] szPassing = new byte[MAX_VIOLATIONCODE]; // 正常行驶 + public byte[] szPassingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 正常行驶违章描述信息 + + public byte[] szNoPassing = new byte[MAX_VIOLATIONCODE]; // 禁止行驶 + public byte[] szNoPassingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 禁止行驶违章描述信息 + + public byte[] szFakePlate = new byte[MAX_VIOLATIONCODE]; // 套牌 + public byte[] szFakePlateDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 套牌违章描述信息 + + public byte[] szParkingSpaceParking = new byte[MAX_VIOLATIONCODE]; // 车位有车 + public byte[] szParkingSpaceParkingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 车位有车违章描述信息、 + + public byte[] szParkingSpaceNoParking = new byte[MAX_VIOLATIONCODE]; // 车位无车 + public byte[] szParkingSpaceNoParkingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 车位无车违章描述信息 + + public byte[] szWithoutSafeBelt = new byte[MAX_VIOLATIONCODE]; // 不系安全带 + public byte[] szWithoutSafeBeltShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 不系安全带显示名称 + public byte[] szWithoutSafeBeltDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 不系安全带违章描述信息 + + public byte[] szDriverSmoking = new byte[MAX_VIOLATIONCODE]; // 驾驶员抽烟 + public byte[] szDriverSmokingShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 驾驶员抽烟显示名称 + public byte[] szDriverSmokingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 驾驶员抽烟带违章描述信息 + + public byte[] szDriverCalling = new byte[MAX_VIOLATIONCODE]; // 驾驶员打电话 + public byte[] szDriverCallingShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 驾驶员打电话显示名称 + public byte[] szDriverCallingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 驾驶员打电话违章描述信息 + + public byte[] szBacking = new byte[MAX_VIOLATIONCODE]; // 违章倒车 + public byte[] szBackingShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章倒车显示名称 + public byte[] szBackingDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章倒车描述信息 + + public byte[] szVehicleInBusRoute = new byte[MAX_VIOLATIONCODE]; // 违章占道 + public byte[] szVehicleInBusRouteShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章占道显示名称 + public byte[] szVehicleInBusRouteDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 违章占道描述信息 + + public byte[] szPedestrianRunRedLight = new byte[MAX_VIOLATIONCODE]; // 行人闯红灯 + public byte[] szPedestrianRunRedLightShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT];// 行人闯红灯显示名称 + public byte[] szPedestrianRunRedLightDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 行人闯红灯描述信息 + + public byte[] szPassNotInOrder = new byte[MAX_VIOLATIONCODE]; // 未按规定依次通行 + public byte[] szPassNotInOrderShowName = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 未按规定依次通行显示名称 + public byte[] szPassNotInOrderDesc = new byte[MAX_VIOLATIONCODE_DESCRIPT]; // 未按规定依次通行描述信息 + } + + // 违章抓拍时间配置表 + public static class TIME_SCHEDULE_INFO extends Structure { + public int bEnable; // 是否启用时间表 + public CFG_TIME_SECTION[] stuTimeSchedule = (CFG_TIME_SECTION[])new CFG_TIME_SECTION().toArray(WEEK_DAY_NUM*MAX_REC_TSECT); // 时间表 + } + + // 违章抓拍自定义时间配置 + public static class VIOLATION_TIME_SCHEDULE extends Structure + { + public int abTrafficGate; // 是否携带交通卡口信息 + public TIME_SCHEDULE_INFO stTrafficGate; // 交通卡口时间配置 + + public int abTrafficJunction; // 是否携带交通路口信息 + public TIME_SCHEDULE_INFO stTrafficJunction; // 交通路口时间配置 + + public int abTrafficTollGate; // 是否携带新交通卡口信息 + public TIME_SCHEDULE_INFO stTrafficTollGate; // 新交通卡口时间配置 + + public int abTrafficRunRedLight; // 是否携带交通闯红灯信息 + public TIME_SCHEDULE_INFO stTrafficRunRedLight; // 交通闯红灯时间配置 + + public int abTrafficRunYellowLight; // 是否携带交通闯黄灯信息 + public TIME_SCHEDULE_INFO stTrafficRunYellowLight; // 交通闯黄灯时间配置 + + public int abTrafficOverLine; // 是否携带交通压线信息 + public TIME_SCHEDULE_INFO stTrafficOverLine; // 交通压线时间配置 + + public int abTrafficOverYellowLine; // 是否携带交通压黄线信息 + public TIME_SCHEDULE_INFO stTrafficOverYellowLine; // 交通压黄线时间配置 + + public int abTrafficRetrograde; // 是否携带交通逆行信息 + public TIME_SCHEDULE_INFO stTrafficRetrograde; // 交通逆行时间配置 + + public int abTrafficTurnLeft; // 是否携带交通违章左转信息 + public TIME_SCHEDULE_INFO stTrafficTurnLeft; // 交通违章左转时间配置 + + public int abTrafficTurnRight; // 是否携带交通违章右转信息 + public TIME_SCHEDULE_INFO stTrafficTurnRight; // 交通路口违章右转类型 + + public int abTrafficU_Turn; // 是否携带交通违章掉头信息 + public TIME_SCHEDULE_INFO stTrafficU_Turn; // 交通违章掉头时间配置 + + public int abTrafficCrossLane; // 是否携带交通违章变道信息 + public TIME_SCHEDULE_INFO stTrafficCrossLane; // 交通违章变道时间配置 + + public int abTrafficParking; // 是否携带交通违章停车信息 + public TIME_SCHEDULE_INFO stTrafficParking; // 交通违章停车时间配置 + + public int abTrafficJam; // 是否携带交通拥堵信息 + public TIME_SCHEDULE_INFO stTrafficJam; // 交通拥堵时间配置 + + public int abTrafficIdle; // 是否携带交通交通空闲信息 + public TIME_SCHEDULE_INFO stTrafficIdle; // 交通交通空闲时间配置 + + public int abTrafficWaitingArea; // 是否携带交通违章驶入待行区信息 + public TIME_SCHEDULE_INFO stTrafficWaitingArea; // 交通违章驶入待行区时间配置 + + public int abTrafficUnderSpeed; // 是否携带交通欠速信息 + public TIME_SCHEDULE_INFO stTrafficUnderSpeed; // 交通欠速时间配置 + + public int abTrafficOverSpeed; // 是否携带交通超速信息 + public TIME_SCHEDULE_INFO stTrafficOverSpeed; // 交通超速时间配置 + + public int abTrafficWrongRoute; // 是否携带交通不按车道行驶信息 + public TIME_SCHEDULE_INFO stTrafficWrongRoute; // 交通不按车道行驶时间配置 + + public int abTrafficYellowInRoute; // 是否携带交通黄牌占道信息 + public TIME_SCHEDULE_INFO stTrafficYellowInRoute; // 交通黄牌占道时间配置 + + public int abTrafficVehicleInRoute; // 是否携带交通有车占道信息 + public TIME_SCHEDULE_INFO stTrafficVehicleInRoute; // 交通有车占道时间配置 + + public int abTrafficControl; // 是否携带交通交通管制信息 + public TIME_SCHEDULE_INFO stTrafficControl; // 交通交通管制时间配置 + + public int abTrafficObjectAlarm; // 是否携带交通指定类型抓拍信息 + public TIME_SCHEDULE_INFO stTrafficObjectAlarm; // 交通指定类型抓拍时间配置 + + public int abTrafficAccident; // 是否携带交通交通事故信息 + public TIME_SCHEDULE_INFO stTrafficAccident; // 交通交通事故时间配置 + + public int abTrafficStay; // 是否携带交通交通停留/滞留信息 + public TIME_SCHEDULE_INFO stTrafficStay; // 交通交通停留/滞留时间配置 + + public int abTrafficPedestrainPriority; // 是否携带交通斑马线行人优先信息 + public TIME_SCHEDULE_INFO stTrafficPedestrainPriority; // 交通斑马线行人优先时间配置 + + public int abTrafficPedestrain; // 是否携带交通交通行人事件信息 + public TIME_SCHEDULE_INFO stTrafficPedestrain; // 交通交通行人事件时间配置 + + public int abTrafficThrow; // 是否携带交通交通抛洒物品事件信息 + public TIME_SCHEDULE_INFO stTrafficThrow; // 交通交通抛洒物品事件时间配置 + + public int abTrafficVehicleInBusRoute; // 是否携带交通违章占道信息 + public TIME_SCHEDULE_INFO stTrafficVehicleInBusRoute; // 交通违章占道时间配置 + + public int abTrafficBacking; // 是否携带交通违章倒车信息 + public TIME_SCHEDULE_INFO stTrafficBacking; // 交通违章倒车时间配置 + + public int abTrafficOverStopLine; // 是否携带交通压停止线信息 + public TIME_SCHEDULE_INFO stTrafficOverStopLine; // 交通压停止线时间配置 + + public int abTrafficParkingOnYellowBox; // 是否携带交通黄网格线抓拍信息 + public TIME_SCHEDULE_INFO stTrafficParkingOnYellowBox; // 交通黄网格线抓拍时间配置 + + public int abTrafficParkingSpaceParking; // 是否携带交通车位有车信息 + public TIME_SCHEDULE_INFO stTrafficParkingSpaceParking; // 交通车位有车时间配置 + + public int abTrafficParkingSpaceNoParking; // 是否携带交通车位无车信息 + public TIME_SCHEDULE_INFO stTrafficParkingSpaceNoParking; // 交通车位无车时间配置 + + public int abTrafficParkingSpaceOverLine; // 是否携带交通车位有车压线信息 + public TIME_SCHEDULE_INFO stTrafficParkingSpaceOverLine; // 交通车位有车压线时间配置 + + public int abParkingSpaceDetection; // 是否携带交通多停车位状态检测信息 + public TIME_SCHEDULE_INFO stParkingSpaceDetection; // 交通多停车位状态检测时间配置 + + public int abTrafficRestrictedPlate; // 是否携带交通受限车牌信息 + public TIME_SCHEDULE_INFO stTrafficRestrictedPlate; // 交通受限车牌时间配置 + + public int abTrafficWithoutSafeBelt; // 是否携带交通不系安全带信息 + public TIME_SCHEDULE_INFO stTrafficWithoutSafeBelt; // 交通不系安全带时间配置 + + public int abTrafficNoPassing; // 是否携带交通禁行信息 + public TIME_SCHEDULE_INFO stTrafficNoPassing; // 交通禁行时间配置 + + public int abVehicleAnalyse; // 是否携带交通车辆特征检测分析信息 + public TIME_SCHEDULE_INFO stVehicleAnalyse; // 交通车辆特征时间配置 + + public int abCrossLineDetection; // 是否携带交通警戒线信息 + public TIME_SCHEDULE_INFO stCrossLineDetection; // 交通警戒线时间配置 + + public int abCrossFenceDetection; // 是否携带交通穿越围栏信息 + public TIME_SCHEDULE_INFO stCrossFenceDetection; // 交通穿越围栏时间配置 + + public int abCrossRegionDetection; // 是否携带交通警戒区信息 + public TIME_SCHEDULE_INFO stCrossRegionDetection; // 交通警戒区时间配置 + + public int abPasteDetection; // 是否携带交通ATM贴条信息 + public TIME_SCHEDULE_INFO stPasteDetection; // 交通ATM贴条时间配置 + + public int abLeftDetection; // 是否携带交通物品遗留信息 + public TIME_SCHEDULE_INFO stLeftDetection; // 交通物品遗留时间配置 + + public int abPreservation; // 是否携带交通物品保全信息 + public TIME_SCHEDULE_INFO stPreservation; // 交通物品保全时间配置 + + public int abTakenAwayDetection; // 是否携带交通物品搬移信息 + public TIME_SCHEDULE_INFO stTakenAwayDetection; // 交通物品搬移时间配置 + + public int abStayDetection; // 是否携带交通停留/滞留信息 + public TIME_SCHEDULE_INFO stStayDetection; // 交通停留/滞留时间配置 + + public int abParkingDetection; // 是否携带交通非法停车信息 + public TIME_SCHEDULE_INFO stParkingDetection; // 交通非法停车时间配置 + + public int abWanderDetection; // 是否携带交通徘徊信息 + public TIME_SCHEDULE_INFO stWanderDetection; // 交通徘徊时间配置 + + public int abMoveDetection; // 是否携带交通运动信息 + public TIME_SCHEDULE_INFO stMoveDetection; // 交通运动时间配置 + + public int abTailDetection; // 是否携带交通尾随信息 + public TIME_SCHEDULE_INFO stTailDetection; // 交通尾随时间配置 + + public int abRioterDetection; // 是否携带交通聚集信息 + public TIME_SCHEDULE_INFO stRioterDetection; // 交通聚集时间配置 + + public int abFightDetection; // 是否携带交通打架信息 + public TIME_SCHEDULE_INFO stFightDetection; // 交通打架时间配置 + + public int abRetrogradeDetection; // 是否携带交通逆行信息 + public TIME_SCHEDULE_INFO stRetrogradeDetection; // 交通逆行时间配置 + + public int abFireDetection; // 是否携带交通火焰信息 + public TIME_SCHEDULE_INFO stFireDetection; // 交通火焰时间配置 + + public int abSmokeDetection; // 是否携带交通烟雾信息 + public TIME_SCHEDULE_INFO stSmokeDetection; // 交通烟雾时间配置 + + public int abNumberStat; // 是否携带交通数量统计信息 + public TIME_SCHEDULE_INFO stNumberStat; // 交通数量统计时间配置 + + public int abVideoAbnormalDetection; // 是否携带交通视频异常信息 + public TIME_SCHEDULE_INFO stVideoAbnormalDetection; // 交通视频异常时间配置 + + public int abPrisonerRiseDetection; // 是否携带看守所囚犯起身检测信息 + public TIME_SCHEDULE_INFO stPrisonerRiseDetection; // 看守所囚犯起身检测时间配置 + + public int abFaceDetection; // 是否携带人脸检测信息 + public TIME_SCHEDULE_INFO stFaceDetection; // 人脸检测时间配置 + + public int abFaceRecognition; // 是否携带人脸识别信息 + public TIME_SCHEDULE_INFO stFaceRecognition; // 人脸识别时间配置 + + public int abDensityDetection; // 是否携带密集度检测信息 + public TIME_SCHEDULE_INFO stDensityDetection; // 密集度检测时间配置 + + public int abQueueDetection; // 是否携带排队检测信息 + public TIME_SCHEDULE_INFO stQueueDetection; // 排队检测时间配置 + + public int abClimbDetection; // 是否携带攀高检测信息 + public TIME_SCHEDULE_INFO stClimbDetection; // 攀高时间配置 + + public int abLeaveDetection; // 是否携带离岗检测信息 + public TIME_SCHEDULE_INFO stLeaveDetection; // 离岗时间配置 + + public int abVehicleOnPoliceCar; // 是否携带车载警车信息 + public TIME_SCHEDULE_INFO stVehicleOnPoliceCar; // 车载警车时间配置 + + public int abVehicleOnBus; // 是否携带车载公交信息 + public TIME_SCHEDULE_INFO stVehicleOnBus; // 车载公交时间配置 + + public int abVehicleOnSchoolBus; // 是否携带车载校车信息 + public TIME_SCHEDULE_INFO stVehicleOnSchoolBus; // 车载校车时间配置 + } + + // 交通全局配置对应图片命名格式参数配置 + public static class TRAFFIC_NAMING_FORMAT extends Structure { + public byte[] szFormat = new byte[CFG_COMMON_STRING_256]; // 图片格式 + } + + // CFG_NET_TIME 时间 + public static class CFG_NET_TIME extends Structure { + public int nStructSize; + public int dwYear; // 年 + public int dwMonth; // 月 + public int dwDay; // 日 + public int dwHour; // 时 + public int dwMinute; // 分 + public int dwSecond; // 秒 + + public CFG_NET_TIME() { + this.nStructSize = this.size(); + } + } + + // PERIOD_OF_VALIDITY + public static class PERIOD_OF_VALIDITY extends Structure { + public CFG_NET_TIME stBeginTime; // 标定开始时间 + public CFG_NET_TIME stEndTime; // 标定到期时间 + } + + // 交通全局配置对应标定相关配置 + public static class TRAFFIC_CALIBRATION_INFO extends Structure { + public byte[] szUnit = new byte[CFG_COMMON_STRING_256]; // 标定单位 + public byte[] szCertificate = new byte[CFG_COMMON_STRING_256]; // 标定证书 + public PERIOD_OF_VALIDITY stPeriodOfValidity; // 标定有效期 + } + + // TRAFFIC_EVENT_CHECK_MASK + public static class TRAFFIC_EVENT_CHECK_MASK extends Structure { + public int abTrafficGate; // 是否携带交通卡口信息 + public int nTrafficGate; // 交通卡口检测模式掩码 + + public int abTrafficJunction; // 是否携带交通路口信息 + public int nTrafficJunction; // 交通路口检测模式掩码 + + public int abTrafficTollGate; // 是否携带新交通卡口信息 + public int nTrafficTollGate; // 新交通卡口检测模式掩码 + + public int abTrafficRunRedLight; // 是否携带交通闯红灯信息 + public int nTrafficRunRedLight; // 交通闯红灯检测模式掩码 + + public int abTrafficRunYellowLight; // 是否携带交通闯黄灯信息 + public int nTrafficRunYellowLight; // 交通闯黄灯检测模式掩码 + + public int abTrafficOverLine; // 是否携带交通压线信息 + public int nTrafficOverLine; // 交通压线检测模式掩码 + + public int abTrafficOverYellowLine; // 是否携带交通压黄线信息 + public int nTrafficOverYellowLine; // 交通压黄线检测模式掩码 + + public int abTrafficRetrograde; // 是否携带交通逆行信息 + public int nTrafficRetrograde; // 交通逆行检测模式掩码 + + public int abTrafficTurnLeft; // 是否携带交通违章左转信息 + public int nTrafficTurnLeft; // 交通违章左转检测模式掩码 + + public int abTrafficTurnRight; // 是否携带交通违章右转信息 + public int nTrafficTurnRight; // 交通路口违章右转类型 + + public int abTrafficU_Turn; // 是否携带交通违章掉头信息 + public int nTrafficU_Turn; // 交通违章掉头检测模式掩码 + + public int abTrafficCrossLane; // 是否携带交通违章变道信息 + public int nTrafficCrossLane; // 交通违章变道检测模式掩码 + + public int abTrafficParking; // 是否携带交通违章停车信息 + public int nTrafficParking; // 交通违章停车检测模式掩码 + + public int abTrafficJam; // 是否携带交通拥堵信息 + public int nTrafficJam; // 交通拥堵检测模式掩码 + + public int abTrafficIdle; // 是否携带交通交通空闲信息 + public int nTrafficIdle; // 交通交通空闲检测模式掩码 + + public int abTrafficWaitingArea; // 是否携带交通违章驶入待行区信息 + public int nTrafficWaitingArea; // 交通违章驶入待行区检测模式掩码 + + public int abTrafficUnderSpeed; // 是否携带交通欠速信息 + public int nTrafficUnderSpeed; // 交通欠速检测模式掩码 + + public int abTrafficOverSpeed; // 是否携带交通超速信息 + public int nTrafficOverSpeed; // 交通超速检测模式掩码 + + public int abTrafficWrongRoute; // 是否携带交通不按车道行驶信息 + public int nTrafficWrongRoute; // 交通不按车道行驶检测模式掩码 + + public int abTrafficYellowInRoute; // 是否携带交通黄牌占道信息 + public int nTrafficYellowInRoute; // 交通黄牌占道检测模式掩码 + + public int abTrafficVehicleInRoute; // 是否携带交通有车占道信息 + public int nTrafficVehicleInRoute; // 交通有车占道检测模式掩码 + + public int abTrafficControl; // 是否携带交通交通管制信息 + public int nTrafficControl; // 交通交通管制检测模式掩码 + + public int abTrafficObjectAlarm; // 是否携带交通指定类型抓拍信息 + public int nTrafficObjectAlarm; // 交通指定类型抓拍检测模式掩码 + + public int abTrafficAccident; // 是否携带交通交通事故信息 + public int nTrafficAccident; // 交通交通事故检测模式掩码 + + public int abTrafficStay; // 是否携带交通交通停留/滞留信息 + public int nTrafficStay; // 交通交通停留/滞留检测模式掩码 + + public int abTrafficPedestrainPriority; // 是否携带交通斑马线行人优先信息 + public int nTrafficPedestrainPriority; // 交通斑马线行人优先检测模式掩码 + + public int abTrafficPedestrain; // 是否携带交通交通行人事件信息 + public int nTrafficPedestrain; // 交通交通行人事件检测模式掩码 + + public int abTrafficThrow; // 是否携带交通交通抛洒物品事件信息 + public int nTrafficThrow; // 交通交通抛洒物品事件检测模式掩码 + + public int abTrafficVehicleInBusRoute; // 是否携带交通违章占道信息 + public int nTrafficVehicleInBusRoute; // 交通违章占道检测模式掩码 + + public int abTrafficBacking; // 是否携带交通违章倒车信息 + public int nTrafficBacking; // 交通违章倒车检测模式掩码 + + public int abTrafficOverStopLine; // 是否携带交通压停止线信息 + public int nTrafficOverStopLine; // 交通压停止线检测模式掩码 + + public int abTrafficParkingOnYellowBox; // 是否携带交通黄网格线抓拍信息 + public int nTrafficParkingOnYellowBox; // 交通黄网格线抓拍检测模式掩码 + + public int abTrafficParkingSpaceParking; // 是否携带交通车位有车信息 + public int nTrafficParkingSpaceParking; // 交通车位有车检测模式掩码 + + public int abTrafficParkingSpaceNoParking; // 是否携带交通车位无车信息 + public int nTrafficParkingSpaceNoParking; // 交通车位无车检测模式掩码 + + public int abTrafficParkingSpaceOverLine; // 是否携带交通车位有车压线信息 + public int nTrafficParkingSpaceOverLine; // 交通车位有车压线检测模式掩码 + + public int abParkingSpaceDetection; // 是否携带交通多停车位状态检测信息 + public int nParkingSpaceDetection; // 交通多停车位状态检测检测模式掩码 + + public int abTrafficRestrictedPlate; // 是否携带交通受限车牌信息 + public int nTrafficRestrictedPlate; // 交通受限车牌检测模式掩码 + + public int abTrafficWithoutSafeBelt; // 是否携带交通不系安全带信息 + public int nTrafficWithoutSafeBelt; // 交通不系安全带检测模式掩码 + + public int abTrafficNoPassing; // 是否携带交通禁行信息 + public int nTrafficNoPassing; // 交通禁行检测模式掩码 + + public int abVehicleAnalyse; // 是否携带交通车辆特征检测分析信息 + public int nVehicleAnalyse; // 交通车辆特征检测模式掩码 + + public int abCrossLineDetection; // 是否携带交通警戒线信息 + public int nCrossLineDetection; // 交通警戒线检测模式掩码 + + public int abCrossFenceDetection; // 是否携带交通穿越围栏信息 + public int nCrossFenceDetection; // 交通穿越围栏检测模式掩码 + + public int abCrossRegionDetection; // 是否携带交通警戒区信息 + public int nCrossRegionDetection; // 交通警戒区检测模式掩码 + + public int abPasteDetection; // 是否携带交通ATM贴条信息 + public int nPasteDetection; // 交通ATM贴条检测模式掩码 + + public int abLeftDetection; // 是否携带交通物品遗留信息 + public int nLeftDetection; // 交通物品遗留检测模式掩码 + + public int abPreservation; // 是否携带交通物品保全信息 + public int nPreservation; // 交通物品保全检测模式掩码 + + public int abTakenAwayDetection; // 是否携带交通物品搬移信息 + public int nTakenAwayDetection; // 交通物品搬移检测模式掩码 + + public int abStayDetection; // 是否携带交通停留/滞留信息 + public int nStayDetection; // 交通停留/滞留检测模式掩码 + + public int abParkingDetection; // 是否携带交通非法停车信息 + public int nParkingDetection; // 交通非法停车检测模式掩码 + + public int abWanderDetection; // 是否携带交通徘徊信息 + public int nWanderDetection; // 交通徘徊检测模式掩码 + + public int abMoveDetection; // 是否携带交通运动信息 + public int nMoveDetection; // 交通运动检测模式掩码 + + public int abTailDetection; // 是否携带交通尾随信息 + public int nTailDetection; // 交通尾随检测模式掩码 + + public int abRioterDetection; // 是否携带交通聚集信息 + public int nRioterDetection; // 交通聚集检测模式掩码 + + public int abFightDetection; // 是否携带交通打架信息 + public int nFightDetection; // 交通打架检测模式掩码 + + public int abRetrogradeDetection; // 是否携带交通逆行信息 + public int nRetrogradeDetection; // 交通逆行检测模式掩码 + + public int abFireDetection; // 是否携带交通火焰信息 + public int nFireDetection; // 交通火焰检测模式掩码 + + public int abSmokeDetection; // 是否携带交通烟雾信息 + public int nSmokeDetection; // 交通烟雾检测模式掩码 + + public int abNumberStat; // 是否携带交通数量统计信息 + public int nNumberStat; // 交通数量统计检测模式掩码 + + public int abVideoAbnormalDetection; // 是否携带交通视频异常信息 + public int nVideoAbnormalDetection; // 交通视频异常检测模式掩码 + + public int abPrisonerRiseDetection; // 是否携带看守所囚犯起身检测信息 + public int nPrisonerRiseDetection; // 看守所囚犯起身检测检测模式掩码 + + public int abFaceDetection; // 是否携带人脸检测信息 + public int nFaceDetection; // 人脸检测检测模式掩码 + + public int abFaceRecognition; // 是否携带人脸识别信息 + public int nFaceRecognition; // 人脸识别检测模式掩码 + + public int abDensityDetection; // 是否携带密集度检测信息 + public int nDensityDetection; // 密集度检测检测模式掩码 + + public int abQueueDetection; // 是否携带排队检测信息 + public int nQueueDetection; // 排队检测检测模式掩码 + + public int abClimbDetection; // 是否携带攀高检测信息 + public int nClimbDetection; // 攀高检测模式掩码 + + public int abLeaveDetection; // 是否携带离岗检测信息 + public int nLeaveDetection; // 离岗检测模式掩码 + + public int abVehicleOnPoliceCar; // 是否携带车载警车信息 + public int nVehicleOnPoliceCar; // 车载警车检测模式掩码 + + public int abVehicleOnBus; // 是否携带车载公交信息 + public int nVehicleOnBus; // 车载公交检测模式掩码 + + public int abVehicleOnSchoolBus; // 是否携带车载校车信息 + public int nVehicleOnSchoolBus; // 车载校车检测模式掩码 + + } + + // 交通全局配置对应灯组状态配置 + public static class ENABLE_LIGHT_STATE_INFO extends Structure { + public int bEnable; // 是否启动应用层收到的灯组状态给底层 + } + + // 车道检测类型 + public static class EM_CHECK_TYPE extends Structure { + public int EM_CHECK_TYPE_UNKNOWN = 0; // 不识别的检测类型 + public int EM_CHECK_TYPE_PHYSICAL = 1; // 物理检测 + public int EM_CHECK_TYPE_VIDEO = 2; // 视频检测 + } + + // TRAFFIC_EVENT_CHECK_INFO + public static class TRAFFIC_EVENT_CHECK_INFO extends Structure { + public int abTrafficGate; // 是否携带交通卡口信息 + public int emTrafficGate; // 交通卡口检测类型 EM_CHECK_TYPE + + public int abTrafficJunction; // 是否携带交通路口信息 + public int emTrafficJunction; // 交通路口检测类型 + + public int abTrafficTollGate; // 是否携带新交通卡口信息 + public int emTrafficTollGate; // 新交通卡口检测类型 + + public int abTrafficRunRedLight; // 是否携带交通闯红灯信息 + public int emTrafficRunRedLight; // 交通闯红灯检测类型 + + public int abTrafficRunYellowLight; // 是否携带交通闯黄灯信息 + public int emTrafficRunYellowLight; // 交通闯黄灯检测类型 + + public int abTrafficOverLine; // 是否携带交通压线信息 + public int emTrafficOverLine; // 交通压线检测类型 + + public int abTrafficOverYellowLine; // 是否携带交通压黄线信息 + public int emTrafficOverYellowLine; // 交通压黄线检测类型 + + public int abTrafficRetrograde; // 是否携带交通逆行信息 + public int emTrafficRetrograde; // 交通逆行检测类型 + + public int abTrafficTurnLeft; // 是否携带交通违章左转信息 + public int emTrafficTurnLeft; // 交通违章左转检测类型 + + public int abTrafficTurnRight; // 是否携带交通违章右转信息 + public int emTrafficTurnRight; // 交通路口违章右转类型 + + public int abTrafficU_Turn; // 是否携带交通违章掉头信息 + public int emTrafficU_Turn; // 交通违章掉头检测类型 + + public int abTrafficCrossLane; // 是否携带交通违章变道信息 + public int emTrafficCrossLane; // 交通违章变道检测类型 + + public int abTrafficParking; // 是否携带交通违章停车信息 + public int emTrafficParking; // 交通违章停车检测类型 + + public int abTrafficJam; // 是否携带交通拥堵信息 + public int emTrafficJam; // 交通拥堵检测类型 + + public int abTrafficIdle; // 是否携带交通交通空闲信息 + public int emTrafficIdle; // 交通交通空闲检测类型 + + public int abTrafficWaitingArea; // 是否携带交通违章驶入待行区信息 + public int emTrafficWaitingArea; // 交通违章驶入待行区检测类型 + + public int abTrafficUnderSpeed; // 是否携带交通欠速信息 + public int emTrafficUnderSpeed; // 交通欠速检测类型 + + public int abTrafficOverSpeed; // 是否携带交通超速信息 + public int emTrafficOverSpeed; // 交通超速检测类型 + + public int abTrafficWrongRoute; // 是否携带交通不按车道行驶信息 + public int emTrafficWrongRoute; // 交通不按车道行驶检测类型 + + public int abTrafficYellowInRoute; // 是否携带交通黄牌占道信息 + public int emTrafficYellowInRoute; // 交通黄牌占道检测类型 + + public int abTrafficVehicleInRoute; // 是否携带交通有车占道信息 + public int emTrafficVehicleInRoute; // 交通有车占道检测类型 + + public int abTrafficControl; // 是否携带交通交通管制信息 + public int emTrafficControl; // 交通交通管制检测类型 + + public int abTrafficObjectAlarm; // 是否携带交通指定类型抓拍信息 + public int emTrafficObjectAlarm; // 交通指定类型抓拍检测类型 + + public int abTrafficAccident; // 是否携带交通交通事故信息 + public int emTrafficAccident; // 交通交通事故检测类型 + + public int abTrafficStay; // 是否携带交通交通停留/滞留信息 + public int emTrafficStay; // 交通交通停留/滞留检测类型 + + public int abTrafficPedestrainPriority; // 是否携带交通斑马线行人优先信息 + public int emTrafficPedestrainPriority; // 交通斑马线行人优先检测类型 + + public int abTrafficPedestrain; // 是否携带交通交通行人事件信息 + public int emTrafficPedestrain; // 交通交通行人事件检测类型 + + public int abTrafficThrow; // 是否携带交通交通抛洒物品事件信息 + public int emTrafficThrow; // 交通交通抛洒物品事件检测类型 + + public int abTrafficVehicleInBusRoute; // 是否携带交通违章占道信息 + public int emTrafficVehicleInBusRoute; // 交通违章占道检测类型 + + public int abTrafficBacking; // 是否携带交通违章倒车信息 + public int emTrafficBacking; // 交通违章倒车检测类型 + + public int abTrafficOverStopLine; // 是否携带交通压停止线信息 + public int emTrafficOverStopLine; // 交通压停止线检测类型 + + public int abTrafficParkingOnYellowBox; // 是否携带交通黄网格线抓拍信息 + public int emTrafficParkingOnYellowBox; // 交通黄网格线抓拍检测类型 + + public int abTrafficParkingSpaceParking; // 是否携带交通车位有车信息 + public int emTrafficParkingSpaceParking; // 交通车位有车检测类型 + + public int abTrafficParkingSpaceNoParking; // 是否携带交通车位无车信息 + public int emTrafficParkingSpaceNoParking; // 交通车位无车检测类型 + + public int abTrafficParkingSpaceOverLine; // 是否携带交通车位有车压线信息 + public int emTrafficParkingSpaceOverLine; // 交通车位有车压线检测类型 + + public int abParkingSpaceDetection; // 是否携带交通多停车位状态检测信息 + public int emParkingSpaceDetection; // 交通多停车位状态检测检测类型 + + public int abTrafficRestrictedPlate; // 是否携带交通受限车牌信息 + public int emTrafficRestrictedPlate; // 交通受限车牌检测类型 + + public int abTrafficWithoutSafeBelt; // 是否携带交通不系安全带信息 + public int emTrafficWithoutSafeBelt; // 交通不系安全带检测类型 + + public int abTrafficNoPassing; // 是否携带交通禁行信息 + public int emTrafficNoPassing; // 交通禁行检测类型 + + public int abVehicleAnalyse; // 是否携带交通车辆特征检测分析信息 + public int emVehicleAnalyse; // 交通车辆特征检测类型 + + public int abCrossLineDetection; // 是否携带交通警戒线信息 + public int emCrossLineDetection; // 交通警戒线检测类型 + + public int abCrossFenceDetection; // 是否携带交通穿越围栏信息 + public int emCrossFenceDetection; // 交通穿越围栏检测类型 + + public int abCrossRegionDetection; // 是否携带交通警戒区信息 + public int emCrossRegionDetection; // 交通警戒区检测类型 + + public int abPasteDetection; // 是否携带交通ATM贴条信息 + public int emPasteDetection; // 交通ATM贴条检测类型 + + public int abLeftDetection; // 是否携带交通物品遗留信息 + public int emLeftDetection; // 交通物品遗留检测类型 + + public int abPreservation; // 是否携带交通物品保全信息 + public int emPreservation; // 交通物品保全检测类型 + + public int abTakenAwayDetection; // 是否携带交通物品搬移信息 + public int emTakenAwayDetection; // 交通物品搬移检测类型 + + public int abStayDetection; // 是否携带交通停留/滞留信息 + public int emStayDetection; // 交通停留/滞留检测类型 + + public int abParkingDetection; // 是否携带交通非法停车信息 + public int emParkingDetection; // 交通非法停车检测类型 + + public int abWanderDetection; // 是否携带交通徘徊信息 + public int emWanderDetection; // 交通徘徊检测类型 + + public int abMoveDetection; // 是否携带交通运动信息 + public int emMoveDetection; // 交通运动检测类型 + + public int abTailDetection; // 是否携带交通尾随信息 + public int emTailDetection; // 交通尾随检测类型 + + public int abRioterDetection; // 是否携带交通聚集信息 + public int emRioterDetection; // 交通聚集检测类型 + + public int abFightDetection; // 是否携带交通打架信息 + public int emFightDetection; // 交通打架检测类型 + + public int abRetrogradeDetection; // 是否携带交通逆行信息 + public int emRetrogradeDetection; // 交通逆行检测类型 + + public int abFireDetection; // 是否携带交通火焰信息 + public int emFireDetection; // 交通火焰检测类型 + + public int abSmokeDetection; // 是否携带交通烟雾信息 + public int emSmokeDetection; // 交通烟雾检测类型 + + public int abNumberStat; // 是否携带交通数量统计信息 + public int emNumberStat; // 交通数量统计检测类型 + + public int abVideoAbnormalDetection; // 是否携带交通视频异常信息 + public int emVideoAbnormalDetection; // 交通视频异常检测类型 + + public int abPrisonerRiseDetection; // 是否携带看守所囚犯起身检测信息 + public int emPrisonerRiseDetection; // 看守所囚犯起身检测检测类型 + + public int abFaceDetection; // 是否携带人脸检测信息 + public int emFaceDetection; // 人脸检测检测类型 + + public int abFaceRecognition; // 是否携带人脸识别信息 + public int emFaceRecognition; // 人脸识别检测类型 + + public int abDensityDetection; // 是否携带密集度检测信息 + public int emDensityDetection; // 密集度检测检测类型 + + public int abQueueDetection; // 是否携带排队检测信息 + public int emQueueDetection; // 排队检测检测类型 + + public int abClimbDetection; // 是否携带攀高检测信息 + public int emClimbDetection; // 攀高检测类型 + + public int abLeaveDetection; // 是否携带离岗检测信息 + public int emLeaveDetection; // 离岗检测类型 + + public int abVehicleOnPoliceCar; // 是否携带车载警车信息 + public int emVehicleOnPoliceCar; // 车载警车检测类型 + + public int abVehicleOnBus; // 是否携带车载公交信息 + public int emVehicleOnBus; // 车载公交检测类型 + + public int abVehicleOnSchoolBus; // 是否携带车载校车信息 + public int emVehicleOnSchoolBus; // 车载校车检测类型 + + public int abStandUpDetection; // 是否携带学生起立信息 + public int emStandUpDetection; // 学生起立检测类型 + } + + // MixModeConfig中关于车道配置信息 + public static class MIX_MODE_LANE_INFO extends Structure { + public int nLaneNum; // 车道配置个数 + public TRAFFIC_EVENT_CHECK_INFO[] stCheckInfo = (TRAFFIC_EVENT_CHECK_INFO[]) new TRAFFIC_EVENT_CHECK_INFO().toArray(MAX_LANE_CONFIG_NUMBER); // 车道配置对应事件检测信息 + } + + // MixModeConfig 混合模式违章配置 + public static class MIX_MODE_CONFIG extends Structure { + public int bLaneDiffEnable; // 是否按车道区分 + public MIX_MODE_LANE_INFO stLaneInfo; + public TRAFFIC_EVENT_CHECK_INFO stCheckInfo; + + } + + // CFG_CMD_TRAFFICGLOBAL 交通全局配置配置表 + public static class CFG_TRAFFICGLOBAL_INFO extends Structure + { + public VIOLATIONCODE_INFO stViolationCode; // 违章代码配置表 + public int bEnableRedList; // 使能红名单检测,使能后,名单内车辆违章不上报 + + public int abViolationTimeSchedule; // 是否携带违章抓拍自定义时间配置 + public VIOLATION_TIME_SCHEDULE stViolationTimeSchedule; // 违章抓拍自定义时间配置 + + public int abEnableBlackList; // 是否携带使能黑名单检测信息 + public int bEnableBlackList; // 使能黑名单检测 + + public int abPriority; // 是否携带违章优先级参数 + public int nPriority; // 违章优先级个数 + public byte[] szPriority = new byte[MAX_PRIORITY_NUMBER*CFG_COMMON_STRING_256]; // 违章优先级, 0为最高优先级 + + public int abNamingFormat; // 是否携带图片命名格式参数 + public TRAFFIC_NAMING_FORMAT stNamingFormat; // 图片命名格式参数配置 + + public int abVideoNamingFormat; // 是否携带录像命名格式参数 + public TRAFFIC_NAMING_FORMAT stVideoNamingFormat; // 录像命名格式参数配置 + + public int abCalibration; // 是否携带标定信息 + public TRAFFIC_CALIBRATION_INFO stCalibration; // 标定信息 + + public int abAddress; // 是否携带查询地址参数 + public byte[] szAddress = new byte[CFG_COMMON_STRING_256]; // 查询地址,UTF-8编码 + + public int abTransferPolicy; // 是否携带传输策略参数 + public int emTransferPolicy; // 传输策略, EM_TRANSFER_POLICY + + public int abSupportModeMaskConfig; // 是否携带违章掩码 + public TRAFFIC_EVENT_CHECK_MASK stSupportModeMaskConfig; // 违章类型支持的检测模式掩码配置 + + public int abIsEnableLightState; // 是否携带灯组状态 + public ENABLE_LIGHT_STATE_INFO stIsEnableLightState; // 交通全局配置对应图片命名格式参数配置 + + public int abMixModeInfo; // 是否含有混合模式配置 + public MIX_MODE_CONFIG stMixModeInfo; // 混合模式配置 + } + + // 手动抓拍参数 + public static class MANUAL_SNAP_PARAMETER extends Structure + { + public int nChannel; // 抓图通道,从0开始 + public byte[] bySequence = new byte[64]; // 抓图序列号字符串 + public byte[] byReserved = new byte[60]; // 保留字段 + } + + // 视频统计小计信息 + public static class NET_VIDEOSTAT_SUBTOTAL extends Structure + { + public int nTotal; // 设备运行后人数统计总数 + public int nHour; // 小时内的总人数 + public int nToday; // 当天的总人数 + public int nOSD; // 统计人数,用于OSD显示, 可手动清除 + public byte[] reserved = new byte[252]; + } + + // 视频统计摘要信息 + public static class NET_VIDEOSTAT_SUMMARY extends Structure + { + public int nChannelID; // 通道号 + public byte[] szRuleName = new byte[32]; // 规则名称 + public NET_TIME_EX stuTime; // 统计时间 + public NET_VIDEOSTAT_SUBTOTAL stuEnteredSubtotal; // 进入小计 + public NET_VIDEOSTAT_SUBTOTAL stuExitedSubtotal; // 出去小计 + public byte[] reserved = new byte[512]; + } + + // CLIENT_AttachVideoStatSummary 入参 + public static class NET_IN_ATTACH_VIDEOSTAT_SUM extends Structure + { + public int dwSize; + public int nChannel; // 视频通道号 + public StdCallCallback cbVideoStatSum; // 视频统计摘要信息回调, fVideoStatSumCallBack 回调 + public LLong dwUser; // 用户数据 + + public NET_IN_ATTACH_VIDEOSTAT_SUM() + { + this.dwSize = this.size(); + } + } + // CLIENT_AttachVideoStatSummary 出参 + public static class NET_OUT_ATTACH_VIDEOSTAT_SUM extends Structure + { + public int dwSize; + + public NET_OUT_ATTACH_VIDEOSTAT_SUM() + { + this.dwSize = this.size(); + } + + } + + // 接口(CLIENT_StartFindNumberStat)输入参数 + public static class NET_IN_FINDNUMBERSTAT extends Structure + { + public int dwSize; // 此结构体大小 + public int nChannelID; // 要进行查询的通道号 + public NET_TIME stStartTime; // 开始时间 暂时精确到小时 + public NET_TIME stEndTime; // 结束时间 暂时精确到小时 + public int nGranularityType; // 查询粒度0:分钟,1:小时,2:日,3:周,4:月,5:季,6:年 + public int nWaittime; // 等待接收数据的超时时间 + public int nPlanID; // 计划ID,仅球机有效,从1开始 + + public NET_IN_FINDNUMBERSTAT() { + this.dwSize = this.size(); + } + } + + // 接口(CLIENT_StartFindNumberStat)输出参数 + public static class NET_OUT_FINDNUMBERSTAT extends Structure + { + public int dwSize; // 此结构体大小 + public int dwTotalCount; // 符合此次查询条件的结果总条数 + + public NET_OUT_FINDNUMBERSTAT() { + this.dwSize = this.size(); + } + } + + + // 接口(CLIENT_DoFindNumberStat)输入参数 + public static class NET_IN_DOFINDNUMBERSTAT extends Structure + { + public int dwSize; // 此结构体大小 + public int nBeginNumber; // [0, totalCount-1], 查询起始序号,表示从beginNumber条记录开始,取count条记录返回; + public int nCount; // 每次查询的流量统计条数 + public int nWaittime; // 等待接收数据的超时时间 + + public NET_IN_DOFINDNUMBERSTAT() { + this.dwSize = this.size(); + } + } + + public static class NET_NUMBERSTAT extends Structure + { + public int dwSize; + public int nChannelID; //统计通道号 + public byte[] szRuleName = new byte[NET_CHAN_NAME_LEN]; //规则名称 + public NET_TIME stuStartTime; //开始时间 + public NET_TIME stuEndTime; //结束时间 + public int nEnteredSubTotal; //进入人数小计 + public int nExitedSubtotal; //出去人数小计 + public int nAvgInside; //平均保有人数(除去零值) + public int nMaxInside; //最大保有人数 + public int nEnteredWithHelmet; //戴安全帽进入人数小计 + public int nEnteredWithoutHelmet; //不戴安全帽进入人数小计 + public int nExitedWithHelmet; //戴安全帽出去人数小计 + public int nExitedWithoutHelmet; //不戴安全帽出去人数小计 + + public NET_NUMBERSTAT() { + this.dwSize = this.size(); + } + + public static class ByReference extends NET_NUMBERSTAT implements Structure.ByReference { } + } + + // 接口(CLIENT_DoFindNumberStat)输出参数 + public static class NET_OUT_DOFINDNUMBERSTAT extends Structure + { + public int dwSize; // 此结构体大小 + public int nCount; // 查询返回人数统计信息个数 + public Pointer pstuNumberStat; // 返回人数统计信息数组, NET_NUMBERSTAT 类型 + public int nBufferLen; // 用户申请的内存大小,以NET_NUMBERSTAT中的dwsize大小为单位 + + public NET_OUT_DOFINDNUMBERSTAT() { + this.dwSize = this.size(); + } + } + + public static class CONNECT_STATE extends Structure + { + public static final int CONNECT_STATE_UNCONNECT = 0; + public static final int CONNECT_STATE_CONNECTING = 1; + public static final int CONNECT_STATE_CONNECTED = 2; + public static final int CONNECT_STATE_ERROR = 255; + } + + // 虚拟摄像头状态查询 + public static class NET_DEV_VIRTUALCAMERA_STATE_INFO extends Structure + { + public int nStructSize; //结构体大小 + public int nChannelID; //通道号 + public int emConnectState; //连接状态, 取值范围为CONNECT_STATE中的值 + public int uiPOEPort; //此虚拟摄像头所连接的POE端口号,0表示不是POE连接, 类型为unsigned int + public byte[] szDeviceName = new byte[64]; //设备名称 + public byte[] szDeviceType = new byte[128]; //设备类型 + public byte[] szSystemType = new byte[128]; //系统版本 + public byte[] szSerialNo = new byte[NET_SERIALNO_LEN];//序列号 + public int nVideoInput; //视频输入 + public int nAudioInput; //音频输入 + public int nAlarmOutput; //外部报警 + + public NET_DEV_VIRTUALCAMERA_STATE_INFO() + { + this.nStructSize = this.size(); + } + } + + // 录像文件类型 + public static class NET_RECORD_TYPE extends Structure + { + public final static int NET_RECORD_TYPE_ALL = 0; // 所有录像 + public final static int NET_RECORD_TYPE_NORMAL = 1; // 普通录像 + public final static int NET_RECORD_TYPE_ALARM = 2; // 外部报警录像 + public final static int NET_RECORD_TYPE_MOTION = 3; // 动检报警录像 + } + + // 对讲方式 + public static class EM_USEDEV_MODE extends Structure + { + public static final int NET_TALK_CLIENT_MODE = 0; // 设置客户端方式进行语音对讲 + public static final int NET_TALK_SERVER_MODE = 1; // 设置服务器方式进行语音对讲 + public static final int NET_TALK_ENCODE_TYPE = 2; // 设置语音对讲编码格式(对应 NETDEV_TALKDECODE_INFO) + public static final int NET_ALARM_LISTEN_MODE = 3; // 设置报警订阅方式 + public static final int NET_CONFIG_AUTHORITY_MODE = 4; // 设置通过权限进行配置管理 + public static final int NET_TALK_TALK_CHANNEL = 5; // 设置对讲通道(0~MaxChannel-1) + public static final int NET_RECORD_STREAM_TYPE = 6; // 设置待查询及按时间回放的录像码流类型(0-主辅码流,1-主码流,2-辅码流) + public static final int NET_TALK_SPEAK_PARAM = 7; // 设置语音对讲喊话参数,对应结构体 NET_SPEAK_PARAM + public static final int NET_RECORD_TYPE = 8; // 设置按时间录像回放及下载的录像文件类型(详见 NET_RECORD_TYPE) + public static final int NET_TALK_MODE3 = 9; // 设置三代设备的语音对讲参数, 对应结构体 NET_TALK_EX + public static final int NET_PLAYBACK_REALTIME_MODE = 10; // 设置实时回放功能(0-关闭,1开启) + public static final int NET_TALK_TRANSFER_MODE = 11; // 设置语音对讲是否为转发模式, 对应结构体 NET_TALK_TRANSFER_PARAM + public static final int NET_TALK_VT_PARAM = 12; // 设置VT对讲参数, 对应结构体 NET_VT_TALK_PARAM + public static final int NET_TARGET_DEV_ID = 13; // 设置目标设备标示符, 用以查询新系统能力(非0-转发系统能力消息) + } + + // 语音编码类型 + public static class NET_TALK_CODING_TYPE extends Structure + { + public static final int NET_TALK_DEFAULT = 0; // 无头PCM + public static final int NET_TALK_PCM = 1; // 带头PCM + public static final int NET_TALK_G711a = 2; // G711a + public static final int NET_TALK_AMR = 3; // AMR + public static final int NET_TALK_G711u = 4; // G711u + public static final int NET_TALK_G726 = 5; // G726 + public static final int NET_TALK_G723_53 = 6; // G723_53 + public static final int NET_TALK_G723_63 = 7; // G723_63 + public static final int NET_TALK_AAC = 8; // AAC + public static final int NET_TALK_OGG = 9; // OGG + public static final int NET_TALK_G729 = 10; // G729 + public static final int NET_TALK_MPEG2 = 11; // MPEG2 + public static final int NET_TALK_MPEG2_Layer2 = 12; // MPEG2-Layer2 + public static final int NET_TALK_G722_1 = 13; // G.722.1 + public static final int NET_TALK_ADPCM = 21; // ADPCM + public static final int NET_TALK_MP3 = 22; // MP3 + } + + // 设备支持的语音对讲类型 + public static class NETDEV_TALKFORMAT_LIST extends Structure + { + public int nSupportNum; // 个数 + public NETDEV_TALKDECODE_INFO[] type = (NETDEV_TALKDECODE_INFO[])new NETDEV_TALKDECODE_INFO().toArray(64); // 编码类型 + + public byte[] reserved = new byte[64]; + } + + // 语音编码信息 + public static class NETDEV_TALKDECODE_INFO extends Structure + { + public int encodeType; // 编码类型, encodeType对应NET_TALK_CODING_TYPE + public int nAudioBit; // 位数,如8或16, 目前只能是16 + public int dwSampleRate; // 采样率,如8000或16000, 目前只能是16000 + public int nPacketPeriod; // 打包周期, 单位ms, 目前只能是25 + public byte[] reserved = new byte[60]; + } + + // 语音对讲喊话参数 + public static class NET_SPEAK_PARAM extends Structure + { + public int dwSize; // 结构体大小 + public int nMode; // 0:对讲(默认模式),1:喊话;从喊话切换到对讲要重新设置 + public int nSpeakerChannel; // 扬声器通道号,喊话时有效 + public boolean bEnableWait; // 开启对讲时是否等待设备的响应,默认不等待.TRUE:等待;FALSE:不等待 + // 超时时间由CLIENT_SetNetworkParam设置,对应NET_PARAM的nWaittime字段 + public NET_SPEAK_PARAM() + { + this.dwSize = this.size(); + } + } + + // 是否开启语音对讲的转发模式 + public static class NET_TALK_TRANSFER_PARAM extends Structure + { + public int dwSize; + public boolean bTransfer; // 是否开启语音对讲转发模式, TRUE: 开启转发 + + public NET_TALK_TRANSFER_PARAM() + { + this.dwSize = this.size(); + } + } + + // 预览类型,对应CLIENT_RealPlayEx接口 + public static class NET_RealPlayType extends Structure + { + public static final int NET_RType_Realplay = 0; // 实时预览 + public static final int NET_RType_Multiplay = 1; // 多画面预览 + public static final int NET_RType_Realplay_0 = 2; // 实时监视-主码流 ,等同于NET_RType_Realplay + public static final int NET_RType_Realplay_1 = 3; // 实时监视-从码流1 + public static final int NET_RType_Realplay_2 = 4; // 实时监视-从码流2 + public static final int NET_RType_Realplay_3 = 5; // 实时监视-从码流3 + public static final int NET_RType_Multiplay_1 = 6; // 多画面预览-1画面 + public static final int NET_RType_Multiplay_4 = 7; // 多画面预览-4画面 + public static final int NET_RType_Multiplay_8 = 8; // 多画面预览-8画面 + public static final int NET_RType_Multiplay_9 = 9; // 多画面预览-9画面 + public static final int NET_RType_Multiplay_16 = 10; // 多画面预览-16画面 + public static final int NET_RType_Multiplay_6 = 11; // 多画面预览-6画面 + public static final int NET_RType_Multiplay_12 = 12; // 多画面预览-12画面 + public static final int NET_RType_Multiplay_25 = 13; // 多画面预览-25画面 + public static final int NET_RType_Multiplay_36 = 14; // 多画面预览-36画面 + public static final int NET_RType_Realplay_Test = 255; // 带宽测试码流 + } + + // 回调视频数据帧的帧参数结构体 + public static class tagVideoFrameParam extends Structure + { + public byte encode; // 编码类型 + public byte frametype; // I = 0, P = 1, B = 2... + public byte format; // PAL - 0, NTSC - 1 + public byte size; // CIF - 0, HD1 - 1, 2CIF - 2, D1 - 3, VGA - 4, QCIF - 5, QVGA - 6 , + // SVCD - 7,QQVGA - 8, SVGA - 9, XVGA - 10,WXGA - 11,SXGA - 12,WSXGA - 13,UXGA - 14,WUXGA - 15, LFT - 16, 720 - 17, 1080 - 18 ,1_3M-19 + // 2M-20, 5M-21;当size=255时,成员变量width,height 有效 + public int fourcc; // 如果是H264编码则总为0,否则值为*( DWORD*)"DIVX",即0x58564944 + public short width; // 宽,单位是像素,当size=255时有效 + public short height; // 高,单位是像素,当size=255时有效 + public NET_TIME struTime; // 时间信息 + } + + // 回调音频数据帧的帧参数结构体 + public static class tagCBPCMDataParam extends Structure + { + public byte channels; // 声道数 + public byte samples; // 采样 0 - 8000, 1 - 11025, 2 - 16000, 3 - 22050, 4 - 32000, 5 - 44100, 6 - 48000 + public byte depth; // 采样深度 取值8或者16等。直接表示 + public byte param1; // 0 - 指示无符号,1-指示有符号 + public int reserved; // 保留 + } + + // 视频监视断开事件类型 + public static class EM_REALPLAY_DISCONNECT_EVENT_TYPE extends Structure + { + public static final int DISCONNECT_EVENT_REAVE = 0; // 表示高级用户抢占低级用户资源 + public static final int DISCONNECT_EVENT_NETFORBID = 1; // 禁止入网 + public static final int DISCONNECT_EVENT_SUBCONNECT = 2; // 动态子链接断开 + } + + // 电池电压过低报警 + public static class ALARM_BATTERYLOWPOWER_INFO extends Structure + { + public int dwSize; //结构体大小 + public int nAction; //0:开始1:停止 + public int nBatteryLeft; //剩余电量百分比,单位% + public NET_TIME stTime; //事件发生时间 + public int nChannelID; //通道号,标识子设备电池,从0开始 + + public ALARM_BATTERYLOWPOWER_INFO() + { + this.dwSize = this.size(); + } + } + + // 温度过高报警 + public static class ALARM_TEMPERATURE_INFO extends Structure + { + public int dwSize; //结构体大小 + public byte[] szSensorName = new byte[NET_MACHINE_NAME_NUM];//温度传感器名称 + public int nChannelID; //通道号 + public int nAction; //0:开始1:停止 + public float fTemperature; //当前温度值,单位摄氏度 + public NET_TIME stTime; //事件发生时间 + + public ALARM_TEMPERATURE_INFO() + { + this.dwSize = this.size(); + } + } + + // 普通报警信息 + public static class NET_CLIENT_STATE_EX extends Structure + { + public int channelcount; + public int alarminputcount; + public byte[] alarm = new byte[32]; // 外部报警 + public byte[] motiondection = new byte[32]; // 动态检测 + public byte[] videolost = new byte[32]; // 视频丢失 + public byte[] bReserved = new byte[32]; + } + + // 视频遮挡报警状态信息对应结构体 + public static class NET_CLIENT_VIDEOBLIND_STATE extends Structure + { + public int dwSize; + public int channelcount; + public int[] dwAlarmState = new int[NET_MAX_CHANMASK];//每一个int按位表示32通道的报警状态,0-表示无报警,1-表示有报警 + + public NET_CLIENT_VIDEOBLIND_STATE() + { + this.dwSize = this.size(); + } + } + + // 视频丢失报警状态信息对应结构体 + public static class NET_CLIENT_VIDEOLOST_STATE extends Structure + { + public int dwSize; + public int channelcount; + public int[] dwAlarmState = new int[NET_MAX_CHANMASK];//每一个int按位表示32通道的报警状态(只有dwAlarmState[0]有效),0-表示无报警,1-表示有报警 + + public NET_CLIENT_VIDEOLOST_STATE() + { + this.dwSize = this.size(); + } + } + + // 门禁开门 CLIENT_ControlDevice接口的 CTRLTYPE_CTRL_ACCESS_OPEN 命令参数 + public static class NET_CTRL_ACCESS_OPEN extends Structure { + public int dwSize; + public int nChannelID; // 通道号(0开始) + public Pointer szTargetID; // 转发目标设备ID,为NULL表示不转发 + public byte[] szUserID = new byte[MAX_COMMON_STRING_32];//远程用户ID + public int emOpenDoorType; // 开门方式, 参考 EM_OPEN_DOOR_TYPE + + public NET_CTRL_ACCESS_OPEN() { + this.dwSize = this.size(); + } + } + + // 门禁控制--开门方式 + public static class EM_OPEN_DOOR_TYPE extends Structure + { + public static final int EM_OPEN_DOOR_TYPE_UNKNOWN = 0; + public static final int EM_OPEN_DOOR_TYPE_REMOTE = 1; // 远程开门 + public static final int EM_OPEN_DOOR_TYPE_LOCAL_PASSWORD = 2; // 本地密码开门 + public static final int EM_OPEN_DOOR_TYPE_LOCAL_CARD = 3; // 本地刷卡开门 + public static final int EM_OPEN_DOOR_TYPE_LOCAL_BUTTON = 4; // 本地按钮开门 + } + + // 门禁关门CLIENT_ControlDevice接口的 CTRLTYPE_CTRL_ACCESS_CLOSE 命令参数 + public static class NET_CTRL_ACCESS_CLOSE extends Structure + { + public int dwSize; + public int nChannelID;//通道号(0开始) + + public NET_CTRL_ACCESS_CLOSE() { + this.dwSize = this.size(); + } + } + + // 门禁状态类型 + public static class EM_NET_DOOR_STATUS_TYPE extends Structure + { + public static final int EM_NET_DOOR_STATUS_UNKNOWN=0; + public static final int EM_NET_DOOR_STATUS_OPEN=EM_NET_DOOR_STATUS_UNKNOWN+1; //门打开 + public static final int EM_NET_DOOR_STATUS_CLOSE=EM_NET_DOOR_STATUS_OPEN+1; //门关闭 + public static final int EM_NET_DOOR_STATUS_BREAK=EM_NET_DOOR_STATUS_CLOSE+1; //门异常打开 + } + + // 门禁状态信息(CLIENT_QueryDevState 接口输入参数) + public static class NET_DOOR_STATUS_INFO extends Structure + { + public int dwSize; + public int nChannel;//门禁通道号 + public int emStateType;//门禁状态信息, 对应枚举EM_NET_DOOR_STATUS_TYPE + + public NET_DOOR_STATUS_INFO() { + this.dwSize = this.size(); + } + } + + // 开启道闸参数(对应 CTRLTYPE_CTRL_OPEN_STROBE 命令) + public static class NET_CTRL_OPEN_STROBE extends Structure + { + public int dwSize; + public int nChannelId; // 通道号 + public byte[] szPlateNumber = new byte[64]; // 车牌号码 + + public NET_CTRL_OPEN_STROBE() { + this.dwSize = this.size(); + } + } + + // 关闭道闸参数(对应 CTRLTYPE_CTRL_CLOSE_STROBE 命令) + public static class NET_CTRL_CLOSE_STROBE extends Structure + { + public int dwSize; + public int nChannelId; // 通道号 + + public NET_CTRL_CLOSE_STROBE() { + this.dwSize = this.size(); + } + } + + // 报警状态 (对应 CTRLTYPE_TRIGGER_ALARM_OUT 命令) + public static class ALARMCTRL_PARAM extends Structure + { + public int dwSize; + public int nAlarmNo; // 报警通道号,从0开始 + public int nAction; // 1:触发报警,0:停止报警 + + public ALARMCTRL_PARAM() { + this.dwSize = this.size(); + } + } + + // 查询 IVS 前端设备入参 + public static class NET_IN_IVS_REMOTE_DEV_INFO extends Structure + { + public int dwSize; // 该结构体大小 + public int nChannel; // 通道号 + + public NET_IN_IVS_REMOTE_DEV_INFO() { + this.dwSize = this.size(); + } + } + + // 查询 IVS 前端设备出参 + public static class NET_OUT_IVS_REMOTE_DEV_INFO extends Structure + { + public int dwSize; // 该结构体大小 + public int nPort; // 端口 + public byte[] szIP = new byte[64]; // 设备IP + public byte[] szUser = new byte[64]; // 用户名 + public byte[] szPassword = new byte[64]; // 密码 + public byte[] szAddress = new byte[128]; // 机器部署地点 + + public NET_OUT_IVS_REMOTE_DEV_INFO() { + this.dwSize = this.size(); + } + } + + // 传感器感应方式枚举类型 + public static class NET_SENSE_METHOD extends Structure + { + public static final int NET_SENSE_UNKNOWN = -1;//未知类型 + public static final int NET_SENSE_DOOR = 0; //门磁 + public static final int NET_SENSE_PASSIVEINFRA = 1; //被动红外 + public static final int NET_SENSE_GAS = 2; //气感 + public static final int NET_SENSE_SMOKING = 3; //烟感 + public static final int NET_SENSE_WATER = 4; //水感 + public static final int NET_SENSE_ACTIVEFRA = 5; //主动红外 + public static final int NET_SENSE_GLASS = 6; //玻璃破碎 + public static final int NET_SENSE_EMERGENCYSWITCH = 7; //紧急开关 + public static final int NET_SENSE_SHOCK = 8; //震动 + public static final int NET_SENSE_DOUBLEMETHOD = 9; //双鉴(红外+微波) + public static final int NET_SENSE_THREEMETHOD = 10; //三技术 + public static final int NET_SENSE_TEMP = 11; //温度 + public static final int NET_SENSE_HUMIDITY = 12; //湿度 + public static final int NET_SENSE_WIND = 13; //风速 + public static final int NET_SENSE_CALLBUTTON = 14; //呼叫按钮 + public static final int NET_SENSE_GASPRESSURE = 15; //气体压力 + public static final int NET_SENSE_GASCONCENTRATION = 16; //燃气浓度 + public static final int NET_SENSE_GASFLOW = 17; //气体流量 + public static final int NET_SENSE_OTHER = 18; //其他 + public static final int NET_SENSE_OIL = 19; //油量检测,汽油、柴油等车辆用油检测 + public static final int NET_SENSE_MILEAGE = 20; //里程数检测 + public static final int NET_SENSE_URGENCYBUTTON = 21; //紧急按钮 + public static final int NET_SENSE_STEAL = 22; //盗窃 + public static final int NET_SENSE_PERIMETER = 23; //周界 + public static final int NET_SENSE_PREVENTREMOVE = 24; //防拆 + public static final int NET_SENSE_DOORBELL = 25; //门铃 + public static final int NET_SENSE_ALTERVOLT = 26; //交流电压传感器 + public static final int NET_SENSE_DIRECTVOLT = 27; //直流电压传感器 + public static final int NET_SENSE_ALTERCUR = 28; //交流电流传感器 + public static final int NET_SENSE_DIRECTCUR = 29; //直流电流传感器 + public static final int NET_SENSE_RSUGENERAL = 30; //高新兴通用模拟量4~20mA或0~5V + public static final int NET_SENSE_RSUDOOR = 31; //高新兴门禁感应 + public static final int NET_SENSE_RSUPOWEROFF = 32; //高新兴断电感应 + public static final int NET_SENSE_TEMP1500 = 33;//1500温度传感器 + public static final int NET_SENSE_TEMPDS18B20 = 34;//DS18B20温度传感器 + public static final int NET_SENSE_HUMIDITY1500 = 35; //1500湿度传感器 + public static final int NET_SENSE_NUM = 36; //枚举类型总数 + } + + //-------------------------------报警属性--------------------------------- + // 云台联动 + public static class NET_PTZ_LINK extends Structure + { + public int iType;//0-None,1-Preset,2-Tour,3-Pattern + public int iValue; + } + + ////////////////////////////////HDVR专用////////////////////////////////// + // 报警联动扩展结构体 + public static class NET_MSG_HANDLE_EX extends Structure + { + /* 消息处理方式,可以同时多种处理方式,包括 + * 0x00000001 - 报警上传 + * 0x00000002 - 联动录象 + * 0x00000004 - 云台联动 + * 0x00000008 - 发送邮件 + * 0x00000010 - 本地轮巡 + * 0x00000020 - 本地提示 + * 0x00000040 - 报警输出 + * 0x00000080 - Ftp上传 + * 0x00000100 - 蜂鸣 + * 0x00000200 - 语音提示 + * 0x00000400 - 抓图 + */ + /*当前报警所支持的处理方式,按位掩码表示*/ + public int dwActionMask; + /*触发动作,按位掩码表示,具体动作所需要的参数在各自的配置中体现*/ + public int dwActionFlag; + /*报警触发的输出通道,报警触发的输出,为1表示触发该输出*/ + public byte[] byRelAlarmOut = new byte[NET_MAX_ALARMOUT_NUM_EX]; + public int dwDuration;/*报警持续时间*/ + /*联动录象*/ + public byte[] byRecordChannel = new byte[NET_MAX_VIDEO_IN_NUM_EX];/*报警触发的录象通道,为1表示触发该通道*/ + public int dwRecLatch;/*录象持续时间*/ + /*抓图通道*/ + public byte[] bySnap = new byte[NET_MAX_VIDEO_IN_NUM_EX]; + /*轮巡通道*/ + public byte[] byTour = new byte[NET_MAX_VIDEO_IN_NUM_EX];/*轮巡通道0-31路*/ + /*云台联动*/ + public NET_PTZ_LINK[] struPtzLink = (NET_PTZ_LINK[])new NET_PTZ_LINK().toArray(NET_MAX_VIDEO_IN_NUM_EX); + public int dwEventLatch;/*联动开始延时时间,s为单位,范围是0~15,默认值是0*/ + /*报警触发的无线输出通道,报警触发的输出,为1表示触发该输出*/ + public byte[] byRelWIAlarmOut = new byte[NET_MAX_ALARMOUT_NUM_EX]; + public byte bMessageToNet; + public byte bMMSEn;/*短信报警使能*/ + public byte bySnapshotTimes;/*短信发送抓图张数*/ + public byte bMatrixEn;/*!<矩阵使能*/ + public int dwMatrix;/*!<矩阵掩码*/ + public byte bLog;/*!<日志使能,目前只有在WTN动态检测中使用*/ + public byte bSnapshotPeriod;/*!<抓图帧间隔,每隔多少帧抓一张图片,一定时间内抓拍的张数还与抓图帧率有关。0表示不隔帧,连续抓拍。*/ + public byte[] byTour2 = new byte[NET_MAX_VIDEO_IN_NUM_EX];/*轮巡通道32-63路*/ + public byte byEmailType;/*<0,图片附件,1,录像附件>*/ + public byte byEmailMaxLength;/*<附件录像时的最大长度,单位MB>*/ + public byte byEmailMaxTime;/*<附件是录像时最大时间长度,单位秒>*/ + public byte[] byReserved = new byte[475]; + } + + public static class EM_NET_DEFENCE_AREA_TYPE extends Structure + { + public static final int EM_NET_DEFENCE_AREA_TYPE_UNKNOW = 0; //未知 + public static final int EM_NET_DEFENCE_AREA_TYPE_INTIME = 1; //即时防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_DELAY = 2; //延时防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_FULLDAY = 3; //24小时防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_Follow = 4; //跟随防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_MEDICAL = 5; //医疗紧急防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_PANIC = 6; //恐慌防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_FIRE = 7; //火警防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_FULLDAYSOUND = 8; //24小时有声防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_FULLDATSLIENT = 9; //24小时无声防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_ENTRANCE1 = 10; //出入防区1 + public static final int EM_NET_DEFENCE_AREA_TYPE_ENTRANCE2 = 11; //出入防区2 + public static final int EM_NET_DEFENCE_AREA_TYPE_INSIDE = 12; //内部防区 + public static final int EM_NET_DEFENCE_AREA_TYPE_OUTSIDE = 13; //外部防区 + public static final int EN_NET_DEFENCE_AREA_TYPE_PEOPLEDETECT = 14; //人员检测防区 + } + + // 本地报警事件(对NET_ALARM_ALARM_EX升级) + public static class ALARM_ALARM_INFO_EX2 extends Structure + { + public int dwSize; + public int nChannelID; //通道号 + public int nAction; //0:开始, 1:停止 + public NET_TIME stuTime; //报警事件发生的时间 + public int emSenseType; //传感器类型, 取值范围为 NET_SENSE_METHOD 中的值 + public NET_MSG_HANDLE_EX stuEventHandler; //联动信息 + public int emDefenceAreaType; //防区类型, 取值类型为EM_NET_DEFENCE_AREA_TYPE中的值 + public int nEventID; //事件ID + public byte[] szName = new byte[NET_COMMON_STRING_32]; // 通道名称 + public int nCount; // 事件发生次数 + + public ALARM_ALARM_INFO_EX2() { + this.dwSize = this.size(); + } + } + + // 布撤防状态变化事件的信息 + public static class ALARM_ARMMODE_CHANGE_INFO extends Structure + { + public int dwSize; + public NET_TIME stuTime; // 报警事件发生的时间 + public int bArm; // 变化后的状态,对应 NET_ALARM_MODE + public int emSceneMode; // 情景模式,对应 NET_SCENE_MODE + public int dwID; // ID号, 遥控器编号或键盘地址, emTriggerMode为NET_EM_TRIGGER_MODE_NET类型时为0 + public int emTriggerMode; // 触发方式,对应 NET_EM_TRIGGER_MODE + + public ALARM_ARMMODE_CHANGE_INFO() { + this.dwSize = this.size(); + } + } + + // 布撤防模式 + public static class NET_ALARM_MODE extends Structure + { + public static final int NET_ALARM_MODE_UNKNOWN = -1; // 未知 + public static final int NET_ALARM_MODE_DISARMING = 0; // 撤防 + public static final int NET_ALARM_MODE_ARMING = 1; // 布防 + public static final int NET_ALARM_MODE_FORCEON = 2; // 强制布防 + public static final int NET_ALARM_MODE_PARTARMING = 3; // 部分布防 + } + + // 布撤防场景模式 + public static class NET_SCENE_MODE extends Structure + { + public static final int NET_SCENE_MODE_UNKNOWN = 0; // 未知场景 + public static final int NET_SCENE_MODE_OUTDOOR = 1; // 外出模式 + public static final int NET_SCENE_MODE_INDOOR = 2; // 室内模式 + public static final int NET_SCENE_MODE_WHOLE = 3; // 全局模式 + public static final int NET_SCENE_MODE_RIGHTNOW = 4; // 立即模式 + public static final int NET_SCENE_MODE_SLEEPING = 5; // 就寝模式 + public static final int NET_SCENE_MODE_CUSTOM = 6; // 自定义模式 + } + + // 触发方式 + public static class NET_EM_TRIGGER_MODE extends Structure + { + public static final int NET_EM_TRIGGER_MODE_UNKNOWN = 0; + public static final int NET_EM_TRIGGER_MODE_NET = 1; // 网络用户(平台或Web) + public static final int NET_EM_TRIGGER_MODE_KEYBOARD = 2; // 键盘 + public static final int NET_EM_TRIGGER_MODE_REMOTECONTROL = 3; // 遥控器 + } + + // 紧急救助事件详情 + public static class ALARM_RCEMERGENCY_CALL_INFO extends Structure + { + public int dwSize; + public int nAction; // -1:未知 0:开始 1:停止 + public int emType; // 紧急类型,对应 EM_RCEMERGENCY_CALL_TYPE + public NET_TIME stuTime; // 事件发生时间 + public int emMode; // 报警方式,对应 EM_RCEMERGENCY_MODE_TYPE + public int dwID; // 用于标示不同的紧急事件(只有emMode是遥控器类型时有效, 表示遥控器的编号, 0表示无效ID) + + public ALARM_RCEMERGENCY_CALL_INFO() { + this.dwSize = this.size(); + } + } + + // 紧急救助事件类型 + public static class EM_RCEMERGENCY_CALL_TYPE extends Structure + { + public static final int EM_RCEMERGENCY_CALL_UNKNOWN = 0; + public static final int EM_RCEMERGENCY_CALL_FIRE = 1; // 火警 + public static final int EM_RCEMERGENCY_CALL_DURESS = 2; // 胁迫 + public static final int EM_RCEMERGENCY_CALL_ROBBER = 3; // 匪警 + public static final int EM_RCEMERGENCY_CALL_MEDICAL = 4; // 医疗 + public static final int EM_RCEMERGENCY_CALL_EMERGENCY = 5; // 紧急 + } + + // 报警方式 + public static class EM_RCEMERGENCY_MODE_TYPE extends Structure + { + public static final int EM_RCEMERGENCY_MODE_UNKNOWN = 0; + public static final int EM_RCEMERGENCY_MODE_KEYBOARD = 1; // 键盘 + public static final int EM_RCEMERGENCY_MODE_WIRELESS_CONTROL = 2; // 遥控器 + } + + ///////////////////////////////////////////////////// + ////////用户信息管理对应接口CLIENT_QueryUserInfoNew///////// + // 用户信息表 + public static class USER_MANAGE_INFO_NEW extends Structure { + public int dwSize; // 结构体大小 + public int dwRightNum; // 权限信息有效个数 + public OPR_RIGHT_NEW[] rightList = (OPR_RIGHT_NEW[])new OPR_RIGHT_NEW().toArray(NET_NEW_MAX_RIGHT_NUM); // 权限信息,有效个数由 dwRightNum 成员决定, 用户权限个数上限NET_NEW_MAX_RIGHT_NUM = 1024 + public int dwGroupNum; // 用户组信息有效个数 + public USER_GROUP_INFO_NEW[] groupList = (USER_GROUP_INFO_NEW[])new USER_GROUP_INFO_NEW().toArray(NET_MAX_GROUP_NUM); // 用户组信息,此参数废弃,请使用groupListEx + public int dwUserNum; // 用户数 + public USER_INFO_NEW[] userList = (USER_INFO_NEW[])new USER_INFO_NEW().toArray(NET_MAX_USER_NUM); // 用户列表, 用户个数上限NET_MAX_USER_NUM=200 + public int dwFouctionMask; // 掩码: 0x00000001 - 支持用户复用, 0x00000002 - 密码修改需要校验 + public byte byNameMaxLength; // 支持的用户名最大长度 + public byte byPSWMaxLength; // 支持的密码最大长度 + public byte[] byReserve = new byte[254]; + public USER_GROUP_INFO_EX2[] groupListEx = (USER_GROUP_INFO_EX2[])new USER_GROUP_INFO_EX2().toArray(NET_MAX_GROUP_NUM); // 用户组信息扩展, 用户组个数上限NET_MAX_GROUP_NUM=20 + + public USER_MANAGE_INFO_NEW() { + this.dwSize = this.size(); + } + } + + // 权限信息 + public static class OPR_RIGHT_NEW extends Structure { + public int dwSize; //结构体大小 + public int dwID; //权限ID,每个 权限都有各自的ID + public byte[] name = new byte[NET_RIGHT_NAME_LENGTH]; //名称 权限名长度 NET_RIGHT_NAME_LENGTH=32 + public byte[] memo = new byte[NET_MEMO_LENGTH]; //说明备注长度NET_MEMO_LENGTH=32 + + public OPR_RIGHT_NEW() { + this.dwSize = this.size(); + } + } + + // 用户组信息 + public static class USER_GROUP_INFO_NEW extends Structure { + public int dwSize; + public int dwID; // 用户组ID, 每个用户组都有各自的ID + public byte[] name = new byte[NET_USER_NAME_LENGTH_EX]; // 用户组名称/NET_USER_NAME_LENGTH_EX=16 + public int dwRightNum; // 用户组权限有效个数 + public int[] rights = new int[NET_NEW_MAX_RIGHT_NUM]; // 用户组支持权限数组 + public byte[] memo = new byte[NET_MEMO_LENGTH]; // 用户组备注说明 + public USER_GROUP_INFO_NEW() { + this.dwSize = this.size(); + } + } + + // 用户组信息扩展,用户组名加长 + public static class USER_GROUP_INFO_EX2 extends Structure { + public int dwSize; // 结构体大小 + public int dwID; // ID + public byte[] name = new byte[NET_NEW_USER_NAME_LENGTH]; // 用户名 长度NET_NEW_USER_NAME_LENGTH=128 + public int dwRightNum; // 权限数量 + public int[] rights = new int[NET_NEW_MAX_RIGHT_NUM]; // 用户权限 个数上限 NET_NEW_MAX_RIGHT_NUM = 1024 + public byte[] memo = new byte[NET_MEMO_LENGTH]; // 说明, 备注长度NET_MEMO_LENGTH=32 + + public USER_GROUP_INFO_EX2() { + this.dwSize = this.size(); + } + } + + // 用户信息结构体 + public static class USER_INFO_NEW extends Structure { + public int dwSize; // 结构体大小 + public int dwID; // 用户ID + public int dwGroupID; // 用户组组ID + public byte[] name = new byte[NET_NEW_USER_NAME_LENGTH]; // 用户名称,长度NET_NEW_USER_NAME_LENGTH=128 + public byte[] passWord = new byte[NET_NEW_USER_PSW_LENGTH]; // 用户密码,NET_NEW_USER_PSW_LENGTH=128 + public int dwRightNum; // 用户权限有效个数 + public int[] rights = new int[NET_NEW_MAX_RIGHT_NUM]; // 用户支持权限数组,个数上限 NET_NEW_MAX_RIGHT_NUM = 1024 + public byte[] memo = new byte[NET_MEMO_LENGTH]; // 用户备注说明, 备注长度NET_MEMO_LENGTH=32 + public int dwFouctionMask; // 掩码,0x00000001 - 支持用户复用 + public NET_TIME stuTime; // 最后修改时间 + public byte byIsAnonymous; // 是否可以匿名登录, 0:不可匿名登录, 1: 可以匿名登录 + public byte[] byReserve = new byte[7]; // 保留字节 + + public USER_INFO_NEW() { + this.dwSize = this.size(); + } + } + + + //------------------------白名单相关结构体------------------------- + // CLIENT_FindRecord接口输入参数 + public static class NET_IN_FIND_RECORD_PARAM extends Structure { + public int dwSize; // 结构体大小 + public int emType; // 待查询记录类型,emType对应 EM_NET_RECORD_TYPE + public Pointer pQueryCondition; // 查询类型对应的查询条件 =1时,是白名单账户记录, 查询条件对应 FIND_RECORD_TRAFFICREDLIST_CONDITION 结构体,记录信息对应 NET_TRAFFIC_LIST_RECORD 结构体 + + public NET_IN_FIND_RECORD_PARAM() { + this.dwSize = this.size(); + } + } + + // 交通黑白名单账户记录查询条件 + public static class FIND_RECORD_TRAFFICREDLIST_CONDITION extends Structure { + public int dwSize; + public byte[] szPlateNumber = new byte[NET_MAX_PLATE_NUMBER_LEN]; // 车牌号 + public byte[] szPlateNumberVague = new byte[NET_MAX_PLATE_NUMBER_LEN]; // 车牌号码模糊查询 + public int nQueryResultBegin; // 第一个条返回结果在查询结果中的偏移量 + public boolean bRapidQuery; // 是否快速查询, TRUE:为快速,快速查询时不等待所有增、删、改操作完成。默认为非快速查询 + + public FIND_RECORD_TRAFFICREDLIST_CONDITION() { + this.dwSize = this.size(); + } + } + + // 交通流量记录查询条件 + public static class FIND_RECORD_TRAFFICFLOW_CONDITION extends Structure { + public int dwSize; + public int abChannelId; // 通道号查询条件是否有效 + public int nChannelId; // 通道号 + public int abLane; // 车道号查询条件是否有效 + public int nLane; // 车道号 + public int bStartTime; // 开始时间查询条件是否有效 + public NET_TIME stStartTime; // 开始时间 + public int bEndTime; // 结束时间查询条件是否有效 + public NET_TIME stEndTime; // 结束时间 + public int bStatisticsTime; // 查询是否为统计时间,为BOOL类型,bStartTime及bEndTime均为1 + public FIND_RECORD_TRAFFICFLOW_CONDITION() { + this.dwSize = this.size(); + } + } + + // 门禁出入记录查询条件 + public static class FIND_RECORD_ACCESSCTLCARDREC_CONDITION_EX extends Structure { + public int dwSize; + public int bCardNoEnable; // 启用卡号查询, 为BOOL类型 + public byte[] szCardNo = new byte[NET_MAX_CARDNO_LEN]; // 卡号 + public int bTimeEnable; // 启用时间段查询, 为BOOL类型 + public NET_TIME stStartTime; // 起始时间 + public NET_TIME stEndTime; // 结束时间 + + public FIND_RECORD_ACCESSCTLCARDREC_CONDITION_EX() { + this.dwSize = this.size(); + } + } + + // 开门方式(门禁事件,门禁出入记录,实际的开门方式) + public static class NET_ACCESS_DOOROPEN_METHOD { + public static final int NET_ACCESS_DOOROPEN_METHOD_UNKNOWN = 0; + public static final int NET_ACCESS_DOOROPEN_METHOD_PWD_ONLY = 1; // 密码开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_CARD = 2; // 刷卡开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_CARD_FIRST = 3; // 先刷卡后密码开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_PWD_FIRST = 4; // 先密码后刷卡开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_REMOTE = 5; // 远程开锁,如通过室内机或者平台对门口机开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_BUTTON = 6; // 开锁按钮进行开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_FINGERPRINT = 7; // 指纹开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_PWD_CARD_FINGERPRINT = 8; // 密码+刷卡+指纹组合开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_PWD_FINGERPRINT = 10; // 密码+指纹组合开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_CARD_FINGERPRINT = 11; // 刷卡+指纹组合开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_PERSONS = 12; // 多人开锁 + public static final int NET_ACCESS_DOOROPEN_METHOD_KEY = 13; // 钥匙开门 + public static final int NET_ACCESS_DOOROPEN_METHOD_COERCE_PWD = 14; // 胁迫密码开门 + public static final int NET_ACCESS_DOOROPEN_METHOD_FACE_RECOGNITION = 16; // 人脸识别开门 + } + + // 卡类型 + public static class NET_ACCESSCTLCARD_TYPE { + public static final int NET_ACCESSCTLCARD_TYPE_UNKNOWN = -1; + public static final int NET_ACCESSCTLCARD_TYPE_GENERAL = 0; // 一般卡 + public static final int NET_ACCESSCTLCARD_TYPE_VIP = 1; // VIP卡 + public static final int NET_ACCESSCTLCARD_TYPE_GUEST = 2; // 来宾卡 + public static final int NET_ACCESSCTLCARD_TYPE_PATROL = 3; // 巡逻卡 + public static final int NET_ACCESSCTLCARD_TYPE_BLACKLIST = 4; // 黑名单卡 + public static final int NET_ACCESSCTLCARD_TYPE_CORCE = 5; // 胁迫卡 + public static final int NET_ACCESSCTLCARD_TYPE_POLLING = 6; // 巡检卡 + public static final int NET_ACCESSCTLCARD_TYPE_MOTHERCARD = 0xff; // 母卡 + } + + // 门禁刷卡记录记录集信息 + public static class NET_RECORDSET_ACCESS_CTL_CARDREC extends Structure { + public int dwSize; + public int nRecNo; // 记录集编号,只读 + public byte[] szCardNo = new byte[NET_MAX_CARDNO_LEN];// 卡号 + public byte[] szPwd = new byte[NET_MAX_CARDPWD_LEN]; // 密码 + public NET_TIME stuTime; // 刷卡时间 + public int bStatus; // 刷卡结果,TRUE表示成功,FALSE表示失败 + public int emMethod; // 开门方式 NET_ACCESS_DOOROPEN_METHOD + public int nDoor; // 门号,即CFG_CMD_ACCESS_EVENT配置CFG_ACCESS_EVENT_INFO的数组下标 + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + public int nReaderID; // 读卡器ID (废弃,不再使用) + public byte[] szSnapFtpUrl = new byte[MAX_PATH]; // 开锁抓拍上传的FTP地址 + public byte[] szReaderID = new byte[NET_COMMON_STRING_32];// 读卡器ID // 开门并上传抓拍照片,在记录集记录存储地址,成功才有 + public int emCardType; // 卡类型 NET_ACCESSCTLCARD_TYPE + public int nErrorCode; // 开门失败的原因,仅在bStatus为FALSE时有效 + // 0x00 没有错误 + // 0x10 未授权 + // 0x11 卡挂失或注销 + // 0x12 没有该门权限 + // 0x13 开门模式错误 + // 0x14 有效期错误 + // 0x15 防反潜模式 + // 0x16 胁迫报警未打开 + // 0x17 门常闭状态 + // 0x18 AB互锁状态 + // 0x19 巡逻卡 + // 0x1A 设备处于闯入报警状态 + // 0x20 时间段错误 + // 0x21 假期内开门时间段错误 + // 0x30 需要先验证有首卡权限的卡片 + // 0x40 卡片正确,输入密码错误 + // 0x41 卡片正确,输入密码超时 + // 0x42 卡片正确,输入指纹错误 + // 0x43 卡片正确,输入指纹超时 + // 0x44 指纹正确,输入密码错误 + // 0x45 指纹正确,输入密码超时 + // 0x50 组合开门顺序错误 + // 0x51 组合开门需要继续验证 + // 0x60 验证通过,控制台未授权 + public byte[] szRecordURL = new byte[NET_COMMON_STRING_128];// 刷卡录像的地址 + public int nNumbers; // 抓图的张数 + public int emAttendanceState; // 考勤状态 ,参考 NET_ATTENDANCESTATE + public int emDirection; // 开门方向, 参考 NET_ENUM_DIRECTION_ACCESS_CTL + public NET_RECORDSET_ACCESS_CTL_CARDREC() { + this.dwSize = this.size(); + } + } + + //考勤状态 + public static class NET_ATTENDANCESTATE extends Structure { + public static final int NET_ATTENDANCESTATE_UNKNOWN = 0; + public static final int NET_ATTENDANCESTATE_SIGNIN = 1; //签入 + public static final int NET_ATTENDANCESTATE_GOOUT = 2; //外出 + public static final int NET_ATTENDANCESTATE_GOOUT_AND_RETRUN = 3; //外出归来 + public static final int NET_ATTENDANCESTATE_SIGNOUT = 4; // 签出 + public static final int NET_ATTENDANCESTATE_WORK_OVERTIME_SIGNIN = 5; // 加班签到 + public static final int NET_ATTENDANCESTATE_WORK_OVERTIME_SIGNOUT = 6; // 加班签出 + } + + // 开门方向 + public static class NET_ENUM_DIRECTION_ACCESS_CTL extends Structure { + public static final int NET_ENUM_DIRECTION_UNKNOWN = 0; + public static final int NET_ENUM_DIRECTION_ENTRY = 1; // 进门 + public static final int NET_ENUM_DIRECTION_EXIT = 2; // 出门 + } + + // 记录集类型 + public static class EM_NET_RECORD_TYPE extends Structure { + public static final int NET_RECORD_UNKNOWN = 0; + public static final int NET_RECORD_TRAFFICREDLIST = 1; // 交通白名单账户记录, 查询条件对应 FIND_RECORD_TRAFFICREDLIST_CONDITION 结构体,记录信息对应 NET_TRAFFIC_LIST_RECORD 结构体 + public static final int NET_RECORD_TRAFFICBLACKLIST = 2; // 交通黑名单账号记录,查询条件对应 FIND_RECORD_TRAFFICREDLIST_CONDITION 结构体,记录信息对应 NET_TRAFFIC_LIST_RECORD 结构体 + public static final int NET_RECORD_BURN_CASE = 3; // 刻录案件记录,查询条件对应 FIND_RECORD_BURN_CASE_CONDITION 结构体,记录信息对应 NET_BURN_CASE_INFO 结构体 + public static final int NET_RECORD_ACCESSCTLCARD = 4; // 门禁卡,查询条件对应 FIND_RECORD_ACCESSCTLCARD_CONDITION 结构体,记录信息对应 NET_RECORDSET_ACCESS_CTL_CARD 结构体 + public static final int NET_RECORD_ACCESSCTLPWD = 5; // 门禁密码,查询条件对应 FIND_RECORD_ACCESSCTLPWD_CONDITION 结构体,记录信息对应 NET_RECORDSET_ACCESS_CTL_PWD + public static final int NET_RECORD_ACCESSCTLCARDREC = 6; // 门禁出入记录(必须同时按卡号和时间段查询,建议用 NET_RECORD_ACCESSCTLCARDREC_EX 查询),查询条件对应 FIND_RECORD_ACCESSCTLCARDREC_CONDITION 结构体,记录信息对应 NET_RECORDSET_ACCESS_CTL_CARDREC 结构体 + public static final int NET_RECORD_ACCESSCTLHOLIDAY = 7; // 假日记录集,查询条件对应 FIND_RECORD_ACCESSCTLHOLIDAY_CONDITION 结构体,记录信息对应 NET_RECORDSET_HOLIDAY 结构体 + public static final int NET_RECORD_TRAFFICFLOW_STATE = 8; // 查询交通流量记录,查询条件对应 FIND_RECORD_TRAFFICFLOW_CONDITION 结构体,记录信息对应 NET_RECORD_TRAFFIC_FLOW_STATE 结构体 + public static final int NET_RECORD_VIDEOTALKLOG = 9; // 通话记录,查询条件对应 FIND_RECORD_VIDEO_TALK_LOG_CONDITION 结构体,记录信息对应 NET_RECORD_VIDEO_TALK_LOG 结构体 + public static final int NET_RECORD_REGISTERUSERSTATE = 10; // 状态记录,查询条件对应 FIND_RECORD_REGISTER_USER_STATE_CONDITION 结构体,记录信息对应 NET_RECORD_REGISTER_USER_STATE 结构体 + public static final int NET_RECORD_VIDEOTALKCONTACT = 11; // 联系人记录,查询条件对应 FIND_RECORD_VIDEO_TALK_CONTACT_CONDITION 结构体,记录信息对应 NET_RECORD_VIDEO_TALK_CONTACT 结构体 + public static final int NET_RECORD_ANNOUNCEMENT = 12; // 公告记录,查询条件对应 FIND_RECORD_ANNOUNCEMENT_CONDITION 结构体,记录信息对应 NET_RECORD_ANNOUNCEMENT_INFO 结构体 + public static final int NET_RECORD_ALARMRECORD = 13; // 报警记录,查询条件对应 FIND_RECORD_ALARMRECORD_CONDITION 结构体,记录信息对应 NET_RECORD_ALARMRECORD_INFO 结构体 + public static final int NET_RECORD_COMMODITYNOTICE = 14; // 下发商品记录,查询条件对应 FIND_RECORD_COMMODITY_NOTICE_CONDITION 结构体,记录信息对应 NET_RECORD_COMMODITY_NOTICE 结构体 + public static final int NET_RECORD_HEALTHCARENOTICE = 15; // 就诊信息记录,查询条件对应 FIND_RECORD_HEALTH_CARE_NOTICE_CONDITION 结构体,记录信息对应 NET_RECORD_HEALTH_CARE_NOTICE 结构体 + public static final int NET_RECORD_ACCESSCTLCARDREC_EX = 16; // 门禁出入记录(可选择部分条件查询,建议替代NET_RECORD_ACCESSCTLCARDREC),查询条件对应 FIND_RECORD_ACCESSCTLCARDREC_CONDITION_EX 结构体,记录信息对应 NET_RECORDSET_ACCESS_CTL_CARDREC 结构体 + public static final int NET_RECORD_GPS_LOCATION = 17; // GPS位置信息记录, 只实现import和clear,记录信息对应 NET_RECORD_GPS_LOCATION_INFO 结构体 + public static final int NET_RECORD_RESIDENT = 18; // 公租房租户信息,查询条件对应 FIND_RECORD_RESIDENT_CONDTION结构体, 记录信息对应 NET_RECORD_RESIDENT_INFO 结构体 + public static final int NET_RECORD_SENSORRECORD = 19; // 监测量数据记录,查询条件对应 FIND_RECORD_SENSORRECORD_CONDITION 结构体,记录信息对应 NET_RECORD_SENSOR_RECORD 结构体 + public static final int NET_RECORD_ACCESSQRCODE = 20; // 开门二维码记录集,记录信息对应 NET_RECORD_ACCESSQRCODE_INFO结构体 + } + + //交通黑白名单记录信息 + public static class NET_TRAFFIC_LIST_RECORD extends Structure { + public int dwSize; + public int nRecordNo; // 之前查询到的记录号 + public byte[] szMasterOfCar = new byte[NET_MAX_NAME_LEN]; // 车主姓名 + public byte[] szPlateNumber = new byte[NET_MAX_PLATE_NUMBER_LEN];// 车牌号码 + public int emPlateType; // 车牌类型,对应EM_NET_PLATE_TYPE + public int emPlateColor; // 车牌颜色 ,对应EM_NET_PLATE_COLOR_TYPE + public int emVehicleType; // 车辆类型 ,对应EM_NET_VEHICLE_TYPE + public int emVehicleColor; // 车身颜色,对应EM_NET_VEHICLE_COLOR_TYPE + public NET_TIME stBeginTime; // 开始时间 + public NET_TIME stCancelTime; // 撤销时间 + public int nAuthrityNum; // 权限个数 + public NET_AUTHORITY_TYPE[] stAuthrityTypes = (NET_AUTHORITY_TYPE[])new NET_AUTHORITY_TYPE().toArray(NET_MAX_AUTHORITY_LIST_NUM); // 权限列表 , 白名单仅有 + public int emControlType; // 布控类型 ,黑名单仅有,对应EM_NET_TRAFFIC_CAR_CONTROL_TYPE + + public static class ByReference extends NET_TRAFFIC_LIST_RECORD implements Structure.ByReference {} + public static class ByValue extends NET_TRAFFIC_LIST_RECORD implements Structure.ByValue {} + + public NET_TRAFFIC_LIST_RECORD() { + this.dwSize = this.size(); + } + } + + // 交通流量记录 + public static class NET_RECORD_TRAFFIC_FLOW_STATE extends Structure { + public int dwSize; + public int nRecordNum; // 记录编号 + public int nChannel; // 通道号 + public int nLane; // 车道号 + public int nVehicles; // 通过车辆总数 + public float fAverageSpeed; // 平均车速,单位km/h + public float fTimeOccupyRatio; // 时间占有率,即单位时间内通过断面的车辆所用时间的总和占单位时间的比例 + public float fSpaceOccupyRatio; // 空间占有率,即按百分率计量的车辆长度总和除以时间间隔内车辆平均行驶距离 + public float fSpaceHeadway; // 车头间距,相邻车辆之间的距离,单位米/辆 + public float fTimeHeadway; // 车头时距,单位秒/辆 + public int nLargeVehicles; // 大车交通量(9米<车长<12米),辆/单位时间 + public int nMediumVehicles; // 中型车交通量(6米<车长<9米),辆/单位时间 + public int nSmallVehicles; // 小车交通量(4米<车长<6米),辆/单位时间, + public float fBackOfQueue; // 排队长度,单位:米, 从信号交叉口停车线到上游排队车辆末端之间的距离 + + public NET_RECORD_TRAFFIC_FLOW_STATE() { + this.dwSize = this.size(); + } + } + + //权限列表 , 白名单仅有 + public static class NET_AUTHORITY_TYPE extends Structure { + public int dwSize; + public int emAuthorityType; //权限类型,对应EM_NET_AUTHORITY_TYPE + public boolean bAuthorityEnable; //权限使能 + + public NET_AUTHORITY_TYPE() { + this.dwSize = this.size(); + } + } + + //权限类型 + public static class EM_NET_AUTHORITY_TYPE extends Structure { + public static final int NET_AUTHORITY_UNKNOW = 0; + public static final int NET_AUTHORITY_OPEN_GATE = 1; //开闸权限 + } + + // CLIENT_FindRecord接口输出参数 + public static class NET_OUT_FIND_RECORD_PARAM extends Structure { + public int dwSize; // 结构体大小 + public LLong lFindeHandle; // 查询记录句柄,唯一标识某次查询 + + public NET_OUT_FIND_RECORD_PARAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_FindNextRecord接口输入参数 + public static class NET_IN_FIND_NEXT_RECORD_PARAM extends Structure { + public int dwSize; // 结构体大小 + public LLong lFindeHandle; // 查询句柄 + public int nFileCount; // 当前想查询的记录条数 + + public NET_IN_FIND_NEXT_RECORD_PARAM() { + this.dwSize = this.size(); + } + } + + //CLIENT_FindNextRecord接口输出参数 + public static class NET_OUT_FIND_NEXT_RECORD_PARAM extends Structure { + public int dwSize; // 结构体大小 + public Pointer pRecordList; // 记录列表,用户分配内存,对应 交通黑白名单记录信息 NET_TRAFFIC_LIST_RECORD + public int nMaxRecordNum; // 列表记录数 + public int nRetRecordNum; // 查询到的记录条数,当查询到的条数小于想查询的条数时,查询结束 + + public NET_OUT_FIND_NEXT_RECORD_PARAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_QueryRecordCount接口输入参数 + public static class NET_IN_QUEYT_RECORD_COUNT_PARAM extends Structure + { + public int dwSize;//结构体大小 + public LLong lFindeHandle;//查询句柄 + + public NET_IN_QUEYT_RECORD_COUNT_PARAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_QueryRecordCount接口输出参数 + public static class NET_OUT_QUEYT_RECORD_COUNT_PARAM extends Structure + { + public int dwSize;//结构体大小 + public int nRecordCount;//设备返回的记录条数 + + public NET_OUT_QUEYT_RECORD_COUNT_PARAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_OperateTrafficList接口输入参数, + public static class NET_IN_OPERATE_TRAFFIC_LIST_RECORD extends Structure { + public int dwSize; + public int emOperateType; // emOperateType对应EM_RECORD_OPERATE_TYPE + public int emRecordType; // 要操作记录信息类型,emRecordType对应EM_NET_RECORD_TYPE + public Pointer pstOpreateInfo; // 对应 添加NET_INSERT_RECORD_INFO/ 删除NET_REMOVE_RECORD_INFO / 修改NET_UPDATE_RECORD_INFO + + public NET_IN_OPERATE_TRAFFIC_LIST_RECORD() { + this.dwSize = this.size(); + } + } + // 添加 + public static class NET_INSERT_RECORD_INFO extends Structure { + public int dwSize; + public NET_TRAFFIC_LIST_RECORD.ByReference pRecordInfo = new NET_TRAFFIC_LIST_RECORD.ByReference(); // 记录内容信息 + + public NET_INSERT_RECORD_INFO () { + this.dwSize = this.size(); + } + } + // 删除 + public static class NET_REMOVE_RECORD_INFO extends Structure { + public int dwSize; + public int nRecordNo; // 之前查询到的记录号,对应NET_TRAFFIC_LIST_RECORD里的nRecordNo + + public NET_REMOVE_RECORD_INFO() { + this.dwSize = this.size(); + } + } + // 修改 + public static class NET_UPDATE_RECORD_INFO extends Structure{ + public int dwSize; + public NET_TRAFFIC_LIST_RECORD.ByReference pRecordInfo; // 记录内容信息 ,对应 NET_TRAFFIC_LIST_RECORD + + public NET_UPDATE_RECORD_INFO() { + this.dwSize = this.size(); + } + } + + // 黑白名单操作类型 + public static class EM_RECORD_OPERATE_TYPE extends Structure { + public static final int NET_TRAFFIC_LIST_INSERT = 0; // 增加记录操作 + public static final int NET_TRAFFIC_LIST_UPDATE = 1; // 更新记录操作 + public static final int NET_TRAFFIC_LIST_REMOVE = 2; // 删除记录操作 + public static final int NET_TRAFFIC_LIST_MAX = 3; + } + + // CLIENT_OperateTrafficList接口输出参数,现阶段实现的操作接口中,只有返回nRecordNo的操作,stRetRecord暂时不可用,是null + public static class NET_OUT_OPERATE_TRAFFIC_LIST_RECORD extends Structure { + public int dwSize; + public int nRecordNo; //记录号 + + public NET_OUT_OPERATE_TRAFFIC_LIST_RECORD() { + this.dwSize = this.size(); + } + } + + // 记录集操作参数 + public static class NET_CTRL_RECORDSET_PARAM extends Structure { + public int dwSize; + public int emType; // 记录集信息类型,对应EM_NET_RECORD_TYPE + public Pointer pBuf; // 新增\更新\查询\导入时,为记录集信息缓存,详见EM_NET_RECORD_TYPE注释 + // 删除时,为记录编号(int型) + public int nBufLen; // 记录集信息缓存大小 + + public NET_CTRL_RECORDSET_PARAM() { + this.dwSize = this.size(); + } + } + + // 黑白名单上传 + public static class NETDEV_BLACKWHITE_LIST_INFO extends Structure { + public byte[] szFile = new byte[MAX_PATH_STOR]; // 黑白名单文件路径 + public int nFileSize; // 升级文件大小 + public byte byFileType; // 当前文件类型,0-黑名单,1-白名单 + public byte byAction; // 动作,0-覆盖,1-追加 + public byte[] byReserved = new byte[126]; // 保留 + } + + // GPS信息(车载设备) + public static class GPS_Info extends Structure { + public NET_TIME revTime; // 定位时间 + public byte[] DvrSerial = new byte[50]; // 设备序列号 + public double longitude; // 经度(单位是百万分之度,范围0-360度) + public double latidude; // 纬度(单位是百万分之度,范围0-180度) + public double height; // 高度(米) + public double angle; // 方向角(正北方向为原点,顺时针为正) + public double speed; // 速度(单位是海里,speed/1000*1.852公里/小时) + public short starCount; // 定位星数,无符号 + public int antennaState; // 天线状态(true 好,false 坏) + public int orientationState; // 定位状态(true 定位,false 不定位) + + public static class ByValue extends GPS_Info implements Structure.ByValue { } + } + + // 报警状态信息 + public static class ALARM_STATE_INFO extends Structure { + public int nAlarmCount; // 发生的报警事件个数 + public int[] nAlarmState = new int[128]; // 发生的报警事件类型 + public byte[] byRserved = new byte[128]; // 保留字节 + + public static class ByValue extends ALARM_STATE_INFO implements Structure.ByValue { } + } + + // 对应CLIENT_SearchDevicesByIPs接口 + public static class DEVICE_IP_SEARCH_INFO extends Structure { + public int dwSize; // 结构体大小 + public int nIpNum; // 当前搜索的IP个数 + public byte[] szIP = new byte[NET_MAX_SAERCH_IP_NUM*64]; // 具体待搜索的IP信息 + + public DEVICE_IP_SEARCH_INFO() { + this.dwSize = this.size(); + } + } + + // CLIENT_UploadRemoteFile 接口输入参数(上传文件到设备) + public static class NET_IN_UPLOAD_REMOTE_FILE extends Structure { + public int dwSize; + public String pszFileSrc; // 源文件路径 + public String pszFileDst; // 目标文件路径 + public String pszFolderDst; // 目标文件夹路径:可为NULL, NULL时设备使用默认路径 + public int nPacketLen; // 文件分包大小(字节): 0表示不分包 + + public NET_IN_UPLOAD_REMOTE_FILE(){ + this.dwSize = this.size(); + } + } + + // CLIENT_UploadRemoteFile 接口输出参数(上传文件到设备) + public static class NET_OUT_UPLOAD_REMOTE_FILE extends Structure { + public int dwSize; + + public NET_OUT_UPLOAD_REMOTE_FILE() { + this.dwSize = this.size(); + } + } + + // CLIENT_ParkingControlAttachRecord()接口输入参数 + public static class NET_IN_PARKING_CONTROL_PARAM extends Structure { + public int dwSize; + public StdCallCallback cbCallBack; // 数据回调函数,fParkingControlRecordCallBack 回调 + public LLong dwUser; // 用户定义参数 + + public NET_IN_PARKING_CONTROL_PARAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_ParkingControlDetachRecord()接口输出参数 + public static class NET_OUT_PARKING_CONTROL_PARAM extends Structure { + public int dwSize; + + public NET_OUT_PARKING_CONTROL_PARAM() { + this.dwSize = this.size(); + } + } + + // 过车记录信息 + public static class NET_CAR_PASS_ITEM extends Structure { + public int dwSize; + public NET_TIME stuTime; // 过车时间 + public int dwCardNo; // 卡号 + public int emCardType; // 智能停车系统出入口机IC卡用户类型,对应 NET_ECK_IC_CARD_USER_TYPE + public int emFlag; // 过车记录类型,对应 NET_ECK_CAR_PASS_FLAG + + public static class ByReference extends NET_CAR_PASS_ITEM implements Structure.ByReference {} + + public NET_CAR_PASS_ITEM(){ + this.dwSize = this.size(); + } + } + + // 智能停车系统出入口机IC卡用户类型 + public static class NET_ECK_IC_CARD_USER_TYPE extends Structure { + public static final int NET_ECK_IC_CARD_USER_UNKNOWN = 0; + public static final int NET_ECK_IC_CARD_USER_ALL = 1; // 全部类型 + public static final int NET_ECK_IC_CARD_USER_TEMP = 2; // 临时用户 + public static final int NET_ECK_IC_CARD_USER_LONG = 3; // 长期用户 + public static final int NET_ECK_IC_CARD_USER_ADMIN = 4; // 管理员 + public static final int NET_ECK_IC_CARD_USER_BLACK_LIST = 5; // 黑名单 + } + + // 智能停车系统出入口机异常过车记录类型 + public static class NET_ECK_CAR_PASS_FLAG extends Structure { + public static final int NET_ECK_CAR_PASS_FLAG_NORMAL = 0; // 正常 + public static final int NET_ECK_CAR_PASS_FLAG_ABNORMAL = 1; // 异常 + public static final int NET_ECK_CAR_PASS_FLAG_ALL = 2; // 全部 + } + + // CLIENT_ParkingControlStartFind接口输入参数****************** + public static class NET_IN_PARKING_CONTROL_START_FIND_PARAM extends Structure { + public int dwSize; // 结构体大小 + public int bSearchCount; // 查询记录调试是否有效 + public int dwSearchCount; // 查询记录条数, 数值范围1~100 + public int bBegin; // 查询开始时间是否有效 + public NET_TIME stuBegin; // 查询开始时间 + public int bEnd; // 查询结束时间是否有效 + public NET_TIME stuEnd; // 查询结束时间 + public int bCardType; // 卡类型是否有效 + public int emCardType; // 卡类型,对应 NET_ECK_IC_CARD_USER_TYPE + public int bFlag; // 过车标记是否有效 + public int emFlag; // 过车标记,对应 NET_ECK_CAR_PASS_FLAG + + public NET_IN_PARKING_CONTROL_START_FIND_PARAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_ParkingControlStartFind接口输出参数 + public static class NET_OUT_PARKING_CONTROL_START_FIND_PARAM extends Structure { + public int dwSize; // 结构体大小 + public int dwTotalCount; // 符合此次查询条件的结果总条数 + + public NET_OUT_PARKING_CONTROL_START_FIND_PARAM(){ + this.dwSize = this.size(); + } + } + + // CLIENT_ParkingControlDoFind接口输入参数******************* + public static class NET_IN_PARKING_CONTROL_DO_FIND_PARAM extends Structure { + public int dwSize; // 结构体大小 + public int dwFileCount; // 当前想查询的记录条数 + + public NET_IN_PARKING_CONTROL_DO_FIND_PARAM(){ + this.dwSize = this.size(); + } + } + + // CLIENT_ParkingControlDoFind接口输出参数 + public static class NET_OUT_PARKING_CONTROL_DO_FIND_PARAM extends Structure{ + public int dwSize; // 结构体大小 + public NET_CAR_PASS_ITEM.ByReference pstuRecordList = new NET_CAR_PASS_ITEM.ByReference(); // 记录列表,用户分配内存 + public int nMaxRecordNum; // 列表记录数 + public int nRetRecordNum; // 查询到的记录条数,当查询到的条数小于想查询的条数时,查询结束 + + public NET_OUT_PARKING_CONTROL_DO_FIND_PARAM(){ + this.dwSize = this.size(); + } + } + + // CLIENT_ParkingControlAttachParkInfo()接口输入参数 + public static class NET_IN_PARK_INFO_PARAM extends Structure + { + public int dwSize; + public NET_PARK_INFO_FILTER stuFilter; + public StdCallCallback cbCallBack; // 数据回调函数,fParkInfoCallBack 回调 + public LLong dwUser; // 用户定义参数 + + public NET_IN_PARK_INFO_PARAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_ParkingControlAttachParkInfo()接口输出参数 + public static class NET_OUT_PARK_INFO_PARAM extends Structure + { + public int dwSize; + + public NET_OUT_PARK_INFO_PARAM() { + this.dwSize = this.size(); + } + } + + // 车位检测器信息查询条件 + public static class NET_PARK_INFO_FILTER extends Structure + { + public int dwSize; + public int dwNum; // 车位检测器类型数量 + public int[] emType = new int[NET_ECK_PARK_DETECTOR_TYPE.NET_ECK_PARK_DETECTOR_TYPE_ALL]; // 车位检测器类型 + + public NET_PARK_INFO_FILTER() { + this.dwSize = this.size(); + } + } + + // 车位检测器类型 + public static class NET_ECK_PARK_DETECTOR_TYPE extends Structure + { + public static final int NET_ECK_PARK_DETECTOR_TYPE_SONIC = 0; // 超声波探测器 + public static final int NET_ECK_PARK_DETECTOR_TYPE_CAMERA = 1; // 相机检测器 + public static final int NET_ECK_PARK_DETECTOR_TYPE_ALL = 2; + } + + // 车位信息 + public static class NET_PARK_INFO_ITEM extends Structure + { + public int dwSize; + public byte[] szParkNo = new byte[NET_COMMON_STRING_32]; // 车位号 + public int emState; // 车位状态,对应 NET_ECK_PARK_STATE + public int dwScreenIndex; // 车位号显示对应的诱导屏分屏号 + public int dwFreeParkNum; // 屏号显示的当前空余车位数目 + + public NET_PARK_INFO_ITEM(){ + this.dwSize = this.size(); + } + } + + // 智能停车系统车位状态 + public static class NET_ECK_PARK_STATE extends Structure + { + public static final int NET_ECK_PARK_STATE_UNKOWN = 0; + public static final int NET_ECK_PARK_STATE_PARK = 1; // 车位有车 + public static final int NET_ECK_PARK_STATE_NOPARK = 2; // 车位无车 + } + + // 智能停车系统出入口机设置车位信息 参数 DH_CTRL_ECK_SET_PARK_INFO + public static class NET_CTRL_ECK_SET_PARK_INFO_PARAM extends Structure + { + public int dwSize; + public int nScreenNum; // 屏数量, 不超过 ECK_SCREEN_NUM_MAX + public int[] nScreenIndex = new int[ECK_SCREEN_NUM_MAX]; // 屏号, 每个元素表示屏序号 + public int[] nFreeParkNum = new int[ECK_SCREEN_NUM_MAX]; // 对应屏管理下的空余车位数 + // 长度和下标与nScreenIndex一致,每个元素表示对应屏号下的空余车位 + public NET_CTRL_ECK_SET_PARK_INFO_PARAM(){ + this.dwSize = this.size(); + } + } + + // CLIENT_PowerControl接口输入参数(电视墙电源控制) + public static class NET_IN_WM_POWER_CTRL extends Structure + { + public int dwSize; + public int nMonitorWallID; // 电视墙序号 + public String pszBlockID; // 区块ID, NULL/""-所有区块 + public int nTVID; // 显示单元序号, -1表示区块中所有显示单元 + public int bPowerOn; // 是否打开电源 + + public NET_IN_WM_POWER_CTRL() { + this.dwSize = this.size(); + } + } + + // CLIENT_PowerControl接口输出参数(电视墙电源控制) + public static class NET_OUT_WM_POWER_CTRL extends Structure + { + public int dwSize; + + public NET_OUT_WM_POWER_CTRL() { + this.dwSize = this.size(); + } + } + + // CLIENT_LoadMonitorWallCollection接口输入参数(载入电视墙预案) + public static class NET_IN_WM_LOAD_COLLECTION extends Structure + { + public int dwSize; + public int nMonitorWallID; // 电视墙序号 + public String pszName; // 预案名称 + + public NET_IN_WM_LOAD_COLLECTION() { + this.dwSize = this.size(); + } + } + + // CLIENT_LoadMonitorWallCollection接口输出参数(载入电视墙预案) + public static class NET_OUT_WM_LOAD_COLLECTION extends Structure + { + public int dwSize; + + public NET_OUT_WM_LOAD_COLLECTION() { + this.dwSize = this.size(); + } + } + + // CLIENT_SaveMonitorWallCollection接口输入参数(保存电视墙预案) + public static class NET_IN_WM_SAVE_COLLECTION extends Structure + { + public int dwSize; + public int nMonitorWallID; // 电视墙序号 + public String pszName; // 预案名称 + public String pszControlID; // 控制id + + public NET_IN_WM_SAVE_COLLECTION() { + this.dwSize = this.size(); + } + } + + // CLIENT_SaveMonitorWallCollection接口输出参数(保存电视墙预案) + public static class NET_OUT_WM_SAVE_COLLECTION extends Structure + { + public int dwSize; + + public NET_OUT_WM_SAVE_COLLECTION() { + this.dwSize = this.size(); + } + } + + // 分割模式 + public static class NET_SPLIT_MODE extends Structure + { + public static final int NET_SPLIT_1 = 1; // 1画面 + public static final int NET_SPLIT_2 = 2; // 2画面 + public static final int NET_SPLIT_4 = 4; // 4画面 + public static final int NET_SPLIT_6 = 6; // 6画面 + public static final int NET_SPLIT_8 = 8; // 8画面 + public static final int NET_SPLIT_9 = 9; // 9画面 + public static final int NET_SPLIT_12 = 12; // 12画面 + public static final int NET_SPLIT_16 = 16; // 16画面 + public static final int NET_SPLIT_20 = 20; // 20画面 + public static final int NET_SPLIT_25 = 25; // 25画面 + public static final int NET_SPLIT_36 = 36; // 36画面 + public static final int NET_SPLIT_64 = 64; // 64画面 + public static final int NET_SPLIT_144 = 144; // 144画面 + public static final int NET_PIP_1 = NET_SPLIT_PIP_BASE + 1; // 画中画模式, 1个全屏大画面+1个小画面窗口 + public static final int NET_PIP_3 = NET_SPLIT_PIP_BASE + 3; // 画中画模式, 1个全屏大画面+3个小画面窗口 + public static final int NET_SPLIT_FREE = NET_SPLIT_PIP_BASE * 2; // 自由开窗模式,可以自由创建、关闭窗口,自由设置窗口位置和Z轴次序 + public static final int NET_COMPOSITE_SPLIT_1 = NET_SPLIT_PIP_BASE * 3 + 1;// 融合屏成员1分割 + public static final int NET_COMPOSITE_SPLIT_4 = NET_SPLIT_PIP_BASE * 3 + 4;// 融合屏成员4分割 + } + + // 区块窗口信息 + public static class NET_WINDOW_COLLECTION extends Structure + { + public int dwSize; + public int nWindowID; // 窗口ID + public int bWndEnable; // 窗口是否有效 + public DH_RECT stuRect; // 窗口区域, 自由分割模式下有效 + public int bDirectable; // 坐标是否满足直通条件 + public int nZOrder; // 窗口Z次序 + public int bSrcEnable; // 显示源是否有效 + public byte[] szDeviceID = new byte[NET_DEV_ID_LEN_EX]; // 设备ID + public int nVideoChannel; // 视频通道号 + public int nVideoStream; // 视频码流类型 + public int nAudioChannel; // 音频通道 + public int nAudioStream; // 音频码流类型 + public int nUniqueChannel; // 设备内统一编号的唯一通道号 + + public NET_WINDOW_COLLECTION() { + this.dwSize = this.size(); + } + } + + // 区块收藏 + public static class NET_BLOCK_COLLECTION extends Structure + { + public int dwSize; + public int emSplitMode; // 分割模式,对应 NET_SPLIT_MODE + public NET_WINDOW_COLLECTION[] stuWnds = (NET_WINDOW_COLLECTION[])new NET_WINDOW_COLLECTION().toArray(NET_MAX_SPLIT_WINDOW); // 窗口信息数组 + public int nWndsCount; // 窗口数量 + public byte[] szName = new byte[NET_DEVICE_NAME_LEN]; // 收藏夹名称 + public int nScreen; // 输出通道号, 包括拼接屏 + public byte[] szCompositeID = new byte[NET_DEV_ID_LEN_EX]; // 拼接屏ID + public Pointer pstuWndsEx; // 窗口信息数组指针 DH_WINDOW_COLLECTION[] , 由用户分配内存. 当stuWnds数组大小不够用时可以使用 + public int nMaxWndsCountEx; // 最大窗口数量, 用户填写. pstuWndsEx数组的元素个数 + public int nRetWndsCountEx; // 返回窗口数量 + + public NET_BLOCK_COLLECTION() { + this.dwSize = this.size(); + } + } + + // 电视墙显示单元 + public static class NET_MONITORWALL_OUTPUT extends Structure + { + public int dwSize; + public byte[] szDeviceID = new byte[NET_DEV_ID_LEN]; // 设备ID, 本机时为"" + public int nChannel; // 通道号 + public byte[] szName = new byte[NET_DEV_NAME_LEN]; // 屏幕名称 + + public NET_MONITORWALL_OUTPUT() { + this.dwSize = this.size(); + } + } + + // 电视墙显示区块 + public static class NET_MONITORWALL_BLOCK extends Structure + { + public int dwSize; + public byte[] szName = new byte[NET_DEV_NAME_LEN]; // 区块名称 + public byte[] szCompositeID = new byte[NET_DEV_ID_LEN]; // 拼接屏ID + public byte[] szControlID = new byte[NET_DEV_ID_LEN]; // 控制ID + public int nSingleOutputWidth; // 单个显示单元所占的网格列数 + public int nSingleOutputHeight; // 单个显示单元所占的网格行数 + public DH_RECT stuRect; // 区域坐标 + public NET_TSECT[] stuPowerSchedule = new NET_TSECT[NET_TSCHE_DAY_NUM * NET_TSCHE_SEC_NUM]; // 开机时间表, 第一维各元素表示周日~周六和节假日 + public Pointer pstuOutputs; // 显示单元数组 NET_MONITORWALL_OUTPUT[] , 用户分配内存 + public int nMaxOutputCount; // 显示单元数组大小, 用户填写 + public int nRetOutputCount; // 返回的显示单元数量 + + public NET_MONITORWALL_BLOCK() { + this.dwSize = this.size(); + } + } + + // 电视墙配置 + public static class NET_MONITORWALL extends Structure + { + public int dwSize; + public byte[] szName = new byte[NET_DEV_NAME_LEN]; // 名称 + public int nGridLine; // 网格行数 + public int nGridColume; // 网格列数 + public Pointer pstuBlocks; // 显示区块数组 NET_MONITORWALL_BLOCK[] , 用户分配内存 + public int nMaxBlockCount; // 显示区块数组大小, 用户填写 + public int nRetBlockCount; // 返回的显示区块数量 + public int bDisable; // 是否禁用, 0-该电视墙有效, 1-该电视墙无效 + public byte[] szDesc = new byte[NET_COMMON_STRING_256]; // 电视墙描述信息 + + public NET_MONITORWALL() { + this.dwSize = this.size(); + } + } + + // 电视墙预案 + public static class NET_MONITORWALL_COLLECTION extends Structure + { + public int dwSize; + public byte[] szName = new byte[NET_DEVICE_NAME_LEN]; // 电视墙预案名称 + public NET_BLOCK_COLLECTION[] stuBlocks = (NET_BLOCK_COLLECTION[])new NET_BLOCK_COLLECTION().toArray(NET_MAX_BLOCK_NUM);// 区块数组 + public int nBlocksCount; // 区块数量 + public byte[] szControlID = new byte[NET_DEV_ID_LEN_EX]; // 控制ID + public NET_MONITORWALL stuMonitorWall; // 电视墙配置 + + public NET_MONITORWALL_COLLECTION() { + this.dwSize = this.size(); + } + } + + // CLIENT_GetMonitorWallCollections接口输入参数(获取电视墙预案信息) + public static class NET_IN_WM_GET_COLLECTIONS extends Structure + { + public int dwSize; + public int nMonitorWallID; // 电视墙ID + + public NET_IN_WM_GET_COLLECTIONS() { + this.dwSize = this.size(); + } + } + + // CLIENT_GetMonitorWallCollections接口输出参数(获取电视墙预案信息) + public static class NET_OUT_WM_GET_COLLECTIONS extends Structure + { + public int dwSize; + public Pointer pCollections; // 电视墙预案数组, 对应 NET_MONITORWALL_COLLECTION 指针 + public int nMaxCollectionsCount; // 电视墙预案数组大小 + public int nCollectionsCount; // 电视墙预案数量 + + public NET_OUT_WM_GET_COLLECTIONS() { + this.dwSize = this.size(); + } + } + + // 级联权限验证信息 + public static class NET_CASCADE_AUTHENTICATOR extends Structure + { + public int dwSize; + public byte[] szUser = new byte[NET_NEW_USER_NAME_LENGTH]; // 用户名 + public byte[] szPwd = new byte[NET_NEW_USER_PSW_LENGTH]; // 密码 + public byte[] szSerialNo = new byte[NET_SERIALNO_LEN]; // 设备序列号 + + public NET_CASCADE_AUTHENTICATOR() { + this.dwSize = this.size(); + } + } + + + public static class EM_SRC_PUSHSTREAM_TYPE extends Structure + { + public static final int EM_SRC_PUSHSTREAM_AUTO = 0; // 设备端根据码流头自动识别,默认值 + public static final int EM_SRC_PUSHSTREAM_HIKVISION = 1; // 海康私有码流 + public static final int EM_SRC_PUSHSTREAM_PS = 2; // PS流 + public static final int EM_SRC_PUSHSTREAM_TS = 3; // TS流 + public static final int EM_SRC_PUSHSTREAM_SVAC = 4; // SVAC码流 + } + + // 显示源 + public static class NET_SPLIT_SOURCE extends Structure + { + public int dwSize; + public int bEnable; // 使能 + public byte[] szIp = new byte[NET_MAX_IPADDR_LEN]; // IP, 空表示没有设置 + public byte[] szUser = new byte[NET_USER_NAME_LENGTH];// 用户名, 建议使用szUserEx + public byte[] szPwd = new byte[NET_USER_PSW_LENGTH]; // 密码, 建议使用szPwdEx + public int nPort; // 端口 + public int nChannelID; // 通道号 + public int nStreamType; // 视频码流, -1-自动, 0-主码流, 1-辅码流1, 2-辅码流2, 3-辅码流3, 4-snap, 5-预览 + public int nDefinition; // 清晰度, 0-标清, 1-高清 + public int emProtocol; // 协议类型,对应 NET_DEVICE_PROTOCOL + public byte[] szDevName = new byte[NET_DEVICE_NAME_LEN]; // 设备名称 + public int nVideoChannel; // 视频输入通道数 + public int nAudioChannel; // 音频输入通道数 + //-------------------------------------------------------------------------------------- + // 以下只对解码器有效 + public int bDecoder; // 是否是解码器 + public byte byConnType; // -1: auto, 0:TCP;1:UDP;2:组播 + public byte byWorkMode; // 0:直连;1:转发 + public short wListenPort; // 指示侦听服务的端口,转发时有效; byConnType为组播时,则作为多播端口 + public byte[] szDevIpEx = new byte[NET_MAX_IPADDR_OR_DOMAIN_LEN]; // szDevIp扩展,前端DVR的IP地址(可以输入域名) + public byte bySnapMode; // 抓图模式(nStreamType==4时有效) 0:表示请求一帧,1:表示定时发送请求 + public byte byManuFactory; // 目标设备的生产厂商, 具体参考EM_IPC_TYPE类 + public byte byDeviceType; // 目标设备的设备类型, 0:IPC + public byte byDecodePolicy; // 目标设备的解码策略, 0:兼容以前 + // 1:实时等级高 2:实时等级中 + // 3:实时等级低 4:默认等级 + // 5:流畅等级高 6:流畅等级中 + // 7:流畅等级低 + //-------------------------------------------------------------------------------------- + public int dwHttpPort; // Http端口号, 0-65535 + public int dwRtspPort; // Rtsp端口号, 0-65535 + public byte[] szChnName = new byte[NET_DEVICE_NAME_LEN]; // 远程通道名称, 只有读取到的名称不为空时才可以修改该通道的名称 + public byte[] szMcastIP = new byte[NET_MAX_IPADDR_LEN]; // 多播IP地址, byConnType为组播时有效 + public byte[] szDeviceID = new byte[NET_DEV_ID_LEN_EX]; // 设备ID, ""-null, "Local"-本地通道, "Remote"-远程通道, 或者填入具体的RemoteDevice中的设备ID + public int bRemoteChannel; // 是否远程通道(只读) + public int nRemoteChannelID; // 远程通道ID(只读), bRemoteChannel=TRUE时有效 + public byte[] szDevClass = new byte[NET_DEV_TYPE_LEN]; // 设备类型, 如IPC, DVR, NVR等 + public byte[] szDevType = new byte[NET_DEV_TYPE_LEN]; // 设备具体型号, 如IPC-HF3300 + public byte[] szMainStreamUrl = new byte[MAX_PATH]; // 主码流url地址, byManuFactory为DH_IPC_OTHER时有效 + public byte[] szExtraStreamUrl = new byte[MAX_PATH]; // 辅码流url地址, byManuFactory为DH_IPC_OTHER时有效 + public int nUniqueChannel; // 设备内统一编号的唯一通道号, 只读 + public NET_CASCADE_AUTHENTICATOR stuCascadeAuth; // 级联认证信息, 设备ID为"Local/Cascade/SerialNo"时有效, 其中SerialNo是设备序列号 + public int nHint; // 0-普通视频源, 1-报警视频源 + public int nOptionalMainUrlCount; // 备用主码流地址数量 + public byte[] szOptionalMainUrls = new byte[NET_MAX_OPTIONAL_URL_NUM * MAX_PATH]; // 备用主码流地址列表 + public int nOptionalExtraUrlCount; // 备用辅码流地址数量 + public byte[] szOptionalExtraUrls = new byte[NET_MAX_OPTIONAL_URL_NUM * MAX_PATH]; // 备用辅码流地址列表 + //-------------------------------------------------------------------------------------- + //协议后续添加字段 + public int nInterval; // 轮巡时间间隔 单位:秒 + public byte[] szUserEx = new byte[NET_NEW_USER_NAME_LENGTH]; // 用户名 + public byte[] szPwdEx = new byte[NET_NEW_USER_PSW_LENGTH]; // 密码 + public int emPushStream; // 推流方式的码流类型,只有byConnType为TCP-Push或UDP-Push才有该字段,对应 EM_SRC_PUSHSTREAM_TYPE + + public NET_SPLIT_SOURCE() { + this.dwSize = this.size(); + } + } + + // 矩阵子卡信息 + public static class NET_MATRIX_CARD extends Structure + { + public int dwSize; + public int bEnable; // 是否有效 + public int dwCardType; // 子卡类型 + public byte[] szInterface = new byte[NET_MATRIX_INTERFACE_LEN]; // 信号接口类型, "CVBS", "VGA", "DVI"... + public byte[] szAddress = new byte[NET_MAX_IPADDR_OR_DOMAIN_LEN]; // 设备ip或域名, 无网络接口的子卡可以为空 + public int nPort; // 端口号, 无网络接口的子卡可以为0 + public int nDefinition; // 清晰度, 0=标清, 1=高清 + public int nVideoInChn; // 视频输入通道数 + public int nAudioInChn; // 音频输入通道数 + public int nVideoOutChn; // 视频输出通道数 + public int nAudioOutChn; // 音频输出通道数 + public int nVideoEncChn; // 视频编码通道数 + public int nAudioEncChn; // 音频编码通道数 + public int nVideoDecChn; // 视频解码通道数 + public int nAudioDecChn; // 音频解码通道数 + public int nStauts; // 状态: -1-未知, 0-正常, 1-无响应, 2-网络掉线, 3-冲突, 4-正在升级, 5-链路状态异常, 6-子板背板未插好, 7-程序版本出错 + public int nCommPorts; // 串口数 + public int nVideoInChnMin; // 视频输入通道号最小值 + public int nVideoInChnMax; // 视频输入通道号最大值 + public int nAudioInChnMin; // 音频输入通道号最小值 + public int nAudioInChnMax; // 音频输入通道号最大值 + public int nVideoOutChnMin; // 视频输出通道号最小值 + public int nVideoOutChnMax; // 视频输出通道号最大值 + public int nAudioOutChnMin; // 音频输出通道号最小值 + public int nAudioOutChnMax; // 音频输出通道号最大值 + public int nVideoEncChnMin; // 视频编码通道号最小值 + public int nVideoEncChnMax; // 视频编码通道号最大值 + public int nAudioEncChnMin; // 音频编码通道号最小值 + public int nAudioEncChnMax; // 音频编码通道号最大值 + public int nVideoDecChnMin; // 视频解码通道号最小值 + public int nVideoDecChnMax; // 视频解码通道号最大值 + public int nAudioDecChnMin; // 音频解码通道号最小值 + public int nAudioDecChnMax; // 音频解码通道号最大值 + public int nCascadeChannels; // 级联通道数 + public int nCascadeChannelBitrate; // 级联通道带宽, 单位Mbps + public int nAlarmInChnCount; // 报警输入通道数 + public int nAlarmInChnMin; // 报警输入通道号最小值 + public int nAlarmInChnMax; // 报警输入通道号最大值 + public int nAlarmOutChnCount; // 报警输出通道数 + public int nAlarmOutChnMin; // 报警输入通道号最小值 + public int nAlarmOutChnMax; // 报警输入通道号最大值 + public int nVideoAnalyseChnCount; // 智能分析通道数 + public int nVideoAnalyseChnMin; // 智能分析通道号最小值 + public int nVideoAnalyseChnMax; // 智能分析通道号最大值 + public int nCommPortMin; // 串口号最小值 + public int nCommPortMax; // 串口号最大值 + public byte[] szVersion = new byte[NET_COMMON_STRING_32]; // 版本信息 + public NET_TIME stuBuildTime; // 编译时间 + public byte[] szBIOSVersion = new byte[NET_COMMON_STRING_64]; // BIOS版本号 + public byte[] szMAC = new byte[NET_MACADDR_LEN]; // MAC地址 + + public NET_MATRIX_CARD() { + this.dwSize = this.size(); + } + } + + // 矩阵子卡列表 + public static class NET_MATRIX_CARD_LIST extends Structure + { + public int dwSize; + public int nCount; // 子卡数量 + public NET_MATRIX_CARD[] stuCards = new NET_MATRIX_CARD[NET_MATRIX_MAX_CARDS]; // 子卡列表 + + public NET_MATRIX_CARD_LIST() { + this.dwSize = this.size(); + for(int i = 0; i < NET_MATRIX_MAX_CARDS; i++) { + stuCards[i] = new NET_MATRIX_CARD(); + } + } + } + + // CLIENT_FindFramInfo 接口输入参数 + public static class NET_IN_FIND_FRAMEINFO_PRAM extends Structure + { + public int dwSize; // 结构体大小 + public boolean abFileName; // 文件名是否作为有效的查询条件,若文件名有效,则不用填充文件信息(stRecordInfo) + public byte[] szFileName = new byte[MAX_PATH]; // 文件名 + public NET_RECORDFILE_INFO stuRecordInfo; // 文件信息 + public int dwFramTypeMask; // 帧类型掩码,详见“帧类型掩码定义” + + public NET_IN_FIND_FRAMEINFO_PRAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_FindFramInfo 接口输出参数 + public static class NET_OUT_FIND_FRAMEINFO_PRAM extends Structure + { + public int dwSize; // 结构体大小 + public LLong lFindHandle; // 文件查找句柄 + + public NET_OUT_FIND_FRAMEINFO_PRAM() { + this.dwSize = this.size(); + } + } + + // CLIENT_FileStreamClearTags / CLIENT_FileStreamSetTags 接口输入参数 + public static class NET_IN_FILE_STREAM_TAGS_INFO extends Structure + { + public int dwSize; // 结构体大小 + public int nArrayCount; // 标签数组个数 + public Pointer pstuTagInfo; // 标签数组,各项内容关系为"且", 用户分配内存,大小为sizeof( NET_FILE_STREAM_TAG_INFO )*nArrayCount + + public NET_IN_FILE_STREAM_TAGS_INFO() { + this.dwSize = this.size(); + } + } + + // CLIENT_FileStreamClearTags / CLIENT_FileStreamSetTags 接口输出参数 + public static class NET_OUT_FILE_STREAM_TAGS_INFO extends Structure + { + public int dwSize; // 结构体大小 + + public NET_OUT_FILE_STREAM_TAGS_INFO() { + this.dwSize = this.size(); + } + } + + // 标签数组 + public static class NET_FILE_STREAM_TAG_INFO extends Structure + { + public int dwSize; // 结构体大小 + public NET_TIME stuTime; // 标签时间 + public byte[] szContext = new byte[NET_COMMON_STRING_64]; // 标签内容,中文必须使用utf8编码 + public byte[] szUserName = new byte[NET_COMMON_STRING_32]; // 用户名,中文必须使用utf8编码,EVS定制增加 + public byte[] szChannelName = new byte[NET_COMMON_STRING_64]; // 通道名称,中文必须使用utf8编码,EVS定制增加 + + public NET_FILE_STREAM_TAG_INFO() { + this.dwSize = this.size(); + } + } + + // CLIENT_FileStreamGetTags 接口输入参数 + public static class NET_IN_FILE_STREAM_GET_TAGS_INFO extends Structure + { + public int dwSize; // 结构体大小 + + public NET_IN_FILE_STREAM_GET_TAGS_INFO() { + this.dwSize = this.size(); + } + } + + // CLIENT_FileStreamGetTags 接口输出参数 + public static class NET_OUT_FILE_STREAM_GET_TAGS_INFO extends Structure + { + public int dwSize; // 结构体大小 + public int nMaxNumber; // 标签数组最大个数 + public int nRetTagsCount; // 实际返回的标签信息个数 + public Pointer pstuTagInfo; // 标签数组 NET_FILE_STREAM_TAG_INFO_EX + + public NET_OUT_FILE_STREAM_GET_TAGS_INFO() { + this.dwSize = this.size(); + } + } + + // 查询到的标签信息 + public static class NET_FILE_STREAM_TAG_INFO_EX extends Structure + { + public int dwSize; // 结构体大小 + public NET_TIME stuTime; // 标签所对于视频的时间,精确到秒 + public int nMillisecond; // 毫秒 + public int nSequence; // 视频序列号 + public byte[] szContext = new byte[NET_COMMON_STRING_64]; // 标签内容,中文必须使用utf8编码 + public NET_TIME stuStartTime; // 录像文件开始时间 + public NET_TIME stuEndTime; // 录像文件结束时间 + public int emType; // 文件类型,对应 NET_FILE_STREAM_TYPE + public byte[] szUserName = new byte[NET_COMMON_STRING_32]; // 用户名,中文必须使用utf8编码,EVS定制增加 + public byte[] szChannelName = new byte[NET_COMMON_STRING_64]; // 通道名称,中文必须使用utf8编码,EVS定制增加 + + public NET_FILE_STREAM_TAG_INFO_EX() { + this.dwSize = this.size(); + } + } + + // 文件类型 + public static class NET_FILE_STREAM_TYPE extends Structure + { + public static final int NET_FILE_STREAM_TYPE_UNKNOWN = 0; // 未知 + public static final int NET_FILE_STREAM_TYPE_NORMAL = 1; // 普通 + public static final int NET_FILE_STREAM_TYPE_ALARM = 2; // 报警 + public static final int NET_FILE_STREAM_TYPE_DETECTION = 3; // 动检 + } + + // 一屏幕的分割模式信息, CLIENT_GetSplitMode/CLIENT_SetSplitMode参数 + public static class NET_SPLIT_MODE_INFO extends Structure + { + public int dwSize; + public int emSplitMode; // 分割模式, NET_SPLIT_MODE + public int nGroupID; // 分组序号 + public int dwDisplayType; // 显示类型;具体见DH_SPLIT_DISPLAY_TYPE(注释各模式下显示内容由"PicInPic"决定, 各模式下显示内容按NVD旧有规则决定(即DisChn字段决定)。兼容,没有这一个项时,默认为普通显示类型,即"General") + + public NET_SPLIT_MODE_INFO() { + this.dwSize = this.size(); + } + } + + // 分割能力, CLIENT_GetSplitCaps 参数 + public static class NET_SPLIT_CAPS extends Structure + { + public int dwSize; + public int nModeCount; // 支持的分割模式数量 + public int[] emSplitMode = new int[NET_MAX_SPLIT_MODE_NUM]; // 支持的分割模式, 见 NET_SPLIT_MODE + public int nMaxSourceCount; // 最大显示源配置数 + public int nFreeWindowCount; // 支持的最大自由开窗数目 + public int bCollectionSupported; // 是否支持区块收藏, BOOL类型,0或1 + public int dwDisplayType; // 掩码表示多个显示类型,具体见NET_SPLIT_DISPLAY_TYPE(注释各模式下显示内容由"PicInPic"决定, 各模式下显示内容按NVD旧有规则决定(即DisChn字段决定)。兼容,没有这一个项时,默认为普通显示类型,即"General") + public int nPIPModeCount; // 画中画支持的分割模式数量 + public int[] emPIPSplitMode = new int[NET_MAX_SPLIT_MODE_NUM]; // 画中画支持的分割模式, 见 NET_SPLIT_MODE + public int[] nInputChannels = new int[NET_SPLIT_INPUT_NUM]; // 支持的输入通道 + public int nInputChannelCount; // 支持的输入通道个数, 0表示没有输入通道限制 + public int nBootModeCount; // 启动分割模式数量 + public int[] emBootMode = new int[NET_MAX_SPLIT_MODE_NUM]; // 支持的启动默认画面分割模式, 见 NET_SPLIT_MODE + + public NET_SPLIT_CAPS() { + this.dwSize = this.size(); + } + } + + // (设置显示源, 支持同时设置多个窗口)CLIENT_SplitSetMultiSource 接口的输入参数 + public static class NET_IN_SPLIT_SET_MULTI_SOURCE extends Structure + { + public int dwSize; + public int emCtrlType; // 视频输出控制方式,见 EM_VIDEO_OUT_CTRL_TYPE + public int nChannel; // 视频输出逻辑通道号, emCtrlType为EM_VIDEO_OUT_CTRL_CHANNEL时有效 + public String pszCompositeID; // 拼接屏ID, emCtrlType为EM_VIDEO_OUT_CTRL_COMPOSITE_ID时有效 + public int bSplitModeEnable; // 是否改变分割模式, BOOL类型,0或1 + public int emSplitMode; // 分割模式, bSplitModeEnable=TRUE时有效,见 NET_SPLIT_MODE + public int nGroupID; // 分割分组号, bSplitModeEnable=TRUE时有效 + public Pointer pnWindows; // 窗口号数组 int[],由用户申请内存,大小为sizeof(int)*nWindowCount + public int nWindowCount; // 窗口数量 + public Pointer pstuSources; // 视频源信息, 分别对应每个窗口, 数量同窗口数 NET_SPLIT_SOURCE[] ,由用户申请内存,大小为sizeof(DH_SPLIT_SOURCE)*nWindowCount + + public NET_IN_SPLIT_SET_MULTI_SOURCE() { + this.dwSize = this.size(); + } + } + + // (设置显示源, 支持同时设置多个窗口) CLIENT_SplitSetMultiSource 接口的输出参数 + public static class NET_OUT_SPLIT_SET_MULTI_SOURCE extends Structure + { + public int dwSize; + + public NET_OUT_SPLIT_SET_MULTI_SOURCE() { + this.dwSize = this.size(); + } + } + + // (下位矩阵切换) CLIENT_MatrixSwitch 输入参数 + public static class NET_IN_MATRIX_SWITCH extends Structure + { + public int dwSize; + public int emSplitMode; // 分割模式,见 NET_SPLIT_MODE + public Pointer pnOutputChannels; // 输出通道, 可同时指定多个输出通道一起切换, 内容一致 + // 由用户申请内存 int[] ,大小为sizeof(int)*nOutputChannelCount + public int nOutputChannelCount; // 输出通道数 + public Pointer pnInputChannels; // 输入通道, 每个分割窗口一个对应一个输入通道 + // 由用户申请内存 int[] ,大小为sizeof(int)*nInputChannelCount + public int nInputChannelCount; // 输入通道数 + + public NET_IN_MATRIX_SWITCH() { + this.dwSize = this.size(); + } + } + + // (下位矩阵切换) CLIENT_MatrixSwitch 输出参数 + public static class NET_OUT_MATRIX_SWITCH extends Structure + { + public int dwSize; + + public NET_OUT_MATRIX_SWITCH() { + this.dwSize = this.size(); + } + } + + // 刻录模式 + public static class NET_BURN_MODE extends Structure + { + public static final int BURN_MODE_SYNC = 0; // 同步 + public static final int BURN_MODE_TURN = 1; // 轮流 + public static final int BURN_MODE_CYCLE = 2; // 循环 + } + + // 刻录流格式 + public static class NET_BURN_RECORD_PACK extends Structure + { + public static final int BURN_PACK_DHAV = 0; // DHAV + public static final int BURN_PACK_PS = 1; // PS + public static final int BURN_PACK_ASF = 2; // ASF + public static final int BURN_PACK_MP4 = 3; // MP4 + public static final int BURN_PACK_TS = 4; // TS + } + + // 刻录扩展模式 + public static class NET_BURN_EXTMODE extends Structure + { + public static final int BURN_EXTMODE_UNKNOWN = 0; // 未知 + public static final int BURN_EXTMODE_NORMAL = 1; // 正常刻录 + public static final int BURN_EXTMODE_NODISK = 2; // 无盘刻录 + } + + // (开始刻录) CLIENT_StartBurn 接口输入参数 + public static class NET_IN_START_BURN extends Structure + { + public int dwSize; + public int dwDevMask; // 刻录设备掩码, 按位表示多个刻录设备组合 + public int[] nChannels = new int[NET_MAX_BURN_CHANNEL_NUM]; // 刻录通道数组 + public int nChannelCount; // 刻录通道数 + public int emMode; // 刻录模式,见 NET_BURN_MODE + public int emPack; // 刻录流格式,见 NET_BURN_RECORD_PACK + public int emExtMode; // 刻录扩展模式, 见 NET_BURN_EXTMODE + + public NET_IN_START_BURN() { + this.dwSize = this.size(); + } + } + + // (开始刻录)CLIENT_StartBurn 接口输出参数 + public static class NET_OUT_START_BURN extends Structure + { + public int dwSize; + + public NET_OUT_START_BURN() { + this.dwSize = this.size(); + } + } + + // (打开会话)CLIENT_StartBurnSession 接口输入参数 + public static class NET_IN_START_BURN_SESSION extends Structure + { + public int dwSize; + public int nSessionID; // 会话ID + + public NET_IN_START_BURN_SESSION() { + this.dwSize = this.size(); + } + } + + // (打开会话)CLIENT_StartBurnSession 接口输出参数 + public static class NET_OUT_START_BURN_SESSION extends Structure + { + public int dwSize; + + public NET_OUT_START_BURN_SESSION() { + this.dwSize = this.size(); + } + } + + // 雷达监测超速报警事件 智能楼宇专用 ( NET_ALARM_RADAR_HIGH_SPEED ) + public static class ALARM_RADAR_HIGH_SPEED_INFO extends Structure + { + public NET_TIME_EX stuTime; // 事件发生时间 + public float fSpeed; // 速度(单位:km/h) + public byte[] szPlateNumber = new byte[16]; // 车牌 + public byte[] byReserved = new byte[1008]; // 预留字段 + } + + // 设备巡检报警事件 智网专用 ( NET_ALARM_POLLING_ALARM ) + public static class ALARM_POLLING_ALARM_INFO extends Structure + { + public NET_TIME_EX stuTime; // 事件发生时间 + public byte[] byReserved = new byte[1024]; // 预留字段 + } + + // 门禁事件 ALARM_ACCESS_CTL_EVENT + public static class ALARM_ACCESS_CTL_EVENT_INFO extends Structure { + public int dwSize; + public int nDoor; // 门通道号 + public byte[] szDoorName = new byte[NET_MAX_DOORNAME_LEN]; // 门禁名称 + public NET_TIME stuTime; // 报警事件发生的时间 + public int emEventType; // 门禁事件类型 参考 NET_ACCESS_CTL_EVENT_TYPE + public int bStatus; // 刷卡结果,TRUE表示成功,FALSE表示失败 + public int emCardType; // 卡类型, 参考 NET_ACCESSCTLCARD_TYPE + public int emOpenMethod; // 开门方式, 参考 NET_ACCESS_DOOROPEN_METHOD + public byte[] szCardNo = new byte[NET_MAX_CARDNO_LEN]; // 卡号 + public byte[] szPwd = new byte[NET_MAX_CARDPWD_LEN]; // 密码 + public byte[] szReaderID = new byte[NET_COMMON_STRING_32]; // 门读卡器ID + public byte[] szUserID = new byte[NET_COMMON_STRING_64]; // 开门用户 + public byte[] szSnapURL = new byte[NET_COMMON_STRING_256]; // 抓拍照片存储地址 + public int nErrorCode; // 开门失败的原因,仅在bStatus为FALSE时有效 + // 0x00 没有错误 + // 0x10 未授权 + // 0x11 卡挂失或注销 + // 0x12 没有该门权限 + // 0x13 开门模式错误 + // 0x14 有效期错误 + // 0x15 防反潜模式 + // 0x16 胁迫报警未打开 + // 0x17 门常闭状态 + // 0x18 AB互锁状态 + // 0x19 巡逻卡 + // 0x1A 设备处于闯入报警状态 + // 0x20 时间段错误 + // 0x21 假期内开门时间段错误 + // 0x30 需要先验证有首卡权限的卡片 + // 0x40 卡片正确,输入密码错误 + // 0x41 卡片正确,输入密码超时 + // 0x42 卡片正确,输入指纹错误 + // 0x43 卡片正确,输入指纹超时 + // 0x44 指纹正确,输入密码错误 + // 0x45 指纹正确,输入密码超时 + // 0x50 组合开门顺序错误 + // 0x51 组合开门需要继续验证 + // 0x60 验证通过,控制台未授权 + public int nPunchingRecNo; // 刷卡记录集中的记录编号 + public int nNumbers; // 抓图张数 + public int emStatus; // 卡状态 NET_ACCESSCTLCARD_STATE + public ALARM_ACCESS_CTL_EVENT_INFO() { + super(); + this.dwSize = this.size(); + } + @Override + public String toString() { + return "ALARM_ACCESS_CTL_EVENT_INFO [dwSize=" + dwSize + ", nDoor=" + + nDoor + ", szDoorName=" + Arrays.toString(szDoorName) + + ", stuTime=" + stuTime + ", emEventType=" + emEventType + + ", bStatus=" + bStatus + ", emCardType=" + emCardType + + ", emOpenMethod=" + emOpenMethod + ", szCardNo=" + + Arrays.toString(szCardNo) + ", szPwd=" + + Arrays.toString(szPwd) + ", szReaderID=" + + Arrays.toString(szReaderID) + ", szUserID=" + + Arrays.toString(szUserID) + ", szSnapURL=" + + Arrays.toString(szSnapURL) + ", nErrorCode=" + nErrorCode + + ", nPunchingRecNo=" + nPunchingRecNo + "]"; + } + } + + // 消警事件 + public static class ALARM_ALARMCLEAR_INFO extends Structure + { + public int dwSize; + public int nChannelID; // 通道号 + public NET_TIME stuTime; // 报警事件发生的时间 + public int bEventAction; // 事件动作,0表示脉冲事件,1表示持续性事件开始,2表示持续性事件结束; + public ALARM_ALARMCLEAR_INFO() { + this.dwSize = this.size(); + } + @Override + public String toString() { + return "ALARM_ALARMCLEAR_INFO [dwSize=" + dwSize + ", nChannelID=" + + nChannelID + ", stuTime=" + stuTime + ", bEventAction=" + + bEventAction + "]"; + } + } + + public static class NET_ALARM_TYPE + { + public static final int NET_ALARM_LOCAL = 0; //开关量防区的报警事件(对应 NET_ALARM_ALARM_EX2 事件) + public static final int NET_ALARM_ALARMEXTENDED = 1; //扩展模块报警事件(对应 NET_ALARM_ALARMEXTENDED 事件) + public static final int NET_ALARM_TEMP = 2; //温度报警事件(对应 NET_ALARM_TEMPERATURE 事件) + public static final int NET_ALARM_URGENCY = 3; //紧急报警事件(对应 NET_URGENCY_ALARM_EX 事件) + public static final int NET_ALARM_RCEMERGENCYCALL = 4; //紧急呼叫报警事件(对应 NET_ALARM_RCEMERGENCY_CALL 事件) + public static final int NET_ALARM_ALL = 5; //所有报警事件 + } + + // CLIENT_ControlDevice 接口的 NET_CTRL_CLEAR_ALARM 命令参数 + public static class NET_CTRL_CLEAR_ALARM extends Structure { + public int dwSize; + public int nChannelID; // 防区通道号, -1 表示所有通道 + public int emAlarmType; // 事件类型(支持的类型较少,建议用nEventType字段) NET_ALARM_TYPE + public String szDevPwd; // 登陆设备的密码,如不使用加密消警,直接赋值为NULL + public int bEventType; // 表示是否启用nEventType字段, TRUE:nEventType代替emAlarmType字段, FALSE:沿用emAlarmType字段,忽略nEventType字段 + public int nEventType; // 事件类型, 对应 fMessCallBack 回调来上的lCommand字段, 即CLIENT_StartListenEx接口获得事件类型 + // 比如DH_ALARM_ALARM_EX2表示本地报警事件 + public NET_CTRL_CLEAR_ALARM() { + this.dwSize = this.size(); + } + @Override + public String toString() { + return "NET_CTRL_CLEAR_ALARM [dwSize=" + dwSize + ", nChannelID=" + + nChannelID + ", emAlarmType=" + emAlarmType + ", szDevPwd=" + + szDevPwd + ", bEventType=" + bEventType + ", nEventType=" + + nEventType + "]"; + } + } + + // CLIENT_ControlDevice接口的 CTRLTYPE_CTRL_START_ALARMBELL / CTRLTYPE_CTRL_STOP_ALARMBELL命令参数 + public static class NET_CTRL_ALARMBELL extends Structure + { + public int dwSize; + public int nChannelID; // 通道号(0开始) + + public NET_CTRL_ALARMBELL(){ + this.dwSize = this.size(); + } + } + + // 警灯配置(对应 CFG_CMD_ALARMLAMP) + public static class CFG_ALARMLAMP_INFO extends Structure + { + public int emAlarmLamp; // 警灯状态,参考 EM_ALARMLAMP_MODE + } + + // 警灯状态 + public static class EM_ALARMLAMP_MODE extends Structure + { + public static final int EM_ALARMLAMP_MODE_UNKNOWN = -1; // 未知 + public static final int EM_ALARMLAMP_MODE_OFF = 0; // 灭 + public static final int EM_ALARMLAMP_MODE_ON = 1; // 亮 + public static final int EM_ALARMLAMP_MODE_BLINK = 2; // 闪烁 + } + + // 发送的通知类型,对应CLIENT_SendNotifyToDev接口 + public static class NET_EM_NOTIFY_TYPE extends Structure + { + public static final int NET_EM_NOTIFY_PATROL_STATUS = 1; // 发送巡更通知 (对应结构体 NET_IN_PATROL_STATUS_INFO, NET_OUT_PATROL_STATUS_INFO ) + } + + // 巡更状态 + public static class NET_EM_PATROL_STATUS extends Structure + { + public static final int NET_EM_PATROL_STATUS_UNKNOWN = 0; // 未知状态 + public static final int NET_EM_PATROL_STATUS_BEGIN = 1; // 巡更开始 + public static final int NET_EM_PATROL_STATUS_END = 2; // 巡更结束 + public static final int NET_EM_PATROL_STATUS_FAIL = 3; // 巡更失败 + } + + // CLIENT_SendNotifyToDev 入参 (对应枚举 NET_EM_NOTIFY_PATROL_STATUS) + public static class NET_IN_PATROL_STATUS_INFO extends Structure + { + public int dwSize; // 结构体大小 + public int emPatrolStatus; // 巡更状态,参考 NET_EM_PATROL_STATUS + + public NET_IN_PATROL_STATUS_INFO() { + this.dwSize = this.size(); + } + } + + // CLIENT_SendNotifyToDev 出参 (对应枚举 NET_EM_NOTIFY_PATROL_STATUS) + public static class NET_OUT_PATROL_STATUS_INFO extends Structure + { + public int dwSize; // 结构体大小 + + public NET_OUT_PATROL_STATUS_INFO() { + this.dwSize = this.size(); + } + } + + // 报警事件类型 NET_ALARM_TALKING_INVITE (设备请求对方发起对讲事件)对应的数据描述信息 + public static class ALARM_TALKING_INVITE_INFO extends Structure + { + public int dwSize; + public int emCaller; // 设备希望的对讲发起方,取值参考 EM_TALKING_CALLER + public NET_TIME stuTime; // 事件触发时间 + public byte[] szCallID = new byte[NET_COMMON_STRING_64]; // 呼叫惟一标识符 + public int nLevel; // 表示所呼叫设备所处层级 + public TALKINGINVITE_REMOTEDEVICEINFO stuRemoteDeviceInfo; // 远端设备信息 + + public ALARM_TALKING_INVITE_INFO() { + this.dwSize = this.size(); + } + } + + // 对讲发起方 + public static class EM_TALKING_CALLER extends Structure + { + public static final int EM_TALKING_CALLER_UNKNOWN = 0; // 未知发起方 + public static final int EM_TALKING_CALLER_PLATFORM = 1; // 对讲发起方为平台 + } + + // Invite事件远程设备协议 + public static class TALKINGINVITE_REMOTEDEVICE_PROTOCOL extends Structure + { + public static final int EM_TALKINGINVITE_REMOTEDEVICE_PROTOCOL_UNKNOWN = 0; // 未知 + public static final int EM_TALKINGINVITE_REMOTEDEVICE_PROTOCOL_HIKVISION = 1; // 海康 + } + + // Invite事件远端设备信息 + public static class TALKINGINVITE_REMOTEDEVICEINFO extends Structure + { + public byte[] szIP = new byte[MAX_REMOTEDEVICEINFO_IPADDR_LEN]; // 设备IP + public int nPort; // 端口 + public int emProtocol; // 协议类型,取值参考 EM_TALKINGINVITE_REMOTEDEVICE_PROTOCOL + public byte[] szUser = new byte[MAX_REMOTEDEVICEINFO_USERNAME_LEN]; // 用户名 + public byte[] szPassword = new byte[MAX_REMOTEDEVICEINFO_USERPSW_LENGTH];// 密码 + public byte[] szReverse = new byte[1024]; // 保留字段 + } + + // IO控制命令,对应 CLIENT_QueryIOControlState 接口 和 CLIENT_IOControl 接口 + public static class NET_IOTYPE extends Structure + { + public static final int NET_ALARMINPUT = 1; // 控制报警输入,对应结构体为 ALARM_CONTROL + public static final int NET_ALARMOUTPUT = 2; // 控制报警输出,对应结构体为 ALARM_CONTROL + public static final int NET_DECODER_ALARMOUT = 3; // 控制报警解码器输出,对应结构体为 DECODER_ALARM_CONTROL + public static final int NET_WIRELESS_ALARMOUT = 5; // 控制无线报警输出,对应结构体为 ALARM_CONTROL + public static final int NET_ALARM_TRIGGER_MODE = 7; // 报警触发方式(手动,自动,关闭),使用 TRIGGER_MODE_CONTROL 结构体 + } + + // 报警IO控制 + public static class ALARM_CONTROL extends Structure + { + public short index; // 端口序号 + public short state; // 端口状态,0 - 关闭,1 - 打开 + } + + // 报警解码器控制 + public static class DECODER_ALARM_CONTROL extends Structure + { + public int decoderNo; // 报警解码器号,从0开始 + public short alarmChn; // 报警输出口,从0开始 + public short alarmState; // 报警输出状态;1:打开,0:关闭 + } + + // 触发方式 + public static class TRIGGER_MODE_CONTROL extends Structure + { + public short index; // 端口序号 + public short mode; // 触发方式(0关闭1手动2自动);不设置的通道,sdk默认将保持原来的设置。 + public byte[] bReserved = new byte[28]; + } + + // 报警输出通道的状态的配置, 对应 命令 CFG_CMD_ALARMOUT + public static class CFG_ALARMOUT_INFO extends Structure + { + public int nChannelID; // 报警通道号(0开始) + public byte[] szChnName = new byte[MAX_CHANNELNAME_LEN]; // 报警通道名称 + public byte[] szOutputType = new byte[MAX_NAME_LEN]; // 输出类型, 用户自定义 + public int nOutputMode; // 输出模式, 0-自动报警, 1-强制报警, 2-关闭报警 + public int nPulseDelay; // 脉冲模式输出时间, 单位为秒(0-255秒) + public int nSlot; // 根地址, 0表示本地通道, 1表示连接在第一个串口上的扩展通道, 2、3...以此类推, -1表示无效 + public int nLevel1; // 第一级级联地址, 表示连接在第nSlot串口上的第nLevel1个探测器或仪表, 从0开始, -1表示无效 + public byte abLevel2; // 类型为bool, 表示nLevel2字段是否存在 + public int nLevel2; // 第二级级联地址, 表示连接在第nLevel1个的仪表上的探测器序号, 从0开始 + } + + // 检测采集设备报警事件, 对应事件类型 NET_ALARM_SCADA_DEV_ALARM + public static class ALARM_SCADA_DEV_INFO extends Structure + { + public int dwSize; + public int nChannel; // 通道号 + public NET_TIME stuTime; // 事件发生的时间 + public byte[] szDevName = new byte[NET_COMMON_STRING_64]; // 故障设备名称 + public byte[] szDesc = new byte[NET_COMMON_STRING_256]; // 报警描述 + public int nAction; // -1:未知 0:脉冲 1:开始 2:停止 + public byte[] szID = new byte[NET_COMMON_STRING_32]; // 点位ID, 目前使用16字节 + public byte[] szSensorID = new byte[NET_COMMON_STRING_32]; // 探测器ID, 目前使用16字节 + public byte[] szDevID = new byte[NET_COMMON_STRING_32]; // 设备ID, 目前使用16字节 + public byte[] szPointName = new byte[NET_COMMON_STRING_64]; // 点位名,与点表匹配 + public int nAlarmFlag; // 0:开始, 1:结束 + + public ALARM_SCADA_DEV_INFO() { + this.dwSize = this.size(); + } + } + + // 点位类型 + public static class EM_NET_SCADA_POINT_TYPE extends Structure + { + public static final int EM_NET_SCADA_POINT_TYPE_UNKNOWN = 0; // 未知 + public static final int EM_NET_SCADA_POINT_TYPE_ALL = 1; // 所有类型 + public static final int EM_NET_SCADA_POINT_TYPE_YC = 2; // 遥测 模拟量输入 + public static final int EM_NET_SCADA_POINT_TYPE_YX = 3; // 遥信 开关量输入 + public static final int EM_NET_SCADA_POINT_TYPE_YT = 4; // 遥调 模拟量输出 + public static final int EM_NET_SCADA_POINT_TYPE_YK = 5; // 遥控 开关量输出 + } + + // CLIENT_SCADAAttachInfo()接口输入参数 + public static class NET_IN_SCADA_ATTACH_INFO extends Structure + { + public int dwSize; + public StdCallCallback cbCallBack; // 数据回调函数, fSCADAAttachInfoCallBack 回调 + public int emPointType; // 点位类型,取值参考 EM_NET_SCADA_POINT_TYPE + public LLong dwUser; // 用户定义参数 + + public NET_IN_SCADA_ATTACH_INFO() { + this.dwSize = this.size(); + } + } + + // CLIENT_SCADAAttachInfo()接口输出参数 + public static class NET_OUT_SCADA_ATTACH_INFO extends Structure + { + public int dwSize; + + public NET_OUT_SCADA_ATTACH_INFO() { + this.dwSize = this.size(); + } + } + + // 监测点位信息列表 + public static class NET_SCADA_NOTIFY_POINT_INFO_LIST extends Structure + { + public int dwSize; + public int nList; // 监测点位信息个数 + public NET_SCADA_NOTIFY_POINT_INFO[] stuList = (NET_SCADA_NOTIFY_POINT_INFO[])new NET_SCADA_NOTIFY_POINT_INFO().toArray(MAX_SCADA_POINT_LIST_INFO_NUM); // 监测点位信息 + + public NET_SCADA_NOTIFY_POINT_INFO_LIST() { + this.dwSize = this.size(); + } + } + + // 监测点位信息 + public static class NET_SCADA_NOTIFY_POINT_INFO extends Structure + { + public int dwSize; + public byte[] szDevName = new byte[NET_COMMON_STRING_64]; // 设备名称,与getInfo获取的名称一致 + public int emPointType; // 点位类型,取值参考 EM_NET_SCADA_POINT_TYPE + public byte[] szPointName = new byte[NET_COMMON_STRING_64]; // 点位名,与点位表的取值一致 + public float fValue; // Type为YC时为浮点数 + public int nValue; // Type为YX时为整数 + public byte[] szFSUID = new byte[NET_COMMON_STRING_64]; // 现场监控单元ID(Field Supervision Unit), 即设备本身 + public byte[] szID = new byte[NET_COMMON_STRING_64]; // 点位ID + public byte[] szSensorID = new byte[NET_COMMON_STRING_64]; // 探测器ID + public NET_TIME_EX stuCollectTime; // 采集时间 + + public NET_SCADA_NOTIFY_POINT_INFO() { + this.dwSize = this.size(); + } + } + + public static class CFG_TRAFFICSNAPSHOT_NEW_INFO extends Structure + { + public int nCount; // 有效成员个数 + public CFG_TRAFFICSNAPSHOT_INFO[] stInfo = (CFG_TRAFFICSNAPSHOT_INFO[])new CFG_TRAFFICSNAPSHOT_INFO().toArray(8); // 交通抓拍表数组 + } + + // CFG_CMD_INTELLECTIVETRAFFIC + public static class CFG_TRAFFICSNAPSHOT_INFO extends Structure + { + public byte[] szDeviceAddress = new byte[MAX_DEVICE_ADDRESS]; // 设备地址 UTF-8编码,256字节 + public int nVideoTitleMask; // OSD叠加类型掩码 从低位到高位分别表示:0-时间 1-地点 2-车牌3-车长 4-车速 5-限速6-大车限速 7-小车限速8-超速 9-违法代码10-车道号 11-车身颜色 12-车牌类型 13-车牌颜色14-红灯点亮时间 15-违章类型 16-雷达方向 17-设备编号 18-标定到期时间 19-车型 20-行驶方向 + public int nRedLightMargin; // 红灯冗余间隔时间 红灯开始的一段时间内,车辆通行不算闯红灯,单位:秒 + public float fLongVehicleLengthLevel; // 超长车长度最小阈值 单位:米,包含 + public float[] arfLargeVehicleLengthLevel = new float[2]; // 大车长度阈值 单位:米,包含小值 + public float[] arfMediumVehicleLengthLevel = new float[2]; // 中型车长度阈值 单位:米,包含小值 + public float[] arfSmallVehicleLengthLevel = new float[2]; // 小车长度阈值 单位:米,包含小值 + public float fMotoVehicleLengthLevel; // 摩托车长度最大阈值 单位:米,不包含 + public BREAKINGSNAPTIMES_INFO stBreakingSnapTimes; // 违章抓拍张数 + public DETECTOR_INFO[] arstDetector = (DETECTOR_INFO[])new DETECTOR_INFO().toArray(MAX_DETECTOR); // 车检器配置,下标是车道号 + public int nCarType; // 抓拍车辆类型 0-大小车都抓拍1-抓拍小车2-抓拍大车3-大小车都不抓拍 + public int nMaxSpeed; // 当测得的速度超过最大速度时,则以最大速度计 0~255km/h + public int nFrameMode; // 帧间隔模式 1-速度自适应(超过速度上限取0间隔,低于速度下限取2间隔,中间取1间隔)2-由联动参数决定 + public int[] arnAdaptiveSpeed = new int[2]; // 速度自适应下限和上限 + public CFG_ALARM_MSG_HANDLE stuEventHandler; // 交通抓拍联动参数 + public int abSchemeRange; // BOOL类型,TRUE:方案针对相机,以车到0的值为准;FALSE:方案针对车道。不可以修改此字段数据, 只内部使用 + public int nVideoTitleMask1; // 从低位到高位分别表示:0-车标 1-红灯结束时间 2-设备制造厂商 3-小车低限速 4-大车低限速 5-小车高限速 6-大车高限速 7-设备工作模式 8-通用自定义 9-车道自定义 10-抓拍触发源 11-停车场区域12-车辆类型(面包车、轿车等等) 13-中车低限速 14-中车高限速 15-道路方向 16-GPS信息 + public int nMergeVideoTitleMask; // 合成图片OSD叠加类型掩码 参照nVideoTitleMask字段 + public int nMergeVideoTitleMask1; // 合成图片OSD叠加类型掩码 参照nVideoTitleMask1字段 + public int nTriggerSource; // 触发源掩码 0-RS232 1-RS485 2-IO 3-Video 4-Net + public int nSnapMode; // 抓拍模式 0-全部抓拍 1-超速抓拍 2-逆向抓拍 3-PK模式 + public int nWorkMode; // 工作模式 0-自动模式,1-线圈抓拍模式,2-线圈抓拍识别,3-视频抓拍,4-视频识别, 5-混合抓拍(带识别) + public int nCarThreShold; // 车长阈值 区分大小车长的阈值,单位: cm + public int nSnapType; // 抓拍或抓录选择 0-正常抓拍模式 1-视频抓拍模式 2-黑屏快抓模式 + public int[] nCustomFrameInterval = new int[3]; // 自定义抓拍帧间隔 第一个元素指车速小于速度自适应下限时的抓拍帧间隔,依次类推 + public int nKeepAlive; // 与雷达、车检器的默认保活周期 单位秒 + public OSD_INFO stOSD; // 原始图片OSD参数配置 + public OSD_INFO stMergeOSD; // 合成图片OSD参数配置 + public CFG_NET_TIME stValidUntilTime; // 标定到期时间,指该时间点之前抓拍照片有效 + public RADAR_INFO stRadar; + public byte[] szRoadwayCode = new byte[MAX_ROADWAYNO]; // 道路代码 + public int nVideoTitleMask2; // 原始图片OSD叠加类型掩码2 从低位到高位分别表示:0-国别 1-尾气数据 + public int nMergeVideoTitleMask2; // 合成图片OSD叠加类型掩码2 参照nVideoTitleMask2字段 + public int nParkType; // 出入口类型,0-默认( 兼容以前,不区分出口/入口 ),1-入口相机, 2-出口相机 + } + + // 车检器配置 + public static class DETECTOR_INFO extends Structure + { + public int nDetectBreaking; // 违章类型掩码 从低位到高位依次是:0-正常1-闯红灯2-压线3-逆行4-欠速5-超速6-有车占道 + // 7-黄牌占道 8-闯黄灯 9-违章占公交车道 10-不系安全带 11-驾驶员抽烟 12-驾驶员打电话 + public COILCONFIG_INFO[] arstCoilCfg = (COILCONFIG_INFO[])new COILCONFIG_INFO().toArray(MAX_COILCONFIG); // 线圈配置数组 + public int nRoadwayNumber; // 车道号 1-16 ; 0表示不启用 + public int nRoadwayDirection; // 车道方向(车开往的方向) 0-南向北 1-西南向东北 2-东 3-西北向东南 4-北向南 5-东北向西南 6-东向西 7-东南向西北 8-忽略 + public int nRedLightCardNum; // 卡口图片序号 表示将电警中的某一张图片作为卡口图片(共三张),0表示不采用,1~3,表示采用对应序号的图片 + public int nCoilsNumber; // 线圈个数 1-3 + public int nOperationType; // 业务模式 0-卡口电警1-电警2-卡口 + public int[] arnCoilsDistance = new int[3]; // 两两线圈的间隔 范围0-1000,单位为厘米 + public int nCoilsWidth; // 每个线圈的宽度 0~200cm + public int[] arnSmallCarSpeedLimit = new int[2]; // 小型车辆速度下限和上限 0~255km/h,不启用大小车限速时作为普通车辆限速 + public int[] arnBigCarSpeedLimit = new int[2]; // 大型车辆速度下限和上限 0~255km/h,启用大小车限速时有效 + public int nOverSpeedMargin; // 限高速宽限值 单位:km/h + public int nBigCarOverSpeedMargin; // 大车限高速宽限值 单位:km/h,启用大小车限速时有效 + public int nUnderSpeedMargin; // 限低速宽限值 单位:km/h + public int nBigCarUnderSpeedMargin; // 大车限低速宽限值 单位:km/h,启用大小车限速时有效 + public byte bSpeedLimitForSize; // bool类型,是否启用大小车限速 + public byte bMaskRetrograde; // bool类型,逆行是否视为违章行为 + public byte[] byReserved = new byte[2]; // 保留对齐 + public byte[] szDrivingDirection = new byte[3*MAX_DRIVINGDIRECTION]; // "DrivingDirection" : ["Approach", "上海", "杭州"],行驶方向 + // "Approach"-上行,即车辆离设备部署点越来越近;"Leave"-下行, + // 即车辆离设备部署点越来越远,第二和第三个参数分别代表上行和 + // 下行的两个地点,UTF-8编码 + public int nOverPercentage; // 超速百分比,超过限速百分比后抓拍 + public int nCarScheme; // 具体的方案Index,具体方案含义参参考打包环境local.png;根据CFG_TRAFFICSNAPSHOT_INFO.abSchemeRange字段区分作用范围 + public int nSigScheme; // 同上,非卡口使用 + public int bEnable; // BOOL类型,车道是否有效,只有有效时才抓拍 + public int[] nYellowSpeedLimit = new int[2]; //黄牌车限速上限和下限 范围0~255km/h + public int nRoadType; //工作路段 0 普通公路 1 高速公路 + public int nSnapMode; //抓拍模式 0-全部抓拍 1-超速抓拍 2-逆向抓拍(鄞州项目用) + public int nDelayMode; //延时抓拍方案 0-使DelaySnapshotDistance,1-使用DelayTime + public int nDelayTime; //延时抓拍时间 闯红灯第三张抓拍位置距离最后一个线圈的时间,单位毫秒 + public int nTriggerMode; //触发模式 0-入线圈触发 1-出线圈触发 2-出入都抓拍 3-关闭 + public int nErrorRange; //速度误差值,进线圈2与进线圈3之间的速度误差值,若实际误差大于或等于该值,视速度无效,否则取平均速度 0-20 + public double dSpeedCorrection; //速度校正系数,即速度值为测出的值乘以该系数 + public int[] nDirection = new int[2]; //相对车道方向需要上报车辆行驶方向,nDirection[0] 0--空 1--正向 ; nDirection[1] 0--空 1--反向 + public byte[] szCustomParkNo = new byte[CFG_COMMON_STRING_32 + 1];// 自定义车位号(停车场用) + public byte[] btReserved = new byte[3]; + } + + // 线圈配置 + public static class COILCONFIG_INFO extends Structure + { + public int nDelayFlashID; // 延时闪光灯序号 每个线圈对应的延时闪关灯序号,范围0~5,0表示不延时任何闪光灯 + public int nFlashSerialNum; // 闪光灯序号 范围0~5,0表示不打开闪光灯(鄞州项目用) + public int nRedDirection; // 红灯方向 每个线圈对应的红灯方向:0-不关联,1-左转红灯,2-直行红灯,3-右转红灯,4-待左,5-待直,6-待右, 只在电警中有效 + public int nTriggerMode ; // 线圈触发模式 触发模式:0-入线圈触发1-出线圈触发(鄞州项目用) + public int nFlashSerialNum2; //多抓第二张对应闪光灯序号 范围0~5,0表示不打开闪光灯 + public int nFlashSerialNum3; //多抓第三张对应闪光灯序号 范围0~5,0表示不打开闪光灯 + } + + // 违章抓拍张数 + public static class BREAKINGSNAPTIMES_INFO extends Structure + { + public int nNormal; // 正常 + public int nRunRedLight; // 闯红灯 + public int nOverLine; // 压线 + public int nOverYellowLine; // 压黄线 + public int nRetrograde; // 逆向 + public int nUnderSpeed; // 欠速 + public int nOverSpeed; // 超速 + public int nWrongRunningRoute; // 有车占道 + public int nYellowInRoute; // 黄牌占道 + public int nSpecialRetrograde; // 特殊逆行 + public int nTurnLeft; // 违章左转 + public int nTurnRight; // 违章右转 + public int nCrossLane; // 违章变道 + public int nU_Turn; // 违章调头 + public int nParking; // 违章停车 + public int nWaitingArea; // 违章进入待行区 + public int nWrongRoute; // 不按车道行驶 + public int nParkingSpaceParking; // 车位有车 + public int nParkingSpaceNoParking; // 车位无车 + public int nRunYellowLight; // 闯黄灯 + public int nStay; // 违章停留 + public int nPedestrainPriority; // 斑马线行人优先违章 + public int nVehicleInBusRoute; // 违章占道 + public int nBacking; // 违章倒车 + public int nOverStopLine; // 压停止线 + public int nParkingOnYellowBox; // 黄网格线停车 + public int nRestrictedPlate; // 受限车牌 + public int nNoPassing; // 禁行 + public int nWithoutSafeBelt; // 不系安全带 + public int nDriverSmoking; // 驾驶员抽烟 + public int nDriverCalling; // 驾驶员打电话 + public int nPedestrianRunRedLight; // 行人闯红灯 + public int nPassNotInOrder; // 未按规定依次通行 + } + + //OSD属性 + public static class OSD_INFO extends Structure + { + public BLACK_REGION_INFO stBackRegionInfo; //OSD黑边属性 + public int nOSDAttrScheme; //OSD属性配置方案 0=未知 , 1=全体OSD项共用属性 , 2=每个OSD项一个属性 + public OSD_ATTR_SCHEME stOSDAttrScheme; //OSD属性配置方案内容 + public OSD_CUSTOM_SORT[] stOSDCustomSorts = (OSD_CUSTOM_SORT[])new OSD_CUSTOM_SORT().toArray(MAX_OSD_CUSTOM_SORT_NUM); //OSD叠加内容自定义排序 + public int nOSDCustomSortNum; + public int nRedLightTimeDisplay; //OSD红灯时间配置 0=未知,1=违法最后一张,2=所有张 + public byte cSeperater; //OSD不同项之间的分隔符 + public byte[] bReserved = new byte[3]; //字节对齐 + public byte[] szOSDOrder = new byte[MAX_CONF_CHAR]; + public int nOSDContentScheme; //0=未知, 1=Mask , 2=CustomizeSort + public OSD_CUSTOM_INFO stOSDCustomInfo; //OSD自定义项 + } + + //OSD黑边 + public static class BLACK_REGION_INFO extends Structure + { + public int nHeight; //黑边高度 取值范围:0 ~ ( 8192-原图片高度) + public int nOSDPosition; //黑边位置 0=未知 , 1=顶部 , 2=底部 + } + + //OSD属性配置方案内容 + public static class OSD_ATTR_SCHEME extends Structure + { + public OSD_WHOLE_ATTR stWholeAttr; //全体OSD项共用属性 + } + + //全体OSD项共用属性 + public static class OSD_WHOLE_ATTR extends Structure + { + public int bPositionAsBlackRegion; //BOOL类型,位置是否同黑边相同,true时,下面的Position无效,BOOL类型 + public CFG_RECT stPostion; //位置,不能超过图片范围 + public int bNewLine; //BOOL类型,超出矩形范围是否换行,bPositionAsBlackRegion为true时有效,BOOL类型 + public int bLoneVehicle; //BOOL类型,车辆信息独立显示,true 一行显示一辆车信息,false 允许多辆车信息显示在一行,BOOL类型 + } + + //OSD叠加内容自定义排序 + public static class OSD_CUSTOM_SORT extends Structure + { + public OSD_CUSTOM_ELEMENT[] stElements = (OSD_CUSTOM_ELEMENT[])new OSD_CUSTOM_ELEMENT().toArray(MAX_OSD_CUSTOM_SORT_ELEM_NUM); //具体叠加元素 + public int nElementNum; + } + + //OSD具体叠加元素 + public static class OSD_CUSTOM_ELEMENT extends Structure + { + public int nNameType; //名称类型, 0:szName字段含义参照szOSDOrder字段定义的项 + // 1:"Name"字段表示自定义项,无需解析 + public byte[] szName = new byte[MAX_OSD_CUSTOM_VALUE_LEN]; // 该项名称 + public byte[] szPrefix = new byte[MAX_PRE_POX_STR_LEN]; // 叠加前缀字符串 + public byte[] szPostfix = new byte[MAX_PRE_POX_STR_LEN]; //叠加后缀字符串 + public int nSeperaterCount; //后面添加分隔符个数 + + } + + //OSD自定义项 + public static class OSD_CUSTOM_INFO extends Structure + { + public OSD_CUSTOM_GENERAL_INFO[] stGeneralInfos = (OSD_CUSTOM_GENERAL_INFO[])new OSD_CUSTOM_GENERAL_INFO().toArray(MAX_OSD_CUSTOM_GENERAL_NUM); //具体叠加元素 + public int nGeneralInfoNum; + } + + public static class OSD_CUSTOM_GENERAL_INFO extends Structure + { + public int bEnable; //BOOL类型,是否叠加 + } + + public static class RADAR_INFO extends Structure + { + public int nAngle; //角度,用于修正雷达探头安装的角度造成的速度误差,范围[0,90] + public int nAntiJammingValue; //抗干扰门槛值 + public int nComeInValue; //来向进入门槛值,取值范围[0,65535] + public int nComeOutValue; //来向离开门槛值 + public int nDelayTime; //雷达延时,单位ms,范围[0,255] + public int nDetectBreaking; //违章类型掩码,从低位到高位依次是: + //0-正常,1-闯红灯, 2-压线, 3-逆行,4-欠速 + //5-超速,6-有车占道,7-黄牌占道,8-闯黄灯,9-违章占公交车道 + public int nDetectMode; //检测模式 0-车头检测 1-车尾检测 2-双向检测 + public int nInstallMode; //雷达安装方式 0-侧面安装 1-上方安装 + public int nLevel; //灵敏度,0级灵敏度最高,范围[0,5] + public int nMultiTargetFilter; //多目标过滤模式,0-正常 1-过滤 + public int nWentEndValue; //去向信号结束门槛值 + public int nWentInValue; //去向进入门槛值 + public int nWentOutValue; //去向离开门槛值 + } + + // 串口状态 + public static class NET_COMM_STATE extends Structure + { + public int uBeOpened; // 串口是否打开,0:未打开 1:打开. + public int uBaudRate; // 波特率, 1~8分别表示 1200 2400 4800 9600 19200 38400 57600 115200 + public int uDataBites; // 数据位,4~8表示4位~8位 + public int uStopBits; // 停止位, 232串口 : 数值0 代表停止位1; 数值1 代表停止位1.5; 数值2 代表停止位2. 485串口 : 数值1 代表停止位1; 数值2 代表停止位2. + public int uParity; // 检验, 0:无校验,1:奇校验;2:偶校验; + public byte[] bReserved = new byte[32]; + } + + + // 门禁卡记录查询条件 + public static class FIND_RECORD_ACCESSCTLCARD_CONDITION extends Structure + { + public int dwSize; + public byte[] szCardNo = new byte[NET_MAX_CARDNO_LEN]; // 卡号 + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + public int bIsValid; // 是否有效, 1:有效, 0:无效 , boolean类型,为1或者0 + public int abCardNo; // 卡号查询条件是否有效,针对成员 szCardNo,boolean类型,为1或者0 + public int abUserID; // 用户ID查询条件是否有效,针对成员 szUserID, boolean类型,为1或者0 + public int abIsValid; // IsValid查询条件是否有效,针对成员 bIsValid, boolean类型,为1或者0 + + public FIND_RECORD_ACCESSCTLCARD_CONDITION() { + this.dwSize = this.size(); + } + } + + // 门禁卡记录集信息 + public static class NET_RECORDSET_ACCESS_CTL_CARD extends Structure + { + public int dwSize; + public int nRecNo; // 记录集编号,只读 + public NET_TIME stuCreateTime = new NET_TIME(); // 创建时间 + public byte[] szCardNo = new byte[NET_MAX_CARDNO_LEN]; // 卡号 + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID, 设备暂不支持 + public int emStatus; // 卡状态 NET_ACCESSCTLCARD_STATE + public int emType; // 卡类型 NET_ACCESSCTLCARD_TYPE + public byte[] szPsw = new byte[NET_MAX_CARDPWD_LEN]; // 卡密码 + public int nDoorNum; // 有效的门数目; + public int[] sznDoors = new int[NET_MAX_DOOR_NUM]; // 有权限的门序号,即CFG_CMD_ACCESS_EVENT配置的数组下标 + public int nTimeSectionNum; // 有效的的开门时间段数目 + public int[] sznTimeSectionNo = new int[NET_MAX_TIMESECTION_NUM]; // 开门时间段索引,即CFG_ACCESS_TIMESCHEDULE_INFO的数组下标 + public int nUserTime; // 使用次数,仅当来宾卡时有效 + public NET_TIME stuValidStartTime = new NET_TIME(); // 开始有效期, 设备暂不支持时分秒 + public NET_TIME stuValidEndTime = new NET_TIME(); // 结束有效期, 设备暂不支持时分秒 + public int bIsValid; // 是否有效,1有效; 0无效, boolean类型,为1或者0 + public NET_ACCESSCTLCARD_FINGERPRINT_PACKET stuFingerPrintInfo; // 下发指纹数据信息,仅为兼容性保留,请使用 stuFingerPrintInfoEx, 如果使用,内部的 pPacketData,请初始化 + public int bFirstEnter; // 是否拥有首卡权限, boolean类型,为1或者0 + public byte[] szCardName = new byte[NET_MAX_CARDNAME_LEN]; // 卡命名 + public byte[] szVTOPosition = new byte[NET_COMMON_STRING_64]; // 门口机关联位置 + public int bHandicap; // 是否为残疾人卡, boolean类型,为1或者0 + public int bEnableExtended; // 启用成员 stuFingerPrintInfoEx, boolean类型,为1或者0 + public NET_ACCESSCTLCARD_FINGERPRINT_PACKET_EX stuFingerPrintInfoEx; // 指纹数据信息, 如果使用,内部的 pPacketData,请初始化 + public int nFaceDataNum; // 人脸数据个数不超过20 + public byte[] szFaceData = new byte[MAX_FACE_DATA_NUM * MAX_FACE_DATA_LEN]; // 人脸模版数据 + public byte[] szDynamicCheckCode = new byte[MAX_COMMON_STRING_16]; // 动态校验码。 + // VTO等设备会保存此校验码,以后每次刷卡都以一定的算法生成新校验码并写入IC卡中,同时更新VTO设备的校验码,只有卡号和此校验码同时验证通过时才可开门。 + public int nRepeatEnterRouteNum; // 反潜路径个数 + public int[] arRepeatEnterRoute = new int[MAX_REPEATENTERROUTE_NUM]; // 反潜路径 + public int nRepeatEnterRouteTimeout; // 反潜超时时间 + public int bNewDoor; // 是否启动新开门授权字段,TRUE表示使用nNewDoorNum和nNewDoors字段下发开门权限, BOOL类型 + public int nNewDoorNum; // 有效的门数目; + public int[] nNewDoors = new int[MAX_ACCESSDOOR_NUM]; // 有权限的门序号,即CFG_CMD_ACCESS_EVENT配置的数组下标 + public int nNewTimeSectionNum; // 有效的的开门时间段数目 + public int[] nNewTimeSectionNo = new int[MAX_ACCESSDOOR_NUM]; // 开门时间段索引,即CFG_ACCESS_TIMESCHEDULE_INFO的数组下标 + public byte[] szCitizenIDNo = new byte[MAX_COMMON_STRING_32]; // 身份证号码 // 缺点:目前方案只支持一卡刷一个设备。 + + public NET_RECORDSET_ACCESS_CTL_CARD() { + this.dwSize = this.size(); + } + } + + // 卡状态 + public static class NET_ACCESSCTLCARD_STATE extends Structure + { + public static final int NET_ACCESSCTLCARD_STATE_UNKNOWN = -1; + public static final int NET_ACCESSCTLCARD_STATE_NORMAL = 0; // 正常 + public static final int NET_ACCESSCTLCARD_STATE_LOSE = 0x01; // 挂失 + public static final int NET_ACCESSCTLCARD_STATE_LOGOFF = 0x02; // 注销 + public static final int NET_ACCESSCTLCARD_STATE_FREEZE = 0x04; // 冻结 + public static final int NET_ACCESSCTLCARD_STATE_ARREARAGE = 0x08; // 欠费 + public static final int NET_ACCESSCTLCARD_STATE_OVERDUE = 0x10; // 逾期 + public static final int NET_ACCESSCTLCARD_STATE_PREARREARAGE = 0x20; // 预欠费(还是可以开门,但有语音提示) + } + + // 指纹数据,只用于下发信息 + public static class NET_ACCESSCTLCARD_FINGERPRINT_PACKET extends Structure + { + public int dwSize; + public int nLength; // 单个数据包长度,单位字节 + public int nCount; // 包个数 + public Pointer pPacketData; // 所有指纹数据包,用户申请内存并填充,长度为 nLength*nCount + + public NET_ACCESSCTLCARD_FINGERPRINT_PACKET() { + this.dwSize = this.size(); + } + } + + // 指纹数据扩展,可用于下发和获取信息 + public static class NET_ACCESSCTLCARD_FINGERPRINT_PACKET_EX extends Structure + { + public int nLength; // 单个数据包长度,单位字节 + public int nCount; // 包个数 + public Pointer pPacketData; // 所有指纹数据包, 用户申请内存,大小至少为nLength * nCount + public int nPacketLen; // pPacketData 指向内存区的大小,用户填写 + public int nRealPacketLen; // 返回给用户实际指纹总大小 + public byte[] byReverseed = new byte[1024]; //保留大小 + } + + + // 查询记录能力集能力集 + public static class CFG_CAP_RECORDFINDER_INFO extends Structure + { + public int nMaxPageSize;//最大分页条数 + } + + // 时间同步服务器配置 + public static class CFG_NTP_INFO extends Structure + { + public int bEnable; // 使能开关,BOOL类型 + public byte[] szAddress = new byte[MAX_ADDRESS_LEN]; // IP地址或网络名 + public int nPort; // 端口号 + public int nUpdatePeriod; // 更新周期,单位为分钟 + public int emTimeZoneType; // 时区, 参考 EM_CFG_TIME_ZONE_TYPE + public byte[] szTimeZoneDesc = new byte[MAX_NAME_LEN]; // 时区描述 + public int nSandbyServerNum; // 实际备用NTP服务器个数 + public CFG_NTP_SERVER[] stuStandbyServer = (CFG_NTP_SERVER[])new CFG_NTP_SERVER().toArray(MAX_NTP_SERVER); // 备选NTP服务器地址 + } + + // NTP服务器 + public static class CFG_NTP_SERVER extends Structure + { + public int bEnable; // BOOL类型 + public byte[] szAddress = new byte[MAX_ADDRESS_LEN]; // IP地址或网络名 + public int nPort; // 端口号 + } + + // 时区定义(NTP) + public static class EM_CFG_TIME_ZONE_TYPE extends Structure + { + public static final int EM_CFG_TIME_ZONE_0 = 0; // {0, 0*3600,"GMT+00:00"} + public static final int EM_CFG_TIME_ZONE_1 = 1; // {1, 1*3600,"GMT+01:00"} + public static final int EM_CFG_TIME_ZONE_2 = 2; // {2, 2*3600,"GMT+02:00"} + public static final int EM_CFG_TIME_ZONE_3 = 3; // {3, 3*3600,"GMT+03:00"} + public static final int EM_CFG_TIME_ZONE_4 = 4; // {4, 3*3600+1800,"GMT+03:30"} + public static final int EM_CFG_TIME_ZONE_5 = 5; // {5, 4*3600,"GMT+04:00"} + public static final int EM_CFG_TIME_ZONE_6 = 6; // {6, 4*3600+1800,"GMT+04:30"} + public static final int EM_CFG_TIME_ZONE_7 = 7; // {7, 5*3600,"GMT+05:00"} + public static final int EM_CFG_TIME_ZONE_8 = 8; // {8, 5*3600+1800,"GMT+05:30"} + public static final int EM_CFG_TIME_ZONE_9 = 9; // {9, 5*3600+1800+900,"GMT+05:45"} + public static final int EM_CFG_TIME_ZONE_10 = 10; // {10, 6*3600,"GMT+06:00"} + public static final int EM_CFG_TIME_ZONE_11 = 11; // {11, 6*3600+1800,"GMT+06:30"} + public static final int EM_CFG_TIME_ZONE_12 = 12; // {12, 7*3600,"GMT+07:00"} + public static final int EM_CFG_TIME_ZONE_13 = 13; // {13, 8*3600,"GMT+08:00"} + public static final int EM_CFG_TIME_ZONE_14 = 14; // {14, 9*3600,"GMT+09:00"} + public static final int EM_CFG_TIME_ZONE_15 = 15; // {15, 9*3600+1800,"GMT+09:30"} + public static final int EM_CFG_TIME_ZONE_16 = 16; // {16, 10*3600,"GMT+10:00"} + public static final int EM_CFG_TIME_ZONE_17 = 17; // {17, 11*3600,"GMT+11:00"} + public static final int EM_CFG_TIME_ZONE_18 = 18; // {18, 12*3600,"GMT+12:00"} + public static final int EM_CFG_TIME_ZONE_19 = 19; // {19, 13*3600,"GMT+13:00"} + public static final int EM_CFG_TIME_ZONE_20 = 20; // {20, -1*3600,"GMT-01:00"} + public static final int EM_CFG_TIME_ZONE_21 = 21; // {21, -2*3600,"GMT-02:00"} + public static final int EM_CFG_TIME_ZONE_22 = 22; // {22, -3*3600,"GMT-03:00"} + public static final int EM_CFG_TIME_ZONE_23 = 23; // {23, -3*3600-1800,"GMT-03:30"} + public static final int EM_CFG_TIME_ZONE_24 = 24; // {24, -4*3600,"GMT-04:00"} + public static final int EM_CFG_TIME_ZONE_25 = 25; // {25, -5*3600,"GMT-05:00"} + public static final int EM_CFG_TIME_ZONE_26 = 26; // {26, -6*3600,"GMT-06:00"} + public static final int EM_CFG_TIME_ZONE_27 = 27; // {27, -7*3600,"GMT-07:00"} + public static final int EM_CFG_TIME_ZONE_28 = 28; // {28, -8*3600,"GMT-08:00"} + public static final int EM_CFG_TIME_ZONE_29 = 29; // {29, -9*3600,"GMT-09:00"} + public static final int EM_CFG_TIME_ZONE_30 = 30; // {30, -10*3600,"GMT-10:00"} + public static final int EM_CFG_TIME_ZONE_31 = 31; // {31, -11*3600,"GMT-11:00"} + public static final int EM_CFG_TIME_ZONE_32 = 32; // {32, -12*3600,"GMT-12:00"} + } + + // 录像信息对应 CLIENT_FindFileEx 接口的 NET_FILE_QUERY_FILE 命令 查询条件 + // 目前支持通过路径查询 + public static class NET_IN_MEDIA_QUERY_FILE extends Structure + { + public int dwSize; // 结构体大小 + public String szDirs; // 工作目录列表,一次可查询多个目录,为空表示查询所有目录。目录之间以分号分隔,如“/mnt/dvr/sda0;/mnt/dvr/sda1”,szDirs==null 或"" 表示查询所有 + public int nMediaType; // 文件类型,0:查询任意类型,1:查询jpg图片,2:查询dav + public int nChannelID; // 通道号从0开始,-1表示查询所有通道 + public NET_TIME stuStartTime; // 开始时间 + public NET_TIME stuEndTime; // 结束时间 + public int[] nEventLists = new int[MAX_IVS_EVENT_NUM]; // 事件类型列表,参见智能分析事件类型 + public int nEventCount; // 事件总数 + public byte byVideoStream; // 视频码流 0-未知 1-主码流 2-辅码流1 3-辅码流2 4-辅码流3 + public byte[] bReserved = new byte[3]; // 字节对齐 + public int[] emFalgLists = new int[EM_RECORD_SNAP_FLAG_TYPE.FLAG_TYPE_MAX]; // 录像或抓图文件标志, 不设置标志表示查询所有文件, 参考 EM_RECORD_SNAP_FLAG_TYPE + public int nFalgCount; // 标志总数 + public NET_RECORD_CARD_INFO stuCardInfo; // 卡号录像信息, emFalgLists包含卡号录像时有效 + public int nUserCount; // 用户名有效个数 + public byte[] szUserName = new byte[MAX_QUERY_USER_NUM * NET_NEW_USER_NAME_LENGTH]; // 用户名 + public int emResultOrder; // 查询结果排序方式, 参考 EM_RESULT_ORDER_TYPE + + public NET_IN_MEDIA_QUERY_FILE() { + this.dwSize = this.size(); + } + } + + // 录像信息对应 CLIENT_FindFileEx 接口的 NET_FILE_QUERY_FILE 命令 查询结果 + public static class NET_OUT_MEDIA_QUERY_FILE extends Structure + { + public int dwSize; // 结构体大小 + public int nChannelID; // 通道号从0开始,-1表示查询所有通道 + public NET_TIME stuStartTime; // 开始时间 + public NET_TIME stuEndTime; // 结束时间 + public int nFileSize; // 文件长度 + public byte byFileType; // 文件类型 1:jpg图片, 2: dav + public byte byDriveNo; // 该字段已废弃,后续开发使用 nDriveNo成员 + public byte byPartition; // 分区号 + public byte byVideoStream; // 视频码流 0-未知 1-主码流 2-辅码流1 3-辅码流 4-辅码流 + public int nCluster; // 簇号 + public byte[] szFilePath = new byte[MAX_PATH]; // 文件路径 + public int[] nEventLists = new int[MAX_IVS_EVENT_NUM]; // 关联的事件列表,事件类型列表,参见智能分析事件类型 + public int nEventCount; //事件总数 + public int[] emFalgLists = new int[EM_RECORD_SNAP_FLAG_TYPE.FLAG_TYPE_MAX]; // 录像或抓图文件标志, 参考 EM_RECORD_SNAP_FLAG_TYPE + public int nFalgCount; //标志总数 + public int nDriveNo; // 磁盘号 + + //频浓缩文件相关信息 + public byte[] szSynopsisPicPath = new byte[NET_COMMON_STRING_512]; // 预处理文件提取到的快照 文件路径 + // 支持HTTP URL表示:"http://www.dahuate.com/1.jpg" + // 支持FTP URL表示: "ftp://ftp.dahuate.com/1.jpg" + // 支持服务器本地路径 + // a)"C:/pic/1.jpg" + // b)"/mnt//2010/8/11/dav/15:40:50.jpg" + public int nSynopsisMaxTime; // 支持浓缩视频最大时间长度,单位 秒 + public int nSynopsisMinTime; // 支持浓缩视频最小时间长度,单位 秒 + + //文件摘要信息 + public int nFileSummaryNum; // 文件摘要信息数 + public NET_FILE_SUMMARY_INFO[] stFileSummaryInfo = (NET_FILE_SUMMARY_INFO[])new NET_FILE_SUMMARY_INFO().toArray(MAX_FILE_SUMMARY_NUM); // 文件摘要信息 + + public NET_OUT_MEDIA_QUERY_FILE() { + this.dwSize = this.size(); + } + } + + // 卡号录像信息 + public static class NET_RECORD_CARD_INFO extends Structure + { + public int dwSize; + public int nType; // 类型, 0-Card, 1-Field + public byte[] szCardNo = new byte[NET_MAX_CARD_INFO_LEN]; // 卡号 + public int emTradeType; // 交易类型, 参考 EM_ATM_TRADE_TYPE + public byte[] szAmount = new byte[NET_COMMON_STRING_64]; // 交易金额, 空字符串表示不限金额 + public int nError; // 错误码, 0-所有错误, 1-吞钞, 2-吞卡 + public int nFieldCount; // 域数量, 按域查询时有效 + public byte[] szFields = new byte[MAX_CARD_RECORD_FIELD_NUM * NET_COMMON_STRING_256]; // 域信息, 按域查询时有效 + public byte[] szChange = new byte[NET_COMMON_STRING_32]; // 零钱 + + public NET_RECORD_CARD_INFO() { + this.dwSize = this.size(); + } + } + + // 文件摘要信息 + public static class NET_FILE_SUMMARY_INFO extends Structure + { + public byte[] szKey = new byte[NET_COMMON_STRING_64]; // 摘要名称 + public byte[] szValue = new byte[NET_COMMON_STRING_512]; // 摘要内容 + public byte[] bReserved = new byte[256]; // 保留字段 + } + + // 录像或抓图文件标志 + public static class EM_RECORD_SNAP_FLAG_TYPE extends Structure + { + public static final int FLAG_TYPE_TIMING = 0; //定时文件 + public static final int FLAG_TYPE_MANUAL = 1; //手动文件 + public static final int FLAG_TYPE_MARKED = 2; //重要文件 + public static final int FLAG_TYPE_EVENT = 3; //事件文件 + public static final int FLAG_TYPE_MOSAIC = 4; //合成图片 + public static final int FLAG_TYPE_CUTOUT = 5; //抠图图片 + public static final int FLAG_TYPE_LEAVE_WORD = 6; //留言文件 + public static final int FLAG_TYPE_TALKBACK_LOCAL_SIDE = 7; //对讲本地方文件 + public static final int FLAG_TYPE_TALKBACK_REMOTE_SIDE = 8; //对讲远程方文件 + public static final int FLAG_TYPE_SYNOPSIS_VIDEO = 9; //浓缩视频 + public static final int FLAG_TYPE_ORIGINAL_VIDEO = 10; //原始视频 + public static final int FLAG_TYPE_PRE_ORIGINAL_VIDEO = 11; //已经预处理的原始视频 + public static final int FLAG_TYPE_BLACK_PLATE = 12; //黑名单图片 + public static final int FLAG_TYPE_ORIGINAL_PIC = 13; //原始图片 + public static final int FLAG_TYPE_CARD = 14; //卡号录像 + public static final int FLAG_TYPE_MAX = 128; + } + + // 交易类型 + public static class EM_ATM_TRADE_TYPE extends Structure + { + public static final int ATM_TRADE_ALL = 0; // 所有类型 + public static final int ATM_TRADE_ENQUIRY = 1; // 查询 + public static final int ATM_TRADE_WITHDRAW = 2; // 取款 + public static final int ATM_TRADE_MODIFY_PASSWORD = 3; // 修改密码 + public static final int ATM_TRADE_TRANSFER = 4; // 转账 + public static final int ATM_TRADE_DEPOSIT = 5; // 存款 + public static final int ATM_TRADE_CARDLESS_ENQUIRY = 6; // 无卡查询 + public static final int ATM_TRADE_CARDLESS_DEPOSIT = 7; // 无卡存款 + public static final int ATM_TRADE_OTHER = 8; // 其他 + } + + // 查询结果排序方式 + public static class EM_RESULT_ORDER_TYPE extends Structure + { + public static final int EM_RESULT_ORDER_UNKNOWN = 0; // 未知 + public static final int EM_RESULT_ORDER_ASCENT_BYTIME = 1; // 按时间升序排序 + public static final int EM_RESULT_ORDER_DESCENT_BYTIME = 2; // 按时间降序排序 + } + + // CLIENT_ControlDevice 接口的 CTRLTYPE_CTRL_START_VIDEO_ANALYSE 命令参数, 开始视频智能分析 + public static class NET_CTRL_START_VIDEO_ANALYSE extends Structure + { + public int dwSize; + public int nChannelId; // 通道号 + + public NET_CTRL_START_VIDEO_ANALYSE() { + this.dwSize = this.size(); + } + } + + // CLIENT_ControlDevice 接口的 CTRLTYPE_CTRL_STOP_VIDEO_ANALYSE 命令参数, 停止视频智能分析 + public static class NET_CTRL_STOP_VIDEO_ANALYSE extends Structure + { + public int dwSize; + public int nChannelId; // 通道号 + + public NET_CTRL_STOP_VIDEO_ANALYSE() { + this.dwSize = this.size(); + } + } + + // CLIENT_AttachVideoAnalyseState 接口输入参数 + public static class NET_IN_ATTACH_VIDEOANALYSE_STATE extends Structure + { + public int dwSize; + public int nChannleId; // 通道号 + public StdCallCallback cbVideoAnalyseState; // 视频分析状态回调函数,fVideoAnalyseState 回调 + public LLong dwUser; // 用户信息 + + public NET_IN_ATTACH_VIDEOANALYSE_STATE() { + this.dwSize = this.size(); + } + } + + // CLIENT_AttachVideoAnalyseState 接口输出参数 + public static class NET_OUT_ATTACH_VIDEOANALYSE_STATE extends Structure + { + public int dwSize; + public LLong lAttachHandle; // 分析进度句柄,唯一标识某一通道的分析进度 + + public NET_OUT_ATTACH_VIDEOANALYSE_STATE() { + this.dwSize = this.size(); + } + } + + public static class NET_VIDEOANALYSE_STATE extends Structure + { + public int dwSize; + public int dwProgress; // 分析进度,0-100 + public byte[] szState = new byte[NET_COMMON_STRING_64]; // 通道状态,Running":运行,"Stop":停止,"NoStart":未启动,"Failed":失败,"Successed":成功 + public byte[] szFailedCode = new byte[NET_COMMON_STRING_64]; // 错误码 + + public NET_VIDEOANALYSE_STATE() { + this.dwSize = this.size(); + } + } + + // 热成像火情报警信息上报事件, 对应事件 NET_ALARM_FIREWARNING_INFO + public static class ALARM_FIREWARNING_INFO_DETAIL extends Structure + { + public int nChannel; // 对应视频通道号 + public int nWarningInfoCount; // 报警信息个数 + public NET_FIREWARNING_INFO[] stuFireWarningInfo + = new NET_FIREWARNING_INFO[MAX_FIREWARNING_INFO_NUM]; // 具体报警信息 + public byte[] reserved = new byte[256]; + + public ALARM_FIREWARNING_INFO_DETAIL() { + for(int i = 0; i < stuFireWarningInfo.length; i++) { + stuFireWarningInfo[i] = new NET_FIREWARNING_INFO(); + } + } + } + + //热成像火情报警信息 + public static class NET_FIREWARNING_INFO extends Structure + { + public int nPresetId; // 预置点编号 从测温规则配置 CFG_RADIOMETRY_RULE_INFO 中选择 + public NET_RECT stuBoundingBox; // 着火点矩形框 + public int nTemperatureUnit; // 温度单位(当前配置的温度单位),见 NET_TEMPERATURE_UNIT + public float fTemperature; // 最高点温度值 同帧检测和差分检测提供 + public int nDistance; // 着火点距离,单位米 0表示无效 + public GPS_POINT stuGpsPoint; // 着火点经纬度 + public PTZ_POSITION_UNIT stuPTZPosition; // 云台运行信息 + public float fAltitude; // 高度(单位:米) + public byte[] reserved = new byte[208]; + } + + // 着火点经纬度 + public static class GPS_POINT extends Structure + { + public int dwLongitude; // 经度(单位是百万分之度,范围0-360度)如东经120.178274度表示为300178274 + public int dwLatidude; // 纬度(单位是百万分之度,范围0-180度)如北纬30.183382度表示为120183382 + // 经纬度的具体转换方式可以参考结构体 NET_WIFI_GPS_INFO 中的注释 + } + + //云台控制坐标单元 + public static class PTZ_POSITION_UNIT extends Structure + { + public int nPositionX; // 云台水平方向角度,归一化到-1~1 + public int nPositionY; // 云台垂直方向角度,归一化到-1~1 + public int nZoom; // 云台光圈放大倍率,归一化到 0~1 + public byte[] szReserve = new byte[32]; // 预留32字节 + } + + // 搜索到的地点信息 + public static class NET_WIFI_GPS_INFO extends Structure + { + public int emPositioningResult; // 定位结果, 参考 NET_GPS_POSITION_RESULT + public int nLongitude; // 经度(单位是百万分之一度) + // 西经:0 - 180000000 实际值应为: 180*1000000 – dwLongitude + // 东经:180000000 - 360000000 实际值应为: dwLongitude – 180*1000000 + // 如: 300168866应为(300168866 - 180*1000000)/1000000 即东经120.168866度 + public int nLatidude; // 纬度(单位是百万分之一度) + // 南纬:0 - 90000000 实际值应为: 90*1000000 – dwLatidude + // 北纬:90000000 – 180000000 实际值应为: dwLatidude – 90*1000000 + // 如: 120186268应为 (120186268 - 90*1000000)/1000000 即北纬30. 186268度 + public int nSpeed; // 速度, 单位千分之一km/H + public byte[] reserved = new byte[112]; // 保留字段 + } + + // 定位结果 + public static class NET_GPS_POSITION_RESULT extends Structure + { + public static final int NET_GPS_POSITION_RESULT_UNKNOWN = 0; // 未知 + public static final int NET_GPS_POSITION_RESULT_FAILED = 1; // 有GPS数据,但定位失败,此时定位数据无意义 + public static final int NET_GPS_POSITION_RESULT_SUCCEED = 2; // 有GPS数据,且定位成功,此时定位数据有意义 + } + + // 温度单位 + public static class NET_TEMPERATURE_UNIT extends Structure + { + public static final int NET_TEMPERATURE_UNIT_UNKNOWN = 0; + public static final int NET_TEMPERATURE_UNIT_CENTIGRADE = 1; // 摄氏度 + public static final int NET_TEMPERATURE_UNIT_FAHRENHEIT = 2; // 华氏度 + } + + // 测温规则配置结构, 对应命令 CFG_CMD_THERMOMETRY_RULE + public static class CFG_RADIOMETRY_RULE_INFO extends Structure + { + public int nCount; // 规则个数 + public CFG_RADIOMETRY_RULE[] stRule = new CFG_RADIOMETRY_RULE[512]; // 测温规则 + + public CFG_RADIOMETRY_RULE_INFO() { + for(int i = 0; i < stRule.length; i++) { + stRule[i] = new CFG_RADIOMETRY_RULE(); + } + } + } + + // 测温规则 + public static class CFG_RADIOMETRY_RULE extends Structure + { + public int bEnable; // 测温使能, BOOL类型 + public int nPresetId; // 预置点编号 + public int nRuleId; // 规则编号 + public byte[] szName = new byte[128]; // 自定义名称 + public int nMeterType; // 测温模式的类型,见 NET_RADIOMETRY_METERTYPE + public CFG_POLYGON[] stCoordinates = new CFG_POLYGON[64]; // 测温点坐标 使用相对坐标体系,取值均为0~8191 + public int nCoordinateCnt; // 测温点坐标实际个数 + public int nSamplePeriod; // 温度采样周期 单位 : 秒 + public CFG_RADIOMETRY_ALARMSETTING[] stAlarmSetting = new CFG_RADIOMETRY_ALARMSETTING[64]; // 测温点报警设置 + public int nAlarmSettingCnt; // 测温点报警设置实际个数 + public CFG_RADIOMETRY_LOCALPARAM stLocalParameters; // 本地参数配置 + + public CFG_RADIOMETRY_RULE() { + for(int i = 0; i < stCoordinates.length; i++) { + stCoordinates[i] = new CFG_POLYGON(); + } + + for(int i = 0; i < stAlarmSetting.length; i++) { + stAlarmSetting[i] = new CFG_RADIOMETRY_ALARMSETTING(); + } + } + } + + // 测温点报警设置 + public static class CFG_RADIOMETRY_ALARMSETTING extends Structure + { + public int nId; // 报警唯一编号 报警编号统一编码 + public int bEnable; // 是否开启该点报警, BOOL类型 + public int nResultType; // 测温报警结果类型,见 CFG_STATISTIC_TYPE,可取值: + // 点测温:具体值, + // 线测温:最大, 最小, 平均 + // 区域测温:最大, 最小, 平均, 标准, 中间, ISO + public int nAlarmCondition; // 报警条件,见 CFG_COMPARE_RESULT + public float fThreshold; // 报警阈值温度 浮点数 + public float fHysteresis; // 温度误差,浮点数,比如0.1 表示正负误差在0.1范围内 + public int nDuration; // 阈值温度持续时间 单位:秒 + } + + // 测温规则本地参数配置 + public static class CFG_RADIOMETRY_LOCALPARAM extends Structure + { + public int bEnable; // 是否启用本地配置, BOOL类型 + public float fObjectEmissivity; // 目标辐射系数 浮点数 0~1 + public int nObjectDistance; // 目标距离 + public int nRefalectedTemp; // 目标反射温度 + } + + // 统计量类型 + public static class CFG_STATISTIC_TYPE extends Structure + { + public static final int CFG_STATISTIC_TYPE_UNKNOWN = 0; + public static final int CFG_STATISTIC_TYPE_VAL = 1; // 具体值 + public static final int CFG_STATISTIC_TYPE_MAX = 2; // 最大 + public static final int CFG_STATISTIC_TYPE_MIN = 3; // 最小 + public static final int CFG_STATISTIC_TYPE_AVR = 4; // 平均 + public static final int CFG_STATISTIC_TYPE_STD = 5; // 标准 + public static final int CFG_STATISTIC_TYPE_MID = 6; // 中间 + public static final int CFG_STATISTIC_TYPE_ISO = 7; // ISO + } + + // 比较运算结果 + public static class CFG_COMPARE_RESULT extends Structure + { + public static final int CFG_COMPARE_RESULT_UNKNOWN = 0; + public static final int CFG_COMPARE_RESULT_BELOW = 1; // 低于 + public static final int CFG_COMPARE_RESULT_MATCH = 2; // 匹配 + public static final int CFG_COMPARE_RESULT_ABOVE = 3; // 高于 + } + + // 记录集新增操作(insert)参数 + public static class NET_CTRL_RECORDSET_INSERT_PARAM extends Structure + { + public int dwSize; + public NET_CTRL_RECORDSET_INSERT_IN stuCtrlRecordSetInfo; // 记录集信息(用户填写) + public NET_CTRL_RECORDSET_INSERT_OUT stuCtrlRecordSetResult; // 记录集信息(设备返回) + + public NET_CTRL_RECORDSET_INSERT_PARAM() { + this.dwSize = this.size(); + } + } + + // 记录集新增操作(insert)输入参数 + public static class NET_CTRL_RECORDSET_INSERT_IN extends Structure + { + public int dwSize; + public int emType; // 记录集信息类型, 取值参考 EM_NET_RECORD_TYPE + public Pointer pBuf; // 记录集信息缓存,详见EM_NET_RECORD_TYPE注释,由用户申请内存. + public int nBufLen; // 记录集信息缓存大小,大小参照记录集信息类型对应的结构体 + + public NET_CTRL_RECORDSET_INSERT_IN() { + this.dwSize = this.size(); + } + } + + // 记录集新增操作(insert)输出参数 + public static class NET_CTRL_RECORDSET_INSERT_OUT extends Structure + { + public int dwSize; + public int nRecNo; // 记录编号(新增insert时设备返回) + + public NET_CTRL_RECORDSET_INSERT_OUT() { + this.dwSize = this.size(); + } + } + + // 门禁密码记录查询条件 + public static class FIND_RECORD_ACCESSCTLPWD_CONDITION extends Structure + { + public int dwSize; + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + + public FIND_RECORD_ACCESSCTLPWD_CONDITION() { + this.dwSize = this.size(); + } + } + + // 门禁密码记录集信息 + public static class NET_RECORDSET_ACCESS_CTL_PWD extends Structure + { + public int dwSize; + public int nRecNo; // 记录集编号,只读 + public NET_TIME stuCreateTime; // 创建时间 + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID, 设备暂不支持 + public byte[] szDoorOpenPwd = new byte[NET_MAX_CARDPWD_LEN]; // 开门密码 + public byte[] szAlarmPwd = new byte[NET_MAX_CARDPWD_LEN]; // 报警密码 + public int nDoorNum; // 有效的的门数目 + public int[] sznDoors = new int[NET_MAX_DOOR_NUM]; // 有权限的门序号,即 CFG_CMD_ACCESS_EVENT 配置CFG_ACCESS_EVENT_INFO的数组下标 + public byte[] szVTOPosition = new byte[NET_COMMON_STRING_64]; // 门口机关联位置 + public int nTimeSectionNum; // 开门时间段个数 + public int[] nTimeSectionIndex = new int[NET_MAX_TIMESECTION_NUM]; // 开门时间段索引,是个数组,每个元素与sznDoors中的门对应 + public int bNewDoor; // BOOL类型, 是否启动新开门授权字段,TRUE表示使用 nNewDoorNum 和 nNewDoors 字段下发开门权限 + public int nNewDoorNum; // 有效的门数目; + public int[] nNewDoors = new int[MAX_ACCESSDOOR_NUM]; // 有权限的门序号,即 CFG_CMD_ACCESS_EVENT 配置的数组下标 + public int nNewTimeSectionNum; // 有效的的开门时间段数目 + public int[] nNewTimeSectionNo = new int[MAX_ACCESSDOOR_NUM]; // 开门时间段索引,即 CFG_ACCESS_TIMESCHEDULE_INFO 的数组下标 + + public NET_RECORDSET_ACCESS_CTL_PWD() { + this.dwSize = this.size(); + } + } + + // 开门二维码记录集信息 + public static class NET_RECORD_ACCESSQRCODE_INFO extends Structure + { + public int dwSize; // 结构体大小 + public int nRecNo; // 记录集编号,只读 + public byte[] szQRCode = new byte[NET_MAX_QRCODE_LEN]; // 二维码 + public int nLeftTimes; // 剩余的有效次数 + public NET_TIME stuStartTime; // 有效期开始时间 + public NET_TIME stuEndTime; // 有效期截止时间 + + public NET_RECORD_ACCESSQRCODE_INFO(){ + this.dwSize = this.size(); + } + } + + // 查询盒子工作状态, 对应命令 NET_DEVSTATE_GET_WORK_STATE + public static class NET_QUERY_WORK_STATE extends Structure + { + public int dwSize; // 保留字段 + public NET_WORKSTATE stuWorkState; // 运行状态 + + public NET_QUERY_WORK_STATE() { + this.dwSize = this.size(); + } + } + + // 设备工作状态 + public static class NET_WORKSTATE extends Structure + { + public int bOnline; // 设备是否在线,BOOL类型 + public byte[] szFirmwareVersion = new byte[NET_COMMON_STRING_128]; // 固件版本号 + public float fTemperature; // 温度值, 单位摄氏度 + public float fPowerDissipation; // 功耗, 单位W + public int nUtilizationOfCPU; // CPU 使用率 + public int nStorageNum; // 存储设备个数 + public NET_STORAGE_INFO[] stuStorages = new NET_STORAGE_INFO[MAX_STORAGE_NUM]; // 存储设备信息 + public int nUpTimeLast; // 上次上电时间, 单位: 秒 + public int nUpTimeTotal; // 总共上电时间, 单位: 秒 + public double dbMemInfoTotal; // 总内存大小, 单位: 字节 + public double dbMemInfoFree; // 剩余内存大小, 单位: 字节 + public byte[] byReserved1 = new byte[4]; // 字节对齐,非保留字节 + public byte[] szDevType = new byte[32]; // 设备型号 + public NET_RESOURCE_STATE stuResourceStat; // 网络资源 + public byte[] byReserved = new byte[8]; // 保留字节 + + public NET_WORKSTATE() { + for(int i = 0; i < MAX_STORAGE_NUM; i++) { + stuStorages[i] = new NET_STORAGE_INFO(); + } + } + } + + // 存储设备信息 + public static class NET_STORAGE_INFO extends Structure + { + public int emState; // 存储设备状态, ENUM_STORAGE_STATE + public int nPartitonNum; // 分区个数 + public NET_PARTITION_INFO[] stuPartions = new NET_PARTITION_INFO[MAX_PARTITION_NUM]; // 分区信息 + public byte[] byReserved = new byte[128]; // 保留字段 + + public NET_STORAGE_INFO() { + for(int i = 0; i < MAX_PARTITION_NUM; i++) { + stuPartions[i] = new NET_PARTITION_INFO(); + } + } + } + + // 网络资源 + public static class NET_RESOURCE_STATE extends Structure + { + public int nIPChanneIn; // IP通道接入速度, 单位: kbps + public int nNetRemain; // 网络接收剩余能力, 单位: kbps + public int nNetCapability; // 网络接收总能力, 单位: kbps + public int nRemotePreview; // 远程预览能力, 单位: kbps + public int nRmtPlayDownload; // 远程回放及下载能力, 单位: kbps + public int nRemoteSendRemain; // 远程发送剩余能力, 单位: kbps + public int nRemoteSendCapability; // 远程发送总能力, 单位: kbps + public byte[] byReserved = new byte[32]; // 保留字节 + } + + // 存储设备分区信息 + public static class NET_PARTITION_INFO extends Structure + { + public double dbTotalBytes; // 分区总空间 + public double dbUsedBytes; // 分区使用的空间 + public int bError; // 是否异常, BOOL类型 + public byte[] byReserved = new byte[64]; // 保留字段 + } + + // CLIENT_GetSelfCheckInfo 输入参数 + public static class NET_IN_GET_SELTCHECK_INFO extends Structure + { + public int dwSize; // 用户使用该结构体时,dwSize 需赋值为 sizeof (NET_IN_GET_SELTCHECK_INFO) + + public NET_IN_GET_SELTCHECK_INFO() { + this.dwSize = this.size(); + } + } + + // 设备自检信息 + public static class NET_SELFCHECK_INFO extends Structure + { + public int dwSize; + public int nAlarmIn; // 报警输入通道数 + public int nAlarmOut; // 报警输出通道数 + public NET_TIME stuTime; // 上报时间 + public byte[] szPlateNo = new byte[NET_MAX_PLATE_NUMBER_LEN]; // 车牌 + public byte[] szICCID = new byte[NET_MAX_SIM_LEN]; // SIM卡号,建议使用szICCIDExInfo字段 + public byte byOrientation; // 定位状态,0-未定位,1-定位 + public byte byACCState; // ACC 状态,0-关闭,1-打开 + public byte byConstantElecState; // 常电状态,0-正常连接,1-断开,2-欠压,3-高压 + public byte byAntennaState; // 通信信号状态,0-正常,1-未知故障,2-未接,3-短路 + + // 外部设备状态 + public byte byReportStation; // 报站器状态,0-未接,1-正常,2-异常 + public byte byControlScreen; // 调度屏状态,0-未接,1-正常,2-异常 + public byte byPOS; // POS机状态,0-未接,1-正常,2-异常 + public byte byCoinBox; // 投币箱状态,0-未接,1-正常,2-异常 + + // 能力集 + public int bTimerSnap; // 定时抓图,TRUE-支持,FALSE-不支持, BOOL类型 + public int bElectronEnclosure; // 电子围栏,TRUE-支持,FALSE-不支持, BOOL类型 + public int bTeleUpgrade; // 远程升级,TRUE-支持,FALSE-不支持, BOOL类型 + + public int nHddNum; // 硬盘个数 + public NET_HDD_STATE[] stuHddStates = new NET_HDD_STATE[NET_MAX_DISKNUM]; // 硬盘状态 + + public Pointer pChannleState; // 通道状态,是一个 NET_CHANNLE_STATE 数组, + // CLIENT_AttachMission接口,NET_MISSION_TYPE_SELFCHECK类型,回调函数,内存由SDK申请,SDK释放 + // CLIENT_GetSelfCheckInfo接口,出参,内存由用户申请,用户释放,大小为sizeof(NET_CHANNLE_STATE)*nChannelMax + public int nChannleNum; // 实际上报的通道个数 + public int nChannelMax; // CLIENT_GetSelfCheckInfo接口,pChannleState内存的最大NET_CHANNLE_STATE个数 + public int emConnState; // PAD/DVR连接状态, 参考 NET_PAD_CONNECT_STATE + public int emHomeState; // Home键状态, 参考 NET_HOME_STATE + public byte[] szICCIDExInfo = new byte[NET_COMMON_STRING_256]; // SIM卡号扩展信息,用于字段扩展使用 + public byte by3GState; // 3G/4G状态, 0-未连接,1-连接,2-模块未找到 + public byte byWifiState; // Wifi状态, 0-未连接,1-连接,2-模块未找到 + public byte byGpsState; // Gps状态, 0-未连接,1-连接,2-模块未找到 + public byte byBlackBoxState; // BlackBox状态, 0-未接,1-正常 + public int nCpuUsage; // CPU使用百分比, 单位% + public int nTemperature; // 设备内部温度, 摄氏度 + + public NET_SELFCHECK_INFO() { + this.dwSize = this.size(); + + for(int i = 0; i < NET_MAX_DISKNUM; i++) { + stuHddStates[i] = new NET_HDD_STATE(); + } + } + } + + // 硬盘状态 + public static class NET_HDD_STATE extends Structure + { + public int dwSize; + public int nState; // 硬盘状态,0-正常,1-错误 + public double dbTotalSize; // 硬盘总容量,字节为单位 + public NET_PARTITION_STATE[] stuPartitions = new NET_PARTITION_STATE[NET_MAX_STORAGE_PARTITION_NUM]; // 分区状态 + public int nPartitionNum; // 分区数 + + public NET_HDD_STATE() { + this.dwSize = this.size(); + + for(int i = 0; i < NET_MAX_STORAGE_PARTITION_NUM; i++) { + stuPartitions[i] = new NET_PARTITION_STATE(); + } + } + } + + // 分区状态 + public static class NET_PARTITION_STATE extends Structure + { + public int dwSize; + public int nStatus; // 分区状态,0-正常,1-错误 + public double dbTotalSize; // 分区总容量,字节为单位 + public double dbRemainSize; // 剩余容量,字节为单位 + + public NET_PARTITION_STATE() { + this.dwSize = this.size(); + } + } + + // 扩展网络配置结构体 + public static class NETDEV_NET_CFG_EX extends Structure + { + public int dwSize; + public byte[] sDevName = new byte[NET_MAX_NAME_LEN]; // 设备主机名 + public short wTcpMaxConnectNum; // TCP最大连接数 + public short wTcpPort; // TCP帧听端口 + public short wUdpPort; // UDP侦听端口 + public short wHttpPort; // HTTP端口号 + public short wHttpsPort; // HTTPS端口号 + public short wSslPort; // SSL端口号 + public int nEtherNetNum; // 以太网口数 + public NET_ETHERNET_EX[] stEtherNet = new NET_ETHERNET_EX[NET_MAX_ETHERNET_NUM_EX]; // 以太网口 + public NET_REMOTE_HOST struAlarmHost; // 报警服务器 + public NET_REMOTE_HOST struLogHost; // 日志服务器 + public NET_REMOTE_HOST struSmtpHost; // SMTP服务器 + public NET_REMOTE_HOST struMultiCast; // 多播组 + public NET_REMOTE_HOST struNfs; // NFS服务器 + public NET_REMOTE_HOST struPppoe; // PPPoE服务器 + public byte[] sPppoeIP = new byte[NET_MAX_IPADDR_LEN]; // PPPoE注册返回的IP + public NET_REMOTE_HOST struDdns; // DDNS服务器 + public byte[] sDdnsHostName = new byte[NET_MAX_HOST_NAMELEN]; // DDNS主机名 + public NET_REMOTE_HOST struDns; // DNS服务器 + public NET_MAIL_CFG struMail; // 邮件配置 + public byte[] bReserved = new byte[128]; // 保留字节 + + public NETDEV_NET_CFG_EX() { + this.dwSize = this.size(); + + for(int i = 0; i < NET_MAX_ETHERNET_NUM_EX; i++) { + stEtherNet[i] = new NET_ETHERNET_EX(); + } + } + } + + // 以太网扩展配置 + public static class NET_ETHERNET_EX extends Structure + { + public byte[] sDevIPAddr = new byte[NET_MAX_IPADDR_LEN]; // DVR IP 地址 + public byte[] sDevIPMask = new byte[NET_MAX_IPADDR_LEN]; // DVR IP 地址掩码 + public byte[] sGatewayIP = new byte[NET_MAX_IPADDR_LEN]; // 网关地址 + + /* + * 1:10Mbps 全双工 + * 2:10Mbps 自适应 + * 3:10Mbps 半双工 + * 4:100Mbps 全双工 + * 5:100Mbps 自适应 + * 6:100Mbps 半双工 + * 7:自适应 + */ + // 为了扩展将DWORD拆成四个 + public byte dwNetInterface; // NSP + public byte bTranMedia; // 0:有线,1:无线 + public byte bValid; // 按位表示,第一位:1:有效 0:无效;第二位:0:DHCP关闭 1:DHCP使能;第三位:0:不支持DHCP 1:支持DHCP + public byte bDefaultEth; // 是否作为默认的网卡 1:默认 0:非默认 + public byte[] byMACAddr = new byte[NET_MACADDR_LEN]; // MAC地址,只读 + public byte bMode; // 网卡所处模式, 0:绑定模式, 1:负载均衡模式, 2:多址模式, 3:容错模式 + public byte[] bReserved1 = new byte[3]; // 字节对齐 + public byte[] szEthernetName = new byte[NET_MAX_NAME_LEN]; // 网卡名,只读 + public byte[] bReserved = new byte[12]; // 保留字节 + } + + + // 远程主机配置 + public static class NET_REMOTE_HOST extends Structure + { + public byte byEnable; // 连接使能 + public byte byAssistant; // 目前只对于PPPoE服务器有用,0:在有线网卡拨号;1:在无线网卡上拨号 + public short wHostPort; // 远程主机 端口 + public byte[] sHostIPAddr = new byte[NET_MAX_IPADDR_LEN]; // 远程主机 IP 地址 + public byte[] sHostUser = new byte[NET_MAX_HOST_NAMELEN]; // 远程主机 用户名 + public byte[] sHostPassword = new byte[NET_MAX_HOST_PSWLEN]; // 远程主机 密码 + } + + // 邮件配置 + public static class NET_MAIL_CFG extends Structure + { + public byte[] sMailIPAddr = new byte[NET_MAX_IPADDR_LEN]; // 邮件服务器IP地址 + public short wMailPort; // 邮件服务器端口 + public short wReserved; // 保留 + public byte[] sSenderAddr = new byte[NET_MAX_MAIL_ADDR_LEN]; // 发送地址 + public byte[] sUserName = new byte[NET_MAX_NAME_LEN]; // 用户名 + public byte[] sUserPsw = new byte[NET_MAX_NAME_LEN]; // 用户密码 + public byte[] sDestAddr = new byte[NET_MAX_MAIL_ADDR_LEN]; // 目的地址 + public byte[] sCcAddr = new byte[NET_MAX_MAIL_ADDR_LEN]; // 抄送地址 + public byte[] sBccAddr = new byte[NET_MAX_MAIL_ADDR_LEN]; // 暗抄地址 + public byte[] sSubject = new byte[NET_MAX_MAIL_SUBJECT_LEN]; // 标题 + } + + // 向视频输出口投放视频和图片文件, CLIENT_ControlDevice接口的 CTRLTYPE_CTRL_DELIVERY_FILE 命令参数 + public static class NET_CTRL_DELIVERY_FILE extends Structure + { + public int dwSize; // 结构体大小 + public int nPort; // 视频输出口 + public int emPlayMode; // 播放类型, 参考 EM_VIDEO_PLAY_MODE_TYPE + public NET_TIME stuStartPlayTime; // 开始播放的时间 + public NET_TIME stuStopPlayTime; // 结束播放的时间,emPlayMode为 EM_VIDEO_PLAY_MODE_TYPE_REPEAT 时,此值有效 + public int nFileCount; // 投放的文件个数 + public NET_DELIVERY_FILE_INFO[] stuFileInfo = new NET_DELIVERY_FILE_INFO[MAX_DELIVERY_FILE_NUM]; // 投放的文件信息 + + public NET_CTRL_DELIVERY_FILE() { + this.dwSize = this.size(); + } + } + + // 投放文件信息 + public static class NET_DELIVERY_FILE_INFO extends Structure + { + public int emFileType; // 文件类型, 参考 EM_DELIVERY_FILE_TYPE + public byte[] szFileURL = new byte[DELIVERY_FILE_URL_LEN]; // 文件的资源地址 + public int nImageSustain; // 每张图片停留多长时间,单位秒 (emFileType为 EM_DELIVERY_FILE_TYPE_IMAGE 时此字段有效) + public byte[] byReserved = new byte[1024]; // 保留字节 + } + + // 视频播放模式 + public static class EM_VIDEO_PLAY_MODE_TYPE extends Structure + { + public static final int EM_VIDEO_PLAY_MODE_TYPE_UNKNOWN = 0; // 未知 + public static final int EM_VIDEO_PLAY_MODE_TYPE_ONCE = 1; // 播放一次 + public static final int EM_VIDEO_PLAY_MODE_TYPE_REPEAT = 2; // 循环播放 + } + + // 投放的文件类型 + public static class EM_DELIVERY_FILE_TYPE extends Structure + { + public static final int EM_DELIVERY_FILE_TYPE_UNKNOWN = 0; // 未知 + public static final int EM_DELIVERY_FILE_TYPE_VIDEO = 1; // 视频 + public static final int EM_DELIVERY_FILE_TYPE_IMAGE = 2; // 图片 + } + + // CLIENT_ControlDevice接口的 CTRLTYPE_CTRL_START_PLAYAUDIO 命令参数 + public static class NET_CTRL_START_PLAYAUDIO extends Structure + { + public int dwSize; + public byte[] szAudioPath = new byte[NET_MAX_AUDIO_PATH]; + + public NET_CTRL_START_PLAYAUDIO() { + this.dwSize = this.size(); + } + } + + // 公告记录信息查询条件 + public static class FIND_RECORD_ANNOUNCEMENT_CONDITION extends Structure + { + public int dwSize; + public int bTimeEnable; // 启用时间段查询, BOOL类型 + public NET_TIME stStartTime; // 起始时间 + public NET_TIME stEndTime; // 结束时间 + + public FIND_RECORD_ANNOUNCEMENT_CONDITION() { + this.dwSize = this.size(); + } + } + + //公告记录信息 + public static class NET_RECORD_ANNOUNCEMENT_INFO extends Structure + { + public int dwSize; + public int nRecNo; // 记录集编号,只读 + public NET_TIME stuCreateTime; // 创建时间 + public NET_TIME stuIssueTime; // 公告发布时间 + public byte[] szAnnounceTitle = new byte[NET_COMMON_STRING_64]; // 公告标题 + public byte[] szAnnounceContent = new byte[NET_COMMON_STRING_256];//公告内容 + public byte[] szAnnounceDoor = new byte[NET_COMMON_STRING_16]; //公告要发送的房间号 + public NET_TIME stuExpireTime; //公告过期的时间 + public int emAnnounceState; //公告的状态 , 参考 NET_ANNOUNCE_STATE + public int emAnnounceReadFlag; //公告是否已经浏览, 参考 NET_ANNOUNCE_READFLAG + + public NET_RECORD_ANNOUNCEMENT_INFO() { + this.dwSize = this.size(); + } + } + + //公告的状态 + public static class NET_ANNOUNCE_STATE extends Structure + { + public static final int NET_ANNOUNCE_STATE_UNSENDED = 0; //初始状态(未发送) + public static final int NET_ANNOUNCE_STATE_SENDED = 1; //已经发送 + public static final int NET_ANNOUNCE_STATE_EXPIRED = 2; //已经过期 + public static final int NET_ANNOUNCE_STATE_UNKNOWN = 3; //未知 + } + + //公告是否已经浏览 + public static class NET_ANNOUNCE_READFLAG extends Structure + { + public static final int NET_ANNOUNCE_READFLAG_UNREADED = 0; //未读 + public static final int NET_ANNOUNCE_READFLAG_READED = 1; //已读 + public static final int NET_ANNOUNCE_READFLAG_UNKNOWN = 2; //未知 + } + + // 开始实时监视并指定回调数据格式入参 + public static class NET_IN_REALPLAY_BY_DATA_TYPE extends Structure + { + public int dwSize; // 结构体大小 + public int nChannelID; // 通道编号 + public Pointer hWnd; // 窗口句柄, HWND类型 + public int rType; // 码流类型 ,参考 NET_RealPlayType + public fRealDataCallBackEx cbRealData; // 数据回调函数 + public int emDataType; // 回调的数据类型,参考 EM_REAL_DATA_TYPE + public LLong dwUser; // 用户数据, Win32时,要改成NativeLong类型 + public String szSaveFileName; // 转换后的文件名 + + public NET_IN_REALPLAY_BY_DATA_TYPE() { + this.dwSize = this.size(); + } + } + + // 开始实时监视并指定回调数据格式出参 + public static class NET_OUT_REALPLAY_BY_DATA_TYPE extends Structure + { + public int dwSize; // 结构体大小 + + public NET_OUT_REALPLAY_BY_DATA_TYPE() { + this.dwSize = this.size(); + } + } + + // 实时监视回调数据类型 + public static class EM_REAL_DATA_TYPE extends Structure + { + public static final int EM_REAL_DATA_TYPE_PRIVATE = 0; // 私有码流 + public static final int EM_REAL_DATA_TYPE_GBPS = 1; // 国标PS码流 + public static final int EM_REAL_DATA_TYPE_TS = 2; // TS码流 + public static final int EM_REAL_DATA_TYPE_MP4 = 3; // MP4文件(从回调函数出来的是私有码流数据,参数dwDataType值为0) + public static final int EM_REAL_DATA_TYPE_H264 = 4; // 裸H264码流 + } + + // 事件类型 NET_ALARM_HIGH_SPEED (车辆超速报警事件)对应的数据块描述信息 + public static class ALARM_HIGH_SPEED_INFO extends Structure + { + public int nAction; // 事件动作,1表示持续性事件开始,2表示持续性事件结束; + public NET_TIME_EX stuTime; // 事件发生的时间 + public double dbPTS; // 时间戳(单位是毫秒) + public NET_GPS_STATUS_INFO stGPSStatusInfo; // GPS信息 + public int nSpeedLimit; // 车连限速值km/h + public int nCurSpeed; // 当前车辆速度km/h + public int nMaxSpeed; // 最高速度Km/h + public byte[] byReserved = new byte[508]; // 保留字节 + } + + // GPS状态信息 + public static class NET_GPS_STATUS_INFO extends Structure + { + public NET_TIME revTime; // 定位时间 + public byte[] DvrSerial = new byte[50]; // 设备序列号 + public byte[] byRserved1 = new byte[6]; // 对齐字节 + public double longitude; // 经度(单位是百万分之度,范围0-360度) + public double latidude; // 纬度(单位是百万分之度,范围0-180度) + public double height; // 高度(米) + public double angle; // 方向角(正北方向为原点,顺时针为正) + public double speed; // 速度(单位km/H) + public short starCount; // 定位星数, emDateSource为 EM_DATE_SOURCE_GPS时有效 + public byte[] byRserved2 = new byte[2]; // 对齐字节 + public int antennaState; // 天线状态, 参考 NET_THREE_STATUS_BOOL, emDateSource为 EM_DATE_SOURCE_GPS时有效 + public int orientationState; // 定位状态, 参考 NET_THREE_STATUS_BOOL + public int workStae; // 工作状态(0=未定位,1=非差分定位,2=差分定位,3=无效PPS,6=正在估算 + // emDateSource为 EM_DATE_SOURCE_GPS时有效 + public int nAlarmCount; // 发生的报警位置个数 + public int[] nAlarmState = new int[128]; // 发生的报警位置,值可能多个, emDateSource为 EM_DATE_SOURCE_GPS时有效 + public byte bOffline; // 0-实时 1-补传 + public byte bSNR; // GPS信噪比,表示GPS信号强度,值越大,信号越强 范围:0~100,0表示不可用 + public byte[] byRserved3 = new byte[2]; // 对齐字节 + public int emDateSource; // 数据来源, 参考 EM_DATE_SOURCE + public byte[] byRserved = new byte[124]; // 保留字节 + } + + //三态布尔类型 + public static class NET_THREE_STATUS_BOOL extends Structure + { + public static final int BOOL_STATUS_FALSE = 0; + public static final int BOOL_STATUS_TRUE = 1; + public static final int BOOL_STATUS_UNKNOWN = 2; //未知 + } + + // 数据来源 + public static class EM_DATE_SOURCE extends Structure + { + public static final int EM_DATE_SOURCE_GPS = 0; // GPS + public static final int EM_DATE_SOURCE_INERTIALNAVIGATION = 1; // 惯性导航数据 + } + + // Gps定位信息 + public static class NET_GPS_LOCATION_INFO extends Structure + { + public GPS_Info stuGpsInfo; // GPS信息 + public ALARM_STATE_INFO stuAlarmStateInfo; // 报警状态信息 + public int nTemperature; // 温度(单位:0.1摄氏度) + public int nHumidity; // 湿度(单位:0.1%) + public int nIdleTime; // 怠速时长(单位:秒) + public int nMileage; // 里程(单位:0.1km) + public int nVoltage; // 设置电压值(单位:0.1伏) + public byte[] byReserved = new byte[1024]; + } + + // 事件类型 NET_ALARM_VIDEO_LOSS (视频丢失事件)对应的数据块描述信息 + public static class ALARM_VIDEO_LOSS_INFO extends Structure + { + public int nAction; // 事件动作,1表示持续性事件开始,2表示持续性事件结束; + public int nChannelID; // 通道号 + public double dbPTS; // 时间戳(单位是毫秒) + public byte[] byReserved1 = new byte[4]; // 字节对齐 + public NET_TIME_EX stuTime; // 事件发生的时间 + public byte[] byReserved = new byte[512]; // 保留字节 + } + + //报警事件类型 NET_ALARM_BUS_SHARP_ACCELERATE(车辆急加速事件)对应的数据描述信息 + public static class ALARM_BUS_SHARP_ACCELERATE_INFO extends Structure + { + public int dwSize; + public NET_GPS_STATUS_INFO stuGPSStatusInfo; // GPS信息 + public NET_TIME_EX stuTime; // 事件发生的时间 + + public ALARM_BUS_SHARP_ACCELERATE_INFO() { + this.dwSize = this.size(); + } + } + + //报警事件类型 NET_ALARM_BUS_SHARP_DECELERATE(车辆急减速事件)对应的数据描述信息 + public static class ALARM_BUS_SHARP_DECELERATE_INFO extends Structure + { + public int dwSize; + public NET_GPS_STATUS_INFO stuGPSStatusInfo; // GPS信息 + public NET_TIME_EX stuTime; // 事件发生的时间 + + public ALARM_BUS_SHARP_DECELERATE_INFO() { + this.dwSize = this.size(); + } + } + + // GPS未定位报警(NET_ALARM_GPS_NOT_ALIGNED) + public static class ALARM_GPS_NOT_ALIGNED_INFO extends Structure + { + public int nAction; // 事件动作,0表示脉冲事件,1表示报警开始,2表示报警结束; + public NET_TIME_EX stuTime; // 事件发生的时间 + public byte[] byReserved = new byte[1024]; // 保留字节 + } + + // 前端断网报警信息, 对应 NET_ALARM_FRONTDISCONNECT + public static class ALARM_FRONTDISCONNET_INFO extends Structure + { + public int dwSize; // 结构体大小 + public int nChannelID; // 通道号 + public int nAction; // 0:开始 1:停止 + public NET_TIME stuTime; // 事件发生时间 + public byte[] szIpAddress = new byte[MAX_PATH]; // 前端IPC的IP地址 + + public ALARM_FRONTDISCONNET_INFO() { + this.dwSize = this.size(); + } + } + + // 存储错误报警, 对应 NET_ALARM_STORAGE_FAILURE_EX + public static class ALARM_STORAGE_FAILURE_EX extends Structure + { + public int dwSize; + public int nAction; // 0:开始 1:停止 + public byte[] szName = new byte[NET_EVENT_NAME_LEN]; // 事件名称 + public byte[] szDevice = new byte[NET_STORAGE_NAME_LEN]; // 存储设备名称 + public byte[] szGroup = new byte[NET_STORAGE_NAME_LEN]; // 存储组名称 + public byte[] szPath = new byte[MAX_PATH]; // 路径 + public int emError; // 错误类型, 参考 EM_STORAGE_ERROR + public int nPhysicNo; // 硬盘所在槽编码, 从1开始 + public NET_TIME_EX stuTime; // 事件发生的时间 + + public ALARM_STORAGE_FAILURE_EX() { + this.dwSize = this.size(); + } + } + + // 存储组不存在事件信息, 对应 NET_ALARM_STORAGE_NOT_EXIST + public static class ALARM_STORAGE_NOT_EXIST_INFO extends Structure + { + public int dwSize; + public int nAction; // 0:开始 1:停止 + public byte[] szGroup = new byte[NET_STORAGE_NAME_LEN]; // 在录像或抓图存储点中设置但不存在的组 + public NET_TIME stuTime; // 事件触发时间 + + public ALARM_STORAGE_NOT_EXIST_INFO() { + this.dwSize = this.size(); + } + } + + // 车辆ACC报警事件, 对应事件类型 NET_ALARM_VEHICLE_ACC + public static class ALARM_VEHICLE_ACC_INFO extends Structure + { + public int dwSize; + public int nACCStatus; // ACC状态, 0:无效, 1:开启, 2:关闭 + public int nAction; // 事件动作, 0:Start, 1:Stop + public NET_GPS_STATUS_INFO stuGPSStatusInfo; // GPS信息 + public int nConstantElectricStatus; // 常电状态, 0:未知, 1:连接, 2:断开 + public NET_TIME_EX stuTime; // 事件发生的时间 + + public ALARM_VEHICLE_ACC_INFO() { + this.dwSize = this.size(); + } + } + + // 事件类型 NET_ALARM_VIDEOBLIND(视频遮挡事件)对应的数据块描述信息 + public static class ALARM_VIDEO_BLIND_INFO extends Structure + { + public int nAction; // 事件动作,1表示持续性事件开始,2表示持续性事件结束; + public int nChannelID; // 通道号 + public double dbPTS; // 时间戳(单位是毫秒) + public NET_TIME_EX stuTime; // 事件发生的时间 + public int nEventID; // 事件ID + public byte[] byReserved = new byte[512]; // 保留字节 + } + + // 紧急事件(对应 NET_URGENCY_ALARM_EX2, 对原有的 NET_URGENCY_ALARM_EX 类型的升级, 指人为触发的紧急事件, 一般处理是联动外部通讯功能请求帮助) + public static class ALARM_URGENCY_ALARM_EX2 extends Structure + { + public int dwSize; + public NET_TIME stuTime; // 事件产生的时间 + public int nID; // 用于标识不同的紧急事件 + + public ALARM_URGENCY_ALARM_EX2() { + this.dwSize = this.size(); + } + } + + // 事件类型 NET_ALARM_DRIVER_NOTCONFIRM (司机未按确认按钮报警事件)对应的数据块描述信息 + public static class ALARM_DRIVER_NOTCONFIRM_INFO extends Structure + { + public int nAction; // 事件动作,1表示持续性事件开始,2表示持续性事件结束; + public NET_TIME_EX stuTime; // 事件发生的时间 + public double dbPTS; // 时间戳(单位是毫秒) + public byte[] byReserved = new byte[512]; // 保留字节 + } + + // CLIENT_AttachBusState, 订阅Bus状态输入参结构 + public static class NET_IN_BUS_ATTACH extends Structure + { + public int dwSize; + public fBusStateCallBack cbBusState; // 状态回调函数 + public LLong dwUser; // 用户数据 + + public NET_IN_BUS_ATTACH() { + this.dwSize = this.size(); + } + } + + // CLIENT_AttachBusState, 订阅Bus状态输出参结构 + public static class NET_OUT_BUS_ATTACH extends Structure + { + public int dwSize; + + public NET_OUT_BUS_ATTACH() { + this.dwSize = this.size(); + } + } + + // 事件类型 NET_ALARM_BUS_PASSENGER_CARD_CHECK (乘客刷卡事件)对应的数据描述信息 + public static class ALARM_PASSENGER_CARD_CHECK extends Structure + { + public int bEventConfirm; // 是否需要回复, BOOL类型 + public byte[] szCardNum = new byte[NET_MAX_BUSCARD_NUM]; // 公交卡号 + public NET_GPS_STATUS_INFO stuGPS; // GPS信息 + public NET_TIME_EX UTC; // 刷卡时间 + public int nTime; // UTC整型 + public int emType; // 刷卡类型, 参考 EM_PASSENGER_CARD_CHECK_TYPE + public byte[] szMac = new byte[NET_MAX_POS_MAC_NUM]; // 刷卡机Mac码 (默认"0000",兼容老设备) + public byte[] reserved = new byte[1012]; // 预留 + } + + public static class EM_PASSENGER_CARD_CHECK_TYPE extends Structure + { + public static final int EM_PASSENGER_CARD_CHECK_TYPE_UNKOWN = 0; // 未知 + public static final int EM_PASSENGER_CARD_CHECK_TYPE_SIGNIN = 1; // 签到/上车 + public static final int EM_PASSENGER_CARD_CHECK_TYPE_SIGNOUT = 2; // 签出/下车 + public static final int EM_PASSENGER_CARD_CHECK_TYPE_NORMAL = 3; // 正常刷卡,不区分上下车 + } + + // CLIENT_AttachEventRestore 接口输入参数 + public static class NET_IN_ATTACH_EVENT_RESTORE extends Structure + { + public int dwSize; //结构体大小 + public byte[] szUuid = new byte[MAX_EVENT_RESTORE_UUID]; //客户端惟一标识 + + public NET_IN_ATTACH_EVENT_RESTORE() { + this.dwSize = this.size(); + } + } + + public static class GPS_TEMP_HUMIDITY_INFO extends Structure + { + public double dTemperature; // 温度值(摄氏度),实际值的1000倍,如30.0摄氏度表示为30000 + public double dHumidity; // 湿度值(%),实际值的1000倍,如30.0%表示为30000 + public byte[] bReserved = new byte[128]; // 保留字节 + + public static class ByValue extends GPS_Info implements Structure.ByValue { } + } + + + // 事件类型 NET_ALARM_FACEINFO_COLLECT (人脸信息录入事件)对应的数据块描述信息 + public static class ALARM_FACEINFO_COLLECT_INFO extends Structure + { + + public int nAction; // 事件动作,1表示持续性事件开始,2表示持续性事件结束; + public NET_TIME_EX stuTime; // 事件发生的时间 + public double dbPTS; // 时间戳(单位是毫秒) + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + public byte[] byReserved = new byte[512]; // 保留字节 + } + + // 人脸信息记录操作类型, 接口 CLIENT_FaceInfoOpreate + public static class EM_FACEINFO_OPREATE_TYPE extends Structure + { + public static final int EM_FACEINFO_OPREATE_ADD = 0; // 添加, pInbuf = NET_IN_ADD_FACE_INFO , pOutBuf = NET_OUT_ADD_FACE_INFO + public static final int EM_FACEINFO_OPREATE_GET = 1; // 获取, pInBuf = NET_IN_GET_FACE_INFO , pOutBuf = NET_OUT_GET_FACE_INFO + public static final int EM_FACEINFO_OPREATE_UPDATE = 2; // 更新, pInbuf = NET_IN_UPDATE_FACE_INFO , pOutBuf = NET_OUT_UPDATE_FACE_INFO + public static final int EM_FACEINFO_OPREATE_REMOVE = 3; // 删除, pInbuf = NET_IN_REMOVE_FACE_INFO , pOutBuf = NET_OUT_REMOVE_FACE_INFO + public static final int EM_FACEINFO_OPREATE_CLEAR = 4; // 清除, pInbuf = NET_IN_CLEAR_FACE_INFO, pOutBuf = NET_OUT_CLEAR_FACE_INFO + } + + // 添加人脸记录信息输入参数 + public static class NET_IN_ADD_FACE_INFO extends Structure + { + public int dwSize; + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + public NET_FACE_RECORD_INFO stuFaceInfo; // 人脸数据 + + public NET_IN_ADD_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 人脸信息 + public static class NET_FACE_RECORD_INFO extends Structure + { + public byte[] szUserName = new byte[MAX_USER_NAME_LEN]; // 用户名 + public int nRoom; // 房间个数 + public NET_FACE_ROOMNO[] szRoomNo = (NET_FACE_ROOMNO[])new NET_FACE_ROOMNO().toArray(MAX_ROOMNUM_COUNT); // 房间号列表 + public int nFaceData; // 人脸模板数据个数 + public NET_FACE_FACEDATA[] szFaceData = (NET_FACE_FACEDATA[])new NET_FACE_FACEDATA().toArray(MAX_FACE_COUTN);// 人脸模板数据 + public byte[] byReserved = new byte[512]; // 保留字节 + } + + public static class NET_FACE_ROOMNO extends Structure { + public byte[] roomNo = new byte[NET_COMMON_STRING_16]; // 房间号 + } + + public static class NET_FACE_FACEDATA extends Structure { + public byte[] faceData = new byte[MAX_FACE_DATA_LEN]; // 人脸数据 + } + + // 添加人脸记录信息输出参数 + public static class NET_OUT_ADD_FACE_INFO extends Structure + { + public int dwSize; + + public NET_OUT_ADD_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 获取人脸记录信息输入参数 + public static class NET_IN_GET_FACE_INFO extends Structure + { + public int dwSize; + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + + public NET_IN_GET_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 获取人脸记录信息输出参数 + public static class NET_OUT_GET_FACE_INFO extends Structure + { + public int dwSize; + public int nFaceData; // 人脸模板数据个数 + public NET_FACE_FACEDATA[] szFaceData = (NET_FACE_FACEDATA[])new NET_FACE_FACEDATA().toArray(MAX_FACE_COUTN); // 人脸模板数据 + + public NET_OUT_GET_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 更新人脸记录信息输入参数 + public static class NET_IN_UPDATE_FACE_INFO extends Structure + { + public int dwSize; + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + public NET_FACE_RECORD_INFO stuFaceInfo; // 人脸数据 + + public NET_IN_UPDATE_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 更新人脸记录信息输出参数 + public static class NET_OUT_UPDATE_FACE_INFO extends Structure + { + public int dwSize; + + public NET_OUT_UPDATE_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 删除人脸记录信息输入参数 + public static class NET_IN_REMOVE_FACE_INFO extends Structure + { + public int dwSize; + public byte[] szUserID = new byte[NET_MAX_USERID_LEN]; // 用户ID + + public NET_IN_REMOVE_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 删除人脸记录信息输出参数 + public static class NET_OUT_REMOVE_FACE_INFO extends Structure + { + public int dwSize; + + public NET_OUT_REMOVE_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 清除人脸记录信息输入参数 + public static class NET_IN_CLEAR_FACE_INFO extends Structure + { + public int dwSize; + + public NET_IN_CLEAR_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 清除人脸记录信息输出参数 + public static class NET_OUT_CLEAR_FACE_INFO extends Structure + { + public int dwSize; + + public NET_OUT_CLEAR_FACE_INFO() { + this.dwSize = this.size(); + } + } + + // 添加节目信息接口输入参数 + public static class NET_IN_ADD_ONE_PROGRAMME extends Structure + { + public int dwSize; + public NET_PROGRAMME_INFO stuProgrammeInfo; // 节目信息 + + public NET_IN_ADD_ONE_PROGRAMME() { + this.dwSize = this.size(); + } + } + + + // 添加节目信息接口输出参数 + public static class NET_OUT_ADD_ONE_PROGRAMME extends Structure + { + public int dwSize; + public byte[] szProgrammeID = new byte[MAX_COMMON_STRING_64]; // 节目ID + + public NET_OUT_ADD_ONE_PROGRAMME() { + this.dwSize = this.size(); + } + } + + // 诱导屏节目配置信息 + public static class NET_PROGRAMME_INFO extends Structure + { + public byte[] szProgrammeName = new byte[MAX_COMMON_STRING_64]; // 节目名称 + public byte[] szProgrammeID = new byte[MAX_COMMON_STRING_64]; // 节目ID + public byte[] szGuideScreenID = new byte[MAX_COMMON_STRING_64]; // 诱导屏ID + public int bEnable; // 节目是否启用,BOOLl类型 + public NET_ORDINARY_INFO stuOrdinaryInfo; // 普通节目信息 + public byte[] byReserved = new byte[512]; // 保留字节 + } + + // 诱导屏普通节目信息 + public static class NET_ORDINARY_INFO extends Structure + { + public int bTempletState; // 节目是否保存为模板, BOOL类型 + public byte[] szDescription = new byte[MAX_COMMON_STRING_128]; // 节目描述信息 + public int nWhnCount; // 诱导屏窗口个数 + public NET_GUIDESCREEN_WINDOW_INFO[] stuWindowsInfo = (NET_GUIDESCREEN_WINDOW_INFO[])new NET_GUIDESCREEN_WINDOW_INFO().toArray(MAX_WINDOWS_COUNT); // 诱导屏窗口信息 + public byte[] byReserved = new byte[128]; // 保留字节 + } + + // 诱导屏窗口信息 + public static class NET_GUIDESCREEN_WINDOW_INFO extends Structure + { + public byte[] szWindowID = new byte[MAX_COMMON_STRING_64]; // 窗口ID + public NET_COLOR_RGBA stuColor; // 窗口背景颜色 + public int nDiaphaneity; // 窗口背景透明度0-100 + public int emTourPeriodType; // 窗口轮训类型, 对应 EM_TOURPERIOD_TYPE + public int nTourPeriodTime; // 自定义轮训时间,单位秒, 轮训类型为自定义轮训时有效 + public int bAutoPlay; // 预览自动播放,Video元素有效, BOOL类型 + public int bLoopPlay; // 预览循环播放,Video元素有效, BOOL类型 + public int emElementsType; // 诱导屏窗口元素类型, 对应 EM_ELEMENTS_TYPE + public int nElementsCount; // 诱导屏窗口元素个数 + public Pointer pstElementsBuf; // 诱导屏窗口元素信息缓存区, 根据类型对应不同的结构体, + public int nBufLen; // 诱导屏窗口元素信息缓存区大小 + public byte[] byReserved = new byte[128]; // 保留字节 + } + + //窗口轮训周期类型 + public static class EM_TOURPERIOD_TYPE extends Structure + { + public static final int EM_TOURPERIOD_UNKNOWN = 0; // 未知 + public static final int EM_TOURPERIOD_PROGRAMME = 1; // 节目周期 + public static final int EM_TOURPERIOD_PLAN = 2; // 计划周期 + public static final int EM_TOURPERIOD_CUSTOM = 3; // 自定义周期 + } + + // 诱导屏窗口元素类型 + public static class EM_ELEMENTS_TYPE extends Structure + { + public static final int EM_ELEMENTS_UNKNOWN = 0; // 未知 + public static final int EM_ELEMENTS_VIDEO = 1; // 视频元素, 对应NET_VIDEO_ELEMENT_INFO + public static final int EM_ELEMENTS_PICTURE = 2; // 图片元素, 对应NET_PICTURE_ELEMENT_INFO + public static final int EM_ELEMENTS_TEXT = 3; // 文本元素, 对应NET_TEXT_ELEMENT_INFO + public static final int EM_ELEMENTS_PLACEHOLDER = 4; // 占位符元素, 对应NET_PLACEHOLDER_ELEMENT_INFO + public static final int EM_ELEMENTS_CAPTURE = 5; // 抓拍元素, 对应NET_CAPTURE_ELEMENT_INFO + } + + /*********************************************************************** + ** 回调 + ***********************************************************************/ + //JNA StdCallCallback方法定义,断线回调 + public interface fDisConnect extends StdCallCallback { + public void invoke(NativeLong lLoginID, String pchDVRIP, int nDVRPort, NativeLong dwUser); + } + + // 网络连接恢复回调函数原形 + public interface fHaveReConnect extends StdCallCallback { + public void invoke(NativeLong lLoginID, String pchDVRIP, int nDVRPort, NativeLong dwUser); + } + + // 消息回调函数原形(pBuf内存由SDK内部申请释放) + public interface fMessCallBack extends StdCallCallback{ + public boolean invoke(int lCommand , NativeLong lLoginID , Pointer pStuEvent , int dwBufLen , String strDeviceIP , NativeLong nDevicePort , NativeLong dwUser); + } + + public interface fFaceFindState extends StdCallCallback { + // pstStates 指向NET_CB_FACE_FIND_STATE的指针 + public void invoke(NativeLong lLoginID, NativeLong lAttachHandle, Pointer pstStates, int nStateNum, NativeLong dwUser); + } + + // 智能分析数据回调;nSequence表示上传的相同图片情况,为0时表示是第一次出现,为2表示最后一次出现或仅出现一次,为1表示此次之后还有 + // int nState = *(int*) reserved 表示当前回调数据的状态, 为0表示当前数据为实时数据,为1表示当前回调数据是离线数据,为2时表示离线数据传送结束 + // pAlarmInfo 对应智能事件信息, pBuffer 对应智能图片信息, dwBufSize 智能图片信息大小 + public interface fAnalyzerDataCallBack extends StdCallCallback { + public int invoke(NativeLong lAnalyzerHandle, int dwAlarmType, Pointer pAlarmInfo, Pointer pBuffer, int dwBufSize, Pointer dwUser, int nSequence, Pointer reserved); + } + + // 抓图回调函数原形(pBuf内存由SDK内部申请释放) + // EncodeType 编码类型,10:表示jpeg图片 0:mpeg4 CmdSerial : 操作流水号,同步抓图的情况下用不上 + public interface fSnapRev extends StdCallCallback{ + public void invoke( NativeLong lLoginID ,Pointer pBuf, int RevLen, int EncodeType, NativeLong CmdSerial, NativeLong dwUser); + } + + // 异步搜索设备回调(pDevNetInfo内存由SDK内部申请释放) + public interface fSearchDevicesCB extends StdCallCallback{ + public void invoke(Pointer pDevNetInfo, Pointer pUserData); + } + + // 按时间回放进度回调函数原形 + public interface fTimeDownLoadPosCallBack extends StdCallCallback { + public void invoke(NativeLong lPlayHandle, int dwTotalSize, int dwDownLoadSize, int index, NET_RECORDFILE_INFO.ByValue recordfileinfo, NativeLong dwUser); + } + + // 回放数据回调函数原形 + public interface fDataCallBack extends StdCallCallback { + public int invoke(NativeLong lRealHandle, int dwDataType, Pointer pBuffer, int dwBufSize, NativeLong dwUser); + } + + // 回放进度回调函数原形 + public interface fDownLoadPosCallBack extends StdCallCallback { + public void invoke(NativeLong lPlayHandle, int dwTotalSize, int dwDownLoadSize, NativeLong dwUser); + } + + // 视频统计摘要信息回调函数原形,lAttachHandle 是 CLIENT_AttachVideoStatSummary 返回值 + public interface fVideoStatSumCallBack extends StdCallCallback { + public void invoke(NativeLong lAttachHandle, NET_VIDEOSTAT_SUMMARY pBuf, int dwBufLen, NativeLong dwUser); + } + + // 用户自定义的数据回调 lTalkHandle是CLIENT_StartTalkEx的返回值 + // byAudioFlag: 0表示是本地录音库采集的音频数据 , 1表示收到的设备发过来的音频数据 + public interface pfAudioDataCallBack extends StdCallCallback { + public void invoke(NativeLong lTalkHandle, Pointer pDataBuf, int dwBufSize, byte byAudioFlag, NativeLong dwUser); + } + + // lHandle是文件传输句柄 ,nTransType是文件传输类型,nState是文件传输状态, + public interface fTransFileCallBack extends StdCallCallback { + public void invoke(NativeLong lHandle, int nTransType, int nState, int nSendSize, int nTotalSize, NativeLong dwUser); + } + + // GPS信息订阅回调--扩展 + public interface fGPSRevEx extends StdCallCallback { + public void invoke(NativeLong lLoginID, GPS_Info.ByValue GpsInfo, ALARM_STATE_INFO.ByValue stAlarmInfo, NativeLong dwUserData, Pointer reserved); + } + + // GPS信息订阅回调--扩展2 + public interface fGPSRevEx2 extends StdCallCallback { + public void invoke(NativeLong lLoginID, NET_GPS_LOCATION_INFO lpData, Pointer dwUserData, Pointer reserved); + } + + // 实时监视数据回调函数--扩展(pBuffer内存由SDK内部申请释放) + // lRealHandle实时监视 dwDataType: 0-原始数据 1-帧数据 2-yuv数据 3-pcm音频数据 + // pBuffer对应BYTE* + // param:当类型为0(原始数据)和2(YUV数据) 时为0。当回调的数据类型为1时param为一个tagVideoFrameParam结构体指针。 + // param:当数据类型是3时,param也是一个tagCBPCMDataParam结构体指针 + public interface fRealDataCallBackEx extends StdCallCallback { + public void invoke(NativeLong lRealHandle, int dwDataType, Pointer pBuffer, int dwBufSize, int param, NativeLong dwUser); + } + + // 视频监视断开回调函数, (param内存由SDK内部申请释放 ) + // lOperateHandle监控句柄 dwEventType对应EM_REALPLAY_DISCONNECT_EVENT_TYPE param对应void*,事件参数 + public interface fRealPlayDisConnect extends StdCallCallback { + public void invoke(NativeLong lOperateHandle, int dwEventType, Pointer param, NativeLong dwUser); + } + + // 订阅过车记录数据回调函数原型 lAttachHandle为CLIENT_ParkingControlAttachRecord返回值 + public interface fParkingControlRecordCallBack extends StdCallCallback { + public void invoke(NativeLong lLoginID, NativeLong lAttachHandle, NET_CAR_PASS_ITEM pInfo, int nBufLen, NativeLong dwUser); + } + + // 订阅车位信息回调函数原型 + public interface fParkInfoCallBack extends StdCallCallback { + public void invoke(NativeLong lLoginID, NativeLong lAttachHandle, NET_PARK_INFO_ITEM pInfo, int nBufLen, NativeLong dwUser); + } + + // 订阅监测点位信息回调函数原型 + public interface fSCADAAttachInfoCallBack extends StdCallCallback { + public void invoke(NativeLong lLoginID, NativeLong lAttachHandle, NET_SCADA_NOTIFY_POINT_INFO_LIST pInfo, int nBufLen, NativeLong dwUser); + } + + // 透明串口回调函数原形(pBuffer内存由SDK内部申请释放)) + public interface fTransComCallBack extends StdCallCallback { + public void invoke(NativeLong lLoginID, NativeLong lTransComChannel, Pointer pBuffer, int dwBufSize, NativeLong dwUser); + } + + //视频分析进度状态实时回调函数 + public interface fVideoAnalyseState extends StdCallCallback { + public int invoke(NativeLong lAttachHandle, NET_VIDEOANALYSE_STATE pAnalyseStateInfos, NativeLong dwUser, Pointer pReserved); + } + + // 侦听服务器回调函数原形 + public interface fServiceCallBack extends StdCallCallback { + public int invoke(NativeLong lHandle, String pIp, int wPort, NativeLong lCommand, Pointer pParam, int dwParamLen, long dwUserData); + } + + //订阅Bus状态回调函数原型 + public interface fBusStateCallBack extends StdCallCallback { + public void invoke(NativeLong lAttachHandle, int lCommand, Pointer pBuf, int dwBufLen, NativeLong dwUser); + } + + // GPS温湿度信息订阅回调 + public interface fGPSTempHumidityRev extends StdCallCallback { + public void invoke(NativeLong lLoginID, GPS_TEMP_HUMIDITY_INFO.ByValue GpsTHInfo, NativeLong dwUserData); + } + + + /************************************************************************ + ** 接口 + ***********************************************************************/ + // JNA直接调用方法定义,cbDisConnect 实际情况并不回调Java代码,仅为定义可以使用如下方式进行定义。 fDisConnect 回调 + public boolean CLIENT_Init(StdCallCallback cbDisConnect, NativeLong dwUser); + + // JNA直接调用方法定义,SDK退出清理 + public void CLIENT_Cleanup(); + + // JNA直接调用方法定义,设置断线重连成功回调函数,设置后SDK内部断线自动重连, fHaveReConnect 回调 + public void CLIENT_SetAutoReconnect(StdCallCallback cbAutoConnect, NativeLong dwUser); + + // 返回函数执行失败代码 + public int CLIENT_GetLastError(); + + // 设置连接设备超时时间和尝试次数 + public void CLIENT_SetConnectTime(int nWaitTime, int nTryTimes); + + // 设置登陆网络环境 + public void CLIENT_SetNetworkParam(NET_PARAM pNetParam); + + // 获取SDK的版本信息 + public int CLIENT_GetSDKVersion(); + + // JNA直接调用方法定义,登陆接口 + public NativeLong CLIENT_LoginEx(String pchDVRIP, int wDVRPort, String pchUserName, String pchPassword, int nSpecCap, Pointer pCapParam, NET_DEVICEINFO lpDeviceInfo, IntByReference error/*= 0*/); + + // JNA直接调用方法定义,登陆扩展接口/////////////////////////////////////////////////// + // nSpecCap 对应 EM_LOGIN_SPAC_CAP_TYPE 登陆类型 + public NativeLong CLIENT_LoginEx2(String pchDVRIP, int wDVRPort, String pchUserName, String pchPassword, int nSpecCap, Pointer pCapParam, NET_DEVICEINFO_Ex lpDeviceInfo, IntByReference error/*= 0*/); + + // JNA直接调用方法定义,向设备注销 + public boolean CLIENT_Logout(NativeLong lLoginID); + + // 获取配置 + // error 为设备返回的错误码: 0-成功 1-失败 2-数据不合法 3-暂时无法设置 4-没有权限 + public boolean CLIENT_GetNewDevConfig(NativeLong lLoginID , String szCommand , int nChannelID , byte[] szOutBuffer , int dwOutBufferSize , IntByReference error , int waiitime); + + // 设置配置 + public boolean CLIENT_SetNewDevConfig(NativeLong lLoginID , String szCommand , int nChannelID , byte[] szInBuffer, int dwInBufferSize, IntByReference error, IntByReference restart, int waittime ); + + // 解析查询到的配置信息 + public boolean CLIENT_ParseData(String szCommand, byte[] szInBuffer, Pointer lpOutBuffer, int dwOutBufferSize, Pointer pReserved); + + // 组成要设置的配置信息 + public boolean CLIENT_PacketData(String szCommand, Pointer lpInBuffer, int dwInBufferSize, byte[] szOutBuffer, int dwOutBufferSize); + + // 设置报警回调函数, fMessCallBack 回调 + public void CLIENT_SetDVRMessCallBack(StdCallCallback cbMessage , NativeLong dwUser); + + // 向设备订阅报警--扩展 + public boolean CLIENT_StartListenEx(NativeLong lLoginID); + + /////////////////////////////////人脸识别接口///////////////////////////////////////// + //人脸识别数据库信息操作(包括添加,修改和删除) + // pstInParam指向NET_IN_OPERATE_FACERECONGNITIONDB类型的指针 + // pstOutParam指向NET_OUT_OPERATE_FACERECONGNITIONDB类型的指针 + public boolean CLIENT_OperateFaceRecognitionDB(NativeLong lLoginID, NET_IN_OPERATE_FACERECONGNITIONDB pstInParam, NET_OUT_OPERATE_FACERECONGNITIONDB pstOutParam, int nWaitTime); + + // 按条件查询人脸识别结果 + // pstInParam指向NET_IN_STARTFIND_FACERECONGNITION类型的指针 + // pstOutParam指向NET_OUT_STARTFIND_FACERECONGNITION类型的指针 + public boolean CLIENT_StartFindFaceRecognition(NativeLong lLoginID, NET_IN_STARTFIND_FACERECONGNITION pstInParam, NET_OUT_STARTFIND_FACERECONGNITION pstOutParam, int nWaitTime); + + // 查找人脸识别结果:nFilecount:需要查询的条数, 返回值为媒体文件条数 返回值 0 ) { + switch (i) { + case 0: + vehicleClass = bundle.getString("LIGHT_DUTY"); + break; + case 1: + vehicleClass = bundle.getString("MEDIUM"); + break; + case 2: + vehicleClass = bundle.getString("OVER_SIZE"); + break; + case 3: + vehicleClass = bundle.getString("MINI_SIZE"); + break; + case 4: + vehicleClass = bundle.getString("LARGE_SIZE"); + break; + default: + break; + } + } + } + + return vehicleClass; + } + + /* + * 获取事件名称 + */ + public String getEventName(int type) { + String name = ""; + switch (type) { + case NetSDKLib.EVENT_IVS_TRAFFICJUNCTION: ///< 交通路口事件 + name = bundle.getString("EVENT_IVS_TRAFFICJUNCTION"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_RUNREDLIGHT: ///< 闯红灯事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_RUNREDLIGHT"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_OVERLINE: ///< 压车道线事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_OVERLINE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_RETROGRADE: ///< 逆行事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_RETROGRADE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_TURNLEFT: ///< 违章左转 + name = bundle.getString("EVENT_IVS_TRAFFIC_TURNLEFT"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_TURNRIGHT: ///< 违章右转 + name = bundle.getString("EVENT_IVS_TRAFFIC_TURNRIGHT"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_UTURN: ///< 违章掉头 + name = bundle.getString("EVENT_IVS_TRAFFIC_UTURN"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_OVERSPEED: ///< 超速 + name = bundle.getString("EVENT_IVS_TRAFFIC_OVERSPEED"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_UNDERSPEED: ///< 低速 + name = bundle.getString("EVENT_IVS_TRAFFIC_UNDERSPEED"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_PARKING: ///< 违章停车 + name = bundle.getString("EVENT_IVS_TRAFFIC_PARKING"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_WRONGROUTE: ///< 不按车道行驶 + name = bundle.getString("EVENT_IVS_TRAFFIC_WRONGROUTE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_CROSSLANE: ///< 违章变道 + name = bundle.getString("EVENT_IVS_TRAFFIC_CROSSLANE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_OVERYELLOWLINE: ///< 压黄线 + name = bundle.getString("EVENT_IVS_TRAFFIC_OVERYELLOWLINE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_YELLOWPLATEINLANE: ///< 黄牌车占道事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_YELLOWPLATEINLANE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_PEDESTRAINPRIORITY: ///< 斑马线行人优先事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_PEDESTRAINPRIORITY"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_MANUALSNAP: ///< 交通手动抓拍事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_MANUALSNAP"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_VEHICLEINROUTE: ///< 有车占道事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_VEHICLEINROUTE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_VEHICLEINBUSROUTE: ///< 占用公交车道事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_VEHICLEINBUSROUTE"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_BACKING: ///< 违章倒车事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_BACKING"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_PARKINGSPACEPARKING: ///< 车位有车事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_PARKINGSPACEPARKING"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_PARKINGSPACENOPARKING: ///< 车位无车事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_PARKINGSPACENOPARKING"); + break; + case NetSDKLib.EVENT_IVS_TRAFFIC_WITHOUT_SAFEBELT: ///< 交通未系安全带事件 + name = bundle.getString("EVENT_IVS_TRAFFIC_WITHOUT_SAFEBELT"); + break; + default: + break; + } + + return name; + } + + public String getRecordType() { + return bundle.getString("RECORD_TYPE"); + } + + public String getStartTime() { + return bundle.getString("START_TIME"); + } + + public String getEndTime() { + return bundle.getString("END_TIME"); + } + + public String[] getDownloadTableName() { + String[] name = {getIndex(), + getChannel(), + getRecordType(), + getStartTime(), + getEndTime()}; + return name; + } + + public String getDownloadByFile() { + return bundle.getString("DOWNLOAD_RECORD_BYFILE"); + } + + public String getQuery() { + return bundle.getString("QUERY"); + } + + public String getDownload() { + return bundle.getString("DOWNLOAD"); + } + + public String getStopDownload() { + return bundle.getString("STOP_DOWNLOAD"); + } + + public String getDownloadByTime() { + return bundle.getString("DOWNLOAD_RECORD_BYTIME"); + } + + public String getSelectTimeAgain() { + return bundle.getString("PLEASE_SELECT_TIME_AGAIN"); + } + + public String getSelectRowWithData() { + return bundle.getString("PLEASE_FIRST_SELECT_ROW_WITH_DATA"); + } + + public String getQueryRecord() { + return bundle.getString("PLEASE_FIRST_QUERY_RECORD"); + } + + public String getDownloadCompleted() { + return bundle.getString("DOWNLOAD_COMPLETED"); + } + + /** + * 获取录像类型 + */ + public String getRecordTypeStr(int nRecordFileType) { + String recordTypeStr = ""; + switch(nRecordFileType) { + case 0: + recordTypeStr = bundle.getString("GENERAL_RECORD"); + break; + case 1: + recordTypeStr = bundle.getString("ALARM_RECORD"); + break; + case 2: + recordTypeStr = bundle.getString("MOTION_DETECTION"); + break; + case 3: + recordTypeStr = bundle.getString("CARD_NUMBER_RECORD"); + break; + default: + break; + } + + return recordTypeStr; + } + + public int getRecordTypeInt(String recordFileStr) { + int recordType = -1; + if(recordFileStr.equals(bundle.getString("GENERAL_RECORD"))) { + recordType = 0; + } else if(recordFileStr.equals(bundle.getString("ALARM_RECORD"))) { + recordType = 1; + } else if(recordFileStr.equals(bundle.getString("MOTION_DETECTION"))) { + recordType = 2; + } else if(recordFileStr.equals(bundle.getString("CARD_NUMBER_RECORD"))) { + recordType = 3; + } + + return recordType; + } + + + + +} diff --git a/src/main/java/com/shxy/xyhkcamera/test/SavePath.java b/src/main/java/com/shxy/xyhkcamera/test/SavePath.java new file mode 100644 index 0000000..a7d9e85 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/SavePath.java @@ -0,0 +1,75 @@ +package com.shxy.xyhkcamera.test; + +import java.io.File; + + +public class SavePath { + private SavePath() {} + + private static class SavePathHolder { + private static SavePath instance = new SavePath(); + } + + public static SavePath getSavePath() { + return SavePathHolder.instance; + } + + String s_captureSavePath = "./Capture/" + ToolKits.getDate() + "/"; // 抓拍图片保存路径 + String s_imageSavePath = "./Image/" + ToolKits.getDate() + "/"; // 图片保存路径 + String s_recordFileSavePath = "./RecordFile/" + ToolKits.getDate() + "/"; // 录像保存路径 + + /* + * 设置抓图保存路径 + */ + public String getSaveSnapPath() { + File path1 = new File("./Capture/"); + if (!path1.exists()) { + path1.mkdir(); + } + + File path2 = new File(s_captureSavePath); + if (!path2.exists()) { + path2.mkdir(); + } + + String strFileName = s_captureSavePath + ToolKits.getDate() + ".jpg"; + + return strFileName; + } + + /* + * 设置智能交通图片保存路径 + */ + public String getSaveTrafficImagePath() { + File path1 = new File("./Image/"); + if (!path1.exists()) { + path1.mkdir(); + } + + File path = new File(s_imageSavePath); + if (!path.exists()) { + path.mkdir(); + } + + return s_imageSavePath; + } + + + /* + * 设置录像保存路径 + */ + public String getSaveRecordFilePath() { + File path1 = new File("./RecordFile/"); + if (!path1.exists()) { + path1.mkdir(); + } + + File path2 = new File(s_recordFileSavePath); + if (!path2.exists()) { + path2.mkdir(); + } + String SavedFileName = s_recordFileSavePath + ToolKits.getDate() + ".dav"; // 默认保存路径 + return SavedFileName; + } + +} diff --git a/src/main/java/com/shxy/xyhkcamera/test/ToolKits.java b/src/main/java/com/shxy/xyhkcamera/test/ToolKits.java new file mode 100644 index 0000000..a43f8ce --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/ToolKits.java @@ -0,0 +1,194 @@ +package com.shxy.xyhkcamera.test; + +import java.awt.event.ActionEvent; +import java.awt.event.KeyEvent; +import java.awt.event.KeyListener; +import java.io.FileOutputStream; +import java.io.UnsupportedEncodingException; +import java.text.SimpleDateFormat; + +import javax.swing.JButton; +import javax.swing.JFrame; +import javax.swing.JTextField; + +import com.sun.jna.Pointer; +import com.sun.jna.Structure; + +public class ToolKits { + /*************************************************************************************************** + * 工具方法 * + ***************************************************************************************************/ + public static void GetPointerData(Pointer pNativeData, Structure pJavaStu) { + GetPointerDataToStruct(pNativeData, 0, pJavaStu); + } + + public static void GetPointerDataToStruct(Pointer pNativeData, long OffsetOfpNativeData, Structure pJavaStu) { + pJavaStu.write(); + Pointer pJavaMem = pJavaStu.getPointer(); + pJavaMem.write(0, pNativeData.getByteArray(OffsetOfpNativeData, pJavaStu.size()), 0, pJavaStu.size()); + pJavaStu.read(); + } + + public static void GetPointerDataToStructArr(Pointer pNativeData, Structure[] pJavaStuArr) { + long offset = 0; + for (int i = 0; i < pJavaStuArr.length; ++i) { + GetPointerDataToStruct(pNativeData, offset, pJavaStuArr[i]); + offset += pJavaStuArr[i].size(); + } + } + + /** + * 将结构体数组拷贝到内存 + * + * @param pNativeData + * @param pJavaStuArr + */ + public static void SetStructArrToPointerData(Structure[] pJavaStuArr, Pointer pNativeData) { + long offset = 0; + for (int i = 0; i < pJavaStuArr.length; ++i) { + SetStructDataToPointer(pJavaStuArr[i], pNativeData, offset); + offset += pJavaStuArr[i].size(); + } + } + + public static void SetStructDataToPointer(Structure pJavaStu, Pointer pNativeData, long OffsetOfpNativeData) { + pJavaStu.write(); + Pointer pJavaMem = pJavaStu.getPointer(); + pNativeData.write(OffsetOfpNativeData, pJavaMem.getByteArray(0, pJavaStu.size()), 0, pJavaStu.size()); + } + + public static void savePicture(byte[] pBuf, String sDstFile) { + try { + FileOutputStream fos = new FileOutputStream(sDstFile); + fos.write(pBuf); + fos.close(); + } catch (Exception e) { + e.printStackTrace(); + } + } + + public static void savePicture(byte[] pBuf, int dwBufOffset, int dwBufSize, String sDstFile) { + try { + FileOutputStream fos = new FileOutputStream(sDstFile); + fos.write(pBuf, dwBufOffset, dwBufSize); + fos.close(); + } catch (Exception e) { + e.printStackTrace(); + } + } + + public static void savePicture(Pointer pBuf, int dwBufSize, String sDstFile) { + try { + FileOutputStream fos = new FileOutputStream(sDstFile); + fos.write(pBuf.getByteArray(0, dwBufSize), 0, dwBufSize); + fos.close(); + } catch (Exception e) { + e.printStackTrace(); + } + } + + public static void savePicture(Pointer pBuf, int dwBufOffset, int dwBufSize, String sDstFile) { + try { + FileOutputStream fos = new FileOutputStream(sDstFile); + fos.write(pBuf.getByteArray(dwBufOffset, dwBufSize), 0, dwBufSize); + fos.close(); + } catch (Exception e) { + e.printStackTrace(); + } + } + + // 将Pointer值转为byte[] + public static String GetPointerDataToByteArr(Pointer pointer) { + String str = ""; + if (pointer == null) { + return str; + } + + int length = 0; + byte[] bufferPlace = new byte[1]; + + for (int i = 0; i < 2048; i++) { + pointer.read(i, bufferPlace, 0, 1); + if (bufferPlace[0] == '\0') { + length = i; + break; + } + } + + if (length > 0) { + byte[] buffer = new byte[length]; + pointer.read(0, buffer, 0, length); + try { + str = new String(buffer, "GBK").trim(); + } catch (UnsupportedEncodingException e) { + return str; + } + } + + return str; + } + + // 获取当前时间 + public static String getDate() { + SimpleDateFormat simpleDate = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + String date = simpleDate.format(new java.util.Date()).replace(" ", "_").replace(":", "-"); + + return date; + } + + // 限制JTextField 长度,以及内容 + public static void limitTextFieldLength(final JTextField jTextField, final int size) { + jTextField.addKeyListener(new KeyListener() { + + @Override + public void keyTyped(KeyEvent e) { + String number = "0123456789" + (char) 8; + if (number.indexOf(e.getKeyChar()) < 0 || jTextField.getText().trim().length() >= size) { + e.consume(); + return; + } + } + + @Override + public void keyReleased(KeyEvent e) { + } + + @Override + public void keyPressed(KeyEvent e) { + } + }); + } + + // 获取当前窗口 + public static JFrame getFrame(ActionEvent e) { + JButton btn = (JButton) e.getSource(); + JFrame frame = (JFrame) btn.getRootPane().getParent(); + + return frame; + } + + // 获取操作平台信息 + public static String getLoadLibrary(String library) { + String path = ""; + String os = System.getProperty("os.name"); + if (os.toLowerCase().startsWith("win")) { + path = "./libs/"; + } else if (os.toLowerCase().startsWith("linux")) { + path = ""; + } + + return (path + library); + } + + public static String getOsName() { + String osName = ""; + String os = System.getProperty("os.name"); + if (os.toLowerCase().startsWith("win")) { + osName = "win"; + } else if (os.toLowerCase().startsWith("linux")) { + osName = "linux"; + } + + return osName; + } +} diff --git a/src/main/java/com/shxy/xyhkcamera/test/Utils.java b/src/main/java/com/shxy/xyhkcamera/test/Utils.java new file mode 100644 index 0000000..aab9d78 --- /dev/null +++ b/src/main/java/com/shxy/xyhkcamera/test/Utils.java @@ -0,0 +1,32 @@ +package com.shxy.xyhkcamera.test; + +import java.io.FileInputStream; +import java.io.FileNotFoundException; +import java.io.IOException; +import java.util.Properties; + +import com.sun.jna.Platform; + +public class Utils { + public Utils() { + + } + + + // 读取当前目录下的路径配置文件 + public static String readConfigProperties(String key) { + Properties properties = new Properties(); + String rootPath = System.getProperty("user.dir").replace("\\", "/"); // 获取当前目录 + FileInputStream inputStream = null; + try { + inputStream = new FileInputStream(rootPath + "/config.properties"); + properties.load(inputStream); + } catch (FileNotFoundException e) { + e.printStackTrace(); + }catch (IOException e) { + e.printStackTrace(); + } + + return properties.getProperty(key); + } +} diff --git a/src/main/resources/application-test.yml b/src/main/resources/application-test.yml new file mode 100644 index 0000000..9b7a43f --- /dev/null +++ b/src/main/resources/application-test.yml @@ -0,0 +1,29 @@ +# 开发环境配置 +server: + # 服务器的HTTP端口,默认为8080 + port: 8095 + servlet: + # 应用的访问路径 + context-path: /xymanager +hkconfig: + winpath: D:\\Workspace\\HK\\HCNetSDK.dll + linuxpath: ere +# tomcat: +# # tomcat的URI编码 +# uri-encoding: UTF-8 +# # 连接数满后的排队数,默认为100 +# accept-count: 1000 +# max-swallow-size: -1 # tomcat默认大小2M,超过2M的文件不会被捕获,需要调整此处大小为100MB或者-1即可 +# threads: +# # tomcat最大线程数,默认为200 +# max: 800 +# # Tomcat启动初始化的线程数,默认值10 +# min-spare: 100 + +## 日志配置 +#logging: +# config: classpath:log4j2.xml +# level: +# com.shxy: trace +# org.springframework: warn + diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml new file mode 100644 index 0000000..6b51374 --- /dev/null +++ b/src/main/resources/application.yml @@ -0,0 +1,4 @@ +# Spring配置 +spring: + profiles: + active: test diff --git a/src/main/resources/lib/libcrypto.so.1.1 b/src/main/resources/lib/libcrypto.so.1.1 new file mode 100644 index 0000000..88c3746 Binary files /dev/null and b/src/main/resources/lib/libcrypto.so.1.1 differ diff --git a/src/main/resources/lib/libhcnetsdk.so b/src/main/resources/lib/libhcnetsdk.so new file mode 100644 index 0000000..2607cee Binary files /dev/null and b/src/main/resources/lib/libhcnetsdk.so differ diff --git a/src/main/resources/lib/libssl.so.1.1 b/src/main/resources/lib/libssl.so.1.1 new file mode 100644 index 0000000..f3e4481 Binary files /dev/null and b/src/main/resources/lib/libssl.so.1.1 differ diff --git a/src/main/resources/lib/win/AudioRender.dll b/src/main/resources/lib/win/AudioRender.dll new file mode 100644 index 0000000..4935684 Binary files /dev/null and b/src/main/resources/lib/win/AudioRender.dll differ diff --git a/src/main/resources/lib/win/ClientDemo.exe b/src/main/resources/lib/win/ClientDemo.exe new file mode 100644 index 0000000..75aedfa Binary files /dev/null and b/src/main/resources/lib/win/ClientDemo.exe differ diff --git a/src/main/resources/lib/win/ClientDemoDll/ReadMe.txt b/src/main/resources/lib/win/ClientDemoDll/ReadMe.txt new file mode 100644 index 0000000..8006f36 --- /dev/null +++ b/src/main/resources/lib/win/ClientDemoDll/ReadMe.txt @@ -0,0 +1 @@ +The dll in this directoryiconv.dll,libxml2.dll,zlib1.dll,calib.dllonly used in ClientDemo. \ No newline at end of file diff --git a/src/main/resources/lib/win/ClientDemoDll/calib.dll b/src/main/resources/lib/win/ClientDemoDll/calib.dll new file mode 100644 index 0000000..328c63e Binary files /dev/null and b/src/main/resources/lib/win/ClientDemoDll/calib.dll differ diff --git a/src/main/resources/lib/win/ClientDemoDll/iconv.dll b/src/main/resources/lib/win/ClientDemoDll/iconv.dll new file mode 100644 index 0000000..df71882 Binary files /dev/null and b/src/main/resources/lib/win/ClientDemoDll/iconv.dll differ diff --git a/src/main/resources/lib/win/ClientDemoDll/libcrypto-1_1-x64.dll b/src/main/resources/lib/win/ClientDemoDll/libcrypto-1_1-x64.dll new file mode 100644 index 0000000..f2f96d7 Binary files /dev/null and b/src/main/resources/lib/win/ClientDemoDll/libcrypto-1_1-x64.dll differ diff --git a/src/main/resources/lib/win/ClientDemoDll/libssl-1_1-x64.dll b/src/main/resources/lib/win/ClientDemoDll/libssl-1_1-x64.dll new file mode 100644 index 0000000..8034d79 Binary files /dev/null and b/src/main/resources/lib/win/ClientDemoDll/libssl-1_1-x64.dll differ diff --git a/src/main/resources/lib/win/ClientDemoDll/libxml2.dll b/src/main/resources/lib/win/ClientDemoDll/libxml2.dll new file mode 100644 index 0000000..c8d57f3 Binary files /dev/null and b/src/main/resources/lib/win/ClientDemoDll/libxml2.dll differ diff --git a/src/main/resources/lib/win/ClientDemoDll/zlib1.dll b/src/main/resources/lib/win/ClientDemoDll/zlib1.dll new file mode 100644 index 0000000..82913fb Binary files /dev/null and b/src/main/resources/lib/win/ClientDemoDll/zlib1.dll differ diff --git a/src/main/resources/lib/win/GdiPlus.dll b/src/main/resources/lib/win/GdiPlus.dll new file mode 100644 index 0000000..b759ed6 Binary files /dev/null and b/src/main/resources/lib/win/GdiPlus.dll differ diff --git a/src/main/resources/lib/win/GdiPlus.lib b/src/main/resources/lib/win/GdiPlus.lib new file mode 100644 index 0000000..6fb1bb6 Binary files /dev/null and b/src/main/resources/lib/win/GdiPlus.lib differ diff --git a/src/main/resources/lib/win/HCCore.dll b/src/main/resources/lib/win/HCCore.dll new file mode 100644 index 0000000..48f8411 Binary files /dev/null and b/src/main/resources/lib/win/HCCore.dll differ diff --git a/src/main/resources/lib/win/HCCore.lib b/src/main/resources/lib/win/HCCore.lib new file mode 100644 index 0000000..495c74a Binary files /dev/null and b/src/main/resources/lib/win/HCCore.lib differ diff --git a/src/main/resources/lib/win/HCNetSDK.dll b/src/main/resources/lib/win/HCNetSDK.dll new file mode 100644 index 0000000..2ed412e Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDK.dll differ diff --git a/src/main/resources/lib/win/HCNetSDK.lib b/src/main/resources/lib/win/HCNetSDK.lib new file mode 100644 index 0000000..ff8e9e2 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDK.lib differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/AnalyzeData.dll b/src/main/resources/lib/win/HCNetSDKCom/AnalyzeData.dll new file mode 100644 index 0000000..2317b39 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/AnalyzeData.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/AudioIntercom.dll b/src/main/resources/lib/win/HCNetSDKCom/AudioIntercom.dll new file mode 100644 index 0000000..071a5e2 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/AudioIntercom.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/AudioRender.dll b/src/main/resources/lib/win/HCNetSDKCom/AudioRender.dll new file mode 100644 index 0000000..4935684 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/AudioRender.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCAlarm.dll b/src/main/resources/lib/win/HCNetSDKCom/HCAlarm.dll new file mode 100644 index 0000000..bdb8406 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCAlarm.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCAlarm.lib b/src/main/resources/lib/win/HCNetSDKCom/HCAlarm.lib new file mode 100644 index 0000000..0aa0d4c Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCAlarm.lib differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCCoreDevCfg.dll b/src/main/resources/lib/win/HCNetSDKCom/HCCoreDevCfg.dll new file mode 100644 index 0000000..7cd924e Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCCoreDevCfg.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCDisplay.dll b/src/main/resources/lib/win/HCNetSDKCom/HCDisplay.dll new file mode 100644 index 0000000..f0a2b7c Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCDisplay.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCGeneralCfgMgr.dll b/src/main/resources/lib/win/HCNetSDKCom/HCGeneralCfgMgr.dll new file mode 100644 index 0000000..3719694 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCGeneralCfgMgr.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCGeneralCfgMgr.lib b/src/main/resources/lib/win/HCNetSDKCom/HCGeneralCfgMgr.lib new file mode 100644 index 0000000..7091c25 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCGeneralCfgMgr.lib differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCIndustry.dll b/src/main/resources/lib/win/HCNetSDKCom/HCIndustry.dll new file mode 100644 index 0000000..9af77a1 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCIndustry.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCPlayBack.dll b/src/main/resources/lib/win/HCNetSDKCom/HCPlayBack.dll new file mode 100644 index 0000000..8d8e8a7 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCPlayBack.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCPreview.dll b/src/main/resources/lib/win/HCNetSDKCom/HCPreview.dll new file mode 100644 index 0000000..005656d Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCPreview.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCPreview.lib b/src/main/resources/lib/win/HCNetSDKCom/HCPreview.lib new file mode 100644 index 0000000..18d4d63 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCPreview.lib differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/HCVoiceTalk.dll b/src/main/resources/lib/win/HCNetSDKCom/HCVoiceTalk.dll new file mode 100644 index 0000000..eb04a1e Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/HCVoiceTalk.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/OpenAL32.dll b/src/main/resources/lib/win/HCNetSDKCom/OpenAL32.dll new file mode 100644 index 0000000..4b35df4 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/OpenAL32.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/StreamTransClient.dll b/src/main/resources/lib/win/HCNetSDKCom/StreamTransClient.dll new file mode 100644 index 0000000..a69e9bf Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/StreamTransClient.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/SystemTransform.dll b/src/main/resources/lib/win/HCNetSDKCom/SystemTransform.dll new file mode 100644 index 0000000..f704e49 Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/SystemTransform.dll differ diff --git a/src/main/resources/lib/win/HCNetSDKCom/libiconv2.dll b/src/main/resources/lib/win/HCNetSDKCom/libiconv2.dll new file mode 100644 index 0000000..978e2fa Binary files /dev/null and b/src/main/resources/lib/win/HCNetSDKCom/libiconv2.dll differ diff --git a/src/main/resources/lib/win/HXVA.dll b/src/main/resources/lib/win/HXVA.dll new file mode 100644 index 0000000..b7ebfcc Binary files /dev/null and b/src/main/resources/lib/win/HXVA.dll differ diff --git a/src/main/resources/lib/win/HmMerge.dll b/src/main/resources/lib/win/HmMerge.dll new file mode 100644 index 0000000..d46a6ac Binary files /dev/null and b/src/main/resources/lib/win/HmMerge.dll differ diff --git a/src/main/resources/lib/win/LocalSensorAdd.dat b/src/main/resources/lib/win/LocalSensorAdd.dat new file mode 100644 index 0000000..e69de29 diff --git a/src/main/resources/lib/win/LocalXml.zip b/src/main/resources/lib/win/LocalXml.zip new file mode 100644 index 0000000..3620e68 Binary files /dev/null and b/src/main/resources/lib/win/LocalXml.zip differ diff --git a/src/main/resources/lib/win/MP_Render.dll b/src/main/resources/lib/win/MP_Render.dll new file mode 100644 index 0000000..e5cde63 Binary files /dev/null and b/src/main/resources/lib/win/MP_Render.dll differ diff --git a/src/main/resources/lib/win/NPQos.dll b/src/main/resources/lib/win/NPQos.dll new file mode 100644 index 0000000..c709f56 Binary files /dev/null and b/src/main/resources/lib/win/NPQos.dll differ diff --git a/src/main/resources/lib/win/OpenAL32.dll b/src/main/resources/lib/win/OpenAL32.dll new file mode 100644 index 0000000..4b35df4 Binary files /dev/null and b/src/main/resources/lib/win/OpenAL32.dll differ diff --git a/src/main/resources/lib/win/PlayCtrl.dll b/src/main/resources/lib/win/PlayCtrl.dll new file mode 100644 index 0000000..2a5eb97 Binary files /dev/null and b/src/main/resources/lib/win/PlayCtrl.dll differ diff --git a/src/main/resources/lib/win/PlayCtrl.lib b/src/main/resources/lib/win/PlayCtrl.lib new file mode 100644 index 0000000..ddcf2f4 Binary files /dev/null and b/src/main/resources/lib/win/PlayCtrl.lib differ diff --git a/src/main/resources/lib/win/SuperRender.dll b/src/main/resources/lib/win/SuperRender.dll new file mode 100644 index 0000000..b00c0c2 Binary files /dev/null and b/src/main/resources/lib/win/SuperRender.dll differ diff --git a/src/main/resources/lib/win/YUVProcess.dll b/src/main/resources/lib/win/YUVProcess.dll new file mode 100644 index 0000000..d86ec3f Binary files /dev/null and b/src/main/resources/lib/win/YUVProcess.dll differ diff --git a/src/main/resources/lib/win/hlog.dll b/src/main/resources/lib/win/hlog.dll new file mode 100644 index 0000000..fe2298a Binary files /dev/null and b/src/main/resources/lib/win/hlog.dll differ diff --git a/src/main/resources/lib/win/hpr.dll b/src/main/resources/lib/win/hpr.dll new file mode 100644 index 0000000..eef0d55 Binary files /dev/null and b/src/main/resources/lib/win/hpr.dll differ diff --git a/src/main/resources/lib/win/libcrypto-1_1-x64.dll b/src/main/resources/lib/win/libcrypto-1_1-x64.dll new file mode 100644 index 0000000..6731338 Binary files /dev/null and b/src/main/resources/lib/win/libcrypto-1_1-x64.dll differ diff --git a/src/main/resources/lib/win/libmmd.dll b/src/main/resources/lib/win/libmmd.dll new file mode 100644 index 0000000..8becb5e Binary files /dev/null and b/src/main/resources/lib/win/libmmd.dll differ diff --git a/src/main/resources/lib/win/libssl-1_1-x64.dll b/src/main/resources/lib/win/libssl-1_1-x64.dll new file mode 100644 index 0000000..ac5e8fd Binary files /dev/null and b/src/main/resources/lib/win/libssl-1_1-x64.dll differ diff --git a/src/main/resources/lib/win/zlib1.dll b/src/main/resources/lib/win/zlib1.dll new file mode 100644 index 0000000..9c37a84 Binary files /dev/null and b/src/main/resources/lib/win/zlib1.dll differ diff --git a/src/main/resources/log4j2.xml b/src/main/resources/log4j2.xml new file mode 100644 index 0000000..b16e25c --- /dev/null +++ b/src/main/resources/log4j2.xml @@ -0,0 +1,106 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/src/test/java/com/shxy/xyhkcamera/XyhkcameraApplicationTests.java b/src/test/java/com/shxy/xyhkcamera/XyhkcameraApplicationTests.java new file mode 100644 index 0000000..ee8b77d --- /dev/null +++ b/src/test/java/com/shxy/xyhkcamera/XyhkcameraApplicationTests.java @@ -0,0 +1,36 @@ +package com.shxy.xyhkcamera; + +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.context.SpringBootTest; + +@SpringBootTest +class XyhkcameraApplicationTests { + +// @Autowired +// HcNetSdkUtil hcNetSdkUtil; + @Test + void contextLoads() { +// hcNetSdkUtil.init(); +// HCNetSDK instance = hcNetSdkUtil.createSDKInstance(); +// if (b) { +// int admin = instance.NET_DVR_Login_V30("192.168.1.64", (short) 8000, "admin", "SHxy@510", new HCNetSDK.NET_DVR_DEVICEINFO_V30()); +// System.out.println(admin); +// } + +// String loadLibrary = OSUtils.getLoadLibrary(); +// System.out.println(loadLibrary); + + + HCNetSDK.NET_DVR_SDKSTATE sdkState = new HCNetSDK.NET_DVR_SDKSTATE(); + //获取当前SDK状态信息 + boolean result = SdkInitService.hCNetSDK.NET_DVR_GetSDKState(sdkState); + if (result) { + sdkState.read(); + } else { + int error = SdkInitService.hCNetSDK.NET_DVR_GetLastError(); + } + + } + +}