You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2402 lines
90 KiB
2402 lines
90 KiB
using System;
|
|
using System.Runtime.InteropServices;
|
|
|
|
namespace EC.AutoWeightServer.SDK
|
|
{
|
|
internal class VzClientSDK
|
|
{
|
|
public VzClientSDK()
|
|
{
|
|
//
|
|
// TODO: 在此处添加构造函数逻辑
|
|
//
|
|
}
|
|
|
|
/**可过滤的车牌识别触发类型*/
|
|
public const int VZ_LPRC_TRIG_ENABLE_STABLE = 0x1; /**<允许触发稳定结果*/
|
|
public const int VZ_LPRC_TRIG_ENABLE_VLOOP = 0x2; /**<允许触发虚拟线圈结果*/
|
|
public const int VZ_LPRC_TRIG_ENABLE_IO_IN1 = 0x10; /**<允许外部IO_IN_1触发*/
|
|
public const int VZ_LPRC_TRIG_ENABLE_IO_IN2 = 0x20; /**<允许外部IO_IN_2触发*/
|
|
public const int VZ_LPRC_TRIG_ENABLE_IO_IN3 = 0x40; /**<允许外部IO_IN_3触发*/
|
|
|
|
//车牌类型
|
|
public const int LT_UNKNOWN = 0; //未知车牌
|
|
|
|
public const int LT_BLUE = 1; //蓝牌小汽车
|
|
public const int LT_BLACK = 2; //黑牌小汽车
|
|
public const int LT_YELLOW = 3; //单排黄牌
|
|
public const int LT_YELLOW2 = 4; //双排黄牌(大车尾牌,农用车)
|
|
public const int LT_POLICE = 5; //警车车牌
|
|
public const int LT_ARMPOL = 6; //武警车牌
|
|
public const int LT_INDIVI = 7; //个性化车牌
|
|
public const int LT_ARMY = 8; //单排军车牌
|
|
public const int LT_ARMY2 = 9; //双排军车牌
|
|
public const int LT_EMBASSY = 10; //使馆车牌
|
|
public const int LT_HONGKONG = 11; //香港进出中国大陆车牌
|
|
public const int LT_TRACTOR = 12; //农用车牌
|
|
public const int LT_COACH = 13; //教练车牌
|
|
public const int LT_MACAO = 14; //澳门进出中国大陆车牌
|
|
public const int LT_ARMPOL2 = 15; //双层武警车牌
|
|
public const int LT_ARMPOL_ZONGDUI = 16; // 武警总队车牌
|
|
public const int LT_ARMPOL2_ZONGDUI = 17; // 双层武警总队车牌
|
|
public const int LI_AVIATION = 18; //民航
|
|
public const int LI_ENERGY = 19; //新能源小型车
|
|
public const int LI_NO_PLATE = 20; //无车牌
|
|
|
|
/**可配置的识别类型*/
|
|
public const int VZ_LPRC_REC_BLUE = 1 << LT_BLUE; /**<蓝牌车*/
|
|
public const int VZ_LPRC_REC_YELLOW = 1 << LT_YELLOW | 1 << LT_YELLOW2; /**<黄牌车*/
|
|
public const int VZ_LPRC_REC_BLACK = 1 << LT_BLACK; /**<黑牌车*/
|
|
public const int VZ_LPRC_REC_COACH = 1 << LT_COACH; /**<教练车*/
|
|
public const int VZ_LPRC_REC_POLICE = 1 << LT_POLICE; /**<警车*/
|
|
public const int VZ_LPRC_REC_AMPOL = 1 << LT_ARMPOL; /**<武警车*/
|
|
public const int VZ_LPRC_REC_ARMY = 1 << LT_ARMY | 1 << LT_ARMY2; /**<军车*/
|
|
public const int VZ_LPRC_REC_GANGAO = 1 << LT_HONGKONG | 1 << LT_MACAO; /**<港澳进出大陆车*/
|
|
public const int VZ_LPRC_REC_EMBASSY = 1 << LT_EMBASSY; /**<使馆车*/
|
|
public const int VZ_LPRC_REC_AVIATION = 1 << LT_EMBASSY; /**<民航*/
|
|
public const int VZ_LPRC_REC_ENERGY = 1 << LI_ENERGY; /**<新能源*/
|
|
public const int VZ_LPRC_REC_NO_PLATE = 1 << LI_NO_PLATE; /**<无车牌*/
|
|
|
|
//触发输入的类型
|
|
public enum VZ_InputType : uint
|
|
{
|
|
nWhiteList = 0, //通过
|
|
nNotWhiteList, //不通过
|
|
nNoLicence, //无车牌
|
|
nBlackList, //黑名单
|
|
nExtIoctl1, //开关量/电平输入 1
|
|
nExtIoctl2, //开关量/电平输入 2
|
|
nExtIoctl3 //开关量/电平输入 3
|
|
};
|
|
|
|
//输出配置
|
|
public struct VZ_LPRC_OutputConfig
|
|
{
|
|
public int switchout1; //开关量输出 1
|
|
public int switchout2; //开关量输出 2
|
|
public int switchout3; //开关量输出 3
|
|
public int switchout4; //开关量输出 4
|
|
public int levelout1; //电平输出 1
|
|
public int levelout2; //电平输出 2
|
|
public int rs485out1; //RS485-1
|
|
public int rs485out2; //RS485-2
|
|
private VZ_InputType eInputType; //触发输入的类型
|
|
};
|
|
|
|
public const int MAX_OutputConfig_Len = 7;
|
|
|
|
//输出配置信息
|
|
public struct VZ_OutputConfigInfo
|
|
{
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = MAX_OutputConfig_Len, ArraySubType = UnmanagedType.I1)]
|
|
public VZ_LPRC_OutputConfig[] oConfigInfo; //多个输出配置输出的消息
|
|
};
|
|
|
|
///**加密类型**/
|
|
public const int ENCRYPT_NAME_LENGTH = 32;
|
|
|
|
public struct VZ_EMS_INFO
|
|
{
|
|
public uint uId; //加密ID
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = ENCRYPT_NAME_LENGTH)]
|
|
public string sName; //加密名
|
|
}
|
|
|
|
public const int ENCRYPT_LENGTH = 16;
|
|
public const int SIGNATURE_LENGTH = 32;
|
|
/**当前识别结果加密类型**/
|
|
|
|
public struct VZ_LPRC_ACTIVE_ENCRYPT
|
|
{
|
|
public uint uActiveID;//当前加密类型ID
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = ENCRYPT_LENGTH)]
|
|
public VZ_EMS_INFO[] oEncrpty;//系统加密类型
|
|
|
|
public uint uSize;//系统加密类型长度
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = SIGNATURE_LENGTH)]
|
|
public string signature;//SIGNATURE
|
|
}
|
|
|
|
/**串口参数*/
|
|
|
|
public struct VZ_SERIAL_PARAMETER
|
|
{
|
|
public uint uBaudRate; // <波特率 300,600,1200,2400,4800,9600,19200,34800,57600,115200
|
|
public uint uParity; // <校验位 其值为0-2=no,odd,even
|
|
public uint uDataBits; // <数据位 其值为7,8 位数据位
|
|
public uint uStopBit; // <停止位 其值为1,2位停止位
|
|
};
|
|
|
|
//设置回调函数时需要制定的类型
|
|
public enum VZ_LPRC_CALLBACK_TYPE : uint
|
|
{
|
|
VZ_LPRC_CALLBACK_COMMON_NOTIFY = 0, //SDK通用信息反馈
|
|
VZ_LPRC_CALLBACK_PLATE_STR, //车牌号码字符
|
|
VZ_LRPC_CALLBACK_FULL_IMAGE, //完整图像
|
|
VZ_LPRC_CALLBACK_CLIP_IMAGE, //截取图像
|
|
VZ_LPRC_CALLBACK_PLATE_RESULT, //实时识别结果
|
|
VZ_LPRC_CALLBACK_PLATE_RESULT_STABLE, //稳定识别结果
|
|
VZ_LPRC_CALLBACK_PLATE_RESULT_TRIGGER, //触发的识别结果,包括API(软件)和IO(硬件)方式的
|
|
VZ_LPRC_CALLBACK_VIDEO, //视频帧回调
|
|
}
|
|
|
|
//通用信息反馈类型
|
|
public enum VZ_LPRC_COMMON_NOTIFY : uint
|
|
{
|
|
VZ_LPRC_NO_ERR = 0,
|
|
VZ_LPRC_ACCESS_DENIED, //用户名密码错误
|
|
VZ_LPRC_NETWORK_ERR, //网络连接故障
|
|
}
|
|
|
|
//识别结果的类型
|
|
public enum VZ_LPRC_RESULT_TYPE : uint
|
|
{
|
|
VZ_LPRC_RESULT_REALTIME, /*<实时识别结果*/
|
|
VZ_LPRC_RESULT_STABLE, /*<稳定识别结果*/
|
|
VZ_LPRC_RESULT_FORCE_TRIGGER, /*<调用“VzLPRClient_ForceTrigger”触发的识别结果*/
|
|
VZ_LPRC_RESULT_IO_TRIGGER, /*<外部IO信号触发的识别结果*/
|
|
VZ_LPRC_RESULT_VLOOP_TRIGGER, /*<虚拟线圈触发的识别结果*/
|
|
VZ_LPRC_RESULT_MULTI_TRIGGER, /*<由_FORCE_\_IO_\_VLOOP_中的一种或多种同时触发,具体需要根据每个识别结果的TH_PlateResult::uBitsTrigType来判断*/
|
|
VZ_LPRC_RESULT_TYPE_NUM /*<结果种类个数*/
|
|
}
|
|
|
|
//顶点定义
|
|
//X_1000和Y_1000的取值范围为[0, 1000];
|
|
//即位置信息为实际图像位置在整体图像位置的相对尺寸;
|
|
//例如X_1000 = x*1000/win_width,其中x为点在图像中的水平像素位置,win_width为图像宽度
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_VERTEX
|
|
{
|
|
public uint X_1000;
|
|
public uint Y_1000;
|
|
}
|
|
|
|
public const int VZ_LPRC_ROI_VERTEX_NUM_EX = 12;
|
|
|
|
//识别区域信息定义
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_ROI_EX
|
|
{
|
|
public byte byRes1; //预留
|
|
public byte byEnable; //是否有效
|
|
public byte byDraw; //是否绘制
|
|
public byte byRes2; //预留
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 32, ArraySubType = UnmanagedType.I1)]
|
|
public byte[] byRes3; //预留
|
|
|
|
private uint uNumVertex; //顶点实际个数
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = VZ_LPRC_ROI_VERTEX_NUM_EX)]
|
|
public VZ_LPRC_VERTEX[] struVertex; //顶点数组
|
|
}
|
|
|
|
public const int VZ_LPRC_VIRTUAL_LOOP_NAME_LEN = 32;
|
|
public const int VZ_LPRC_VIRTUAL_LOOP_VERTEX_NUM = 4;
|
|
|
|
//虚拟线圈信息定义
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_VIRTUAL_LOOP
|
|
{
|
|
public byte byID; //序号
|
|
public byte byEnable; //是否有效
|
|
public byte byDraw; //是否绘制
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 1, ArraySubType = UnmanagedType.I1)]
|
|
public byte[] byRes; //预留
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = VZ_LPRC_VIRTUAL_LOOP_NAME_LEN)]
|
|
public string strName;
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = VZ_LPRC_VIRTUAL_LOOP_VERTEX_NUM)]
|
|
public VZ_LPRC_VERTEX[] struVertex; //顶点数组
|
|
|
|
public uint eCrossDir; // 穿越方向限制
|
|
public uint uTriggerTimeGap; // 对相同车牌的触发时间间隔的限制,单位为秒
|
|
public uint uMaxLPWidth; // 最大车牌尺寸限制
|
|
public uint uMinLPWidth; // 最小车牌尺寸限制
|
|
}
|
|
|
|
public const int VZ_LPRC_VIRTUAL_LOOP_MAX_NUM = 8;
|
|
|
|
//虚拟线圈序列
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_VIRTUAL_LOOPS
|
|
{
|
|
public uint uNumVirtualLoop; //实际个数
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = VZ_LPRC_VIRTUAL_LOOP_MAX_NUM)]
|
|
public VZ_LPRC_VIRTUAL_LOOP[] struLoop;
|
|
}
|
|
|
|
public const int VZ_LPRC_PROVINCE_STR_LEN = 128;
|
|
|
|
//预设省份信息
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_PROVINCE_INFO
|
|
{
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = VZ_LPRC_PROVINCE_STR_LEN, ArraySubType = UnmanagedType.I1)]
|
|
public char[] strProvinces; //所有支持的省份简称构成的字符串
|
|
|
|
public int nCurrIndex; //当前的预设省份的序号,在strProvinces中的,-1为未设置
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct TH_RECT
|
|
{
|
|
public int left;
|
|
public int top;
|
|
public int right;
|
|
public int bottom;
|
|
}
|
|
|
|
/**分解时间*/
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VzBDTime
|
|
{
|
|
public byte bdt_sec; /*<秒,取值范围[0,59]*/
|
|
public byte bdt_min; /*<分,取值范围[0,59]*/
|
|
public byte bdt_hour; /*<时,取值范围[0,23]*/
|
|
public byte bdt_mday; /*<一个月中的日期,取值范围[1,31]*/
|
|
public byte bdt_mon; /*<月份,取值范围[1,12]*/
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 3, ArraySubType = UnmanagedType.I1)]
|
|
public byte[] res1; /*<预留*/
|
|
|
|
public uint bdt_year; /*<年份*/
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 4, ArraySubType = UnmanagedType.I1)]
|
|
public byte[] res2; /*<预留*/
|
|
} //broken-down time
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_TIMEVAL
|
|
{
|
|
public uint uTVSec;
|
|
public uint uTVUSec;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct TH_PlateResult
|
|
{
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 16, ArraySubType = UnmanagedType.I1)]
|
|
public char[] license; // 车牌号码
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 8, ArraySubType = UnmanagedType.I1)]
|
|
public char[] color; // 车牌颜色
|
|
|
|
public int nColor; // 车牌颜色序号
|
|
public int nType; // 车牌类型
|
|
public int nConfidence; // 车牌可信度
|
|
public int nBright; // 亮度评价
|
|
public int nDirection; // 运动方向,0 unknown, 1 left, 2 right, 3 up , 4 down
|
|
public TH_RECT rcLocation; //车牌位置
|
|
public int nTime; //识别所用时间
|
|
public VZ_TIMEVAL tvPTS; //识别时间点
|
|
public uint uBitsTrigType; //强制触发结果的类型,见TH_TRIGGER_TYPE_BIT
|
|
public byte nCarBright; //车的亮度
|
|
public byte nCarColor; //车的颜色
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 2, ArraySubType = UnmanagedType.I1)]
|
|
public char[] reserved0; //为了对齐
|
|
|
|
public uint uId; //记录的编号
|
|
public VzBDTime struBDTime; //分解时间
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 84, ArraySubType = UnmanagedType.I1)]
|
|
public char[] reserved; // 保留
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VzYUV420P
|
|
{
|
|
public IntPtr pY;
|
|
public IntPtr pU;
|
|
public IntPtr pV;
|
|
private int widthStepY;
|
|
private int widthStepU;
|
|
private int widthStepV;
|
|
private int width;
|
|
private int height;
|
|
}
|
|
|
|
//图像信息
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_IMAGE_INFO
|
|
{
|
|
public uint uWidth;
|
|
public uint uHeight;
|
|
public uint uPitch;
|
|
public uint uPixFmt;
|
|
public IntPtr pBuffer;
|
|
}
|
|
|
|
//智能视频
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_DRAWMODE
|
|
{
|
|
public byte byDspAddTarget; //dsp叠加报警目标
|
|
public byte byDspAddRule; //dsp叠加设置规则
|
|
public byte byDspAddTrajectory; //dsp叠加轨迹
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 2, ArraySubType = UnmanagedType.I1)]
|
|
public byte[] dwRes;
|
|
};
|
|
|
|
//设备序列号
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_DEV_SERIAL_NUM
|
|
{
|
|
public uint uHi;
|
|
public uint uLo;
|
|
}
|
|
|
|
//********白名单********//
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_TM
|
|
{
|
|
/// short
|
|
public short nYear;
|
|
|
|
/// short
|
|
public short nMonth;
|
|
|
|
/// short
|
|
public short nMDay;
|
|
|
|
/// short
|
|
public short nHour;
|
|
|
|
/// short
|
|
public short nMin;
|
|
|
|
/// short
|
|
public short nSec;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_TM_WEEK_DAY
|
|
{
|
|
/// char
|
|
public byte bSun;
|
|
|
|
/// char
|
|
public byte bMon;
|
|
|
|
/// char
|
|
public byte bTue;
|
|
|
|
/// char
|
|
public byte bWed;
|
|
|
|
/// char
|
|
public byte bThur;
|
|
|
|
/// char
|
|
public byte bFri;
|
|
|
|
/// char
|
|
public byte bSat;
|
|
|
|
/// char
|
|
public byte reserved;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_OSD_Param
|
|
{
|
|
public byte dstampenable; // 0 off 1 on
|
|
public int dateFormat; // 0:YYYY/MM/DD;1:MM/DD/YYYY;2:DD/MM/YYYY
|
|
public int datePosX;
|
|
public int datePosY;
|
|
public byte tstampenable; // 0 off 1 on
|
|
public int timeFormat; // 0:12Hrs;1:24Hrs
|
|
public int timePosX;
|
|
public int timePosY;
|
|
public byte nLogoEnable; // 0 off 1 on
|
|
public int nLogoPositionX; //< logo position
|
|
public int nLogoPositionY; //< logo position
|
|
public byte nTextEnable; //0 off 1 on
|
|
public int nTextPositionX; //< text position
|
|
public int nTextPositionY; //< text position
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 16)]
|
|
public string overlaytext; //user define text //user define text
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_TM_DAY
|
|
{
|
|
/// short
|
|
public short nHour;
|
|
|
|
/// short
|
|
public short nMin;
|
|
|
|
/// short
|
|
public short nSec;
|
|
|
|
/// short
|
|
public short reserved;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_TM_WEEK_SEGMENT
|
|
{
|
|
/// unsigned int
|
|
public uint uEnable;
|
|
|
|
/// VZ_TM_WEEK_DAY->Anonymous_a54d933b_d2e6_4eba_97b3_61ea9b47dd3b
|
|
public VZ_TM_WEEK_DAY struDaySelect;
|
|
|
|
/// VZ_TM_DAY->Anonymous_2bafa8b8_e11f_4cdc_a109_eb09791f91d6
|
|
public VZ_TM_DAY struDayTimeStart;
|
|
|
|
/// VZ_TM_DAY->Anonymous_2bafa8b8_e11f_4cdc_a109_eb09791f91d6
|
|
public VZ_TM_DAY struDayTimeEnd;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_TM_RANGE
|
|
{
|
|
/// VZ_TM->Anonymous_40d76b6c_816a_4821_a5db_3480cee2a116
|
|
public VZ_TM struTimeStart;
|
|
|
|
/// VZ_TM->Anonymous_40d76b6c_816a_4821_a5db_3480cee2a116
|
|
public VZ_TM struTimeEnd;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_TM_PERIOD_OR_RANGE
|
|
{
|
|
/// unsigned int
|
|
public uint uEnable;
|
|
|
|
/// VZ_TM_WEEK_SEGMENT[8]
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 8, ArraySubType = UnmanagedType.Struct)]
|
|
public VZ_TM_WEEK_SEGMENT[] struWeekSeg;
|
|
}
|
|
|
|
/**设备日期时间参数*/
|
|
|
|
public struct VZ_DATE_TIME_INFO
|
|
{
|
|
public uint uYear; /*<年*/
|
|
public uint uMonth; /*<月 [1, 12]*/
|
|
public uint uMDay; /*<月中的天数 [1, 31]*/
|
|
public uint uHour; /*<时*/
|
|
public uint uMin; /*<分*/
|
|
public uint uSec; /*<秒*/
|
|
}
|
|
|
|
public enum VZ_LPR_WLIST_ERROR
|
|
{
|
|
/// VZ_LPR_WLIST_ERROR_NO_ERROR -> 0
|
|
VZ_LPR_WLIST_ERROR_NO_ERROR = 0,
|
|
|
|
VZ_LPR_WLIST_ERROR_PLATEID_EXISTS,
|
|
|
|
VZ_LPR_WLIST_ERROR_INSERT_CUSTOMERINFO_FAILED,
|
|
|
|
VZ_LPR_WLIST_ERROR_INSERT_VEHICLEINFO_FAILED,
|
|
|
|
VZ_LPR_WLIST_ERROR_UPDATE_CUSTOMERINFO_FAILED,
|
|
|
|
VZ_LPR_WLIST_ERROR_UPDATE_VEHICLEINFO_FAILED,
|
|
|
|
VZ_LPR_WLIST_ERROR_PLATEID_EMPTY,
|
|
|
|
VZ_LPR_WLIST_ERROR_ROW_NOT_CHANGED,
|
|
|
|
VZ_LPR_WLIST_ERROR_CUSTOMERINFO_NOT_CHANGED,
|
|
|
|
VZ_LPR_WLIST_ERROR_VEHICLEINFO_NOT_CHANGED,
|
|
|
|
VZ_LPR_WLIST_ERROR_CUSTOMER_VEHICLE_NOT_MATCH,
|
|
|
|
VZ_LPR_WLIST_ERROR_SERVER_GONE,
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
|
public struct VZ_LPR_WLIST_VEHICLE
|
|
{
|
|
/// unsigned int
|
|
public uint uVehicleID; //车辆在数据库的ID
|
|
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string strPlateID; //车牌字符串
|
|
|
|
/// unsigned int
|
|
public uint uCustomerID; //客户在数据库的ID
|
|
|
|
/// unsigned int
|
|
public uint bEnable; //该记录有效标记(是否启用)
|
|
|
|
/// unsigned int
|
|
public uint bEnableTMEnable; //是否开启生效时间
|
|
|
|
/// unsigned int
|
|
public uint bEnableTMOverdule; //是否开启过期时间
|
|
|
|
/// VZ_TM*
|
|
public VZ_TM struTMEnable; //该记录生效时间
|
|
|
|
public VZ_TM struTMOverdule; //该记录过期时间
|
|
|
|
/// unsigned int
|
|
public uint bUsingTimeSeg; //是否使用周期时间段
|
|
|
|
/// VZ_TM_PERIOD_OR_RANGE->Anonymous_6f46bf7e_03f5_450b_84da_e56739a41561
|
|
public VZ_TM_PERIOD_OR_RANGE struTimeSegOrRange;//周期时间段信息
|
|
|
|
/// unsigned int
|
|
public uint bAlarm; //是否触发报警(黑名单记录)
|
|
|
|
public uint iColor; //车辆颜色
|
|
|
|
public uint iPlateType; //车牌类型
|
|
|
|
// 车辆代码
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string strCode; //车辆编码
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 64)]
|
|
public string strComment; //车辆编码
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
|
public struct VZ_LPR_WLIST_CUSTOMER
|
|
{
|
|
/// unsigned int
|
|
public uint uCustomerID;
|
|
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string strName;
|
|
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string strCode;
|
|
|
|
/// char[256]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 256)]
|
|
public string reserved;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPR_WLIST_ROW
|
|
{
|
|
/// VZ_LPR_WLIST_CUSTOMER*
|
|
public IntPtr pCustomer;
|
|
|
|
/// VZ_LPR_WLIST_VEHICLE*
|
|
public IntPtr pVehicle;
|
|
}
|
|
|
|
//查找数据条件
|
|
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
|
public struct VZ_LPR_WLIST_SEARCH_CONSTRAINT
|
|
{
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string key; //查找的字段
|
|
|
|
/// char[128]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 128)]
|
|
public string search_string; //查找的字符串
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
|
public struct VZ_LPR_MSG_PLATE_INFO
|
|
{
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string plate;
|
|
|
|
/// char[128]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 260)]
|
|
public string img_path;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
|
public struct VZ_LPR_DEVICE_INFO
|
|
{
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string device_ip;
|
|
|
|
/// char[64]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 64)]
|
|
public string serial_no;
|
|
}
|
|
|
|
public enum VZ_LPR_WLIST_LIMIT_TYPE
|
|
{
|
|
VZ_LPR_WLIST_LIMIT_TYPE_ONE, //查找一条
|
|
VZ_LPR_WLIST_LIMIT_TYPE_ALL, //查找所有
|
|
VZ_LPR_WLIST_LIMIT_TYPE_RANGE, //查找一段
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPR_WLIST_RANGE_LIMIT
|
|
{
|
|
public int startIndex; //查找起始位置
|
|
public int count; //查找条数
|
|
}
|
|
|
|
//查找条数限制
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPR_WLIST_LIMIT
|
|
{
|
|
/// VZ_LPR_WLIST_LIMIT_TYPE->Anonymous_988ed792_488c_49e0_9b97_4fef91401704
|
|
public VZ_LPR_WLIST_LIMIT_TYPE limitType; //查找条数限制
|
|
|
|
/// VZ_LPR_WLIST_RANGE_LIMIT*
|
|
public IntPtr pRangeLimit; //查找哪一段数据
|
|
}
|
|
|
|
public enum VZ_LPR_WLIST_SORT_DIRECTION
|
|
{
|
|
/// VZ_LPR_WLIST_SORT_DIRECTION_DESC -> 0
|
|
VZ_LPR_WLIST_SORT_DIRECTION_DESC = 0,
|
|
|
|
/// VZ_LPR_WLIST_SORT_DIRECTION_ASC -> 1
|
|
VZ_LPR_WLIST_SORT_DIRECTION_ASC = 1,
|
|
}
|
|
|
|
//结果的排列方式
|
|
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
|
public struct VZ_LPR_WLIST_SORT_TYPE
|
|
{
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string key; //排序的字段
|
|
|
|
/// VZ_LPR_WLIST_SORT_DIRECTION->Anonymous_dde74036_93c7_4601_966c_0439d47c4836
|
|
public VZ_LPR_WLIST_SORT_DIRECTION direction; //排序的方式
|
|
}
|
|
|
|
//查找的方式
|
|
public enum VZ_LPR_WLIST_SEARCH_TYPE
|
|
{
|
|
VZ_LPR_WLIST_SEARCH_TYPE_LIKE, //包含字符
|
|
VZ_LPR_WLIST_SEARCH_TYPE_EQUAL, //完全匹配
|
|
}
|
|
|
|
//查找条件
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPR_WLIST_SEARCH_WHERE
|
|
{
|
|
/// VZ_LPR_WLIST_SEARCH_TYPE->Anonymous_e3b38339_d7de_4d6d_998f_8f03f1a82e9c
|
|
public VZ_LPR_WLIST_SEARCH_TYPE searchType;//查找的方式,如果是完全匹配,每个条件之间为与;是包含字符时,每个条件之间为或
|
|
|
|
/// unsigned int
|
|
public uint searchConstraintCount; //查找条件个数,为0表示没有搜索条件
|
|
|
|
/// VZ_LPR_WLIST_SEARCH_CONSTRAINT*
|
|
public IntPtr pSearchConstraints; //查找条件数组指针
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPR_WLIST_LOAD_CONDITIONS
|
|
{
|
|
/// VZ_LPR_WLIST_SEARCH_WHERE*
|
|
public IntPtr pSearchWhere; //查找条件
|
|
|
|
/// VZ_LPR_WLIST_LIMIT*
|
|
public IntPtr pLimit; //查找条数限制
|
|
|
|
/// VZ_LPR_WLIST_SORT_TYPE*
|
|
public IntPtr pSortType; //结果的排序方式,为空表示按默认排序
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
|
public struct VZ_LPR_WLIST_KEY_DEFINE
|
|
{
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string key;
|
|
|
|
/// char[32]
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string name;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPR_WLIST_IMPORT_RESULT
|
|
{
|
|
/// int
|
|
public int ret;
|
|
|
|
/// int
|
|
public int error_code;
|
|
}
|
|
|
|
public enum VZLPRC_WLIST_CB_TYPE
|
|
{
|
|
/// VZLPRC_WLIST_CB_TYPE_ROW -> 0
|
|
VZLPRC_WLIST_CB_TYPE_ROW = 0,
|
|
|
|
VZLPRC_WLIST_CB_TYPE_CUSTOMER,
|
|
|
|
VZLPRC_WLIST_CB_TYPE_VEHICLE,
|
|
}
|
|
|
|
/**LED补光灯命令*/
|
|
|
|
public enum VZ_LED_CTRL
|
|
{
|
|
VZ_LED_AUTO, /*<自动控制LED的开和关*/
|
|
VZ_LED_MANUAL_ON, /*<手动控制LED开启*/
|
|
VZ_LED_MANUAL_OFF, /*<手动控制LED关闭*/
|
|
}
|
|
|
|
/**************************************中心服务器***********************************************/
|
|
|
|
//中心服务器网络
|
|
public const int LPRC_CENTER_IPLEN = 200;
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_CENTER_SERVER_NET
|
|
{
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = LPRC_CENTER_IPLEN)]
|
|
public string centerServerIp; //中心服务器地址
|
|
|
|
public ushort port; //中心服务器端口
|
|
|
|
public byte enableSsl; //是否使用ssl协议
|
|
|
|
public ushort sslPort; //ssl协议端口
|
|
|
|
public ushort timeout; //超时时间设置错误, 范围【1~30】
|
|
}
|
|
|
|
public const int URLLENGTH = 1000;
|
|
|
|
//中心服务器网络设备注册
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_CENTER_SERVER_DEVICE_REG
|
|
{
|
|
public byte type; //中心服务器设备注册类型 0:取消心跳 1:普通心跳 2:comet轮询
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = URLLENGTH)]
|
|
public string url; //中心服务器设备注册地址
|
|
}
|
|
|
|
//中心服务器网络车牌
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_CENTER_SERVER_PLATE
|
|
{
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = URLLENGTH)]
|
|
public string url; //中心服务器车牌地址
|
|
|
|
public byte enable; //中心服务器车牌推送使能
|
|
|
|
public byte contentLevel; //中心服务器车牌内容详细等级 0:全部 1:较详细 2:较简略 3:简略
|
|
|
|
public byte sendLargeImage; //中心服务器车牌是否发送大图片
|
|
|
|
public byte sendSmallImage; //中心服务器车牌是否发送小图片
|
|
}
|
|
|
|
//中心服务器网络设备端口触发
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_CENTER_SERVER_GIONIN
|
|
{
|
|
public byte enable; //中心服务器网络设备端口触发使能
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = URLLENGTH)]
|
|
public string url; //中心服务器网络设备端口触发地址
|
|
}
|
|
|
|
//中心服务器网络设备串口
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_CENTER_SERVER_SERIAL
|
|
{
|
|
public byte enable; //中心服务器网络设备串口使能
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = URLLENGTH)]
|
|
public string url; //中心服务器网络设备串口地址
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_R_ENCODE_PARAM
|
|
{
|
|
public int default_stream; /* 当前选择的码流 */
|
|
public int stream_id; /* 码流类型 */
|
|
public int resolution; /* 分辨率; */
|
|
public int frame_rate; /* [0, 25],帧率; */
|
|
public int encode_type; /* h264; */
|
|
public int rate_type; /* 码流类型,对应码流控制; */
|
|
public int data_rate; /* 码流上限; */
|
|
public int video_quality; /* 视频质量; */
|
|
}
|
|
|
|
public int VZ_LPRC_MAX_RESOLUTION = 12;
|
|
public int VZ_LPRC_MAX_RATE = 5;
|
|
public int VZ_LPRC_MAX_VIDEO_QUALITY = 12;
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_R_RESOLUTION
|
|
{
|
|
public int resolution_type; /* 码流类型 */
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string resolution_content; //码流类型
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_R_RATE_TYPE
|
|
{
|
|
public int rate_type_value;
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string rate_type_content;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_R_VIDEO_QUALITY
|
|
{
|
|
private int video_quality_type;
|
|
|
|
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 32)]
|
|
public string video_quality_content;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_R_ENCODE_PARAM_PROPERTY
|
|
{
|
|
public int encode_stream; /* 当前选择的码流 */
|
|
public int resolution_cur; /* 分辨率 */
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 12, ArraySubType = UnmanagedType.Struct)]
|
|
public VZ_LPRC_R_RESOLUTION[] resolution; /* 分辨率 */
|
|
|
|
public int frame_rate_cur; /* 当前帧率; */
|
|
public int frame_rate_min; /* 最小帧率; */
|
|
public int frame_rate_max; /* 最大帧率; */
|
|
public int rate_type_cur; /* 码率控制 */
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 5, ArraySubType = UnmanagedType.Struct)]
|
|
public VZ_LPRC_R_RATE_TYPE[] rate_type;
|
|
|
|
public int data_rate_cur; /* 码流上限; */
|
|
public int data_rate_min;
|
|
public int data_rate_max;
|
|
public int video_quality_cur; /* 视频质量; */
|
|
|
|
[MarshalAs(UnmanagedType.ByValArray, SizeConst = 12, ArraySubType = UnmanagedType.Struct)]
|
|
public VZ_LPRC_R_VIDEO_QUALITY[] video_quality;
|
|
}
|
|
|
|
[StructLayout(LayoutKind.Sequential)]
|
|
public struct VZ_LPRC_R_VIDEO_PARAM
|
|
{
|
|
public int brightness;
|
|
public int contrast;
|
|
public int saturation;
|
|
public int sharpness;
|
|
public int hue;
|
|
public int exposure;
|
|
public int max_exposure;
|
|
public int gain;
|
|
public int max_gain;
|
|
public int denoise;
|
|
public int flip;
|
|
public int frquency;
|
|
public int night_mode;
|
|
}
|
|
|
|
//API
|
|
/**
|
|
* @brief 全局初始化,在所有接口调用之前调用
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("kernel32.dll")]
|
|
public static extern void CopyMemory(IntPtr Destination, IntPtr Source, int Length);
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_Setup();
|
|
|
|
/**
|
|
* @brief 全局释放
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern void VzLPRClient_Cleanup();
|
|
|
|
public delegate void VZLPRC_COMMON_NOTIFY_CALLBACK(int handle, IntPtr pUserData,
|
|
VZ_LPRC_COMMON_NOTIFY eNotify, string pStrDetail);
|
|
|
|
/**
|
|
* @brief 设置设备连接反馈结果相关的回调函数
|
|
* @param [IN] func 设备连接结果和状态,通过该回调函数返回
|
|
* @param [IN] pUserData 回调函数中的上下文
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VZLPRClient_SetCommonNotifyCallBack(VZLPRC_COMMON_NOTIFY_CALLBACK func, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 打开一个设备
|
|
* @param [IN] pStrIP 设备的IP地址
|
|
* @param [IN] wPort 设备的端口号
|
|
* @param [IN] pStrUserName 访问设备所需用户名
|
|
* @param [IN] pStrPassword 访问设备所需密码
|
|
* @return 返回设备的操作句柄,当打开失败时,返回-1
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_Open(string pStrIP, ushort wPort, string pStrUserName, string pStrPassword);
|
|
|
|
/**
|
|
* @brief 关闭一个设备
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_Close(int handle);
|
|
|
|
/**
|
|
* @brief 通过IP地址关闭一个设备
|
|
* @param [IN] pStrIP 设备的IP地址
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_CloseByIP(string pStrIP);
|
|
|
|
/**
|
|
* @brief 获取连接状态
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param[IN/OUT] pStatus 输入获取状态的变量地址,输出内容为 1已连上,0未连上
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_IsConnected(int handle, ref byte pStatus);
|
|
|
|
/**
|
|
* @brief 根据句柄获取设备的IP
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] ip 相机IP
|
|
* @param [IN] max_count IP传入长度
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetDeviceIP(int handle, ref byte ip, int max_count);
|
|
|
|
/**
|
|
* @brief 播放实时视频
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] hWnd 窗口的句柄
|
|
* @return 播放句柄,小于0表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_StartRealPlay(int handle, IntPtr hWnd);
|
|
|
|
/**
|
|
* @brief 停止正在播放的窗口上的实时视频
|
|
* @param [IN] hWnd 窗口的句柄
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_StopRealPlay(int hRealHandle);
|
|
|
|
public delegate int VZLPRC_PLATE_INFO_CALLBACK(int handle, IntPtr pUserData,
|
|
IntPtr pResult, uint uNumPlates,
|
|
VZ_LPRC_RESULT_TYPE eResultType,
|
|
IntPtr pImgFull,
|
|
IntPtr pImgPlateClip);
|
|
|
|
/**
|
|
* @brief 设置识别结果的回调函数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] func 识别结果回调函数
|
|
* @param [IN] pUserData 回调函数中的上下文
|
|
* @param [IN] bEnableImage 指定识别结果的回调是否需要包含截图信息:1为需要,0为不需要
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll", CallingConvention = CallingConvention.StdCall)]
|
|
public static extern int VzLPRClient_SetPlateInfoCallBack(int handle, VZLPRC_PLATE_INFO_CALLBACK func, IntPtr pUserData, int bEnableImage);
|
|
|
|
/**
|
|
* @brief 通过该回调函数获得实时图像数据
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pUserData 回调函数的上下文
|
|
* @param [IN] pFrame 图像帧信息,详见结构体定义VzYUV420P
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_callback
|
|
*/
|
|
|
|
public delegate void VZLPRC_VIDEO_FRAME_CALLBACK(int handle, IntPtr pUserData, ref VzYUV420P pFrame);
|
|
|
|
/**
|
|
* @brief 设置实时图像数据的回调函数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] func 实时图像数据函数
|
|
* @param [IN] pUserData 回调函数中的上下文
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll", CallingConvention = CallingConvention.StdCall)]
|
|
public static extern int VzLPRClient_SetVideoFrameCallBack(int handle, VZLPRC_VIDEO_FRAME_CALLBACK pFunc, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 发送软件触发信号,强制处理当前时刻的数据并输出结果
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_ForceTrigger(int handle);
|
|
|
|
/**
|
|
* @brief 设置虚拟线圈
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pVirtualLoops 虚拟线圈的结构体指针
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVirtualLoop(int handle, ref VZ_LPRC_VIRTUAL_LOOPS pVirtualLoops);
|
|
|
|
/**
|
|
* @brief 获取已设置的虚拟线圈
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pVirtualLoops 虚拟线圈的结构体指针
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVirtualLoop(int handle, ref VZ_LPRC_VIRTUAL_LOOPS pVirtualLoops);
|
|
|
|
/**
|
|
* @brief 获取已设置的识别区域
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pROI 识别区域的结构体指针
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetRegionOfInterestEx(int handle, ref VZ_LPRC_ROI_EX pROI);
|
|
|
|
/**
|
|
* @brief 获取已设置的预设省份
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pProvInfo 预设省份信息指针
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetSupportedProvinces(int handle, ref VZ_LPRC_PROVINCE_INFO pProvInfo);
|
|
|
|
/**
|
|
* @brief 设置预设省份
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nIndex 设置预设省份的序号,序号需要参考VZ_LPRC_PROVINCE_INFO::strProvinces中的顺序,从0开始,如果小于0,则表示不设置预设省份
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_PresetProvinceIndex(int handle, int nIndex);
|
|
|
|
/**
|
|
* @brief 将图像保存为JPEG到指定路径
|
|
* @param [IN] pImgInfo 图像结构体,目前只支持默认的格式,即ImageFormatRGB
|
|
* @param [IN] pFullPathName 设带绝对路径和JPG后缀名的文件名字符串
|
|
* @param [IN] nQuality JPEG压缩的质量,取值范围1~100;
|
|
* @return 0表示成功,-1表示失败
|
|
* @note 给定的文件名中的路径需要存在
|
|
* @ingroup group_global
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_ImageSaveToJpeg(IntPtr pImgInfo, string pFullPathName, int nQuality);
|
|
|
|
/**
|
|
* @brief 读出设备序列号,可用于二次加密
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN/OUT] pSN 用于存放读到的设备序列号,详见定义 VZ_DEV_SERIAL_NUM
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetSerialNumber(int handle, ref VZ_DEV_SERIAL_NUM pSN);
|
|
|
|
/**
|
|
* @brief 保存正在播放的视频的当前帧的截图到指定路径
|
|
* @param [IN] nPlayHandle 播放的句柄
|
|
* @param [IN] pFullPathName 设带绝对路径和JPG后缀名的文件名字符串
|
|
* @param [IN] nQuality JPEG压缩的质量,取值范围1~100;
|
|
* @return 0表示成功,-1表示失败
|
|
* @note 使用的文件名中的路径需要存在
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetSnapShootToJpeg2(int nPlayHandle, string pFullPathName, int nQuality);
|
|
|
|
/**
|
|
* @brief 通过该回调函数获得透明通道接收的数据
|
|
* @param [IN] nSerialHandle VzLPRClient_SerialStart返回的句柄
|
|
* @param [IN] pStrIPAddr 设备IP地址
|
|
* @param [IN] usPort1 设备端口号
|
|
* @param [IN] usPort2 预留
|
|
* @param [IN] pUserData 回调函数上下文
|
|
* @ingroup group_global
|
|
*/
|
|
|
|
public delegate int VZDEV_SERIAL_RECV_DATA_CALLBACK(int nSerialHandle, IntPtr pRecvData, int uRecvSize, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 开启透明通道
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nSerialPort 指定使用设备的串口序号:0表示第一个串口,1表示第二个串口
|
|
* @param [IN] func 接收数据的回调函数
|
|
* @param [IN] pUserData 接收数据回调函数的上下文
|
|
* @return 返回透明通道句柄,0表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SerialStart(int handle, int nSerialPort, VZDEV_SERIAL_RECV_DATA_CALLBACK func, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 透明通道发送数据
|
|
* @param [IN] nSerialHandle 由VzLPRClient_SerialStart函数获得的句柄
|
|
* @param [IN] pData 将要传输的数据块的首地址
|
|
* @param [IN] uSizeData 将要传输的数据块的字节数
|
|
* @return 0表示成功,其他值表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SerialSend(int nSerialHandle, IntPtr pData, int uSizeData);
|
|
|
|
/**
|
|
* @brief 透明通道停止发送数据
|
|
* @param [IN] nSerialHandle 由VzLPRClient_SerialStart函数获得的句柄
|
|
* @return 0表示成功,其他值表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SerialStop(int nSerialHandle);
|
|
|
|
/**
|
|
* @brief 设置IO输出的状态
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] uChnId IO输出的通道号,从0开始
|
|
* @param [OUT] nOutput 将要设置的IO输出的状态,0表示继电器开路,1表示继电器闭路
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetIOOutput(int handle, int uChnId, int nOutput);
|
|
|
|
/**
|
|
* @brief 获取IO输出的状态
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] uChnId IO输出的通道号,从0开始
|
|
* @param [OUT] pOutput IO输出的状态,0表示继电器开路,1表示继电器闭路
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetIOOutput(int handle, int uChnId, ref int pOutput);
|
|
|
|
/**
|
|
* @brief 获取GPIO的状态
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] gpioIn 数据为0或1
|
|
* @param [OUT] value 0代表短路,1代表开路
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetGPIOValue(int handle, int gpioIn, IntPtr value);
|
|
|
|
/**
|
|
* @brief 根据ID获取车牌图片
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] id 车牌记录的ID
|
|
* @param [IN] pdata 存储图片的内存
|
|
* @param [IN][OUT] size 为传入传出值,传入为图片内存的大小,返回的是获取到jpg图片内存的大小
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_LoadImageById(int handle, int id, IntPtr pdata, IntPtr size);
|
|
|
|
/**
|
|
* @brief 向白名单表导入客户和车辆记录
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] rowcount 记录的条数
|
|
* @param [IN] pRowDatas 记录的内容数组的地址
|
|
* @param [OUT] results 每条数据是否导入成功
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListImportRows(int handle,
|
|
uint rowcount,
|
|
ref VZ_LPR_WLIST_ROW pRowDatas,
|
|
ref VZ_LPR_WLIST_IMPORT_RESULT pResults);
|
|
|
|
/**
|
|
* @brief 从数据库删除车辆信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] strPlateID 车牌号码
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListDeleteVehicle(int handle, string strPlateID);
|
|
|
|
/**
|
|
* @brief 清空数据库客户信息和车辆信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListClearCustomersAndVehicles(int handle);
|
|
|
|
/**
|
|
* @brief 获取白名单表中所有车辆信息记录的条数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return >=0表示所有车辆信息记录的总数,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListGetVehicleCount(int handle, ref uint pCount,
|
|
ref VZ_LPR_WLIST_SEARCH_WHERE pSearchWhere);
|
|
|
|
/**
|
|
* @brief 查询白名单表车辆记录数据
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pLoadCondition 查询条件
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListLoadVehicle(int handle,
|
|
ref VZ_LPR_WLIST_LOAD_CONDITIONS pLoadCondition);
|
|
|
|
public delegate void VZLPRC_WLIST_QUERY_CALLBACK(VZLPRC_WLIST_CB_TYPE type, IntPtr pLP,
|
|
IntPtr pCustomer,
|
|
IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 设置白名单表和客户信息表的查询结果回调
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] func 查询结果回调函数
|
|
* @param [IN] pUserData 回调函数中的上下文
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListSetQueryCallBack(int handle, VZLPRC_WLIST_QUERY_CALLBACK func, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 往白名单表中更新一个车辆信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pVehicle 将要更新的车辆信息,详见结构体定义VZ_LPR_WLIST_VEHICLE
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListUpdateVehicleByID(int handle, ref VZ_LPR_WLIST_VEHICLE pVehicle);
|
|
|
|
/**
|
|
* @brief 查询白名单表客户和车辆记录条数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] pCount 记录的条数
|
|
* @param [IN] search_constraints 搜索的条件
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_database
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WhiteListGetRowCount(int handle, ref int count, ref VZ_LPR_WLIST_SEARCH_WHERE pSearchWhere);
|
|
|
|
/**
|
|
* @brief 设置LED控制模式
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] eCtrl 控制LED开关模式,详见定义 VZ_LED_CTRL
|
|
* @return 返回值为0表示成功,返回其他值表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetLEDLightControlMode(int handle, VZ_LED_CTRL eCtrl);
|
|
|
|
/**
|
|
* @brief 获取LED当前亮度等级和最大亮度等级
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] pLevelNow 用于输出当前亮度等级的地址
|
|
* @param [OUT] pLevelMax 用于输出最高亮度等级的地址
|
|
* @return 0表示成功,其他值表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetLEDLightStatus(int handle, ref int pLevelNow, ref int pLevelMax);
|
|
|
|
/**
|
|
* @brief 设置LED亮度等级
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nLevel,LED亮度等级
|
|
* @return 0表示成功,其他值表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetLEDLightLevel(int handle, int nLevel);
|
|
|
|
/**
|
|
* @brief 开始录像功能
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] sFileName 录像文件的路径
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SaveRealData(int handle, string sFileName);
|
|
|
|
/**
|
|
* @brief 停止录像
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_StopSaveRealData(int handle);
|
|
|
|
/**
|
|
* @brief 开启脱机功能
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pUserData 接收数据回调函数的上下文
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetOfflineCheck(int handle);
|
|
|
|
/**
|
|
* @brief 关闭脱机功能
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pUserData 接收数据回调函数的上下文
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_CancelOfflineCheck(int handle);
|
|
|
|
/**
|
|
* @brief 通过该回调函数获得透明通道接收的数据
|
|
* @param [IN] nSerialHandle VzLPRClient_SerialStart返回的句柄
|
|
* @param [IN] pRecvData 接收的数据的首地址
|
|
* @param [IN] uRecvSize 接收的数据的尺寸
|
|
* @param [IN] pUserData 回调函数上下文
|
|
* @ingroup group_callback
|
|
*/
|
|
|
|
/**
|
|
* @brief 透明通道发送数据
|
|
* @param [IN] nSerialHandle 由VzLPRClient_SerialStart函数获得的句柄
|
|
* @param [IN] pData 将要传输的数据块的首地址
|
|
* @param [IN] uSizeData 将要传输的数据块的字节数
|
|
* @return 0表示成功,其他值表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
//[DllImport("VzLPRSDK.dll")]
|
|
//public static extern int VzLPRClient_SerialSend(int nSerialHandle,string pData, uint uSizeData);
|
|
|
|
/**
|
|
* @brief 通过该回调函数获得找到的设备基本信息
|
|
* @param [IN] pStrDevName 设备名称
|
|
* @param [IN] pStrIPAddr 设备IP地址
|
|
* @param [IN] usPort1 设备端口号
|
|
* @param [IN] usPort2 预留
|
|
* @param [IN] pUserData 回调函数上下文
|
|
* @ingroup group_callback
|
|
*/
|
|
|
|
public delegate void VZLPRC_FIND_DEVICE_CALLBACK_EX(string pStrDevName, string pStrIPAddr, ushort usPort1, ushort usPort2, uint SL, uint SH, string netmask, string gateway, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 开始查找设备
|
|
* @param [IN] func 找到的设备通过该回调函数返回
|
|
* @param [IN] pUserData 回调函数中的上下文
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_global
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VZLPRClient_StartFindDeviceEx(VZLPRC_FIND_DEVICE_CALLBACK_EX func, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 停止查找设备
|
|
* @ingroup group_global
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VZLPRClient_StopFindDevice();
|
|
|
|
/**
|
|
* @brief 根据起始时间和车牌关键字查询记录
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pStartTime 起始时间,格式如"2015-01-02 12:20:30"
|
|
* @param [IN] pEndTime 起始时间,格式如"2015-01-02 19:20:30"
|
|
* @param [IN] keyword 车牌号关键字, 如"川"
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @说明 通过回调返回数据,最多返回100条数据,超过时请调用分页查询的接口
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_QueryRecordByTimeAndPlate(int handle, string pStartTime, string pEndTime, string keyword);
|
|
|
|
/**
|
|
* @brief 根据时间和车牌号查询记录条数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pStartTime 起始时间,格式如"2015-01-02 12:20:30"
|
|
* @param [IN] pEndTime 起始时间,格式如"2015-01-02 19:20:30"
|
|
* @param [IN] keyword 车牌号关键字, 如"川"
|
|
* @return 返回值为0表示失败,大于0表示记录条数
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_QueryCountByTimeAndPlate(int handle, string pStartTime, string pEndTime, string keyword);
|
|
|
|
/**
|
|
* @brief 根据时间和车牌号查询分页查询记录
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pStartTime 起始时间,格式如"2015-01-02 12:20:30"
|
|
* @param [IN] pEndTime 起始时间,格式如"2015-01-02 19:20:30"
|
|
* @param [IN] keyword 车牌号关键字, 如"川"
|
|
* @param [IN] start 起始位置大于0,小于结束位置
|
|
* @param [IN] end 结束位置大于0,大于起始位置,获取记录条数不能大于100
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_QueryPageRecordByTimeAndPlate(int handle, string pStartTime, string pEndTime, string keyword, int start, int end);
|
|
|
|
/**
|
|
* @brief 设置查询车牌记录的回调函数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] func 识别结果回调函数,如果为NULL,则表示关闭该回调函数的功能
|
|
* @param [IN] pUserData 回调函数中的上下文
|
|
* @param [IN] bEnableImage 指定识别结果的回调是否需要包含截图信息:1为需要,0为不需要
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetQueryPlateCallBack(int handle, VZLPRC_PLATE_INFO_CALLBACK func, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 获取视频OSD参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetOsdParam(int handle, IntPtr pParam);
|
|
|
|
/**
|
|
* @brief 设置视频OSD参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetOsdParam(int handle, IntPtr pParam);
|
|
|
|
/**
|
|
* @brief 获取设备的日期时间
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pDTInfo 将要设置的设备日期时间信息,详见定义 VZ_DATE_TIME_INFO
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetDateTime(int handle, ref VZ_DATE_TIME_INFO info);
|
|
|
|
/**
|
|
* @brief 设置设备的日期时间
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pDTInfo 将要设置的设备日期时间信息,详见定义 VZ_DATE_TIME_INFO
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetDateTime(int handle, ref VZ_DATE_TIME_INFO info);
|
|
|
|
/**
|
|
* @brief 读出用户私有数据,可用于二次加密
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN/OUT] pBuffer 用于存放读到的用户数据
|
|
* @param [IN] uSizeBuf 用户数据缓冲区的最小尺寸,不小于128字节
|
|
* @return 返回值为实际用户数据的字节数,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_ReadUserData(int handle, IntPtr pBuffer, uint uSizeBuf);
|
|
|
|
/**
|
|
* @brief 写入用户私有数据,可用于二次加密
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pUserData 用户数据
|
|
* @param [IN] uSizeData 用户数据的长度,最大128字节
|
|
* @return 返回值为0表示成功,返回其他值表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_WriteUserData(int handle, IntPtr pUserData, uint uSizeData);
|
|
|
|
/**
|
|
* @brief 将图像编码为JPEG,保存到指定内存
|
|
* @param [IN] pImgInfo 图像结构体,目前只支持默认的格式,即ImageFormatRGB
|
|
* @param [IN/OUT] pDstBuf JPEG数据的目的存储首地址
|
|
* @param [IN] uSizeBuf JPEG数据地址的内存的最大尺寸;
|
|
* @param [IN] nQuality JPEG压缩的质量,取值范围1~100;
|
|
* @return >0表示成功,即编码后的尺寸,-1表示失败,-2表示给定的压缩数据的内存尺寸不够大
|
|
* @ingroup group_global
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_ImageEncodeToJpeg(IntPtr pImgInfo, IntPtr pDstBuf, int uSizeBuf, int nQuality);
|
|
|
|
/**
|
|
* @brief 设置IO输出,并自动复位
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] uChnId IO输出的通道号,从0开始
|
|
* @param [IN] nDuration 延时时间,取值范围[500, 5000]毫秒
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetIOOutputAuto(int handle, int uChnId, int nDuration);
|
|
|
|
public delegate void VZLPRC_VIDEO_FRAME_CALLBACK_EX(int handle, IntPtr pUserData, ref VZ_LPRC_IMAGE_INFO pFrame);
|
|
|
|
/**
|
|
* @brief 获取实时视频帧,图像数据通过回调函数到用户层,用户可改动图像内容,并且显示到窗口
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] hWnd 窗口的句柄,如果为有效值,则视频图像会显示到该窗口上,如果为空,则不显示视频图像
|
|
* @param [IN] func 实时图像数据函数
|
|
* @param [IN] pUserData 回调函数中的上下文
|
|
* @return 播放的句柄,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll", CallingConvention = CallingConvention.StdCall)]
|
|
public static extern int VzLPRClient_StartRealPlayFrameCallBack(int handle, IntPtr hWnd, VZLPRC_VIDEO_FRAME_CALLBACK_EX func, IntPtr pUserData);
|
|
|
|
/**
|
|
* @brief 获取已设置的允许的车牌识别触发类型
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] pBitsTrigType 允许的车牌识别触发类型按位或的变量的地址,允许触发类型位详见定义VZ_LPRC_TRIG_ENABLE_XXX
|
|
* @return 返回值:返回值为0表示成功,返回其他值表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetPlateTrigType(int handle, ref int pBitsTrigType);
|
|
|
|
/**
|
|
* @brief 设置允许的车牌识别触发类型
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] uBitsTrigType 允许的车牌识别触发类型按位或的值,允许触发类型位详见定义VZ_LPRC_TRIG_ENABLE_XXX
|
|
* @return 返回值:返回值为0表示成功,返回其他值表示失败
|
|
* @note 如果设置不允许某种类型的触发,那么该种类型的触发结果也不会保存在设备的SD卡中
|
|
* @note 默认输出稳定触发和虚拟线圈触发
|
|
* @note 不会影响手动触发和IO输入触发
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetPlateTrigType(int handle, uint uBitsTrigType);
|
|
|
|
/**
|
|
* @brief 获取智能视频显示模式
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] pDrawMode 显示模式,参考VZ_LPRC_DRAWMODE
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetDrawMode(int handle, ref VZ_LPRC_DRAWMODE pDrawMode);
|
|
|
|
/**
|
|
* @brief 设置智能视频显示模式
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pDrawMode 显示模式,参考VZ_LPRC_DRAWMODE
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetDrawMode(int handle, ref VZ_LPRC_DRAWMODE pDrawMode);
|
|
|
|
/**
|
|
* @brief 获取已设置的需要识别的车牌类型位
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] pBitsRecType 需要识别的车牌类型按位或的变量的地址,车牌类型位详见定义VZ_LPRC_REC_XXX
|
|
* @return 返回值:返回值为0表示成功,返回其他值表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetPlateRecType(int handle, ref int pBitsRecType);
|
|
|
|
/**
|
|
* @brief 设置需要识别的车牌类型
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] uBitsRecType 需要识别的车牌类型按位或的值,车牌类型位详见定义VZ_LPRC_REC_XXX
|
|
* @return 返回值:返回值为0表示成功,返回其他值表示失败
|
|
* @note 在需要识别特定车牌时,调用该接口来设置,将不同类型的车牌位定义取或,得到的结果作为参数传入;
|
|
* @note 在不必要的情况下,使用最少的车牌识别类型,将最大限度提高识别率;
|
|
* @note 默认识别蓝牌和黄牌;
|
|
* @note 例如,需要识别蓝牌、黄牌、警牌,那么输入参数uBitsRecType = VZ_LPRC_REC_BLUE|VZ_LPRC_REC_YELLOW|VZ_LPRC_REC_POLICE
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetPlateRecType(int handle, uint uBitsRecType);
|
|
|
|
/**
|
|
* @brief 获取输出配置0
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pOutputConfig 输出配置
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetOutputConfig(int handle, ref VZ_OutputConfigInfo pOutputConfigInfo);
|
|
|
|
/**
|
|
* @brief 设置输出配置
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pOutputConfig 输出配置
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetOutputConfig(int handle, ref VZ_OutputConfigInfo pOutputConfigInfo);
|
|
|
|
/**
|
|
* @brief 设置车牌识别触发延迟时间
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nDelay 触发延迟时间,时间范围[0, 10000)
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetTriggerDelay(int handle, int nDelay);
|
|
|
|
/**
|
|
* @brief 获取车牌识别触发延迟时间
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] nDelay 触发延迟时间,时间范围[0, 10000)
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetTriggerDelay(int handle, ref int nDelay);
|
|
|
|
/**
|
|
* @brief 设置白名单验证模式
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nType 0 脱机自动启用;1 启用;2 不启用
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetWLCheckMethod(int handle, int nType);
|
|
|
|
/**
|
|
* @brief 获取白名单验证模式
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] nType 0 脱机自动启用;1 启用;2 不启用
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetWLCheckMethod(int handle, ref int nType);
|
|
|
|
/**
|
|
* @brief 设置白名单模糊匹配
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nFuzzyType 0 精确匹配;1 相似字符匹配;2 普通字符模糊匹配
|
|
* @param [IN] nFuzzyLen 允许误识别长度
|
|
* @param [IN] nFuzzyType 忽略汉字
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetWLFuzzy(int handle, int nFuzzyType, int nFuzzyLen, bool bFuzzyCC);
|
|
|
|
/**
|
|
* @brief 获取白名单模糊匹配
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nFuzzyType 0 精确匹配;1 相似字符匹配;2 普通字符模糊匹配
|
|
* @param [IN] nFuzzyLen 允许误识别长度
|
|
* @param [IN] nFuzzyType 忽略汉字
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetWLFuzzy(int handle, ref int nFuzzyType, ref int nFuzzyLen, ref bool bFuzzyCC);
|
|
|
|
/**
|
|
* @brief 设置串口参数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nSerialPort 指定使用设备的串口序号:0表示第一个串口,1表示第二个串口
|
|
* @param [IN] pParameter 将要设置的串口参数,详见定义 VZ_SERIAL_PARAMETER
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetSerialParameter(int handle, int nSerialPort,
|
|
ref VZ_SERIAL_PARAMETER pParameter);
|
|
|
|
/**
|
|
* @brief 获取串口参数
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] nSerialPort 指定使用设备的串口序号:0表示第一个串口,1表示第二个串口
|
|
* @param [OUT] pParameter 将要获取的串口参数,详见定义 VZ_SERIAL_PARAMETER
|
|
* @return 0表示成功,-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetSerialParameter(int handle, int nSerialPort,
|
|
ref VZ_SERIAL_PARAMETER pParameter);
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoFrameSizeIndex(int handle, ref int sizeval);
|
|
|
|
/**
|
|
* @brief 设置主码流分辨率;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] sizeval 详见VZDEV_FRAMESIZE_宏定义
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoFrameSizeIndex(int handle, int sizeval);
|
|
|
|
/**
|
|
* @brief 获取主码流分辨率;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] sizeval
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoFrameSizeIndexEx(int handle, ref int sizeval);
|
|
|
|
/**
|
|
* @brief 设置主码流分辨率;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] sizeval
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoFrameSizeIndexEx(int handle, int sizeval);
|
|
|
|
/**
|
|
* @brief 获取主码流帧率
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] Rateval 帧率,范围1-25
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoFrameRate(int handle, ref int Rateval);//1-25
|
|
|
|
/**
|
|
* @brief 设置主码流帧率;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] Rateval 帧率,范围1-25
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoFrameRate(int handle, int Rateval);//1-25
|
|
|
|
/**
|
|
* @brief 获取主码流压缩模式;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] modeval 详见VZDEV_VIDEO_COMPRESS_宏定义
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoCompressMode(int handle, ref int modeval);//VZDEV_VIDEO_COMPRESS_XXX
|
|
|
|
/**
|
|
* @brief 设置主码流压缩模式;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] modeval 详见VZDEV_VIDEO_COMPRESS_宏定义
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoCompressMode(int handle, int modeval);//VZDEV_VIDEO_COMPRESS_XXX
|
|
|
|
/**
|
|
* @brief 获取主码流比特率;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] rateval 当前视频比特率
|
|
* @param [OUT] ratelist 暂时不用
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoCBR(int handle, ref int rateval/*Kbps*/, ref int ratelist);
|
|
|
|
/**
|
|
* @brief 设置主码流比特率;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] rateval 当前视频比特率
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoCBR(int handle, int rateval/*Kbps*/);
|
|
|
|
/**
|
|
* @brief 获取视频参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] brt 亮度
|
|
* @param [OUT] cst 对比度
|
|
* @param [OUT] sat 饱和度
|
|
* @param [OUT] hue 色度
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoPara(int handle, ref int brt, ref int cst, ref int sat, ref int hue);
|
|
|
|
/**
|
|
* @brief 设置视频参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] brt 亮度
|
|
* @param [IN] cst 对比度
|
|
* @param [IN] sat 饱和度
|
|
* @param [IN] hue 色度
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoPara(int handle, int brt, int cst, int sat, int hue);
|
|
|
|
/**
|
|
* @brief 设置通道主码流编码方式
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] cmd 返回的编码方式, 0->H264 1->MPEG4 2->JPEG 其他->错误
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoEncodeType(int handle, int cmd);
|
|
|
|
/**
|
|
* @brief 获取视频的编码方式
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] pEncType 返回的编码方式, 0:H264 1:MPEG4 2:JPEG 其他:错误
|
|
* @return 返回值为0表示成功,返回-1表示失败
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoEncodeType(int handle, ref int pEncType);
|
|
|
|
/**
|
|
* @brief 获取视频图像质量;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] levelval //0~6,6最好
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetVideoVBR(int handle, ref int levelval);
|
|
|
|
/**
|
|
* @brief 设置视频图像质量;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] levelval //0~6,6最好
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetVideoVBR(int handle, int levelval);
|
|
|
|
/**
|
|
* @brief 获取视频制式;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] frequency 0:MaxOrZero, 1: 50Hz, 2:60Hz
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetFrequency(int handle, ref int frequency);
|
|
|
|
/**
|
|
* @brief 设置视频制式;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] frequency 0:MaxOrZero, 1: 50Hz, 2:60Hz
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetFrequency(int handle, int frequency);
|
|
|
|
/**
|
|
* @brief 获取曝光时间;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] shutter 2:>0~8ms 停车场推荐, 3: 0~4ms, 4:0~2ms 卡口推荐
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetShutter(int handle, ref int shutter);
|
|
|
|
/**
|
|
* @brief 设置曝光时间;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] shutter 2:>0~8ms 停车场推荐, 3: 0~4ms, 4:0~2ms 卡口推荐
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetShutter(int handle, int shutter);
|
|
|
|
/**
|
|
* @brief 获取图像翻转;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] flip, 0: 原始图像, 1:上下翻转, 2:左右翻转, 3:中心翻转
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetFlip(int handle, ref int flip);
|
|
|
|
/**
|
|
* @brief 设置图像翻转;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] flip, 0: 原始图像, 1:上下翻转, 2:左右翻转, 3:中心翻转
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetFlip(int handle, int flip);
|
|
|
|
/**
|
|
* @brief 修改网络参数
|
|
* @param [IN] SL 设备序列号低位字节
|
|
* @param [IN] SH 设备序列号高位字节
|
|
* @param [IN] strNewIP 新IP 格式如"192.168.3.109"
|
|
* @param [IN] strGateway 网关 格式如"192.168.3.1"
|
|
* @param [IN] strNetmask 子网掩码 格式如"255.255.255.0"
|
|
* @note 可以用来实现跨网段修改IP的功能
|
|
* @ingroup group_global
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_UpdateNetworkParam(uint SL, uint SH, string strNewIP, string strGateway, string strNetmask);
|
|
|
|
/**
|
|
* @brief 获取设备序列号;
|
|
* @param [IN] ip ip统一使用字符串的形式传入
|
|
* @param [IN] port 使用和登录时相同的端口
|
|
* @param [OUT] SerHi 序列号高位
|
|
* @param [OUT] SerLo 序列号低位
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetSerialNo(string ip, short port, ref int SerHi, ref int SerLo);
|
|
|
|
/**
|
|
* @brief 开始实时图像数据流,用于实时获取图像数据
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_StartRealPlayDecData(int handle);
|
|
|
|
/**
|
|
* @brief 停止实时图像数据流
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
* @ingroup group_device
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_StopRealPlayDecData(int handle);
|
|
|
|
/**
|
|
* @brief 从解码流中获取JPEG图像,保存到指定内存
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN/OUT] pDstBuf JPEG数据的目的存储首地址
|
|
* @param [IN] uSizeBuf JPEG数据地址的内存的最大尺寸;
|
|
* @param [IN] nQuality JPEG压缩的质量,取值范围1~100;
|
|
* @return >0表示成功,即编码后的尺寸,-1表示失败,-2表示给定的压缩数据的内存尺寸不够大
|
|
* @ingroup group_global
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetJpegStreamFromRealPlayDec(int handle, IntPtr pDstBuf, uint uSizeBuf, int nQuality);
|
|
|
|
/**
|
|
* @brief 设置是否输出实时结果
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] bOutput 是否输出
|
|
* @return 0表示成功,-1表示失败
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetIsOutputRealTimeResult(int handle, bool bOutput);
|
|
|
|
/**
|
|
* @brief 获取设备加密类型和当前加密类型
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pData 加密信息
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetEMS(int handle, ref VZ_LPRC_ACTIVE_ENCRYPT pData);
|
|
|
|
/**
|
|
* @brief 设置设备加密类型
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCurrentKey 当前识别密码
|
|
* @param [IN] nEncyptId 修改的加密类型ID
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetEncrypt(int handle, IntPtr pCurrentKey, uint nEncyptId);
|
|
|
|
/**
|
|
* @brief 修改设备识别密码
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCurrentKey 当前识别密码
|
|
* @param [IN] pNewKey 新识别密码
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_ChangeEncryptKey(int handle, IntPtr pCurrentKey, IntPtr pNewKey);
|
|
|
|
/**
|
|
* @brief 重置设备识别密码
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pPrimeKey 当前设备主密码
|
|
* @param [IN] pNewKey 新识别密码
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_ResetEncryptKey(int handle, IntPtr pPrimeKey, IntPtr pNewKey);
|
|
|
|
/**
|
|
* @brief 语音播放功能
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] voice 播放的语音文字
|
|
* @param [IN] interval 语音文件的播放间隔(0-5000)
|
|
* @param [IN] volume 声音大小(0-100)
|
|
* @param [IN] male 声音类型(男声0,女生1)
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_PlayVoice(int handle, string voice, int interval, int volume, int male);
|
|
|
|
//**************************************************************
|
|
// 中心服务器配置
|
|
/**
|
|
* @brief 设置中心服务器网络
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerNet 中心服务器信息结构
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetCenterServerNet(int handle, ref VZ_LPRC_CENTER_SERVER_NET pCenterServerNet);
|
|
|
|
/**
|
|
* @brief 获取中心服务器网络
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerNet 中心服务器信息结构
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetCenterServerNet(int handle, ref VZ_LPRC_CENTER_SERVER_NET pCenterServerNet);
|
|
|
|
/**
|
|
* @brief 设置中心服务器设备注册
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerDeviceReg 中心服务器注册结构
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetCenterServerDeviceReg(int handle, ref VZ_LPRC_CENTER_SERVER_DEVICE_REG pCenterServerDeviceReg);
|
|
|
|
/**
|
|
* @brief 获取中心服务器设备注册
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerDeviceReg 中心服务器注册结构
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetCenterServerDeviceReg(int handle, ref VZ_LPRC_CENTER_SERVER_DEVICE_REG pCenterServerDeviceReg);
|
|
|
|
/**
|
|
* @brief 设置中心服务器网络车牌推送信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerPlate 中心服务器车牌推送信息
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetCenterServerPlate(int handle, ref VZ_LPRC_CENTER_SERVER_PLATE pCenterServerPlate);
|
|
|
|
/**
|
|
* @brief 获取中心服务器网络车牌推送信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerPlate 中心服务器车牌推送信息
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetCenterServerPlate(int handle, ref VZ_LPRC_CENTER_SERVER_PLATE pCenterServerPlate);
|
|
|
|
/**
|
|
* @brief 设置中心服务器网络
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerNet 中心服务器信息
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetCenterServerGionin(int handle, ref VZ_LPRC_CENTER_SERVER_GIONIN pCenterServerGionin);
|
|
|
|
/**
|
|
* @brief 获取中心服务器网络端口触发信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerGionin 中心服务器端口触发信息
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetCenterServerGionin(int handle, ref VZ_LPRC_CENTER_SERVER_GIONIN pCenterServerGionin);
|
|
|
|
/**
|
|
* @brief 设置中心服务器网络串口信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerSerial 中心服务器串口信息
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetCenterServerSerial(int handle, ref VZ_LPRC_CENTER_SERVER_SERIAL pCenterServerSerial);
|
|
|
|
/**
|
|
* @brief 获取中心服务器网络串口信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerSerial 中心服务器串口信息
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetCenterServerSerial(int handle, ref VZ_LPRC_CENTER_SERVER_SERIAL pCenterServerSerial);
|
|
|
|
/**
|
|
* @brief 设置中心服务器网络主机备份信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerHostBak 中心服务器主机备份信息 例如:"192.168.3.5;192.168.3.6"
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetCenterServerHostBak(int handle, string pCenterServerHostBak);
|
|
|
|
/**
|
|
* @brief 获取中心服务器网络主机备份信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] pCenterServerHostBak 中心服务器主机备份信息 例如:"192.168.3.5;192.168.3.6"
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetCenterServerHostBak(int handle, ref string pCenterServerHostBak);
|
|
|
|
/**
|
|
* @brief 获取设备硬件信息
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] board_version 设备类型
|
|
* @param [OUT] exdataSize 额外数据长度。
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetHwBoardVersion(int handle, ref int board_version, ref long exdataSize);
|
|
|
|
/**
|
|
* @brief 获取设备硬件类型
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] board_type 设备类型(0:3730,1:6446,2:8127)
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetHwBoardType(int handle, ref int board_type);
|
|
|
|
/**
|
|
* @brief 获取定焦版本相机安装距离
|
|
* @param [IN] iUserID VZC_Login函数返回的用户ID
|
|
* @param [OUT] reco_dis安装距离 0:2-4米, 2: 4-6米, 1: 6-8米
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetAlgResultParam(int handle, ref int reco_dis);
|
|
|
|
/**
|
|
* @brief 获取定焦版本相机安装距离
|
|
* @param [IN] iUserID VZC_Login函数返回的用户ID
|
|
* @param [OUT] reco_dis安装距离 0:2-4米, 2: 4-6米, 1: 6-8米
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetAlgResultParam(int handle, int reco_dis);
|
|
|
|
/**
|
|
* @brief 获取图像增强配置
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] mode 设备类型
|
|
* @param [OUT] strength 额外数据长度。
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_GetDenoise(int handle, ref int mode, ref int strength);
|
|
|
|
/**
|
|
* @brief 设置图像增强配置
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] mode 设备类型
|
|
* @param [OUT] strength 额外数据长度。
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_SetDenoise(int handle, int mode, int strength);
|
|
|
|
/**
|
|
* @brief 获取R相机的编码参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] iChannel 通道号
|
|
* @param [IN] stream 0主码流 1子码流
|
|
* @param [OUT] param 编码参数
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_RGet_Encode_Param(int handle, int stream, ref VZ_LPRC_R_ENCODE_PARAM param);
|
|
|
|
/**
|
|
* @brief 设置R相机的编码参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] iChannel 通道号
|
|
* @param [IN] stream 0主码流 1子码流
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_RSet_Encode_Param(int handle, int stream, ref VZ_LPRC_R_ENCODE_PARAM param);
|
|
|
|
/**
|
|
* @brief 获取R相机支持的编码参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] iChannel 通道号
|
|
* @param [IN] stream 0主码流 1子码流
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_RGet_Encode_Param_Property(int handle, ref VZ_LPRC_R_ENCODE_PARAM_PROPERTY param);
|
|
|
|
/**
|
|
* @brief 获取R相机的视频参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [OUT] param 视频参数
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_RGet_Video_Param(int handle, ref VZ_LPRC_R_VIDEO_PARAM param);
|
|
|
|
/**
|
|
* @brief 获取R相机的视频参数;
|
|
* @param [IN] handle 由VzLPRClient_Open函数获得的句柄
|
|
* @param [IN] iChannel 通道号
|
|
* @return 返回值为0表示成功,返回其他值表示失败。
|
|
*/
|
|
|
|
[DllImport("VzLPRSDK.dll")]
|
|
public static extern int VzLPRClient_RSet_Video_Param(int handle, ref VZ_LPRC_R_VIDEO_PARAM param);
|
|
}
|
|
}
|