From ae64126733bedc1a15a0177b105fec7f499ada81 Mon Sep 17 00:00:00 2001 From: zhangnaisong <2434969829@qq.com> Date: 星期一, 05 八月 2024 11:01:01 +0800 Subject: [PATCH] 电磁锁加入使能修改及判断提交 --- ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockProcessLogService.java | 2 ard-work/src/main/java/com/ruoyi/sy/controller/ArdTankLockController.java | 8 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankWallTemporaryServiceImpl.java | 7 ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java | 4 ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java | 2 ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml | 19 ++ ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java | 178 +++++++++++++++++++ ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java | 297 -------------------------------- ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java | 8 9 files changed, 230 insertions(+), 295 deletions(-) diff --git a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdTankLockController.java b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdTankLockController.java index 1c46df5..8bb2520 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/controller/ArdTankLockController.java +++ b/ard-work/src/main/java/com/ruoyi/sy/controller/ArdTankLockController.java @@ -417,4 +417,12 @@ dataTable.setMsg("鏌ヨ鎴愬姛"); return dataTable; } + + @ApiOperation("淇敼鐢电閿佷娇鑳�") + @PreAuthorize("@ss.hasPermi('sy:lock:updateLockEnableByCarId')") + @Log(title = "鐢电閿�" , businessType = BusinessType.UPDATE) + @PutMapping("/updateLockEnableByCarId") + public AjaxResult updateLockEnableByCarId(@RequestBody Map<String,Object> para) { + return toAjax(ardTankLockService.updateLockEnableByCarId(para)); + } } diff --git a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java index 6771295..379e38c 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java +++ b/ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java @@ -86,297 +86,8 @@ ((ArdSyCarDayServiceImpl)SpringUtils.getBean("ardSyCarDayServiceImpl")).insertArdSyCarDay(carId);//鏂板杞﹁締涓婃姤鏃堕棿 Map<String,Object> result = ((ArdSyCarServiceImpl)SpringUtils.getBean("ardSyCarServiceImpl")).getArdSyCarAndDeptByCarId(carId);//鏌ヨ杞﹁締鍙婇儴闂� if(result != null){ - //娓呮筏寮�濮�---------- - /*try{ - String lng = (String) gpsMap.get("lng").toString();//鑾峰彇缁忓害 - String lat = (String) gpsMap.get("lat").toString();//鑾峰彇绾害 - String carName = (String) gpsMap.get("carName");//鑾峰彇杞︾墝鍙� - String time = (String) gpsMap.get("time");//瀹氫綅鏃堕棿 - //鏃堕棿鐘舵�� - Boolean timeType = true; - if(time==null || time == ""){ - timeType = false; - } - String deptNum = (String) result.get("deptId").toString();//鑾峰彇閮ㄩ棬ID - String deptName = (String) result.get("deptName");//鑾峰彇閮ㄩ棬鍚嶇О - String carModel = (String) result.get("carModel");//鑾峰彇杞﹁締妯″瀷 - Integer drct = (Integer) gpsMap.get("drct");//鑾峰彇杞﹁締妯″瀷 - Integer speed = (Integer) gpsMap.get("speed");//杞﹂�� - String reserved = (String) result.get("reserved_1");//rtu鍏宠仈 - //rtu鏍囪瘑 - boolean rtuType = true; - if(reserved==null || reserved==""){ - //鏃犻攣 - rtuType = false; - } - //log.debug("瀹氫綅鏁版嵁锛氳溅杈哻arId:"+carId+"缁忓害lng:"+lng+"绾害lat:"+lat); - //瀹氫箟2缁寸┖闂� - Point2D.Double point = new Point2D.Double(Double.parseDouble(lng), Double.parseDouble(lat)); - List<Point2D.Double> pts = new ArrayList<Point2D.Double>(); - //娉ㄥ叆甯﹂攣杞﹁締Bean - ArdAccessFenceService ardAccessFenceService = SpringUtils.getBean(ArdAccessFenceService.class); - //娉ㄥ叆娌圭偣鍥存爮Bean - ArdOilWallService ardOilWallService = SpringUtils.getBean(ArdOilWallService.class); - //娉ㄥ叆鎶ヨ璁℃暟Bean - ArdAccessNumService accessNumService = SpringUtils.getBean(ArdAccessNumService.class); - //娉ㄥ叆鐢靛瓙閿丅ean - ArdSyCarRtuService carRtuService = SpringUtils.getBean(ArdSyCarRtuService.class); - //娉ㄥ叆閿丅ean - ArdSyCarLockService lockService = SpringUtils.getBean(ArdSyCarLockService.class); - //鏌ヨ瀹氫綅娌硅溅琛ㄤ腑鏄惁鏈夎杞﹁締 - ArdAccessFence ardAccessFence = ardAccessFenceService.queryAccess(carId); - //鏌ヨ鎵�鏈夎娌圭偣鍥存爮 - List<ArdOilWall> ardOilWalls = ardOilWallService.accessAll(); - //鏃ユ湡鏍煎紡 - SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss"); - //濡傛灉娌℃湁璇存槑杞﹁締鏈繘鍏ヨ娌圭偣锛岄渶瑕佸尮閰嶆墍鏈夎娌圭偣鍥存爮 - if(ardAccessFence==null){ - //杞﹁締鏈繘鍏ヨ娌圭偣 - for (int i = 0; i < ardOilWalls.size(); i++) { - pts.clear(); - ArdOilWall ardOilWall = ardOilWalls.get(i); - String[] coord = ardOilWall.getCoord().split(","); - for (int j = 0; j < coord.length; j = j + 3) { - pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j+1]))); - } - if(GeoTools.IsPtInPoly(point, pts)){ - //杩涘叆瑁呮补鐐瑰叆搴� - ArdAccessFence ardAccessFence1 = new ArdAccessFence(); - ardAccessFence1.setId(String.valueOf(UUID.randomUUID())); - ardAccessFence1.setCarId(carId); - ardAccessFence1.setCarName(carName); - ardAccessFence1.setDeptId(deptNum); - ardAccessFence1.setDeptName(deptName); - ardAccessFence1.setIntoShipmentId(ardOilWall.getId()); - ardAccessFence1.setIntoShipmentTime(time); - ardAccessFence1.setLng(lng); - ardAccessFence1.setLat(lat); - ardAccessFence1.setLastTime(time); - ardAccessFence1.setNowWallName("杩涘叆瑁呮补鐐癸細"+ardOilWall.getName()); - ardAccessFence1.setCarModel(carModel); - ardAccessFence1.setIsWarning(0); - ardAccessFence1.setDrct(drct); - ardAccessFence1.setIsAlarm(0); - ardAccessFenceService.access(ardAccessFence1); - if(rtuType){ - //mqtt鍙戦�佹棦瀹歊tu鐘舵�� - feng(carId,"瑁呮补鐐�",carRtuService,lockService); - break; - } - } - } - }else { - //杞﹂�熸爣璁� - Boolean stop = true; - //鍒ゆ柇杞﹂�� - if(rtuType){ - if(speed>5){ - //mqtt鍙戦�佹棦瀹歊tu鐘舵�� - feng(carId,"鏂藉皝",carRtuService,lockService); - stop = false; - } - } - //杞﹁締鏈夊�间紭鍏堝垽鏂槸鍚︿负鎵嬪姩娣诲姞杞﹁締 - if(ardAccessFence.getIsAlarm() == 0 || ardAccessFence.getIsAlarm() == null){ - //杞﹁締闈炴墜鍔ㄦ坊鍔犳暟鎹紝鍒ゆ柇鏄惁鏈夎繘鍏ュ洿鏍廔D - if(ardAccessFence.getIntoShipmentId()==null){ - //娌℃湁杩涘叆瑁呮补鐐癸紝璧嬪�肩粡绾害 - ardAccessFence.setLng(lng); - ardAccessFence.setLat(lat); - //鍒ゆ柇鏄惁杩涘叆瑁呮补鐐瑰洿鏍� - for (int i = 0; i < ardOilWalls.size(); i++) { - pts.clear(); - ArdOilWall ardOilWall = ardOilWalls.get(i); - String[] coord = ardOilWall.getCoord().split(","); - for (int j = 0; j < coord.length; j = j + 3) { - pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j+1]))); - } - if(GeoTools.IsPtInPoly(point, pts)){ - //杩涘叆瑁呮补鐐瑰叆搴� - ardAccessFence.setIntoShipmentId(ardOilWall.getId()); - ardAccessFence.setIntoShipmentTime(time); - ardAccessFence.setNowWallName("杩涘叆瑁呮补鐐癸細"+ardOilWall.getName()); - ardAccessFence.setLastTime(time); - if(rtuType){ - if(stop){ - //mqtt鍙戦�佹棦瀹歊tu鐘舵�� - feng(carId,"瑁呮补鐐�",carRtuService,lockService); - } - } - break; - } - } - ardAccessFenceService.updAccess(ardAccessFence); - }else { - //濡傛灉鏈夎繘鍏ュ洿鏍廔D锛屽垽鏂槸鍚﹀紑鍑鸿娌圭偣 - String out = ardAccessFence.getOutShipmentId(); - //鍑鸿娌圭偣ID涓虹┖ - if(out == null){ - //杞﹁締鏈紑鍑鸿娌圭偣,鍒ゆ柇鏄惁寮�鍑鸿娌圭偣 - String into = ardAccessFence.getIntoShipmentId(); - ArdOilWall ardOilWall = ardOilWallService.one(into); - pts.clear(); - String[] coord = ardOilWall.getCoord().split(","); - for (int j = 0; j < coord.length; j = j + 3) { - pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j + 1]))); - } - if (!GeoTools.IsPtInPoly(point, pts)) { - //杞﹁締寮�鍑鸿娌圭偣 - ardAccessFence.setOutShipmentId(into); - ardAccessFence.setOutShipmentTime(time); - ardAccessFence.setNowWallName("寮�鍑鸿娌圭偣锛�"+ardOilWall.getName()); - ardAccessFence.setLastTime(time); - ardAccessFence.setLng(lng); - ardAccessFence.setLat(lat); - ardAccessFenceService.updAccess(ardAccessFence); - if(rtuType){ - //寮�鍑鸿娌圭偣鍥存爮锛屽彂閫佷笂閿佸強鏂藉皝鍛戒护 - feng(carId,"鏂藉皝",carRtuService,lockService); - } - } - }else { - //杞﹁締宸茬粡寮�鍑鸿娌圭偣锛屾煡鐪嬫槸鍚︽湁鍗告补鐐笽D - String unload = ardAccessFence.getIntoUnloadId(); - //濡傛灉unload涓虹┖锛屽垽鏂槸鍚﹁繘鍏ュ嵏娌圭偣 - if (unload == null) { - //杞﹁締鏈繘鍏ュ嵏娌圭偣 - List<ArdOilWall> ardOilWallUpload = ardOilWallService.uploadAll(); - //鏄惁鍦ㄨ矾涓� - Boolean isRoad = true; - //鍒ゆ柇鏄惁杩涘幓鍗告补鐐� - for (int i = 0; i < ardOilWallUpload.size(); i++) { - pts.clear(); - ArdOilWall ardOilWall = ardOilWallUpload.get(i); - String[] coord = ardOilWall.getCoord().split(","); - for (int j = 0; j < coord.length; j = j + 3) { - pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j + 1]))); - } - if (GeoTools.IsPtInPoly(point, pts)) { - //杩涘叆鍗告补鐐�,瀛樺叆鍗告补鐐瑰洿鏍廔D - ardAccessFence.setIntoUnloadId(ardOilWall.getId()); - ardAccessFence.setIntoUnloadTime(time); - ardAccessFence.setLng(lng); - ardAccessFence.setLat(lat); - ardAccessFence.setNowWallName("杩涘叆鍗告补鐐癸細"+ardOilWall.getName()); - ardAccessFence.setLastTime(time); - ardAccessFenceService.updAccess(ardAccessFence); - //宸茬粡杩涘叆鍗告补鐐癸紝涓嶅湪璺笂涓嶉渶瑕佸仠杞︽姤璀� - isRoad = false; - if(rtuType){ - if(stop){ - //mqtt鍙戦�佹棦瀹歊tu鐘舵�� - feng(carId,"鍗告补鐐�",carRtuService,lockService); - } - } - break; - } - } - //涓嶅湪鍗告补鐐瑰氨鏄湪璺笂 - if(isRoad){ - //鎵�鍦ㄥ洿鏍忓悕绉拌祴null - ardAccessFence.setNowWallName("鍦ㄨ矾涓�"); - //濡傛灉鍦ㄨ矾涓婂垽鏂潗鏍囨槸鍚︿笌涓婃涓�鏍� - if(ardAccessFence.getLng().equals(lng) && ardAccessFence.getLat().equals(lat)){ - if(ardAccessFence.getLastTime()!=null){ - if(timeType){ - //濡傛灉鍧愭爣涓�鏍风浉鍑� - Date nowTime = sdf.parse(time); - Date lastTime = sdf.parse(ardAccessFence.getLastTime()); - Long diff = (nowTime.getTime() - lastTime.getTime())/1000; - ArdAccessNum list = accessNumService.queryNum(); - if(list!=null){ - int alarm = list.getAlarm(); - if(diff>=alarm){ - ardAccessFence.setIsWarning(1); - ardAccessFence.setAlarmLat(lat); - ardAccessFence.setAlarmLng(lng); - ardAccessFenceService.updAccess(ardAccessFence); - } - } - }else { - log.debug(carId+"鍙疯溅瀹氫綅鏃堕棿涓虹┖"); - } - }else { - ardAccessFence.setLastTime(time); - ardAccessFenceService.updAccess(ardAccessFence); - } - }else { - //濡傛灉涓嶄竴鏍锋洿鏂板潗鏍� - ardAccessFence.setLat(lat); - ardAccessFence.setLng(lng); - ardAccessFence.setLastTime(time); - ardAccessFenceService.updAccess(ardAccessFence); - } - } - }else { - //杞﹁締宸茬粡杩涘叆鍗告补鐐癸紝鍒ゆ柇鏄惁宸茬粡寮�鍑哄嵏娌圭偣 - ArdOilWall ardOilWall = ardOilWallService.one(unload); - pts.clear(); - String[] coord = ardOilWall.getCoord().split(","); - for (int j = 0; j < coord.length; j = j + 3) { - pts.add(new Point2D.Double(Double.parseDouble(coord[j]), Double.parseDouble(coord[j + 1]))); - } - if (!GeoTools.IsPtInPoly(point, pts)) { - if(rtuType){ - //寮�鍑轰簡鍗告补鐐瑰洿鏍忥紝鍙戦�佷笂閿佸強鏂借В灏佹寚浠� - feng(carId,"鏂藉皝",carRtuService,lockService); - } - //鍒犻櫎璇ユ潯杞﹁締鏁版嵁 - ardAccessFenceService.delAccess(carId); - }else { - //鏈紑鍑哄嵏娌圭偣锛屾洿鏂扮粡绾害淇濆瓨 - ardAccessFence.setLng(lng); - ardAccessFence.setLat(lat); - ardAccessFence.setLastTime(time); - ardAccessFenceService.updAccess(ardAccessFence); - } - } - } - } - }else - if(ardAccessFence.getIsAlarm()==1){ - //1涓烘墜鍔ㄦ坊鍔犺溅杈嗘棤闇�鎶ヨ淇℃伅锛屾洿鏂颁綅缃嵆鍙� - ardAccessFence.setLng(lng); - ardAccessFence.setLat(lat); - ardAccessFenceService.updAccess(ardAccessFence); - }else if(ardAccessFence.getIsAlarm() == 2){ - //2涓烘墜鍔ㄦ坊鍔犳姤璀﹁溅杈嗘湁鎶ヨ锛屾墍鍦ㄥ洿鏍忓悕绉拌祴null,鎺掓煡鎶ヨ淇℃伅,鍙渶澶勭悊璺笂鎯呭喌 - ardAccessFence.setNowWallName(null); - //濡傛灉鍦ㄨ矾涓婂垽鏂潗鏍囨槸鍚︿笌涓婃涓�鏍� - if(ardAccessFence.getLng().equals(lng) && ardAccessFence.getLat().equals(lat)){ - if(timeType){ - Date nowTime = sdf.parse(time); - Date lastTime = sdf.parse(ardAccessFence.getLastTime()); - Long diff = (nowTime.getTime() - lastTime.getTime())/1000; - ArdAccessNum list = accessNumService.queryNum(); - if(list!=null){ - int alarm = list.getAlarm(); - if(diff>=alarm){ - //鎶ヨ瀛楁涓�1鎻愮ず鎶ヨ - ardAccessFence.setIsWarning(1); - ardAccessFence.setAlarmLat(lat); - ardAccessFence.setAlarmLng(lng); - ardAccessFenceService.updAccess(ardAccessFence); - } - } - }else { - log.debug(carId+"鍙疯溅瀹氫綅鏃堕棿涓虹┖"); - } - }else { - //濡傛灉涓嶄竴鏍锋洿鏂板潗鏍� - ardAccessFence.setLat(lat); - ardAccessFence.setLng(lng); - ardAccessFence.setLastTime(time); - ardAccessFenceService.updAccess(ardAccessFence); - } - } - } - //娓呮筏缁撴潫------------ - }catch(Exception e){ - }*/ - - if(PositionContainer.getTankCarParkingAlarmTHread().get(carId) == null){ + if(PositionContainer.getTankCarParkingAlarmTHread().get(carId) == null){//寮傚父鍋滆溅绾跨▼ Thread tankCarParkingAlarmThread = new Thread(){//鍒涘缓绾跨▼鍒ゆ柇缃愯溅寮傚父鍋滆溅鎶ヨ @Override public void run() { @@ -388,13 +99,13 @@ } - /*Thread autoProcessThread = new Thread(){//鑷姩鎿嶆帶绾跨▼ + Thread autoProcessThread = new Thread(){//鑷姩鎿嶆帶绾跨▼ @Override public void run() { - ((ArdTankLockProcessLogServiceImpl)SpringUtils.getBean("ardTankLockProcessLogServiceImpl")).autoProcessArdTankLockByLockId(ip, userId, password, gpsMap); + ((ArdTankLockProcessLogServiceImpl)SpringUtils.getBean("ardTankLockProcessLogServiceImpl")).autoProcessArdTankLockByLockId(gpsMap); } }; - autoProcessThread.start();*/ + autoProcessThread.start(); gpsMap.putAll(result); String ancestors = (String) gpsMap.get("ancestors");//鑾峰彇鐖剁骇閮ㄩ棬 diff --git a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java index 37c074f..724c442 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java +++ b/ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java @@ -89,4 +89,8 @@ public List<ArdTankLock> getArdTankLockAllWithState(); public Long getArdTankLockCount(); + + public List<ArdTankLock> getArdTankLockWithStateByCarId(String carId); + + public int updateLockEnableByCarId(@Param("carId")String carId, @Param("enable") String enable); } diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockProcessLogService.java b/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockProcessLogService.java index bc4ee17..713604a 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockProcessLogService.java +++ b/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockProcessLogService.java @@ -63,4 +63,6 @@ public int deleteArdTankLockProcessLogById(String id); public AjaxResult processArdTankLockByLockId(String userId, String username, Map<String,String> para); + + public void autoProcessArdTankLockByLockId(Map<String,Object> gpsMap); } diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java b/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java index 2803f8f..58d7e72 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java +++ b/ard-work/src/main/java/com/ruoyi/sy/service/IArdTankLockService.java @@ -83,5 +83,7 @@ public Long getArdTankLockCount(); + public int updateLockEnableByCarId(Map<String,Object> para); + //public void getAlarm(String syUserId,String syPassword); } diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java index ed6a975..14c3c3c 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java +++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java @@ -21,6 +21,7 @@ import okhttp3.Response; import org.apache.commons.codec.digest.DigestUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import com.ruoyi.common.utils.StringUtils; @@ -56,7 +57,16 @@ private ArdTankWallTemporaryMapper ardTankWallTemporaryMapper; @Resource + private ArdTankLockAutoProcessLogMapper ardTankLockAutoProcessLogMapper; + + @Resource private SYClient sYClient; + + @Value("${syCar.userId}") + private String userId; + + @Value("${syCar.password}") + private String password; private SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); @@ -274,6 +284,174 @@ } } + @Override + public void autoProcessArdTankLockByLockId(Map<String, Object> gpsMap) { + List<SysConfig> syURLResult = sysConfigMapper.selectByType("syCarPT"); + String syURL = ""; + if(syURLResult.size() != 0){ + syURL = syURLResult.get(0).getConfigValue(); + }else{ + return; + } + + List<SysConfig> electromagneticLockVelocityResult = sysConfigMapper.selectByType("ElectromagneticLockVelocity"); + Integer electromagneticLockVelocity = 5; + if(!electromagneticLockVelocityResult.isEmpty()){ + electromagneticLockVelocity = Integer.parseInt(electromagneticLockVelocityResult.get(0).getConfigValue()); + } + List<ArdTankLock> ardTankLockResult = ardTankLockMapper.getArdTankLockWithStateByCarId((String) gpsMap.get("carId")); + if(ardTankLockResult.isEmpty()){//闈炵綈杞� + return; + } + + for(ArdTankLock ardTankLock : ardTankLockResult){ + if(!Boolean.valueOf(ardTankLock.getEnable())){ + return;//鏄兘涓篺alse锛屽浜庝笉鍙楁帶鐘舵�� + } + } + + Integer speed = (Integer) gpsMap.get("speed"); + if(speed >= electromagneticLockVelocity){ + for(ArdTankLock ardTankLock : ardTankLockResult){ + ArdTankLockState ardTankLockState = ardTankLock.getArdTankLockState(); + if(ardTankLockState != null){ + if(ardTankLockState.getLockState().equals("寮�閿佺姸鎬�")){ + String lockNum = ardTankLock.getLockNum(); + if(PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum) == null){ + String lockNumHead = lockNum.substring(0,2); + String lockNumTail = lockNum.substring(2,4); + String checkNum = Integer.toHexString(Integer.parseInt(lockNumHead, 16)//閿佺紪鍙烽珮8浣� + + Integer.parseInt(lockNumTail, 16)//閿佺紪鍙蜂綆8浣� + + Integer.parseInt("02", 16)//璁剧疆閿佽姱鐘舵�佸姛鑳界爜02 + + Integer.parseInt("02", 16));//鎿嶄綔 + if(checkNum.length() == 1){ + checkNum = "0" + checkNum; + } + if(checkNum.length() > 2){ + checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length()); + } + + String paramsStr = lockNum + "02" + "02" + checkNum; + paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + paramsStr + "%22%7D"; + PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒 + //String syURL = "http://" + ip + ":9999"; + String passwordMd5 = DigestUtils.md5Hex(password); + Map<String, Object> LogInResult = sYClient.logIn(syURL, passwordMd5, userId); + String sessionId = (String) LogInResult.get("sessionId"); + try{ + Map<String,Object> result = sendCmd(syURL, userId, (String) gpsMap.get("carId"), 199, "DataDownTransfer", paramsStr, sessionId); + if(((String)result.get("rspCode")).equals("0")){ + ArdTankLockAutoProcessLog ardTankLockAutoProcessLog = new ArdTankLockAutoProcessLog(); + ardTankLockAutoProcessLog.setId(IdUtils.simpleUUID()); + ardTankLockAutoProcessLog.setLockId(ardTankLock.getId()); + ardTankLockAutoProcessLog.setLockNum(ardTankLock.getLockNum()); + ardTankLockAutoProcessLog.setCarId(ardTankLock.getCarId()); + ardTankLockAutoProcessLog.setCarPlate((String) gpsMap.get("carName")); + ardTankLockAutoProcessLog.setWallName("瓒呴��"); + ardTankLockAutoProcessLog.setWallType("姘镐箙"); + ardTankLockAutoProcessLog.setProcess("鍏冲姩浣�"); + ardTankLockAutoProcessLog.setProcessReason("閫熷害澶т簬" + electromagneticLockVelocity +",瓒呴�熷叧閿�"); + ardTankLockAutoProcessLog.setLongitude(String.valueOf(gpsMap.get("lng"))); + ardTankLockAutoProcessLog.setLatitude(String.valueOf(gpsMap.get("lat"))); + ardTankLockAutoProcessLog.setVelocity(String.valueOf(gpsMap.get("speed"))); + ardTankLockAutoProcessLog.setProcessTime(this.sdf.format(new Date())); + ardTankLockAutoProcessLogMapper.insertArdTankLockAutoProcessLog(ardTankLockAutoProcessLog); + } + }catch(Exception e){ + + } + PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).remove("lockProcess");//绉婚櫎瀹瑰櫒 + }else{ + continue; + } + }else{ + continue; + } + }else{ + continue; + } + } + }else{ + //涓存椂鐢靛瓙鍥存爮閫昏緫 + List<ArdTankWallTemporary> ardTankWallTemporaryList = ardTankWallTemporaryMapper.getArdTankWallTemporaryByCarId((String) gpsMap.get("carId")); + //Boolean flag = true;//杞﹁締澶勪簬浠绘剰涓存椂鐢靛瓙鍥存爮锛屽氨灏嗘爣璁拌涓篺alse + if(!ardTankWallTemporaryList.isEmpty()){ + for(ArdTankWallTemporary ardTankWallTemporary : ardTankWallTemporaryList){ + Double longitude = ardTankWallTemporary.getLongitude(); + Double latitude = ardTankWallTemporary.getLatitude(); + Integer distance = ardTankWallTemporary.getDistance(); + + Double[] From = new Double[]{longitude,latitude}; + Double[] To = new Double[]{((Number) gpsMap.get("lng")).doubleValue(),((Number) gpsMap.get("lat")).doubleValue()}; + Number realDistance = GisUtil.getDistance(From,To); + if(realDistance.intValue() <= distance){//瀹為檯璺濈灏忎簬鍗婂緞 + for(ArdTankLock ardTankLock : ardTankLockResult){ + ArdTankLockState ardTankLockState = ardTankLock.getArdTankLockState(); + if(ardTankLockState != null){ + if(ardTankLockState.getLockState().equals("鍏抽攣鐘舵��")){ + String lockNum = ardTankLock.getLockNum(); + if(PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).get("lockProcess") == null){ + String lockNumHead = lockNum.substring(0,2); + String lockNumTail = lockNum.substring(2,4); + String checkNum = Integer.toHexString(Integer.parseInt(lockNumHead, 16)//閿佺紪鍙烽珮8浣� + + Integer.parseInt(lockNumTail, 16)//閿佺紪鍙蜂綆8浣� + + Integer.parseInt("02", 16)//璁剧疆閿佽姱鐘舵�佸姛鑳界爜02 + + Integer.parseInt("01", 16));//鎿嶄綔 + if(checkNum.length() == 1){ + checkNum = "0" + checkNum; + } + if(checkNum.length() > 2){ + checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length()); + } + + String paramsStr = lockNum + "02" + "01" + checkNum; + paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + paramsStr + "%22%7D"; + PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒 + String passwordMd5 = DigestUtils.md5Hex(password); + Map<String, Object> LogInResult = sYClient.logIn(syURL, passwordMd5, userId); + String sessionId = (String) LogInResult.get("sessionId"); + try{ + Map<String,Object> result = sendCmd(syURL, userId, (String) gpsMap.get("carId"), 199, "DataDownTransfer", paramsStr, sessionId); + if(((String)result.get("rspCode")).equals("0")){ + ArdTankLockAutoProcessLog ardTankLockAutoProcessLog = new ArdTankLockAutoProcessLog(); + ardTankLockAutoProcessLog.setId(IdUtils.simpleUUID()); + ardTankLockAutoProcessLog.setLockId(ardTankLock.getId()); + ardTankLockAutoProcessLog.setLockNum(ardTankLock.getLockNum()); + ardTankLockAutoProcessLog.setCarId(ardTankLock.getCarId()); + ardTankLockAutoProcessLog.setCarPlate((String) gpsMap.get("carName")); + ardTankLockAutoProcessLog.setWallId(ardTankWallTemporary.getId()); + ardTankLockAutoProcessLog.setWallName(ardTankWallTemporary.getWallName()); + ardTankLockAutoProcessLog.setWallType("涓存椂"); + ardTankLockAutoProcessLog.setProcess("寮�鍔ㄤ綔"); + ardTankLockAutoProcessLog.setProcessReason("閫熷害灏忎簬" + electromagneticLockVelocity +",骞惰繘鍏ヤ复鏃剁數瀛愬洿鏍�'" + ardTankWallTemporary.getWallName() + "'" + ",寮�閿�"); + ardTankLockAutoProcessLog.setLongitude(String.valueOf(gpsMap.get("lng"))); + ardTankLockAutoProcessLog.setLatitude(String.valueOf(gpsMap.get("lat"))); + ardTankLockAutoProcessLog.setVelocity(String.valueOf(gpsMap.get("speed"))); + ardTankLockAutoProcessLog.setProcessTime(this.sdf.format(new Date())); + ardTankLockAutoProcessLogMapper.insertArdTankLockAutoProcessLog(ardTankLockAutoProcessLog); + } + }catch(Exception e){ + + } + PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).remove("lockProcess");//绉婚櫎瀹瑰櫒 + }else{ + continue; + } + }else{ + continue; + } + }else{ + continue; + } + } + } + } + } + //鐢靛瓙鍥存爮閫昏緫 + + } + } + public Map<String,Object> sendCmd(String syURL,String userId,String carId,Integer cmdId,String cmd,String paramsStr,String sessionId){ OkHttpClient okHttpClient = new OkHttpClient(); diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java index 95c3123..2120ab0 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java +++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockServiceImpl.java @@ -860,6 +860,14 @@ return result; } + @Override + public int updateLockEnableByCarId(Map<String, Object> para) { + String carId = (String) para.get("carId"); + String enable = String.valueOf((Boolean) para.get("enable")); + int result = ardTankLockMapper.updateLockEnableByCarId(carId, enable); + return result; + } + /*@Override public void getAlarm(String syUserId,String syPassword) { List<SysConfig> syURLResult = sysConfigMapper.selectByType("syCarPT"); diff --git a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankWallTemporaryServiceImpl.java b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankWallTemporaryServiceImpl.java index e288e1d..35f5587 100644 --- a/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankWallTemporaryServiceImpl.java +++ b/ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankWallTemporaryServiceImpl.java @@ -392,8 +392,11 @@ thread.start(); PositionContainer.getCarWallThreadMap().put((String) map.get("carId"), thread); }else{ - //蹇界暐瓒呮椂 - continue; + //瓒呮椂 + ArdTankWallTemporary ardTankWallTemporary = new ArdTankWallTemporary(); + ardTankWallTemporary.setId((String) map.get("id")); + ardTankWallTemporary.setProcessMark("-1");//-1涓哄埌鏈� + ardTankWallTemporaryMapper.updateArdTankWallTemporary(ardTankWallTemporary); } } }catch (Exception e){ diff --git a/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml b/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml index ef81f55..0a21a5e 100644 --- a/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml +++ b/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml @@ -271,4 +271,23 @@ <select id="getArdTankLockCount" resultType="java.lang.Long" > select count(*) from ard_tank_lock </select> + + <select id="getArdTankLockWithStateByCarId" resultMap="ArdTankLockWithStateResult" > + select t.id,t.lock_num,t.lock_name,t.img_position_top,t.img_position_left, + t.car_id,t.enable,t.restart_state,t.online_time,t.sid,t.lock_id,t.slock_num, + t.lock_state,t.lock_position_state,t.lock_shell_state,t.srestart_state, + t.batter_voltage,t.power_voltage,t.upload_time,t.unique_mark from ( + select atl.*,atls.id as sid,atls.lock_id,atls.lock_num as slock_num,atls.lock_state, + atls.lock_position_state,atls.lock_shell_state,atls.restart_state as srestart_state, + atls.batter_voltage,atls.power_voltage,atls.upload_time,atls.unique_mark, + rank() over(partition by atl.lock_num,atl.online_time order by atls.upload_time desc) rn + from ard_tank_lock atl + left join ard_tank_lock_state atls on atl.lock_num = atls.lock_num + where atl.car_id = #{carId})t where t.rn = 1 + </select> + + <update id="updateLockEnableByCarId" parameterType="java.lang.String"> + update ard_tank_lock set enable = #{enable} + where car_id = #{carId} + </update> </mapper> \ No newline at end of file -- Gitblit v1.9.3