/* * 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:需要查询的条数, 返回值为媒体文件条数 返回值