|
@@ -0,0 +1,808 @@
|
|
|
+package com.ruoyi.hksdk;
|
|
|
+
|
|
|
+import com.sun.jna.Pointer;
|
|
|
+import com.sun.jna.ptr.ByteByReference;
|
|
|
+import com.sun.jna.ptr.IntByReference;
|
|
|
+
|
|
|
+import java.io.*;
|
|
|
+import java.nio.ByteBuffer;
|
|
|
+import java.text.SimpleDateFormat;
|
|
|
+import java.util.Date;
|
|
|
+import java.util.Timer;
|
|
|
+
|
|
|
+import static com.ruoyi.hksdk.ClientDemo.hCNetSDK;
|
|
|
+import static com.ruoyi.hksdk.ClientDemo.playControl;
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ * 视频取流预览,下载,抓图mok
|
|
|
+ * @create 2022-03-30-9:48
|
|
|
+ */
|
|
|
+public class VideoDemo {
|
|
|
+ Timer downloadtimer;
|
|
|
+ Timer Playbacktimer;
|
|
|
+ static FRealDataCallBack fRealDataCallBack;
|
|
|
+ static fPlayEScallback fPlayescallback;
|
|
|
+ static playDataCallBack playBackCallBack;
|
|
|
+ static int lPlay = -1;
|
|
|
+ static int Count=0;
|
|
|
+ int m_lLoadHandle;
|
|
|
+ int iPlayBack;
|
|
|
+ static File file;
|
|
|
+ static boolean palybackFlay=false;
|
|
|
+ static FileOutputStream outputStream;
|
|
|
+ static IntByReference m_lPort= new IntByReference(-1);
|
|
|
+ static String resultFileName = "..\\Download" + new String("returnFile" + ".h264");
|
|
|
+ static FileOutputStream fileOutputStream = null;
|
|
|
+ static int fileLenth = 0;
|
|
|
+
|
|
|
+ public static void realPlay(int userID, int iChannelNo) {
|
|
|
+ if (userID == -1) {
|
|
|
+ System.out.println("请先注册");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ HCNetSDK.NET_DVR_PREVIEWINFO strClientInfo = new HCNetSDK.NET_DVR_PREVIEWINFO();
|
|
|
+ strClientInfo.read();
|
|
|
+ strClientInfo.hPlayWnd = 0;
|
|
|
+ strClientInfo.lChannel = iChannelNo;
|
|
|
+ strClientInfo.dwStreamType=0;
|
|
|
+ strClientInfo.dwLinkMode=0;
|
|
|
+ strClientInfo.bBlocked=1;
|
|
|
+ strClientInfo.write();
|
|
|
+
|
|
|
+
|
|
|
+ if (fRealDataCallBack == null) {
|
|
|
+ fRealDataCallBack = new FRealDataCallBack();
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ lPlay = hCNetSDK.NET_DVR_RealPlay_V40(userID, strClientInfo, fRealDataCallBack , null);
|
|
|
+ if (lPlay == -1) {
|
|
|
+ int iErr = hCNetSDK.NET_DVR_GetLastError();
|
|
|
+ System.out.println("取流失败" + iErr);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ System.out.println("取流成功");
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ * 预览一段时间;如果要一直取流预览,需要保证程序一直运行
|
|
|
+ */
|
|
|
+ try {
|
|
|
+ Thread.sleep(10000);
|
|
|
+ } catch (InterruptedException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+
|
|
|
+ if (lPlay>=0) {
|
|
|
+ if (hCNetSDK.NET_DVR_StopRealPlay(lPlay))
|
|
|
+ {
|
|
|
+ System.out.println("停止预览成功");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public static void getPicbyPlayCtrl(){
|
|
|
+
|
|
|
+
|
|
|
+ try {
|
|
|
+ Thread.sleep(3000);
|
|
|
+ } catch (InterruptedException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ IntByReference pWidth = new IntByReference(0);
|
|
|
+ IntByReference pHieght = new IntByReference(0);
|
|
|
+ boolean bFlag = playControl.PlayM4_GetPictureSize(m_lPort.getValue(), pWidth, pHieght);
|
|
|
+ if (!bFlag) {
|
|
|
+ System.out.println("获取失败:" + playControl.PlayM4_GetLastError(m_lPort.getValue()));
|
|
|
+ }
|
|
|
+ System.out.println(pWidth.getValue());
|
|
|
+ System.out.println(pHieght.getValue());
|
|
|
+ IntByReference RealPicSize = new IntByReference(0);
|
|
|
+ int picsize = pWidth.getValue() * pHieght.getValue() * 5;
|
|
|
+ HCNetSDK.BYTE_ARRAY picByte = new HCNetSDK.BYTE_ARRAY(picsize);
|
|
|
+ picByte.write();
|
|
|
+ Pointer pByte = picByte.getPointer();
|
|
|
+ boolean b_GetPic = playControl.PlayM4_GetJPEG(m_lPort.getValue(), pByte, picsize, RealPicSize);
|
|
|
+ if (!b_GetPic) {
|
|
|
+ System.out.println("抓图失败:" + playControl.PlayM4_GetLastError(m_lPort.getValue()));
|
|
|
+ }
|
|
|
+ picByte.read();
|
|
|
+ SimpleDateFormat sf = new SimpleDateFormat("yyyyMMddHHmmss");
|
|
|
+ String newName = sf.format(new Date());
|
|
|
+ FileOutputStream fout = null;
|
|
|
+ try {
|
|
|
+
|
|
|
+ fout = new FileOutputStream(System.getProperty("user.dir") + "//pic//" + newName + ".jpg");
|
|
|
+
|
|
|
+ long offset = 0;
|
|
|
+ ByteBuffer buffers = pByte.getByteBuffer(offset, RealPicSize.getValue());
|
|
|
+ byte[] bytes = new byte[RealPicSize.getValue()];
|
|
|
+ buffers.rewind();
|
|
|
+ buffers.get(bytes);
|
|
|
+ fout.write(bytes);
|
|
|
+ fout.close();
|
|
|
+ } catch (FileNotFoundException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ } catch (IOException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ System.out.println("抓图成功!");
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ * 按时间回放获取码流数据
|
|
|
+ * @param userID
|
|
|
+ */
|
|
|
+
|
|
|
+ public void playBackBytime(int userID,int lChannel)
|
|
|
+ {
|
|
|
+ file = new File(System.getProperty("user.dir") + "\\Download\\Videodatabytime.mp4");
|
|
|
+
|
|
|
+ if (!file.exists()) {
|
|
|
+ try {
|
|
|
+ file.createNewFile();
|
|
|
+ } catch (Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ try {
|
|
|
+ outputStream = new FileOutputStream(file);
|
|
|
+ } catch (FileNotFoundException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ HCNetSDK.NET_DVR_VOD_PARA net_dvr_vod_para = new HCNetSDK.NET_DVR_VOD_PARA();
|
|
|
+ net_dvr_vod_para.dwSize=net_dvr_vod_para.size();
|
|
|
+ net_dvr_vod_para.struIDInfo.dwChannel=lChannel;
|
|
|
+
|
|
|
+ net_dvr_vod_para.struBeginTime.dwYear=2022;
|
|
|
+ net_dvr_vod_para.struBeginTime.dwMonth=11;
|
|
|
+ net_dvr_vod_para.struBeginTime.dwDay=18;
|
|
|
+ net_dvr_vod_para.struBeginTime.dwHour=10;
|
|
|
+ net_dvr_vod_para.struBeginTime.dwMinute=00;
|
|
|
+ net_dvr_vod_para.struBeginTime.dwSecond=00;
|
|
|
+
|
|
|
+ net_dvr_vod_para.struEndTime.dwYear=2022;
|
|
|
+ net_dvr_vod_para.struEndTime.dwMonth=11;
|
|
|
+ net_dvr_vod_para.struEndTime.dwDay=18;
|
|
|
+ net_dvr_vod_para.struEndTime.dwHour=10;
|
|
|
+ net_dvr_vod_para.struEndTime.dwMinute=10;
|
|
|
+ net_dvr_vod_para.struEndTime.dwSecond=00;
|
|
|
+ net_dvr_vod_para.hWnd=null;
|
|
|
+ net_dvr_vod_para.write();
|
|
|
+
|
|
|
+ int iPlayBack=hCNetSDK.NET_DVR_PlayBackByTime_V40(userID,net_dvr_vod_para);
|
|
|
+ if (iPlayBack<=-1)
|
|
|
+ {
|
|
|
+ System.out.println("按时间回放失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ palybackFlay = true;
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ boolean bCrtl=hCNetSDK.NET_DVR_PlayBackControl(iPlayBack, HCNetSDK.NET_DVR_PLAYSTART, 0, null);
|
|
|
+ if (playBackCallBack==null)
|
|
|
+ {
|
|
|
+ playBackCallBack = new playDataCallBack();
|
|
|
+ }
|
|
|
+ boolean bRet=hCNetSDK.NET_DVR_SetPlayDataCallBack_V40(iPlayBack,playBackCallBack,Pointer.NULL);
|
|
|
+
|
|
|
+ Playbacktimer = new Timer();
|
|
|
+ Playbacktimer.schedule(new PlaybackTask(), 0, 5000);
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ * 按文件回放录像
|
|
|
+ * @param userID 用户ID
|
|
|
+ * @param lChannel 通道号
|
|
|
+ */
|
|
|
+ public static void playBackByfile(int userID,int lChannel)
|
|
|
+ {
|
|
|
+ file = new File(System.getProperty("user.dir") + "\\Download\\Videodatabyfile.mp4");
|
|
|
+
|
|
|
+ if (!file.exists()) {
|
|
|
+ try {
|
|
|
+ file.createNewFile();
|
|
|
+ } catch (Exception e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ try {
|
|
|
+ outputStream = new FileOutputStream(file);
|
|
|
+ } catch (FileNotFoundException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ String strFileName="";
|
|
|
+ HCNetSDK.NET_DVR_FILECOND_V40 struFileCond = new HCNetSDK.NET_DVR_FILECOND_V40();
|
|
|
+ struFileCond.read();
|
|
|
+ struFileCond.lChannel= lChannel;
|
|
|
+ struFileCond.byFindType=0;
|
|
|
+
|
|
|
+ struFileCond.struStartTime.dwYear=2022;
|
|
|
+ struFileCond.struStartTime.dwMonth=11;
|
|
|
+ struFileCond.struStartTime.dwDay=18;
|
|
|
+ struFileCond.struStartTime.dwHour=10;
|
|
|
+ struFileCond.struStartTime.dwMinute=00;
|
|
|
+ struFileCond.struStartTime.dwSecond=00;
|
|
|
+
|
|
|
+ struFileCond.struStopTime.dwYear=2022;
|
|
|
+ struFileCond.struStopTime.dwMonth=11;
|
|
|
+ struFileCond.struStopTime.dwDay=18;
|
|
|
+ struFileCond.struStopTime.dwHour=10;
|
|
|
+ struFileCond.struStopTime.dwMinute=30;
|
|
|
+ struFileCond.struStopTime.dwSecond=00;
|
|
|
+ struFileCond.write();
|
|
|
+ int FindFileHandle=hCNetSDK.NET_DVR_FindFile_V40(userID,struFileCond);
|
|
|
+ if (FindFileHandle<=-1)
|
|
|
+ {
|
|
|
+ System.out.println("查找建立失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ }
|
|
|
+
|
|
|
+ while (true)
|
|
|
+ {
|
|
|
+ HCNetSDK.NET_DVR_FINDDATA_V40 struFindData = new HCNetSDK.NET_DVR_FINDDATA_V40();
|
|
|
+
|
|
|
+ long State=hCNetSDK.NET_DVR_FindNextFile_V40(FindFileHandle,struFindData);
|
|
|
+ if (State<=-1)
|
|
|
+ {
|
|
|
+
|
|
|
+ System.out.println("查找失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ else if (State==1000)
|
|
|
+ {
|
|
|
+ struFindData.read();
|
|
|
+ try {
|
|
|
+ strFileName=new String(struFindData.sFileName,"UTF-8").trim();
|
|
|
+ System.out.println("文件名称:"+strFileName);
|
|
|
+ System.out.println("文件大小:"+struFindData.dwFileSize);
|
|
|
+ } catch (UnsupportedEncodingException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ System.out.println("获取文件成功");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1001)
|
|
|
+ {
|
|
|
+ System.out.println("未查找到文件");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1002)
|
|
|
+ {
|
|
|
+ System.out.println("正在查找,请等待");
|
|
|
+ continue;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ else if (State==1003)
|
|
|
+ {
|
|
|
+ System.out.println("没有更多的文件,查找结束");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1004)
|
|
|
+ {
|
|
|
+
|
|
|
+ System.out.println("没有更多的文件,查找结束");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1005)
|
|
|
+ {
|
|
|
+
|
|
|
+ System.out.println("没有更多的文件,查找结束");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ boolean b_CloseHandle=hCNetSDK.NET_DVR_FindClose_V30(FindFileHandle);
|
|
|
+ if (!b_CloseHandle) {
|
|
|
+ System.out.println("关闭失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ int lPlayByFileHandle=hCNetSDK.NET_DVR_PlayBackByName(userID,strFileName,null);
|
|
|
+ if (lPlayByFileHandle<=-1)
|
|
|
+ {
|
|
|
+ System.out.println("按文件回放失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ IntByReference intP1=new IntByReference(0);
|
|
|
+ IntByReference intInlen=new IntByReference(0);
|
|
|
+ boolean b_PlayBackStart=hCNetSDK.NET_DVR_PlayBackControl_V40(lPlayByFileHandle,HCNetSDK.NET_DVR_PLAYSTART,intP1.getPointer(),4,Pointer.NULL,intInlen);
|
|
|
+ if (!b_PlayBackStart) {
|
|
|
+ System.out.println("开始播放失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ if (playBackCallBack==null)
|
|
|
+ {
|
|
|
+ playBackCallBack=new playDataCallBack();
|
|
|
+ }
|
|
|
+ boolean bRet=hCNetSDK.NET_DVR_SetPlayDataCallBack_V40(lPlayByFileHandle,playBackCallBack,Pointer.NULL);
|
|
|
+ while (true)
|
|
|
+ {
|
|
|
+ int Pos=hCNetSDK.NET_DVR_GetDownloadPos(lPlayByFileHandle);
|
|
|
+ if (Pos!=100)
|
|
|
+ {
|
|
|
+ System.out.println("回放进度:"+Pos);
|
|
|
+
|
|
|
+ try {
|
|
|
+ Thread.sleep(1000);
|
|
|
+ } catch (InterruptedException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ boolean b_Stop=hCNetSDK.NET_DVR_StopPlayBack(lPlayByFileHandle);
|
|
|
+ if (!b_Stop) {
|
|
|
+ System.out.println("停止回放失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ System.out.println("回放成功");
|
|
|
+ return;
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ public static void downloadRecordByFile(int userID, int iChannelNo)
|
|
|
+ {
|
|
|
+ String strFileName="";
|
|
|
+ HCNetSDK.NET_DVR_FILECOND_V40 struFileCond = new HCNetSDK.NET_DVR_FILECOND_V40();
|
|
|
+ struFileCond.read();
|
|
|
+ struFileCond.lChannel= iChannelNo;
|
|
|
+ struFileCond.dwFileType = 0Xff;
|
|
|
+ struFileCond.byFindType = 0;
|
|
|
+
|
|
|
+ struFileCond.struStartTime.dwYear=2022;
|
|
|
+ struFileCond.struStartTime.dwMonth=11;
|
|
|
+ struFileCond.struStartTime.dwDay=19;
|
|
|
+ struFileCond.struStartTime.dwHour=12;
|
|
|
+ struFileCond.struStartTime.dwMinute=00;
|
|
|
+ struFileCond.struStartTime.dwSecond=00;
|
|
|
+
|
|
|
+ struFileCond.struStopTime.dwYear=2022;
|
|
|
+ struFileCond.struStopTime.dwMonth=11;
|
|
|
+ struFileCond.struStopTime.dwDay=19;
|
|
|
+ struFileCond.struStopTime.dwHour=15;
|
|
|
+ struFileCond.struStopTime.dwMinute=00;
|
|
|
+ struFileCond.struStopTime.dwSecond=00;
|
|
|
+ struFileCond.write();
|
|
|
+ int FindFileHandle=hCNetSDK.NET_DVR_FindFile_V40(userID,struFileCond);
|
|
|
+ if (FindFileHandle<=-1)
|
|
|
+ {
|
|
|
+ System.out.println("查找建立失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ }
|
|
|
+
|
|
|
+ while (true)
|
|
|
+ {
|
|
|
+ HCNetSDK.NET_DVR_FINDDATA_V40 struFindData = new HCNetSDK.NET_DVR_FINDDATA_V40();
|
|
|
+
|
|
|
+ long State=hCNetSDK.NET_DVR_FindNextFile_V40(FindFileHandle,struFindData);
|
|
|
+ if (State<=-1)
|
|
|
+ {
|
|
|
+
|
|
|
+ System.out.println("查找失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ else if (State==1000)
|
|
|
+ {
|
|
|
+ struFindData.read();
|
|
|
+ try {
|
|
|
+ strFileName=new String(struFindData.sFileName,"UTF-8").trim();
|
|
|
+ System.out.println("文件名称:"+strFileName);
|
|
|
+ System.out.println("文件大小:"+struFindData.dwFileSize);
|
|
|
+ } catch (UnsupportedEncodingException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ System.out.println("获取文件成功");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1001)
|
|
|
+ {
|
|
|
+ System.out.println("未查找到文件");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1002)
|
|
|
+ {
|
|
|
+ System.out.println("正在查找,请等待");
|
|
|
+ continue;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ else if (State==1003)
|
|
|
+ {
|
|
|
+ System.out.println("没有更多的文件,查找结束");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1004)
|
|
|
+ {
|
|
|
+
|
|
|
+ System.out.println("没有更多的文件,查找结束");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+ else if (State==1005)
|
|
|
+ {
|
|
|
+
|
|
|
+ System.out.println("没有更多的文件,查找结束");
|
|
|
+ break;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ boolean b_CloseHandle=hCNetSDK.NET_DVR_FindClose_V30(FindFileHandle);
|
|
|
+ if (!b_CloseHandle) {
|
|
|
+ System.out.println("关闭失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ String SaveDir=".\\Download\\test.mp4";
|
|
|
+
|
|
|
+ int FileName=hCNetSDK.NET_DVR_GetFileByName(userID,strFileName,SaveDir.getBytes());
|
|
|
+ if (FileName<=-1)
|
|
|
+ {
|
|
|
+ System.out.println("下载录像失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ IntByReference intP=new IntByReference(5);
|
|
|
+ IntByReference intInlen1=new IntByReference(0);
|
|
|
+ boolean b_PlayBack=hCNetSDK.NET_DVR_PlayBackControl_V40(FileName,32,intP.getPointer(),4,Pointer.NULL,intInlen1);
|
|
|
+ if (!b_PlayBack) {
|
|
|
+ System.out.println("转封装失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+ IntByReference intP1=new IntByReference(0);
|
|
|
+ IntByReference intInlen=new IntByReference(0);
|
|
|
+ boolean b_PlayBackStart=hCNetSDK.NET_DVR_PlayBackControl_V40(FileName,HCNetSDK.NET_DVR_PLAYSTART,intP1.getPointer(),4,Pointer.NULL,intInlen);
|
|
|
+ if (!b_PlayBackStart) {
|
|
|
+ System.out.println("开始播放失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ IntByReference intInlen1=new IntByReference(0);
|
|
|
+ boolean b_PlayBack=hCNetSDK.NET_DVR_PlayBackControl_V40(FileName,24,intP.getPointer(),4, Pointer.NULL,intInlen1);
|
|
|
+ if (!b_PlayBack) {
|
|
|
+ System.out.println("设置下载速度失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }*/
|
|
|
+ while (true)
|
|
|
+ {
|
|
|
+ int Pos=hCNetSDK.NET_DVR_GetDownloadPos(FileName);
|
|
|
+ if (Pos!=100)
|
|
|
+ {
|
|
|
+ System.out.println("下载进度:"+Pos);
|
|
|
+
|
|
|
+ try {
|
|
|
+ Thread.sleep(1000);
|
|
|
+ } catch (InterruptedException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+ else {
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ boolean b_Stop=hCNetSDK.NET_DVR_StopGetFile(FileName);
|
|
|
+ if (!b_Stop) {
|
|
|
+ System.out.println("停止下载失败,错误码为" + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ System.out.println("下载成功");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ public void dowmloadRecordByTime(int userID)
|
|
|
+ {
|
|
|
+ HCNetSDK.NET_DVR_PLAYCOND net_dvr_playcond = new HCNetSDK.NET_DVR_PLAYCOND();
|
|
|
+ net_dvr_playcond.read();
|
|
|
+ net_dvr_playcond.dwChannel=1;
|
|
|
+
|
|
|
+ net_dvr_playcond.struStartTime.dwYear=2022;
|
|
|
+ net_dvr_playcond.struStartTime.dwMonth=4;
|
|
|
+ net_dvr_playcond.struStartTime.dwDay=17;
|
|
|
+ net_dvr_playcond.struStartTime.dwHour=10;
|
|
|
+ net_dvr_playcond.struStartTime.dwMinute=00;
|
|
|
+ net_dvr_playcond.struStartTime.dwSecond=00;
|
|
|
+
|
|
|
+ net_dvr_playcond.struStopTime.dwYear=2022;
|
|
|
+ net_dvr_playcond.struStopTime.dwMonth=4;
|
|
|
+ net_dvr_playcond.struStopTime.dwDay=17;
|
|
|
+ net_dvr_playcond.struStopTime.dwHour=10;
|
|
|
+ net_dvr_playcond.struStopTime.dwMinute=10;
|
|
|
+ net_dvr_playcond.struStopTime.dwSecond=00;
|
|
|
+ net_dvr_playcond.write();
|
|
|
+ String sFileName = ".\\Download\\" + System.currentTimeMillis() + ".mp4";
|
|
|
+ System.out.println(sFileName);
|
|
|
+ m_lLoadHandle = hCNetSDK.NET_DVR_GetFileByTime_V40(userID,sFileName,net_dvr_playcond);
|
|
|
+ if (m_lLoadHandle >= 0)
|
|
|
+ {
|
|
|
+ hCNetSDK.NET_DVR_PlayBackControl(m_lLoadHandle, HCNetSDK.NET_DVR_PLAYSTART, 0, null);
|
|
|
+
|
|
|
+ IntByReference intInlen=new IntByReference(0);
|
|
|
+ boolean b_PlayBack=ClientDemo.hCNetSDK.NET_DVR_PlayBackControl_V40(m_lLoadHandle,24,intP.getPointer(),4,Pointer.NULL,intInlen);
|
|
|
+ if (!b_PlayBack) {
|
|
|
+ System.out.println("设置下载速度失败,错误码为" + ClientDemo.hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }*/
|
|
|
+ Date nowTime = new Date(System.currentTimeMillis());
|
|
|
+ SimpleDateFormat sdFormatter = new SimpleDateFormat("yyyy-MM-dd-hh-mm-ss");
|
|
|
+ System.out.println("开始下载时间:"+sdFormatter.format(nowTime));
|
|
|
+ downloadtimer = new Timer();
|
|
|
+ downloadtimer.schedule(new downloadTask(), 0, 5000);
|
|
|
+ } else
|
|
|
+ {
|
|
|
+ System.out.println("按时间下载失败");
|
|
|
+ System.out.println("laste error " + hCNetSDK.NET_DVR_GetLastError());
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ 类: DownloadTask
|
|
|
+ 类描述: 下载定时器响应函数
|
|
|
+ *************************************************/
|
|
|
+ class downloadTask extends java.util.TimerTask
|
|
|
+ {
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void run()
|
|
|
+ {
|
|
|
+ IntByReference nPos = new IntByReference(0);
|
|
|
+ hCNetSDK.NET_DVR_PlayBackControl(m_lLoadHandle, HCNetSDK.NET_DVR_PLAYGETPOS, 0, nPos);
|
|
|
+ if (nPos.getValue() > 100)
|
|
|
+ {
|
|
|
+ m_lLoadHandle=-1;
|
|
|
+ downloadtimer.cancel();
|
|
|
+ System.out.println( "由于网络原因或DVR忙,下载异常终止!");
|
|
|
+ }
|
|
|
+ if (nPos.getValue() == 100)
|
|
|
+ {
|
|
|
+ Date nowTime = new Date(System.currentTimeMillis());
|
|
|
+ SimpleDateFormat sdFormatter = new SimpleDateFormat("yyyy-MM-dd-hh-mm-ss");
|
|
|
+ System.out.println("结束下载时间:"+sdFormatter.format(nowTime));
|
|
|
+ m_lLoadHandle=-1;
|
|
|
+ downloadtimer.cancel();
|
|
|
+ System.out.println("按时间下载结束!");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ class PlaybackTask extends java.util.TimerTask
|
|
|
+ {
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void run()
|
|
|
+ {
|
|
|
+ System.out.println("定时器触发");
|
|
|
+ IntByReference nPos = new IntByReference(0);
|
|
|
+
|
|
|
+ System.out.println("iPlayBack "+iPlayBack);
|
|
|
+ boolean bret=hCNetSDK.NET_DVR_PlayBackControl(iPlayBack, HCNetSDK.NET_DVR_PLAYGETPOS, 0, nPos);
|
|
|
+ if (bret)
|
|
|
+ {
|
|
|
+ System.out.println("回放进度" + nPos.getValue());
|
|
|
+ }
|
|
|
+ else
|
|
|
+ {
|
|
|
+ System.out.println("获取回放进度失败");
|
|
|
+ }
|
|
|
+
|
|
|
+ if (nPos.getValue() > 100)
|
|
|
+ {
|
|
|
+
|
|
|
+ hCNetSDK.NET_DVR_StopPlayBack(iPlayBack);
|
|
|
+ if (outputStream != null) {
|
|
|
+ try {
|
|
|
+ outputStream.close();
|
|
|
+ } catch (IOException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ palybackFlay = true;
|
|
|
+ System.out.println("由于网络原因或DVR忙,回放异常终止!");
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ if (nPos.getValue() == 100)
|
|
|
+ {
|
|
|
+ hCNetSDK.NET_DVR_StopPlayBack(iPlayBack);
|
|
|
+ if (outputStream != null) {
|
|
|
+ try {
|
|
|
+ outputStream.close();
|
|
|
+ } catch (IOException e) {
|
|
|
+
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+ palybackFlay = true;
|
|
|
+ System.out.println("按时间回放结束");
|
|
|
+ return;
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ public static void getIPChannelInfo(int userID) {
|
|
|
+ IntByReference ibrBytesReturned = new IntByReference(0);
|
|
|
+ HCNetSDK.NET_DVR_IPPARACFG_V40 m_strIpparaCfg = new HCNetSDK.NET_DVR_IPPARACFG_V40();
|
|
|
+ m_strIpparaCfg.write();
|
|
|
+
|
|
|
+ Pointer lpIpParaConfig = m_strIpparaCfg.getPointer();
|
|
|
+ boolean bRet = hCNetSDK.NET_DVR_GetDVRConfig(userID, HCNetSDK.NET_DVR_GET_IPPARACFG_V40, 0, lpIpParaConfig, m_strIpparaCfg.size(), ibrBytesReturned);
|
|
|
+ m_strIpparaCfg.read();
|
|
|
+ System.out.println("起始数字通道号:" + m_strIpparaCfg.dwStartDChan);
|
|
|
+
|
|
|
+ for (int iChannum = 0; iChannum < m_strIpparaCfg.dwDChanNum; iChannum++) {
|
|
|
+ int channum = iChannum + m_strIpparaCfg.dwStartDChan;
|
|
|
+ m_strIpparaCfg.struStreamMode[iChannum].read();
|
|
|
+ if (m_strIpparaCfg.struStreamMode[iChannum].byGetStreamType == 0) {
|
|
|
+ m_strIpparaCfg.struStreamMode[iChannum].uGetStream.setType(HCNetSDK.NET_DVR_IPCHANINFO.class);
|
|
|
+ m_strIpparaCfg.struStreamMode[iChannum].uGetStream.struChanInfo.read();
|
|
|
+ if (m_strIpparaCfg.struStreamMode[iChannum].uGetStream.struChanInfo.byEnable == 1) {
|
|
|
+ System.out.println("IP通道" + channum + "在线");
|
|
|
+ } else {
|
|
|
+ System.out.println("IP通道" + channum + "不在线");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ static class fPlayEScallback implements HCNetSDK.FPlayESCallBack {
|
|
|
+ public void invoke( int lPreviewHandle, HCNetSDK.NET_DVR_PACKET_INFO_EX pstruPackInfo,Pointer pUser)
|
|
|
+ {
|
|
|
+ System.out.println("进入码流回调");
|
|
|
+ System.out.println(pstruPackInfo.dwPacketSize);
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ static class playDataCallBack implements HCNetSDK.FPlayDataCallBack{
|
|
|
+ public void invoke(int lPlayHandle, int dwDataType, Pointer pBuffer, int dwBufSize, int dwUser)
|
|
|
+ {
|
|
|
+ System.out.println("回放码流回调...");
|
|
|
+
|
|
|
+ long offset = 0;
|
|
|
+ ByteBuffer buffers = pBuffer.getByteBuffer(offset, dwBufSize);
|
|
|
+ byte[] bytes = new byte[dwBufSize];
|
|
|
+ buffers.rewind();
|
|
|
+ buffers.get(bytes);
|
|
|
+ try {
|
|
|
+ outputStream.write(bytes);
|
|
|
+ } catch (IOException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ static class FRealDataCallBack implements HCNetSDK.FRealDataCallBack_V30 {
|
|
|
+
|
|
|
+ public void invoke(int lRealHandle, int dwDataType, ByteByReference pBuffer, int dwBufSize, Pointer pUser) {
|
|
|
+ if (Count == 100) {
|
|
|
+ System.out.println("码流数据回调...dwBufSize="+dwBufSize);
|
|
|
+ Count = 0;
|
|
|
+ }
|
|
|
+ Count++;
|
|
|
+
|
|
|
+ switch (dwDataType) {
|
|
|
+ case HCNetSDK.NET_DVR_SYSHEAD:
|
|
|
+ if (!playControl.PlayM4_GetPort(m_lPort))
|
|
|
+ {
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ if (dwBufSize > 0) {
|
|
|
+ if (!playControl.PlayM4_SetStreamOpenMode(m_lPort.getValue(), PlayCtrl.STREAME_REALTIME))
|
|
|
+ {
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ if (!playControl.PlayM4_OpenStream(m_lPort.getValue(), pBuffer, dwBufSize, 1024 * 1024))
|
|
|
+ {
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ if (!playControl.PlayM4_Play(m_lPort.getValue(), null))
|
|
|
+ {
|
|
|
+ break;
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ case HCNetSDK.NET_DVR_STREAMDATA:
|
|
|
+ if ((dwBufSize > 0) && (m_lPort.getValue() != -1)) {
|
|
|
+ if (!playControl.PlayM4_InputData(m_lPort.getValue(), pBuffer, dwBufSize))
|
|
|
+ {
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+}
|