ÎļþÃû´Ó ard-work/src/main/java/com/ruoyi/utils/sdk/dhsdk/service/impl/DhClientServiceImpl.java ÐÞ¸Ä |
| | |
| | | package com.ruoyi.utils.sdk.dhsdk.service.impl;
|
| | |
|
| | | import com.ruoyi.alarm.global.domain.GuidePriorityQueue;
|
| | | import com.ruoyi.alarm.global.domain.GuideTask;
|
| | | import com.ruoyi.common.annotation.SdkOperate;
|
| | | import com.ruoyi.common.utils.file.FileUtils;
|
| | | import com.ruoyi.common.utils.file.MimeTypeUtils;
|
| | | import com.ruoyi.common.utils.uuid.IdUtils;
|
| | | import com.ruoyi.device.camera.domain.ArdCameras;
|
| | | import com.ruoyi.device.camera.domain.CameraCmd;
|
| | | import com.ruoyi.device.camera.service.IArdCamerasService;
|
| | | import com.ruoyi.device.channel.domain.ArdChannel;
|
| | | import com.ruoyi.device.channel.service.IArdChannelService;
|
| | | import com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib;
|
| | | import com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.LLong;
|
| | | import com.ruoyi.utils.sdk.dhsdk.lib.enumeration.EM_NEW_CONFIG;
|
| | | import com.ruoyi.utils.sdk.dhsdk.lib.enumeration.NET_EM_CFG_OPERATE_TYPE;
|
| | | import com.ruoyi.utils.sdk.dhsdk.lib.structure.CFG_VIDEO_IN_FOCUS;
|
| | | import com.ruoyi.utils.sdk.dhsdk.lib.structure.DH_OUT_PTZ_VIEW_RANGE_STATUS;
|
| | | import com.ruoyi.utils.sdk.dhsdk.module.*;
|
| | | import com.ruoyi.utils.sdk.dhsdk.service.IDhClientService;
|
| | | import com.ruoyi.utils.sdk.common.GlobalVariable;
|
| | | import com.ruoyi.media.domain.Vtdu;
|
| | | import com.ruoyi.media.service.IVtduService;
|
| | | import com.ruoyi.utils.gis.GisUtil;
|
| | | import com.ruoyi.utils.minio.MinioUtil;
|
| | | import com.sun.jna.Pointer;
|
| | | import lombok.extern.slf4j.Slf4j;
|
| | | import org.springframework.beans.factory.annotation.Value;
|
| | | import org.springframework.stereotype.Service;
|
| | |
|
| | | import javax.annotation.Resource;
|
| | | import java.io.*;
|
| | | import java.text.DecimalFormat;
|
| | | import java.util.*;
|
| | | import java.util.concurrent.PriorityBlockingQueue;
|
| | |
|
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.*;
|
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.NET_PTZ_ControlType.NET_PTZ_POINT_MOVE_CONTROL;
|
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.NET_PTZ_ControlType.NET_PTZ_POINT_SET_CONTROL;
|
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.ToolKits.getErrorCodePrint;
|
| | | import static com.ruoyi.utils.sdk.dhsdk.module.LoginModule.netsdk;
|
| | |
|
| | |
|
| | | /**
|
| | | * @ClassName DhSdkServiceImpl
|
| | | * @Description:
|
| | | * @Author åèä¹
|
| | | * @Date 2023/10/13 21:19
|
| | | * @Version 1.0
|
| | | */
|
| | | @Service
|
| | | @Slf4j(topic = "dhSdk")
|
| | | public class DhClientServiceImpl implements IDhClientService {
|
| | | @Resource
|
| | | private IArdCamerasService ardCamerasService;
|
| | | @Resource
|
| | | private IArdChannelService ardChannelService;
|
| | | @Resource
|
| | | private IVtduService vtduService;
|
| | | @Value("${minio.endpoint}")
|
| | | private String minioEndPoint;
|
| | | private final Object lock = new Object();
|
| | |
|
| | | // è®¾å¤æçº¿éç¥åè°
|
| | | private static DisConnect disConnect = new DisConnect();
|
| | | // ç½ç»è¿æ¥æ¢å¤
|
| | | private static HaveReConnect haveReConnect = new HaveReConnect();
|
| | |
|
| | |
|
| | | /**
|
| | | * ç»å½
|
| | | * åèä¹
|
| | | * 2023/10/17 8:28:13
|
| | | */
|
| | | @Override
|
| | | public Boolean login(ArdCameras camera) {
|
| | | LoginModule.init(disConnect, haveReConnect);
|
| | | NetSDKLib.NET_DEVICEINFO_Ex m_stDeviceInfo = new NetSDKLib.NET_DEVICEINFO_Ex();
|
| | | LLong loginId = LoginModule.login(camera.getIp(), camera.getPort(), camera.getUsername(), camera.getPassword(), m_stDeviceInfo);
|
| | | if (loginId.longValue() <= 0) {
|
| | | camera.setChanNum(0);
|
| | | camera.setLoginId(-1);
|
| | | camera.setState("0");
|
| | | ardCamerasService.updateArdCameras(camera);
|
| | | return false;
|
| | | }
|
| | | if (GlobalVariable.loginMap.containsKey(camera.getId())) {
|
| | | GlobalVariable.loginMap.remove(camera.getId());
|
| | | }
|
| | | //å é¤ç®¡çéé
|
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId());
|
| | | camera.setState("1");
|
| | | camera.setChanNum(m_stDeviceInfo.byChanNum);
|
| | | camera.setStartDChan(1);
|
| | | camera.setLoginId((int) loginId.longValue());
|
| | | ardCamerasService.updateArdCameras(camera);
|
| | | GlobalVariable.loginMap.put(camera.getId(), loginId);
|
| | |
|
| | | //è·åææ°éé
|
| | | for (int i = 1; i < m_stDeviceInfo.byChanNum + 1; i++) {
|
| | | ArdChannel channel = new ArdChannel();
|
| | | AV_CFG_ChannelName av_cfg_channelName = new AV_CFG_ChannelName();
|
| | | boolean b = ConfigModule.GetNewDevConfig(loginId, i - 1, CFG_CMD_CHANNELTITLE, av_cfg_channelName);
|
| | | if (b) {
|
| | | String chanName = null;
|
| | | try {
|
| | | chanName = new String(av_cfg_channelName.szName, "GBK").trim();
|
| | | } catch (UnsupportedEncodingException e) {
|
| | | e.printStackTrace();
|
| | | }
|
| | | channel.setName(chanName);
|
| | | } else {
|
| | | channel.setName("éé" + i);
|
| | | }
|
| | | channel.setDeviceId(camera.getId());
|
| | | channel.setChanNo(i);
|
| | | ardChannelService.insertArdChannel(channel);
|
| | | }
|
| | | //é
ç½®å°æµåªä½
|
| | | for (int i = 1; i < m_stDeviceInfo.byChanNum + 1; i++) {
|
| | | String name = camera.getId() + "_" + i;
|
| | | String rtspSource = "rtsp://" + camera.getUsername() + ":" + camera.getPassword() + "@" + camera.getIp() + ":" + camera.getRtspPort() + "/cam/realmonitor?channel=" + i + "&subtype=0";
|
| | | Vtdu vtdu = vtduService.selectVtduByName(name);
|
| | | if (vtdu != null) {
|
| | | vtduService.deleteVtduByName(name);
|
| | | }
|
| | | //æ·»å å°æµåªä½
|
| | | CameraCmd cmd = new CameraCmd(camera.getId(), i);
|
| | | Map<String, Object> videoCompressionCfg = getVideoCompressionCfg(cmd);
|
| | | vtdu = new Vtdu();
|
| | | if (videoCompressionCfg.get("videoEncType") != null) {
|
| | | if (videoCompressionCfg.get("videoEncType").equals("æ åh264")) {
|
| | | vtdu.setIsCode("0");//é»è®¤ä¸è½¬ç
|
| | | } else {
|
| | | vtdu.setIsCode("1");//é»è®¤è½¬ç
|
| | | }
|
| | | } else {
|
| | | vtdu.setIsCode("0");//é»è®¤ä¸è½¬ç
|
| | | }
|
| | | vtdu.setRtspSource(rtspSource);
|
| | | vtdu.setName(camera.getId() + "_" + i);
|
| | | vtdu.setMode("1");//é»è®¤CPU软解ç
|
| | | vtdu.setCameraId(camera.getId());
|
| | | vtduService.insertVtdu(vtdu);
|
| | | }
|
| | |
|
| | | //å建å¼å¯¼éå
|
| | | if (!GuidePriorityQueue.cameraQueueMap.containsKey(camera.getId())) {
|
| | | Comparator<GuideTask> comparator = GuidePriorityQueue.getComparator();
|
| | | PriorityBlockingQueue<GuideTask> priorityQueue = new PriorityBlockingQueue<>(1000, comparator);
|
| | | GuidePriorityQueue.cameraQueueMap.put(camera.getId(), priorityQueue);
|
| | | }
|
| | | return true;
|
| | | }
|
| | |
|
| | | /**
|
| | | * 注é
|
| | | * åèä¹
|
| | | * 2023/10/17 8:28:13
|
| | | */
|
| | | @Override
|
| | | public Boolean logout(String cameraId) {
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | return LoginModule.logout(loginId);
|
| | | }
|
| | |
|
| | | /**
|
| | | * æ¯å¦å¨çº¿æ£æµ
|
| | | * åèä¹
|
| | | * 2023/10/17 8:28:13
|
| | | */
|
| | | @Override
|
| | | public boolean isOnLine(CameraCmd cmd) {
|
| | | try {
|
| | | String cameraId = cmd.getCameraId();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | NetSDKLib.NET_WORKSTATE dh_ptz_location_info = new NetSDKLib.NET_WORKSTATE();
|
| | | boolean b = ConfigModule.queryDevState(loginId, NET_DEVSTATE_ONLINE, dh_ptz_location_info);
|
| | | if (!b) {
|
| | | return false;
|
| | | }
|
| | | } catch (Exception ex) {
|
| | | log.error("æ£æµå¨çº¿å¼å¸¸ï¼" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | return true;
|
| | | }
|
| | |
|
| | | /**
|
| | | * äºå°æ§å¶
|
| | | * åèä¹
|
| | | * 2023/10/17 8:28:13
|
| | | */
|
| | | @Override
|
| | | @SdkOperate
|
| | | public boolean pTZControl(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | boolean enable = cmd.isEnable();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | Integer speed = cmd.getSpeed();
|
| | | Integer code = cmd.getCode();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | int dwStop;
|
| | | if (enable) {
|
| | | dwStop = 0;//å¼å¯
|
| | | } else {
|
| | | dwStop = 1;//å
³é
|
| | | }
|
| | | int dwPTZCommand = -1;
|
| | | switch (code) {
|
| | | /*æ¹å*/
|
| | | case 1:
|
| | | dwPTZCommand = NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTTOP;
|
| | | break;
|
| | | case 2:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_UP_CONTROL;
|
| | | break;
|
| | | case 3:
|
| | | dwPTZCommand = NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTTOP;
|
| | | break;
|
| | | case 4:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_LEFT_CONTROL;
|
| | | break;
|
| | | case 5:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_POINT_LOOP_CONTROL;
|
| | | break;
|
| | | case 6:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_RIGHT_CONTROL;
|
| | | break;
|
| | | case 7:
|
| | | dwPTZCommand = NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTDOWN;
|
| | | break;
|
| | | case 8:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_DOWN_CONTROL;
|
| | | break;
|
| | | case 9:
|
| | | dwPTZCommand = NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTDOWN;
|
| | | break;
|
| | | /*ç¦è·*/
|
| | | case 10:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_ZOOM_ADD_CONTROL;
|
| | | break;
|
| | | case 11:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_ZOOM_DEC_CONTROL;
|
| | | break;
|
| | | /*ç¦ç¹*/
|
| | | case 12:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_FOCUS_ADD_CONTROL;
|
| | | break;
|
| | | case 13:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_FOCUS_DEC_CONTROL;
|
| | | break;
|
| | | /*å
å*/
|
| | | case 14:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_APERTURE_ADD_CONTROL;
|
| | | break;
|
| | | case 15:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_APERTURE_DEC_CONTROL;
|
| | | break;
|
| | | case 16:
|
| | | dwPTZCommand = NET_PTZ_ControlType.NET_PTZ_LAMP_CONTROL;
|
| | | break;
|
| | | }
|
| | | boolean bool = PtzControlModule.ptzControl(loginId, chanNo - 1, dwPTZCommand, speed, speed, 0, dwStop);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | }
|
| | |
|
| | | /**
|
| | | * è·åPTZå¼
|
| | | * åèä¹
|
| | | * 2023/10/17 8:28:13
|
| | | */
|
| | | @Override
|
| | | public Map<String, Object> getPtz(CameraCmd cmd) {
|
| | | Map<String, Object> ptzMap = new HashMap<>();
|
| | | String cameraId = cmd.getCameraId();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return null;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | NetSDKLib.NET_PTZ_LOCATION_INFO dh_ptz_location_info = new NetSDKLib.NET_PTZ_LOCATION_INFO();
|
| | | boolean b = ConfigModule.queryDevState(loginId, NET_DEVSTATE_PTZ_LOCATION, dh_ptz_location_info);
|
| | | if (b) {
|
| | | DecimalFormat df = new DecimalFormat("0.0");//设置ä¿ç使°
|
| | | String nPTZPan = df.format((float) dh_ptz_location_info.nPTZPan / 10);
|
| | | float t = (float) dh_ptz_location_info.nPTZTilt / 10 * -1;
|
| | | String nPTZTilt = df.format(t < 0 ? t + 360 : t);
|
| | | String nPTZZoom = df.format((float) dh_ptz_location_info.nPTZZoom);
|
| | | ptzMap.put("p", nPTZPan);
|
| | | ptzMap.put("t", nPTZTilt);
|
| | | ptzMap.put("z", nPTZZoom);
|
| | | }
|
| | | return ptzMap;
|
| | | }
|
| | |
|
| | | /**
|
| | | * @æè¿° 设置ptzä¿¡æ¯
|
| | | * @åæ° [userId, channelNum]
|
| | | * @è¿åå¼ boolean
|
| | | * @å建人 åèä¹
|
| | | * @å建æ¶é´ 2023/1/17 16:36
|
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ 注æä¿¯ä»°è§åº¦è´å¼éè¦å ä¸360å¾å°çæ£å¼è¿è¡è®¾ç½®
|
| | | */
|
| | | @Override
|
| | | @SdkOperate
|
| | | public boolean setPtz(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | Map<String, Double> ptz = cmd.getPtzMap();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | | int p = (int) (ptz.get("p") * 10);
|
| | | int t = (int) (ptz.get("t") * 10);
|
| | | t = t > 900 ? 3600 - t : t * -1;
|
| | |
|
| | | int z = ptz.get("z").intValue() == 0 ? 1 : ptz.get("z").intValue();
|
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_EXACTGOTO, p, t, z, 0);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error(ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | /**
|
| | | * @æè¿° è®¾ç½®é¶æ¹ä½è§
|
| | | * @åæ° [userId, channelNum]
|
| | | * @è¿åå¼ boolean
|
| | | * @å建人 åèä¹
|
| | | * @å建æ¶é´ 2023/1/17 16:36
|
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ 注æä¿¯ä»°è§åº¦è´å¼éè¦å ä¸360å¾å°çæ£å¼è¿è¡è®¾ç½®
|
| | | */
|
| | | @Override
|
| | | public boolean setZeroPtz(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | boolean bool = NetSDKLib.NETSDK_INSTANCE.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RESETZERO, 0, 0, 0, 0);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | }
|
| | |
|
| | | /**
|
| | | * @æè¿° æªå¾ åæå¡å¨
|
| | | * @åæ° [cameraId, channelNum]
|
| | | * @è¿åå¼ java.lang.String
|
| | | * @å建人 åèä¹
|
| | | * @å建æ¶é´ 2023/2/2 14:59
|
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯
|
| | | */
|
| | | @Override
|
| | | public String picCutCate(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return "";
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | String bucketName = "pic";
|
| | | String picUrl = "";
|
| | | String bucketObject = "/capture/" + IdUtils.simpleUUID() + ".jpeg";
|
| | | fCaptureReceiveCB m_CaptureReceiveCB = new fCaptureReceiveCB(minioEndPoint, bucketName, bucketObject);
|
| | | CapturePictureModule.setSnapRevCallBack(m_CaptureReceiveCB);
|
| | | boolean b = CapturePictureModule.remoteCapturePicture(loginId, chanNo - 1);
|
| | | if (b) {
|
| | | picUrl = minioEndPoint + "/" + bucketName + bucketObject;
|
| | | }
|
| | | return picUrl;
|
| | |
|
| | | }
|
| | |
|
| | | /**
|
| | | * @æè¿° çæ¶å½å
|
| | | * @åæ° [userId, channelNum, enable]
|
| | | * @è¿åå¼ void
|
| | | * @å建人 åèä¹
|
| | | * @å建æ¶é´ 2023/1/20 11:18
|
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯
|
| | | */
|
| | | @Override
|
| | | public String record(CameraCmd cmd) {
|
| | | try {
|
| | | String url = "";
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | String path = FileUtils.createFile("D:/recordTemp/" + cameraId + ".mp4");
|
| | | boolean enable = cmd.isEnable();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return "";
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | |
|
| | | if (enable) {
|
| | | LLong lRealHandle = new LLong(0);
|
| | | if (!GlobalVariable.previewMap.containsKey(cameraId)) {
|
| | | lRealHandle = RealPlayModule.startRealPlay(loginId, chanNo - 1, path);
|
| | | if (lRealHandle.longValue() <= 0) {
|
| | | log.error("åæµå¤±è´¥" + getErrorCodePrint());
|
| | | return "";
|
| | | }
|
| | | log.debug("åæµæå");
|
| | | GlobalVariable.previewMap.put(cameraId, lRealHandle.intValue());
|
| | | }
|
| | | log.debug("å½åå¼å§");
|
| | | } else {
|
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) {
|
| | | LLong lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId));
|
| | | RealPlayModule.stopRealPlay(lRealHandle);
|
| | | GlobalVariable.previewMap.remove(cameraId);
|
| | | }
|
| | | log.debug("å½å忢");
|
| | | }
|
| | | return url;
|
| | | } catch (Exception ex) {
|
| | | log.error("å½åå¼å¸¸" + ex.getMessage());
|
| | | return "";
|
| | | }
|
| | | }
|
| | |
|
| | | @Override
|
| | | public boolean recordStart(CameraCmd cmd) {
|
| | | try {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | String path = FileUtils.createFile("D:/recordTemp/" + cameraId + ".mp4");
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | LLong lRealHandle;
|
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) {
|
| | | lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId));
|
| | | RealPlayModule.stopRealPlay(lRealHandle);
|
| | | GlobalVariable.previewMap.remove(cameraId);
|
| | | log.debug("忢å½åå½å");
|
| | | }
|
| | | lRealHandle = RealPlayModule.startRealPlay(loginId, chanNo - 1, path);
|
| | | if (lRealHandle.longValue() <= 0) {
|
| | | log.error("åæµå¤±è´¥" + getErrorCodePrint());
|
| | | }
|
| | | log.debug("åæµæå");
|
| | | GlobalVariable.previewMap.put(cameraId, lRealHandle.intValue());
|
| | | GlobalVariable.threadMap.put(cameraId, Thread.currentThread().getName());
|
| | | //if (!netsdk.CLIENT_SaveRealData(lRealHandle, path)) {
|
| | | // log.error("ä¿åè§é¢æä»¶å°ä¸´æ¶æä»¶å¤¹å¤±è´¥ é误ç 为: " +getErrorCodePrint());
|
| | | // return false;
|
| | | //}
|
| | | log.debug("å½åå¼å§");
|
| | | return true;
|
| | | } catch (Exception ex) {
|
| | | log.error("å¼å§å½åå¼å¸¸" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | @Override
|
| | | public String recordStopToMinio(CameraCmd cmd) {
|
| | | String url = "";
|
| | | try {
|
| | | String cameraId = cmd.getCameraId();
|
| | | String path = FileUtils.createFile("D:/recordTemp/" + cameraId + ".mp4");
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return "";
|
| | | }
|
| | | LLong lRealHandle;
|
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) {
|
| | | lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId));
|
| | | RealPlayModule.stopRealPlay(lRealHandle);
|
| | | GlobalVariable.previewMap.remove(cameraId);
|
| | | log.debug("忢å½åå½å");
|
| | | }
|
| | | //åå
¥minio
|
| | | String BucketName = cmd.getRecordBucketName();
|
| | | String ObjectName = cmd.getRecordObjectName() + ".mp4";
|
| | | FileInputStream stream = new FileInputStream(path);
|
| | | boolean b = MinioUtil.uploadObject(BucketName, ObjectName, stream, stream.available(), "video/MP4");
|
| | | if (b) {
|
| | | url = MinioUtil.getBucketObjectUrl(BucketName, ObjectName);
|
| | | log.debug("ä¸ä¼ æä»¶æå!" + url);
|
| | | }
|
| | | return url;
|
| | | } catch (Exception ex) {
|
| | | log.error("å½åå¼å¸¸" + ex.getMessage());
|
| | | return "";
|
| | | }
|
| | | }
|
| | |
|
| | | @Override
|
| | | public boolean recordStopNotToMinio(CameraCmd cmd) {
|
| | | boolean result = false;
|
| | | try {
|
| | | String cameraId = cmd.getCameraId();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong lRealHandle;
|
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) {
|
| | | lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId));
|
| | | RealPlayModule.stopRealPlay(lRealHandle);
|
| | | GlobalVariable.previewMap.remove(cameraId);
|
| | | log.debug("忢å½åå½å");
|
| | | }
|
| | |
|
| | | result = true;
|
| | | } catch (Exception ex) {
|
| | | log.error("å½åå¼å¸¸" + ex.getMessage());
|
| | | }
|
| | | return result;
|
| | | }
|
| | |
|
| | | /**
|
| | | * å¼å¯¼ç®æ ä½ç½®
|
| | | * åèä¹
|
| | | * 2023/10/17 8:27:48
|
| | | */
|
| | | @Override
|
| | | public boolean guideTargetPosition(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | | ArdCameras cameras = ardCamerasService.selectArdCamerasById(cameraId);
|
| | | double[] cameraPositon = new double[]{cameras.getLongitude(), cameras.getLatitude(), cameras.getAltitude()};
|
| | | double[] targetPositions = cmd.getTargetPosition();
|
| | | double[] cameraPTZ = GisUtil.getCameraPTZ(cameraPositon, targetPositions, 20, 150);
|
| | | int p = (int) (cameraPTZ[0] * 10);
|
| | | int t = (int) (cameraPTZ[1] * 10);
|
| | | int z = (int) (cameraPTZ[2]);
|
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_EXACTGOTO, p, t, z, 0);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error("å¼å¯¼å¼å¸¸:" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | //转è³é¢ç½®ç¹
|
| | | @Override
|
| | | public boolean gotoPreset(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | Integer PresetIndex = cmd.getPresetIndex();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | |
|
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NET_PTZ_POINT_MOVE_CONTROL, 0, PresetIndex, 0, 0);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error("转è³é¢ç½®ç¹å¼å¸¸:" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | @Override
|
| | | //设置é¢ç½®ä½
|
| | | public boolean setPreset(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | Integer PresetIndex = cmd.getPresetIndex();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | |
|
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NET_PTZ_POINT_SET_CONTROL, 0, PresetIndex, 0, 0);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error("设置é¢ç½®ç¹å¼å¸¸:" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | //忢èç¦æ¨¡å¼
|
| | | @Override
|
| | | public boolean controlFocusMode(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | boolean enable = cmd.isEnable();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | | CFG_VIDEO_IN_FOCUS cfg_video_in_focus = new CFG_VIDEO_IN_FOCUS();
|
| | | cfg_video_in_focus.nVideoInFocusRealNum = 3;//é
置使ç¨ä¸ªæ°
|
| | | for (int i = 0; i < 3; i++) {
|
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nSensitivity = 1;//èç¦çµæåº¦, 0-é«, 1-é»è®¤, 2-ä½
|
| | |
|
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nIRCorrection = 2;//红å¤å
èç¦ä¿®æ£, 0-ä¸ä¿®æ£, 1-ä¿®æ£, 2-èªå¨ä¿®æ£
|
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nFocusLimit = 10000;//èç¦æéå¼, å使¯«ç±³
|
| | | if (enable) {//èç¦æ¨¡å¼, 0-å
³é, 1-è¾
å©èç¦, 2-èªå¨èç¦, 3-åèªå¨èç¦, 4-æå¨èç¦
|
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nMode = 4;//æå¨èç¦
|
| | | cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 0;//èç¦æéManual
|
| | | log.debug("å½å为æå¨èç¦æ¨¡å¼");
|
| | | } else {
|
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nMode = 2;//èªå¨èç¦
|
| | | cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 1;//èç¦æéAuto
|
| | | log.debug("å½å为èªå¨èç¦æ¨¡å¼");
|
| | | }
|
| | | }
|
| | | cfg_video_in_focus.nChannelIndex = chanNo - 1;
|
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, NetSDKLib.CFG_CMD_VIDEOIN_FOCUS, cfg_video_in_focus);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error("忢èç¦æ¨¡å¼å¼å¸¸:" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | @Override
|
| | | public String getFocusMode(CameraCmd cmd) {
|
| | | String mode = "";
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return "";
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | | NET_VIDEOIN_FOCUSMODE_INFO focusModeInfo = new NET_VIDEOIN_FOCUSMODE_INFO();
|
| | | int emCfgOpType = NET_EM_CFG_OPERATE_TYPE.NET_EM_CFG_VIDEOIN_FOCUSMODE;
|
| | | boolean bool = ConfigModule.GetConfig(loginId, chanNo - 1, emCfgOpType, focusModeInfo);
|
| | | if (!bool) {
|
| | | log.error("è·å失败,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | System.out.println("é
置类å:" + focusModeInfo.emCfgType); // å
·ä½ä¿¡æ¯ï¼åèåºéçæä¸¾
|
| | | System.out.println("èç¦æ¨¡å¼:" + focusModeInfo.emFocusMode);
|
| | | switch (focusModeInfo.emFocusMode) {
|
| | | case 0:
|
| | | mode = "å
³é";
|
| | | break;
|
| | | case 1:
|
| | | mode = "è¾
å©èç¦";
|
| | | break;
|
| | | case 2:
|
| | | mode = "èªå¨èç¦";
|
| | | break;
|
| | | case 3:
|
| | | mode = "åèªå¨èç¦";
|
| | | break;
|
| | | case 4:
|
| | | mode = "æå¨èç¦";
|
| | | break;
|
| | | }
|
| | |
|
| | | } catch (Exception ex) {
|
| | | log.error("è·åèç¦æ¨¡å¼å¼å¸¸:" + ex.getMessage());
|
| | |
|
| | | }
|
| | | return mode;
|
| | | }
|
| | |
|
| | | //éé¾
|
| | | @Override
|
| | | public boolean controlDefogcfg(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | boolean enable = cmd.isEnable();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | | String command = EM_NEW_CONFIG.CFG_CMD_VIDEOINDEFOG.getValue();
|
| | | //CFG_VIDEOINDEFOG_LIST cfg_videoindefog_list=new CFG_VIDEOINDEFOG_LIST();
|
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, command, null);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error("忢éé¾å¼å¸¸:" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | //红å¤
|
| | | @Override
|
| | | public boolean controlInfrarecfg(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | boolean enable = cmd.isEnable();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | | CFG_LIGHTING_INFO cfg_lighting_info = new CFG_LIGHTING_INFO();
|
| | | cfg_lighting_info.nLightingDetailNum = 1;
|
| | | if (enable) {
|
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_MANUAL;
|
| | | } else {
|
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_OFF;
|
| | | }
|
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, CFG_CMD_LIGHTING, cfg_lighting_info);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error("åæ¢çº¢å¤å¼å¸¸:" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | //è·åèç¦å¼
|
| | | @Override
|
| | | public int getFocusPos(CameraCmd cmd) {
|
| | | int result = 0;
|
| | | try {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return result;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | NET_PTZ_LOCATION_INFO net_ptz_location_info = new NET_PTZ_LOCATION_INFO();
|
| | | net_ptz_location_info.nChannelID = chanNo - 1;
|
| | | boolean bool = ConfigModule.queryDevState(loginId, NET_DEVSTATE_PTZ_LOCATION, net_ptz_location_info);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | result = net_ptz_location_info.nFocusMapValue;
|
| | | } catch (Exception ex) {
|
| | | log.error("è·åèç¦å¼å¼å¸¸:" + ex.getMessage());
|
| | | }
|
| | | return result;
|
| | | }
|
| | |
|
| | | //设置èç¦å¼
|
| | | @Override
|
| | | public boolean setFocusPos(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | boolean enable = cmd.isEnable();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return false;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | try {
|
| | | CFG_LIGHTING_INFO cfg_lighting_info = new CFG_LIGHTING_INFO();
|
| | | cfg_lighting_info.nLightingDetailNum = 1;
|
| | | if (enable) {
|
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_MANUAL;
|
| | | } else {
|
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_OFF;
|
| | | }
|
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, CFG_CMD_LIGHTING, cfg_lighting_info);
|
| | | if (!bool) {
|
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint());
|
| | | }
|
| | | return bool;
|
| | | } catch (Exception ex) {
|
| | | log.error("设置èç¦å¼å¼å¸¸:" + ex.getMessage());
|
| | | return false;
|
| | | }
|
| | | }
|
| | |
|
| | | //è·åç æµåç¼©åæ°
|
| | | @Override
|
| | | public Map<String, Object> getVideoCompressionCfg(CameraCmd cmd) {
|
| | | Map<String, Object> map = new HashMap<>();
|
| | | try {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return null;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | CFG_ENCODE_INFO cfg_encode_info = new CFG_ENCODE_INFO();
|
| | | cfg_encode_info.nChannelID = chanNo - 1;
|
| | | boolean b = ConfigModule.GetNewDevConfig(loginId, chanNo - 1, CFG_CMD_ENCODE, cfg_encode_info);
|
| | | if (b) {
|
| | | int emCompression = cfg_encode_info.stuMainStream[0].stuVideoFormat.emCompression;//è§é¢æ ¼å¼
|
| | | String videoEncType = "";
|
| | | switch (emCompression) {
|
| | | case 0:
|
| | | videoEncType = "MPEG4";
|
| | | break;
|
| | | case 1:
|
| | | videoEncType = "MS-MPEG4";
|
| | | break;
|
| | | case 2:
|
| | | videoEncType = "MPEG2";
|
| | | break;
|
| | | case 3:
|
| | | videoEncType = "MPEG1";
|
| | | break;
|
| | | case 4:
|
| | | videoEncType = "H.263";
|
| | | break;
|
| | | case 5:
|
| | | videoEncType = "MJPG";
|
| | | break;
|
| | | case 6:
|
| | | videoEncType = "FCC-MPEG4";
|
| | | break;
|
| | | case 7:
|
| | | videoEncType = "æ åh264";
|
| | | break;
|
| | | case 8:
|
| | | videoEncType = "æ åh265";
|
| | | break;
|
| | | case 9:
|
| | | videoEncType = "SVAC";
|
| | | break;
|
| | | default:
|
| | | videoEncType = "æªç¥";
|
| | | break;
|
| | | }
|
| | | int nBitRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nBitRate;
|
| | | int nWidth = cfg_encode_info.stuMainStream[0].stuVideoFormat.nWidth;
|
| | | int nHeight = cfg_encode_info.stuMainStream[0].stuVideoFormat.nHeight;
|
| | | String resolution = nWidth + "*" + nHeight;
|
| | | float nFrameRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nFrameRate;
|
| | | map.put("resolution", resolution);//å辨ç
|
| | | map.put("videoBitrate", String.valueOf(nBitRate));//æ¯ç¹ç
|
| | | map.put("videoEncType", videoEncType);//ç¼ç
|
| | | map.put("nFrameRate", String.valueOf(nFrameRate));//帧ç
|
| | | }
|
| | | } catch (Exception ex) {
|
| | | log.error("åç æµåç¼©åæ°å¼å¸¸:" + ex.getMessage());
|
| | | }
|
| | | return map;
|
| | | }
|
| | |
|
| | | //è·åGISä¿¡æ¯æ°æ®
|
| | | @Override
|
| | | public Map<String, Object> getGisInfo(CameraCmd cmd) {
|
| | | Map<String, Object> map = new HashMap<>();
|
| | | try {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer chanNo = cmd.getChanNo();
|
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) {
|
| | | return null;
|
| | | }
|
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId);
|
| | | DH_OUT_PTZ_VIEW_RANGE_STATUS dh_out_ptz_view_range_status = new DH_OUT_PTZ_VIEW_RANGE_STATUS();
|
| | | boolean b = ConfigModule.queryDevState(loginId, NET_DEVSTATE_PTZ_VIEW_RANGE, dh_out_ptz_view_range_status);
|
| | | if (b) {
|
| | | float nAngelH = (float) dh_out_ptz_view_range_status.nAngelH / 10;
|
| | | float nAngelV = (float) dh_out_ptz_view_range_status.nAngelV / 10;
|
| | | map = getPtz(cmd);//è·åptz
|
| | | map.put("fHorFieldAngle", nAngelH);// æ°´å¹³è§åºè§
|
| | | map.put("fVerFieldAngle", nAngelV);// åç´è§åºè§
|
| | | }
|
| | | } catch (Exception ex) {
|
| | | log.error("è·åäºå°å¯è§åå¼å¸¸" + ex.getMessage());
|
| | | }
|
| | | return map;
|
| | | }
|
| | |
|
| | | // è®¾å¤æçº¿åè°: å½è®¾å¤åºç°æçº¿æ¶ï¼SDKä¼è°ç¨è¯¥å½æ°
|
| | | private static class DisConnect implements NetSDKLib.fDisConnect {
|
| | | public void invoke(LLong m_hLoginHandle, String pchDVRIP, int nDVRPort, Pointer dwUser) {
|
| | | log.warn("Device[" + pchDVRIP + ":" + nDVRPort + "] DisConnect!");
|
| | | }
|
| | | }
|
| | |
|
| | | // ç½ç»è¿æ¥æ¢å¤åè°:设å¤éè¿æååè°ï¼å½å·²æçº¿ç设å¤éè¿æåæ¶ï¼SDKä¼è°ç¨è¯¥å½æ°
|
| | | private static class HaveReConnect implements NetSDKLib.fHaveReConnect {
|
| | | @Override
|
| | | public void invoke(LLong lLoginID, String pchDVRIP, int nDVRPort, Pointer dwUser) {
|
| | | log.warn("ReConnect Device[" + pchDVRIP + ":" + nDVRPort + "]");
|
| | | }
|
| | | }
|
| | |
|
| | | // æå¾æ¥æ¶åè°:彿徿åï¼sdkä¼è°ç¨è¯¥å½æ°
|
| | | public static class fCaptureReceiveCB implements NetSDKLib.fSnapRev {
|
| | | private String minioEndPoint;
|
| | | private String ObjectName;
|
| | | private String bucketName;
|
| | |
|
| | | public fCaptureReceiveCB(String minioEndPoint, String bucketName, String ObjectName) {
|
| | | this.minioEndPoint = minioEndPoint;
|
| | | this.bucketName = bucketName;
|
| | | this.ObjectName = ObjectName;
|
| | | }
|
| | |
|
| | | public void invoke(LLong lLoginID, Pointer pBuf, int RevLen, int EncodeType, int CmdSerial, Pointer dwUser) {
|
| | | if (pBuf != null && RevLen > 0) {
|
| | | byte[] buf = pBuf.getByteArray(0, RevLen);
|
| | | //åå¨å°minio
|
| | | InputStream input = new ByteArrayInputStream(buf);
|
| | |
|
| | | try {
|
| | | boolean b = MinioUtil.uploadObject(bucketName, ObjectName, input, input.available(), MimeTypeUtils.IMAGE_JPEG);
|
| | | if (b) {
|
| | | String url = minioEndPoint + "/" + bucketName + ObjectName;
|
| | | log.debug("ä¸ä¼ æä»¶æå!" + url);
|
| | | }
|
| | | } catch (IOException ex) {
|
| | | log.error("ä¸ä¼ æä»¶å¼å¸¸ï¼" + ex.getMessage());
|
| | | }
|
| | | }
|
| | | }
|
| | | }
|
| | | package com.ruoyi.utils.sdk.dhsdk.service.impl; |
| | | |
| | | import com.ruoyi.alarm.global.domain.GuidePriorityQueue; |
| | | import com.ruoyi.alarm.global.domain.GuideTask; |
| | | import com.ruoyi.common.annotation.SdkOperate; |
| | | import com.ruoyi.common.utils.file.FileUtils; |
| | | import com.ruoyi.common.utils.file.MimeTypeUtils; |
| | | import com.ruoyi.common.utils.uuid.IdUtils; |
| | | import com.ruoyi.device.camera.strategy.SdkStrategy; |
| | | import com.ruoyi.device.camera.domain.ArdCameras; |
| | | import com.ruoyi.device.camera.domain.CameraCmd; |
| | | import com.ruoyi.device.camera.service.IArdCamerasService; |
| | | import com.ruoyi.device.channel.domain.ArdChannel; |
| | | import com.ruoyi.device.channel.service.IArdChannelService; |
| | | import com.ruoyi.media.domain.Vtdu; |
| | | import com.ruoyi.media.service.IVtduService; |
| | | import com.ruoyi.utils.gis.GisUtil; |
| | | import com.ruoyi.utils.minio.MinioUtil; |
| | | import com.ruoyi.utils.sdk.common.GlobalVariable; |
| | | import com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib; |
| | | import com.ruoyi.utils.sdk.dhsdk.lib.enumeration.EM_NEW_CONFIG; |
| | | import com.ruoyi.utils.sdk.dhsdk.lib.enumeration.NET_EM_CFG_OPERATE_TYPE; |
| | | import com.ruoyi.utils.sdk.dhsdk.lib.structure.CFG_VIDEO_IN_FOCUS; |
| | | import com.ruoyi.utils.sdk.dhsdk.lib.structure.DH_OUT_PTZ_VIEW_RANGE_STATUS; |
| | | import com.ruoyi.utils.sdk.dhsdk.module.*; |
| | | import com.sun.jna.Pointer; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.beans.factory.annotation.Value; |
| | | import org.springframework.scheduling.annotation.Async; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import javax.annotation.Resource; |
| | | import java.io.*; |
| | | import java.text.DecimalFormat; |
| | | import java.util.Comparator; |
| | | import java.util.HashMap; |
| | | import java.util.List; |
| | | import java.util.Map; |
| | | import java.util.concurrent.PriorityBlockingQueue; |
| | | |
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.*; |
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.NET_DEVSTATE_PTZ_VIEW_RANGE; |
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.NET_PTZ_ControlType.NET_PTZ_POINT_MOVE_CONTROL; |
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.NetSDKLib.NET_PTZ_ControlType.NET_PTZ_POINT_SET_CONTROL; |
| | | import static com.ruoyi.utils.sdk.dhsdk.lib.ToolKits.getErrorCodePrint; |
| | | import static com.ruoyi.utils.sdk.dhsdk.module.LoginModule.netsdk; |
| | | |
| | | /** |
| | | * @Description: 大åsdkçç¥ |
| | | * @ClassName: DhSdkStrategy |
| | | * @Author: åèä¹ |
| | | * @Date: 2023å¹´11æ07æ¥10:51:09 |
| | | **/ |
| | | @Slf4j(topic = "dhSdk") |
| | | @Service |
| | | public class DhSdkStrategy implements SdkStrategy { |
| | | |
| | | @Resource |
| | | private IArdCamerasService ardCamerasService; |
| | | @Resource |
| | | private IArdChannelService ardChannelService; |
| | | @Resource |
| | | private IVtduService vtduService; |
| | | @Value("${minio.endpoint}") |
| | | private String minioEndPoint; |
| | | |
| | | |
| | | // è®¾å¤æçº¿éç¥åè° |
| | | private static DisConnect disConnect = new DisConnect(); |
| | | // ç½ç»è¿æ¥æ¢å¤ |
| | | private static HaveReConnect haveReConnect = new HaveReConnect(); |
| | | |
| | | |
| | | /** |
| | | * ç»å½ |
| | | * åèä¹ |
| | | * 2023/10/17 8:28:13 |
| | | * @return |
| | | */ |
| | | @Override |
| | | |
| | | public boolean login(ArdCameras camera) { |
| | | LoginModule.init(disConnect, haveReConnect); |
| | | NetSDKLib.NET_DEVICEINFO_Ex m_stDeviceInfo = new NetSDKLib.NET_DEVICEINFO_Ex(); |
| | | NetSDKLib.LLong loginId = LoginModule.login(camera.getIp(), camera.getPort(), camera.getUsername(), camera.getPassword(), m_stDeviceInfo); |
| | | if (loginId.longValue() <= 0) { |
| | | camera.setChanNum(0); |
| | | camera.setLoginId(-1); |
| | | camera.setState("0"); |
| | | ardCamerasService.updateArdCameras(camera); |
| | | //å é¤ç®¡çéé |
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId()); |
| | | return false; |
| | | } |
| | | if (GlobalVariable.loginMap.containsKey(camera.getId())) { |
| | | GlobalVariable.loginMap.remove(camera.getId()); |
| | | } |
| | | //å é¤ç®¡çéé |
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId()); |
| | | camera.setState("1"); |
| | | camera.setChanNum(m_stDeviceInfo.byChanNum); |
| | | camera.setStartDChan(1); |
| | | camera.setLoginId((int) loginId.longValue()); |
| | | ardCamerasService.updateArdCameras(camera); |
| | | GlobalVariable.loginMap.put(camera.getId(), loginId); |
| | | |
| | | //è·åææ°éé |
| | | for (int i = 1; i < m_stDeviceInfo.byChanNum + 1; i++) { |
| | | ArdChannel channel = new ArdChannel(); |
| | | NetSDKLib.AV_CFG_ChannelName av_cfg_channelName = new NetSDKLib.AV_CFG_ChannelName(); |
| | | boolean b = ConfigModule.GetNewDevConfig(loginId, i - 1, CFG_CMD_CHANNELTITLE, av_cfg_channelName); |
| | | if (b) { |
| | | String chanName = null; |
| | | try { |
| | | chanName = new String(av_cfg_channelName.szName, "GBK").trim(); |
| | | } catch (UnsupportedEncodingException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | channel.setName(chanName); |
| | | } else { |
| | | channel.setName("éé" + i); |
| | | } |
| | | channel.setDeviceId(camera.getId()); |
| | | channel.setChanNo(i); |
| | | ardChannelService.insertArdChannel(channel); |
| | | } |
| | | //é
ç½®å°æµåªä½ |
| | | for (int i = 1; i < m_stDeviceInfo.byChanNum + 1; i++) { |
| | | String name = camera.getId() + "_" + i; |
| | | String rtspSource = "rtsp://" + camera.getUsername() + ":" + camera.getPassword() + "@" + camera.getIp() + ":" + camera.getRtspPort() + "/cam/realmonitor?channel=" + i + "&subtype=0"; |
| | | Vtdu vtdu = vtduService.selectVtduByName(name); |
| | | if (vtdu != null) { |
| | | vtduService.deleteVtduByName(name); |
| | | } |
| | | //æ·»å å°æµåªä½ |
| | | CameraCmd cmd = new CameraCmd(camera.getId(), i); |
| | | Map<String, Object> videoCompressionCfg = getVideoCompressionCfg(cmd); |
| | | vtdu = new Vtdu(); |
| | | if (videoCompressionCfg.get("videoEncType") != null) { |
| | | if (videoCompressionCfg.get("videoEncType").equals("æ åh264")) { |
| | | vtdu.setIsCode("0");//é»è®¤ä¸è½¬ç |
| | | } else { |
| | | vtdu.setIsCode("1");//é»è®¤è½¬ç |
| | | } |
| | | } else { |
| | | vtdu.setIsCode("0");//é»è®¤ä¸è½¬ç |
| | | } |
| | | vtdu.setRtspSource(rtspSource); |
| | | vtdu.setName(camera.getId() + "_" + i); |
| | | vtdu.setMode("1");//é»è®¤CPU软解ç |
| | | vtdu.setCameraId(camera.getId()); |
| | | vtduService.insertVtdu(vtdu); |
| | | } |
| | | |
| | | //å建å¼å¯¼éå |
| | | if (!GuidePriorityQueue.cameraQueueMap.containsKey(camera.getId())) { |
| | | Comparator<GuideTask> comparator = GuidePriorityQueue.getComparator(); |
| | | PriorityBlockingQueue<GuideTask> priorityQueue = new PriorityBlockingQueue<>(1000, comparator); |
| | | GuidePriorityQueue.cameraQueueMap.put(camera.getId(), priorityQueue); |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | @Override |
| | | @Async("loginExecutor") |
| | | public void asyncLogin(ArdCameras camera){ |
| | | LoginModule.init(disConnect, haveReConnect); |
| | | NetSDKLib.NET_DEVICEINFO_Ex m_stDeviceInfo = new NetSDKLib.NET_DEVICEINFO_Ex(); |
| | | NetSDKLib.LLong loginId = LoginModule.login(camera.getIp(), camera.getPort(), camera.getUsername(), camera.getPassword(), m_stDeviceInfo); |
| | | if (loginId.longValue() <= 0) { |
| | | camera.setChanNum(0); |
| | | camera.setLoginId(-1); |
| | | camera.setState("0"); |
| | | ardCamerasService.updateArdCameras(camera); |
| | | //å é¤ç®¡çéé |
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId()); |
| | | return; |
| | | } |
| | | if (GlobalVariable.loginMap.containsKey(camera.getId())) { |
| | | GlobalVariable.loginMap.remove(camera.getId()); |
| | | } |
| | | //å é¤ç®¡çéé |
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId()); |
| | | camera.setState("1"); |
| | | camera.setChanNum(m_stDeviceInfo.byChanNum); |
| | | camera.setStartDChan(1); |
| | | camera.setLoginId((int) loginId.longValue()); |
| | | ardCamerasService.updateArdCameras(camera); |
| | | GlobalVariable.loginMap.put(camera.getId(), loginId); |
| | | |
| | | //è·åææ°éé |
| | | for (int i = 1; i < m_stDeviceInfo.byChanNum + 1; i++) { |
| | | ArdChannel channel = new ArdChannel(); |
| | | NetSDKLib.AV_CFG_ChannelName av_cfg_channelName = new NetSDKLib.AV_CFG_ChannelName(); |
| | | boolean b = ConfigModule.GetNewDevConfig(loginId, i - 1, CFG_CMD_CHANNELTITLE, av_cfg_channelName); |
| | | if (b) { |
| | | String chanName = null; |
| | | try { |
| | | chanName = new String(av_cfg_channelName.szName, "GBK").trim(); |
| | | } catch (UnsupportedEncodingException e) { |
| | | e.printStackTrace(); |
| | | } |
| | | channel.setName(chanName); |
| | | } else { |
| | | channel.setName("éé" + i); |
| | | } |
| | | channel.setDeviceId(camera.getId()); |
| | | channel.setChanNo(i); |
| | | ardChannelService.insertArdChannel(channel); |
| | | } |
| | | //é
ç½®å°æµåªä½ |
| | | for (int i = 1; i < m_stDeviceInfo.byChanNum + 1; i++) { |
| | | String name = camera.getId() + "_" + i; |
| | | String rtspSource = "rtsp://" + camera.getUsername() + ":" + camera.getPassword() + "@" + camera.getIp() + ":" + camera.getRtspPort() + "/cam/realmonitor?channel=" + i + "&subtype=0"; |
| | | Vtdu vtdu = vtduService.selectVtduByName(name); |
| | | if (vtdu != null) { |
| | | vtduService.deleteVtduByName(name); |
| | | } |
| | | //æ·»å å°æµåªä½ |
| | | CameraCmd cmd = new CameraCmd(camera.getId(), i); |
| | | Map<String, Object> videoCompressionCfg = getVideoCompressionCfg(cmd); |
| | | vtdu = new Vtdu(); |
| | | if (videoCompressionCfg.get("videoEncType") != null) { |
| | | if (videoCompressionCfg.get("videoEncType").equals("æ åh264")) { |
| | | vtdu.setIsCode("0");//é»è®¤ä¸è½¬ç |
| | | } else { |
| | | vtdu.setIsCode("1");//é»è®¤è½¬ç |
| | | } |
| | | } else { |
| | | vtdu.setIsCode("0");//é»è®¤ä¸è½¬ç |
| | | } |
| | | vtdu.setRtspSource(rtspSource); |
| | | vtdu.setName(camera.getId() + "_" + i); |
| | | vtdu.setMode("1");//é»è®¤CPU软解ç |
| | | vtdu.setCameraId(camera.getId()); |
| | | vtduService.insertVtdu(vtdu); |
| | | } |
| | | |
| | | //å建å¼å¯¼éå |
| | | if (!GuidePriorityQueue.cameraQueueMap.containsKey(camera.getId())) { |
| | | Comparator<GuideTask> comparator = GuidePriorityQueue.getComparator(); |
| | | PriorityBlockingQueue<GuideTask> priorityQueue = new PriorityBlockingQueue<>(1000, comparator); |
| | | GuidePriorityQueue.cameraQueueMap.put(camera.getId(), priorityQueue); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 注é |
| | | * åèä¹ |
| | | * 2023/10/17 8:28:13 |
| | | * @return |
| | | */ |
| | | @Override |
| | | public boolean logout(String cameraId) { |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | NetSDKLib.LLong loginId = (NetSDKLib.LLong) GlobalVariable.loginMap.get(cameraId); |
| | | return LoginModule.logout(loginId); |
| | | } |
| | | |
| | | /** |
| | | * æ¯å¦å¨çº¿æ£æµ |
| | | * åèä¹ |
| | | * 2023/10/17 8:28:13 |
| | | */ |
| | | @Override |
| | | public boolean isOnLine(CameraCmd cmd) { |
| | | try { |
| | | String cameraId = cmd.getCameraId(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | NetSDKLib.LLong loginId = (NetSDKLib.LLong) GlobalVariable.loginMap.get(cameraId); |
| | | NetSDKLib.NET_WORKSTATE dh_ptz_location_info = new NetSDKLib.NET_WORKSTATE(); |
| | | boolean b = ConfigModule.queryDevState(loginId, NET_DEVSTATE_ONLINE, dh_ptz_location_info); |
| | | if (!b) { |
| | | return false; |
| | | } |
| | | } catch (Exception ex) { |
| | | log.error("æ£æµå¨çº¿å¼å¸¸ï¼" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | |
| | | /** |
| | | * äºå°æ§å¶ |
| | | * åèä¹ |
| | | * 2023/10/17 8:28:13 |
| | | */ |
| | | @Override |
| | | public boolean pTZControl(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | boolean enable = cmd.isEnable(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | Integer speed = cmd.getSpeed(); |
| | | Integer code = cmd.getCode(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | NetSDKLib.LLong loginId = (NetSDKLib.LLong) GlobalVariable.loginMap.get(cameraId); |
| | | int dwStop; |
| | | if (enable) { |
| | | dwStop = 0;//å¼å¯ |
| | | } else { |
| | | dwStop = 1;//å
³é |
| | | } |
| | | int dwPTZCommand = -1; |
| | | switch (code) { |
| | | /*æ¹å*/ |
| | | case 1: |
| | | dwPTZCommand = NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTTOP; |
| | | break; |
| | | case 2: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_UP_CONTROL; |
| | | break; |
| | | case 3: |
| | | dwPTZCommand = NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTTOP; |
| | | break; |
| | | case 4: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_LEFT_CONTROL; |
| | | break; |
| | | case 5: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_POINT_LOOP_CONTROL; |
| | | break; |
| | | case 6: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_RIGHT_CONTROL; |
| | | break; |
| | | case 7: |
| | | dwPTZCommand = NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_LEFTDOWN; |
| | | break; |
| | | case 8: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_DOWN_CONTROL; |
| | | break; |
| | | case 9: |
| | | dwPTZCommand = NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RIGHTDOWN; |
| | | break; |
| | | /*ç¦è·*/ |
| | | case 10: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_ZOOM_ADD_CONTROL; |
| | | break; |
| | | case 11: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_ZOOM_DEC_CONTROL; |
| | | break; |
| | | /*ç¦ç¹*/ |
| | | case 12: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_FOCUS_ADD_CONTROL; |
| | | break; |
| | | case 13: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_FOCUS_DEC_CONTROL; |
| | | break; |
| | | /*å
å*/ |
| | | case 14: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_APERTURE_ADD_CONTROL; |
| | | break; |
| | | case 15: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_APERTURE_DEC_CONTROL; |
| | | break; |
| | | case 16: |
| | | dwPTZCommand = NetSDKLib.NET_PTZ_ControlType.NET_PTZ_LAMP_CONTROL; |
| | | break; |
| | | } |
| | | boolean bool = PtzControlModule.ptzControl(loginId, chanNo - 1, dwPTZCommand, speed, speed, 0, dwStop); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } |
| | | |
| | | /** |
| | | * è·åPTZå¼ |
| | | * åèä¹ |
| | | * 2023/10/17 8:28:13 |
| | | */ |
| | | @Override |
| | | public Map<String, Object> getPtz(CameraCmd cmd) { |
| | | Map<String, Object> ptzMap = new HashMap<>(); |
| | | String cameraId = cmd.getCameraId(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return null; |
| | | } |
| | | NetSDKLib.LLong loginId = (NetSDKLib.LLong) GlobalVariable.loginMap.get(cameraId); |
| | | NetSDKLib.NET_PTZ_LOCATION_INFO dh_ptz_location_info = new NetSDKLib.NET_PTZ_LOCATION_INFO(); |
| | | boolean b = ConfigModule.queryDevState(loginId, NET_DEVSTATE_PTZ_LOCATION, dh_ptz_location_info); |
| | | if (b) { |
| | | DecimalFormat df = new DecimalFormat("0.0");//设置ä¿ç使° |
| | | String nPTZPan = df.format((float) dh_ptz_location_info.nPTZPan / 10); |
| | | float t = (float) dh_ptz_location_info.nPTZTilt / 10 * -1; |
| | | String nPTZTilt = df.format(t < 0 ? t + 360 : t); |
| | | String nPTZZoom = df.format((float) dh_ptz_location_info.nPTZZoom); |
| | | ptzMap.put("p", nPTZPan); |
| | | ptzMap.put("t", nPTZTilt); |
| | | ptzMap.put("z", nPTZZoom); |
| | | } |
| | | return ptzMap; |
| | | } |
| | | |
| | | @Override |
| | | public Map<String, Object> getPtzScope(CameraCmd cmd) { |
| | | return null; |
| | | } |
| | | |
| | | /** |
| | | * @æè¿° 设置ptzä¿¡æ¯ |
| | | * @åæ° [userId, channelNum] |
| | | * @è¿åå¼ boolean |
| | | * @å建人 åèä¹ |
| | | * @å建æ¶é´ 2023/1/17 16:36 |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ 注æä¿¯ä»°è§åº¦è´å¼éè¦å ä¸360å¾å°çæ£å¼è¿è¡è®¾ç½® |
| | | */ |
| | | @Override |
| | | public boolean setPtz(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | Map<String, Double> ptz = cmd.getPtzMap(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | int p = (int) (ptz.get("p") * 10); |
| | | int t = (int) (ptz.get("t") * 10); |
| | | t = t > 900 ? 3600 - t : t * -1; |
| | | |
| | | int z = ptz.get("z").intValue() == 0 ? 1 : ptz.get("z").intValue(); |
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_EXACTGOTO, p, t, z, 0); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error(ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * @æè¿° è®¾ç½®é¶æ¹ä½è§ |
| | | * @åæ° [userId, channelNum] |
| | | * @è¿åå¼ boolean |
| | | * @å建人 åèä¹ |
| | | * @å建æ¶é´ 2023/1/17 16:36 |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ 注æä¿¯ä»°è§åº¦è´å¼éè¦å ä¸360å¾å°çæ£å¼è¿è¡è®¾ç½® |
| | | */ |
| | | @Override |
| | | public boolean setZeroPtz(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | boolean bool = NetSDKLib.NETSDK_INSTANCE.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_RESETZERO, 0, 0, 0, 0); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } |
| | | |
| | | /** |
| | | * @æè¿° æªå¾ åæå¡å¨ |
| | | * @åæ° [cameraId, channelNum] |
| | | * @è¿åå¼ java.lang.String |
| | | * @å建人 åèä¹ |
| | | * @å建æ¶é´ 2023/2/2 14:59 |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ |
| | | */ |
| | | @Override |
| | | public String picCutCate(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return ""; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | String bucketName = "pic"; |
| | | String picUrl = ""; |
| | | String bucketObject = "/capture/" + IdUtils.simpleUUID() + ".jpeg"; |
| | | fCaptureReceiveCB m_CaptureReceiveCB = new fCaptureReceiveCB(minioEndPoint, bucketName, bucketObject); |
| | | CapturePictureModule.setSnapRevCallBack(m_CaptureReceiveCB); |
| | | boolean b = CapturePictureModule.remoteCapturePicture(loginId, chanNo - 1); |
| | | if (b) { |
| | | picUrl = minioEndPoint + "/" + bucketName + bucketObject; |
| | | } |
| | | return picUrl; |
| | | |
| | | } |
| | | |
| | | /** |
| | | * @æè¿° çæ¶å½å |
| | | * @åæ° [userId, channelNum, enable] |
| | | * @è¿åå¼ void |
| | | * @å建人 åèä¹ |
| | | * @å建æ¶é´ 2023/1/20 11:18 |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ |
| | | */ |
| | | @Override |
| | | public String record(CameraCmd cmd) { |
| | | try { |
| | | String url = ""; |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | String path = FileUtils.createFile("D:/recordTemp/" + cameraId + ".mp4"); |
| | | boolean enable = cmd.isEnable(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return ""; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | |
| | | if (enable) { |
| | | LLong lRealHandle = new LLong(0); |
| | | if (!GlobalVariable.previewMap.containsKey(cameraId)) { |
| | | lRealHandle = RealPlayModule.startRealPlay(loginId, chanNo - 1, path); |
| | | if (lRealHandle.longValue() <= 0) { |
| | | log.error("åæµå¤±è´¥" + getErrorCodePrint()); |
| | | return ""; |
| | | } |
| | | log.debug("åæµæå"); |
| | | GlobalVariable.previewMap.put(cameraId, lRealHandle.intValue()); |
| | | } |
| | | log.debug("å½åå¼å§"); |
| | | } else { |
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) { |
| | | LLong lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId)); |
| | | RealPlayModule.stopRealPlay(lRealHandle); |
| | | GlobalVariable.previewMap.remove(cameraId); |
| | | } |
| | | log.debug("å½å忢"); |
| | | } |
| | | return url; |
| | | } catch (Exception ex) { |
| | | log.error("å½åå¼å¸¸" + ex.getMessage()); |
| | | return ""; |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public boolean recordStart(CameraCmd cmd) { |
| | | try { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | String path = FileUtils.createFile("D:/recordTemp/" + cameraId + ".mp4"); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | LLong lRealHandle; |
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) { |
| | | lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId)); |
| | | RealPlayModule.stopRealPlay(lRealHandle); |
| | | GlobalVariable.previewMap.remove(cameraId); |
| | | log.debug("忢å½åå½å"); |
| | | } |
| | | lRealHandle = RealPlayModule.startRealPlay(loginId, chanNo - 1, path); |
| | | if (lRealHandle.longValue() <= 0) { |
| | | log.error("åæµå¤±è´¥" + getErrorCodePrint()); |
| | | } |
| | | log.debug("åæµæå"); |
| | | GlobalVariable.previewMap.put(cameraId, lRealHandle.intValue()); |
| | | GlobalVariable.threadMap.put(cameraId, Thread.currentThread().getName()); |
| | | //if (!netsdk.CLIENT_SaveRealData(lRealHandle, path)) { |
| | | // log.error("ä¿åè§é¢æä»¶å°ä¸´æ¶æä»¶å¤¹å¤±è´¥ é误ç 为: " +getErrorCodePrint()); |
| | | // return false; |
| | | //} |
| | | log.debug("å½åå¼å§"); |
| | | return true; |
| | | } catch (Exception ex) { |
| | | log.error("å¼å§å½åå¼å¸¸" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public String recordStopToMinio(CameraCmd cmd) { |
| | | String url = ""; |
| | | try { |
| | | String cameraId = cmd.getCameraId(); |
| | | String path = FileUtils.createFile("D:/recordTemp/" + cameraId + ".mp4"); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return ""; |
| | | } |
| | | LLong lRealHandle; |
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) { |
| | | lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId)); |
| | | RealPlayModule.stopRealPlay(lRealHandle); |
| | | GlobalVariable.previewMap.remove(cameraId); |
| | | log.debug("忢å½åå½å"); |
| | | } |
| | | //åå
¥minio |
| | | String BucketName = cmd.getRecordBucketName(); |
| | | String ObjectName = cmd.getRecordObjectName() + ".mp4"; |
| | | FileInputStream stream = new FileInputStream(path); |
| | | boolean b = MinioUtil.uploadObject(BucketName, ObjectName, stream, stream.available(), "video/MP4"); |
| | | if (b) { |
| | | url = MinioUtil.getBucketObjectUrl(BucketName, ObjectName); |
| | | log.debug("ä¸ä¼ æä»¶æå!" + url); |
| | | } |
| | | return url; |
| | | } catch (Exception ex) { |
| | | log.error("å½åå¼å¸¸" + ex.getMessage()); |
| | | return ""; |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public boolean recordStopNotToMinio(CameraCmd cmd) { |
| | | boolean result = false; |
| | | try { |
| | | String cameraId = cmd.getCameraId(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong lRealHandle; |
| | | if (GlobalVariable.previewMap.containsKey(cameraId)) { |
| | | lRealHandle = new LLong(GlobalVariable.previewMap.get(cameraId)); |
| | | RealPlayModule.stopRealPlay(lRealHandle); |
| | | GlobalVariable.previewMap.remove(cameraId); |
| | | log.debug("忢å½åå½å"); |
| | | } |
| | | |
| | | result = true; |
| | | } catch (Exception ex) { |
| | | log.error("å½åå¼å¸¸" + ex.getMessage()); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | @Override |
| | | public List<ArdChannel> getCameraChannelList(ArdCameras camera) { |
| | | return null; |
| | | } |
| | | |
| | | /** |
| | | * å¼å¯¼ç®æ ä½ç½® |
| | | * åèä¹ |
| | | * 2023/10/17 8:27:48 |
| | | */ |
| | | @Override |
| | | public boolean guideTargetPosition(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | ArdCameras cameras = ardCamerasService.selectArdCamerasById(cameraId); |
| | | double[] cameraPositon = new double[]{cameras.getLongitude(), cameras.getLatitude(), cameras.getAltitude()}; |
| | | double[] targetPositions = cmd.getTargetPosition(); |
| | | double[] cameraPTZ = GisUtil.getCameraPTZ(cameraPositon, targetPositions, 20, 150); |
| | | int p = (int) (cameraPTZ[0] * 10); |
| | | int t = (int) (cameraPTZ[1] * 10); |
| | | int z = (int) (cameraPTZ[2]); |
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NetSDKLib.NET_EXTPTZ_ControlType.NET_EXTPTZ_EXACTGOTO, p, t, z, 0); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error("å¼å¯¼å¼å¸¸:" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | //转è³é¢ç½®ç¹ |
| | | @Override |
| | | public boolean gotoPreset(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | Integer PresetIndex = cmd.getPresetIndex(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | |
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NET_PTZ_POINT_MOVE_CONTROL, 0, PresetIndex, 0, 0); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error("转è³é¢ç½®ç¹å¼å¸¸:" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | //设置é¢ç½®ä½ |
| | | public boolean setPreset(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | Integer PresetIndex = cmd.getPresetIndex(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | |
| | | boolean bool = netsdk.CLIENT_DHPTZControlEx(loginId, chanNo - 1, NET_PTZ_POINT_SET_CONTROL, 0, PresetIndex, 0, 0); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error("设置é¢ç½®ç¹å¼å¸¸:" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | //忢èç¦æ¨¡å¼ |
| | | @Override |
| | | public boolean controlFocusMode(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | boolean enable = cmd.isEnable(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | CFG_VIDEO_IN_FOCUS cfg_video_in_focus = new CFG_VIDEO_IN_FOCUS(); |
| | | cfg_video_in_focus.nVideoInFocusRealNum = 3;//é
置使ç¨ä¸ªæ° |
| | | for (int i = 0; i < 3; i++) { |
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nSensitivity = 1;//èç¦çµæåº¦, 0-é«, 1-é»è®¤, 2-ä½ |
| | | |
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nIRCorrection = 2;//红å¤å
èç¦ä¿®æ£, 0-ä¸ä¿®æ£, 1-ä¿®æ£, 2-èªå¨ä¿®æ£ |
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nFocusLimit = 10000;//èç¦æéå¼, å使¯«ç±³ |
| | | if (enable) {//èç¦æ¨¡å¼, 0-å
³é, 1-è¾
å©èç¦, 2-èªå¨èç¦, 3-åèªå¨èç¦, 4-æå¨èç¦ |
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nMode = 4;//æå¨èç¦ |
| | | cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 0;//èç¦æéManual |
| | | log.debug("å½å为æå¨èç¦æ¨¡å¼"); |
| | | } else { |
| | | cfg_video_in_focus.stVideoInFocusUnit[i].nMode = 2;//èªå¨èç¦ |
| | | cfg_video_in_focus.stVideoInFocusUnit[i].emFocusMode = 1;//èç¦æéAuto |
| | | log.debug("å½å为èªå¨èç¦æ¨¡å¼"); |
| | | } |
| | | } |
| | | cfg_video_in_focus.nChannelIndex = chanNo - 1; |
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, NetSDKLib.CFG_CMD_VIDEOIN_FOCUS, cfg_video_in_focus); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error("忢èç¦æ¨¡å¼å¼å¸¸:" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public String getFocusMode(CameraCmd cmd) { |
| | | String mode = ""; |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return ""; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | NET_VIDEOIN_FOCUSMODE_INFO focusModeInfo = new NET_VIDEOIN_FOCUSMODE_INFO(); |
| | | int emCfgOpType = NET_EM_CFG_OPERATE_TYPE.NET_EM_CFG_VIDEOIN_FOCUSMODE; |
| | | boolean bool = ConfigModule.GetConfig(loginId, chanNo - 1, emCfgOpType, focusModeInfo); |
| | | if (!bool) { |
| | | log.error("è·å失败,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | System.out.println("é
置类å:" + focusModeInfo.emCfgType); // å
·ä½ä¿¡æ¯ï¼åèåºéçæä¸¾ |
| | | System.out.println("èç¦æ¨¡å¼:" + focusModeInfo.emFocusMode); |
| | | switch (focusModeInfo.emFocusMode) { |
| | | case 0: |
| | | mode = "å
³é"; |
| | | break; |
| | | case 1: |
| | | mode = "è¾
å©èç¦"; |
| | | break; |
| | | case 2: |
| | | mode = "èªå¨èç¦"; |
| | | break; |
| | | case 3: |
| | | mode = "åèªå¨èç¦"; |
| | | break; |
| | | case 4: |
| | | mode = "æå¨èç¦"; |
| | | break; |
| | | } |
| | | |
| | | } catch (Exception ex) { |
| | | log.error("è·åèç¦æ¨¡å¼å¼å¸¸:" + ex.getMessage()); |
| | | |
| | | } |
| | | return mode; |
| | | } |
| | | |
| | | @Override |
| | | public boolean controlPTHeateRpwron(CameraCmd cmd) { |
| | | return false; |
| | | } |
| | | |
| | | @Override |
| | | public boolean controlCameraDeicing(CameraCmd cmd) { |
| | | return false; |
| | | } |
| | | |
| | | @Override |
| | | public int getPTZLockInfo(CameraCmd cmd) { |
| | | return 0; |
| | | } |
| | | |
| | | @Override |
| | | public String captureJPEGPicture(CameraCmd cmd) { |
| | | return null; |
| | | } |
| | | |
| | | //éé¾ |
| | | @Override |
| | | public boolean controlDefogcfg(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | boolean enable = cmd.isEnable(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | String command = EM_NEW_CONFIG.CFG_CMD_VIDEOINDEFOG.getValue(); |
| | | //CFG_VIDEOINDEFOG_LIST cfg_videoindefog_list=new CFG_VIDEOINDEFOG_LIST(); |
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, command, null); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error("忢éé¾å¼å¸¸:" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | //çº¢å¤ |
| | | @Override |
| | | public boolean controlInfrarecfg(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | boolean enable = cmd.isEnable(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | CFG_LIGHTING_INFO cfg_lighting_info = new CFG_LIGHTING_INFO(); |
| | | cfg_lighting_info.nLightingDetailNum = 1; |
| | | if (enable) { |
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_MANUAL; |
| | | } else { |
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_OFF; |
| | | } |
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, CFG_CMD_LIGHTING, cfg_lighting_info); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error("åæ¢çº¢å¤å¼å¸¸:" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | //è·åèç¦å¼ |
| | | @Override |
| | | public int getFocusPos(CameraCmd cmd) { |
| | | int result = 0; |
| | | try { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return result; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | NET_PTZ_LOCATION_INFO net_ptz_location_info = new NET_PTZ_LOCATION_INFO(); |
| | | net_ptz_location_info.nChannelID = chanNo - 1; |
| | | boolean bool = ConfigModule.queryDevState(loginId, NET_DEVSTATE_PTZ_LOCATION, net_ptz_location_info); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | result = net_ptz_location_info.nFocusMapValue; |
| | | } catch (Exception ex) { |
| | | log.error("è·åèç¦å¼å¼å¸¸:" + ex.getMessage()); |
| | | } |
| | | return result; |
| | | } |
| | | |
| | | //设置èç¦å¼ |
| | | @Override |
| | | public boolean setFocusPos(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | boolean enable = cmd.isEnable(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return false; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | try { |
| | | CFG_LIGHTING_INFO cfg_lighting_info = new CFG_LIGHTING_INFO(); |
| | | cfg_lighting_info.nLightingDetailNum = 1; |
| | | if (enable) { |
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_MANUAL; |
| | | } else { |
| | | cfg_lighting_info.stuLightingDetail[0].emMode = EM_CFG_LIGHTING_MODE.EM_CFG_LIGHTING_MODE_OFF; |
| | | } |
| | | boolean bool = ConfigModule.SetDevConfig(loginId, chanNo - 1, CFG_CMD_LIGHTING, cfg_lighting_info); |
| | | if (!bool) { |
| | | log.error("æ§å¶å¤±è´¥,请ç¨åéè¯" + getErrorCodePrint()); |
| | | } |
| | | return bool; |
| | | } catch (Exception ex) { |
| | | log.error("设置èç¦å¼å¼å¸¸:" + ex.getMessage()); |
| | | return false; |
| | | } |
| | | } |
| | | |
| | | //è·åç æµåç¼©åæ° |
| | | @Override |
| | | public Map<String, Object> getVideoCompressionCfg(CameraCmd cmd) { |
| | | Map<String, Object> map = new HashMap<>(); |
| | | try { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return null; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | CFG_ENCODE_INFO cfg_encode_info = new CFG_ENCODE_INFO(); |
| | | cfg_encode_info.nChannelID = chanNo - 1; |
| | | boolean b = ConfigModule.GetNewDevConfig(loginId, chanNo - 1, CFG_CMD_ENCODE, cfg_encode_info); |
| | | if (b) { |
| | | int emCompression = cfg_encode_info.stuMainStream[0].stuVideoFormat.emCompression;//è§é¢æ ¼å¼ |
| | | String videoEncType = ""; |
| | | switch (emCompression) { |
| | | case 0: |
| | | videoEncType = "MPEG4"; |
| | | break; |
| | | case 1: |
| | | videoEncType = "MS-MPEG4"; |
| | | break; |
| | | case 2: |
| | | videoEncType = "MPEG2"; |
| | | break; |
| | | case 3: |
| | | videoEncType = "MPEG1"; |
| | | break; |
| | | case 4: |
| | | videoEncType = "H.263"; |
| | | break; |
| | | case 5: |
| | | videoEncType = "MJPG"; |
| | | break; |
| | | case 6: |
| | | videoEncType = "FCC-MPEG4"; |
| | | break; |
| | | case 7: |
| | | videoEncType = "æ åh264"; |
| | | break; |
| | | case 8: |
| | | videoEncType = "æ åh265"; |
| | | break; |
| | | case 9: |
| | | videoEncType = "SVAC"; |
| | | break; |
| | | default: |
| | | videoEncType = "æªç¥"; |
| | | break; |
| | | } |
| | | int nBitRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nBitRate; |
| | | int nWidth = cfg_encode_info.stuMainStream[0].stuVideoFormat.nWidth; |
| | | int nHeight = cfg_encode_info.stuMainStream[0].stuVideoFormat.nHeight; |
| | | String resolution = nWidth + "*" + nHeight; |
| | | float nFrameRate = cfg_encode_info.stuMainStream[0].stuVideoFormat.nFrameRate; |
| | | map.put("resolution", resolution);//å辨ç |
| | | map.put("videoBitrate", String.valueOf(nBitRate));//æ¯ç¹ç |
| | | map.put("videoEncType", videoEncType);//ç¼ç |
| | | map.put("nFrameRate", String.valueOf(nFrameRate));//帧ç |
| | | } |
| | | } catch (Exception ex) { |
| | | log.error("åç æµåç¼©åæ°å¼å¸¸:" + ex.getMessage()); |
| | | } |
| | | return map; |
| | | } |
| | | |
| | | //è·åGISä¿¡æ¯æ°æ® |
| | | @Override |
| | | public Map<String, Object> getGisInfo(CameraCmd cmd) { |
| | | Map<String, Object> map = new HashMap<>(); |
| | | try { |
| | | String cameraId = cmd.getCameraId(); |
| | | Integer chanNo = cmd.getChanNo(); |
| | | if (!GlobalVariable.loginMap.containsKey(cameraId)) { |
| | | return null; |
| | | } |
| | | LLong loginId = (LLong) GlobalVariable.loginMap.get(cameraId); |
| | | DH_OUT_PTZ_VIEW_RANGE_STATUS dh_out_ptz_view_range_status = new DH_OUT_PTZ_VIEW_RANGE_STATUS(); |
| | | boolean b = ConfigModule.queryDevState(loginId, NET_DEVSTATE_PTZ_VIEW_RANGE, dh_out_ptz_view_range_status); |
| | | if (b) { |
| | | float nAngelH = (float) dh_out_ptz_view_range_status.nAngelH / 10; |
| | | float nAngelV = (float) dh_out_ptz_view_range_status.nAngelV / 10; |
| | | map = getPtz(cmd);//è·åptz |
| | | map.put("fHorFieldAngle", nAngelH);// æ°´å¹³è§åºè§ |
| | | map.put("fVerFieldAngle", nAngelV);// åç´è§åºè§ |
| | | } |
| | | } catch (Exception ex) { |
| | | log.error("è·åäºå°å¯è§åå¼å¸¸" + ex.getMessage()); |
| | | } |
| | | return map; |
| | | } |
| | | |
| | | // è®¾å¤æçº¿åè°: å½è®¾å¤åºç°æçº¿æ¶ï¼SDKä¼è°ç¨è¯¥å½æ° |
| | | private static class DisConnect implements NetSDKLib.fDisConnect { |
| | | public void invoke(LLong m_hLoginHandle, String pchDVRIP, int nDVRPort, Pointer dwUser) { |
| | | log.warn("Device[" + pchDVRIP + ":" + nDVRPort + "] DisConnect!"); |
| | | } |
| | | } |
| | | |
| | | // ç½ç»è¿æ¥æ¢å¤åè°:设å¤éè¿æååè°ï¼å½å·²æçº¿ç设å¤éè¿æåæ¶ï¼SDKä¼è°ç¨è¯¥å½æ° |
| | | private static class HaveReConnect implements NetSDKLib.fHaveReConnect { |
| | | @Override |
| | | public void invoke(LLong lLoginID, String pchDVRIP, int nDVRPort, Pointer dwUser) { |
| | | log.warn("ReConnect Device[" + pchDVRIP + ":" + nDVRPort + "]"); |
| | | } |
| | | } |
| | | |
| | | // æå¾æ¥æ¶åè°:彿徿åï¼sdkä¼è°ç¨è¯¥å½æ° |
| | | public static class fCaptureReceiveCB implements NetSDKLib.fSnapRev { |
| | | private String minioEndPoint; |
| | | private String ObjectName; |
| | | private String bucketName; |
| | | |
| | | public fCaptureReceiveCB(String minioEndPoint, String bucketName, String ObjectName) { |
| | | this.minioEndPoint = minioEndPoint; |
| | | this.bucketName = bucketName; |
| | | this.ObjectName = ObjectName; |
| | | } |
| | | |
| | | public void invoke(LLong lLoginID, Pointer pBuf, int RevLen, int EncodeType, int CmdSerial, Pointer dwUser) { |
| | | if (pBuf != null && RevLen > 0) { |
| | | byte[] buf = pBuf.getByteArray(0, RevLen); |
| | | //åå¨å°minio |
| | | InputStream input = new ByteArrayInputStream(buf); |
| | | |
| | | try { |
| | | boolean b = MinioUtil.uploadObject(bucketName, ObjectName, input, input.available(), MimeTypeUtils.IMAGE_JPEG); |
| | | if (b) { |
| | | String url = minioEndPoint + "/" + bucketName + ObjectName; |
| | | log.debug("ä¸ä¼ æä»¶æå!" + url); |
| | | } |
| | | } catch (IOException ex) { |
| | | log.error("ä¸ä¼ æä»¶å¼å¸¸ï¼" + ex.getMessage()); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | } |