package com.netsdk.demo.customize.configuration; import java.io.File; import com.netsdk.demo.util.CaseMenu; import com.netsdk.lib.NetSDKLib; import com.netsdk.lib.NetSDKLib.LLong; import com.netsdk.lib.NetSDKLib.NET_DEVICEINFO_Ex; import com.netsdk.lib.ToolKits; import com.netsdk.lib.enumeration.NET_EM_CFG_OPERATE_TYPE; import com.netsdk.lib.structure.NET_CFG_TIME_RECORDBACKUP_RESTORE_INFO; import com.sun.jna.Pointer; import com.sun.jna.ptr.IntByReference; public class Recording { public static final NetSDKLib netSdk = NetSDKLib.NETSDK_INSTANCE; // 登陆句柄 private static LLong loginHandle = new LLong(0); // 设备信息扩展 private NET_DEVICEINFO_Ex deviceInfo = new NET_DEVICEINFO_Ex(); public void InitTest(){ // 初始化SDK库 netSdk.CLIENT_Init(DisConnectCallBack.getInstance(), null); // 设置断线重连成功回调函数 netSdk.CLIENT_SetAutoReconnect(HaveReConnectCallBack.getInstance(), null); //打开日志,可选 NetSDKLib.LOG_SET_PRINT_INFO setLog = new NetSDKLib.LOG_SET_PRINT_INFO(); String logPath = new File(".").getAbsoluteFile().getParent() + File.separator + "sdk_log" + File.separator + "sdk.log"; setLog.bSetFilePath = 1; System.arraycopy(logPath.getBytes(), 0, setLog.szLogFilePath, 0, logPath.getBytes().length); setLog.bSetPrintStrategy = 1; setLog.nPrintStrategy = 0; if (!netSdk.CLIENT_LogOpen(setLog)){ System.err.println("Open SDK Log Failed!!!"); } Login(); } public void Login(){ // 登陆设备 int nSpecCap = NetSDKLib.EM_LOGIN_SPAC_CAP_TYPE.EM_LOGIN_SPEC_CAP_TCP; // TCP登入 IntByReference nError = new IntByReference(0); loginHandle = netSdk.CLIENT_LoginEx2(m_strIp, m_nPort, m_strUser, m_strPassword ,nSpecCap, null, deviceInfo, nError); if (loginHandle.longValue() != 0) { System.out.printf("Login Device[%s] Success!\n", m_strIp); } else { System.err.printf("Login Device[%s] Fail.Error[%s]\n", m_strIp, ToolKits.getErrorCode()); LoginOut(); } } public void LoginOut(){ System.out.println("End Test"); if( loginHandle.longValue() != 0) { netSdk.CLIENT_Logout(loginHandle); } System.out.println("See You..."); netSdk.CLIENT_Cleanup(); System.exit(0); } //////////////////////////////////////////////////////////////// private String m_strIp = "172.12.250.99"; private int m_nPort = 37777; private String m_strUser = "admin"; private String m_strPassword = "admin123"; //////////////////////////////////////////////////////////////// public void GetRecordingConfig() { int emCfgOpType = NET_EM_CFG_OPERATE_TYPE.NET_EM_CFG_TIME_RECORDBACKUP_RESTORE; NET_CFG_TIME_RECORDBACKUP_RESTORE_INFO msg = new NET_CFG_TIME_RECORDBACKUP_RESTORE_INFO(); msg.write(); boolean ret = netSdk.CLIENT_GetConfig(loginHandle, emCfgOpType,-1, msg.getPointer(), msg.size(), 3000, null); if(ret) { System.out.println("GetRecordingConfig success"); msg.read(); System.out.println(msg.bEnable); System.out.println(msg.stuProcessTime[0].stuStartTime.toTime()); System.out.println(msg.stuProcessTime[0].stuEndTime.toTime()); }else { System.err.printf("GetRecordingConfig failed, ErrCode=%x\n", netSdk.CLIENT_GetLastError()); } } public void SetRecordingConfig() { int emCfgOpType = NET_EM_CFG_OPERATE_TYPE.NET_EM_CFG_TIME_RECORDBACKUP_RESTORE; NET_CFG_TIME_RECORDBACKUP_RESTORE_INFO msg = new NET_CFG_TIME_RECORDBACKUP_RESTORE_INFO(); msg.bEnable = 1; msg.nProcessTimeCount = 1; msg.stuProcessTime[0].stuStartTime.dwHour = 10; msg.stuProcessTime[0].stuStartTime.dwMinute = 10; msg.stuProcessTime[0].stuStartTime.dwSecond = 10; msg.stuProcessTime[0].stuEndTime.dwHour = 12; msg.stuProcessTime[0].stuEndTime.dwMinute = 12; msg.stuProcessTime[0].stuEndTime.dwSecond = 12; msg.nTaskCount = 1; msg.stuTask[0].nChannelCount=2; msg.stuTask[0].nChannels[0]=0; msg.stuTask[0].nChannels[1]=1; msg.stuTask[0].nRemoteChannels[0]=0; msg.stuTask[0].nRemoteChannels[1]=1; msg.stuTask[0].szDeviceIP = "192.168.1.100".getBytes(); msg.stuTask[0].nPort = 37777; msg.stuTask[0].szUserName="admin".getBytes(); msg.stuTask[0].szPassword="admin123".getBytes(); msg.stuTask[0].stuStartTime.dwHour = 8; msg.stuTask[0].stuEndTime.dwHour = 18; msg.stuTask[0].stuStartTime.dwMinute = 0; msg.stuTask[0].stuEndTime.dwMinute =0; msg.stuTask[0].stuStartTime.dwSecond = 0; msg.stuTask[0].stuEndTime.dwSecond = 0; msg.write(); boolean ret = netSdk.CLIENT_SetConfig(loginHandle, emCfgOpType, -1, msg.getPointer(), msg.size(), 3000, null, null); if(ret) { System.out.println("SetRecordingConfig success"); }else { System.err.printf("SetRecordingConfig failed, ErrCode=%x\n", netSdk.CLIENT_GetLastError()); } } /** * 设备断线回调 */ private static class DisConnectCallBack implements NetSDKLib.fDisConnect { private DisConnectCallBack() { } private static class CallBackHolder { private static DisConnectCallBack instance = new DisConnectCallBack(); } public static DisConnectCallBack getInstance() { return CallBackHolder.instance; } public void invoke(NetSDKLib.LLong lLoginID, String pchDVRIP, int nDVRPort, Pointer dwUser) { System.out.printf("Device[%s] Port[%d] DisConnect!\n", pchDVRIP, nDVRPort); } } /** * 设备重连回调 */ private static class HaveReConnectCallBack implements NetSDKLib.fHaveReConnect { private HaveReConnectCallBack() { } private static class CallBackHolder { private static HaveReConnectCallBack instance = new HaveReConnectCallBack(); } public static HaveReConnectCallBack getInstance() { return CallBackHolder.instance; } public void invoke(NetSDKLib.LLong m_hLoginHandle, String pchDVRIP, int nDVRPort, Pointer dwUser) { System.out.printf("ReConnect Device[%s] Port[%d]\n", pchDVRIP, nDVRPort); } } public void RunTest() { System.out.println("Run Test"); CaseMenu menu = new CaseMenu(); menu.addItem(new CaseMenu.Item(this , "GetRecordingConfig" , "GetRecordingConfig")); menu.addItem(new CaseMenu.Item(this , "SetRecordingConfig" , "SetRecordingConfig")); menu.run(); } public static void main(String[]args) { Recording demo = new Recording(); demo.InitTest(); demo.RunTest(); demo.LoginOut(); } }