From b3dbfe5ab42efc7e744df5a391a8568e1b7c2289 Mon Sep 17 00:00:00 2001 From: zhangnaisong <2434969829@qq.com> Date: 星期五, 16 二月 2024 17:06:18 +0800 Subject: [PATCH] 无人机websocket客户端心跳保活提交 --- ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java | 74 +++++++++++++++++++++++++++++++++---- 1 files changed, 66 insertions(+), 8 deletions(-) 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 da4c163..83c365d 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 @@ -26,6 +26,7 @@ import org.eclipse.paho.client.mqttv3.MqttException; import java.awt.geom.Point2D; +import java.math.BigDecimal; import java.text.SimpleDateFormat; import java.util.*; @@ -85,8 +86,8 @@ ((ArdSyCarDayServiceImpl)SpringUtils.getBean("ardSyCarDayServiceImpl")).insertArdSyCarDay(carId);//鏂板杞﹁締涓婃姤鏃堕棿 Map<String,Object> result = ((ArdSyCarServiceImpl)SpringUtils.getBean("ardSyCarServiceImpl")).getArdSyCarAndDeptByCarId(carId);//鏌ヨ杞﹁締鍙婇儴闂� if(result != null){ -// if("30".equals(carId)){ - //娓呮筏寮�濮�---------- + //娓呮筏寮�濮�---------- + try{ String lng = (String) gpsMap.get("lng").toString();//鑾峰彇缁忓害 String lat = (String) gpsMap.get("lat").toString();//鑾峰彇绾害 String carName = (String) gpsMap.get("carName");//鑾峰彇杞︾墝鍙� @@ -108,7 +109,7 @@ //鏃犻攣 rtuType = false; } -// log.debug("瀹氫綅鏁版嵁锛氳溅杈哻arId:"+carId+"缁忓害lng:"+lng+"绾害lat:"+lat); + // 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>(); @@ -368,11 +369,13 @@ } } } -// } - } - //娓呮筏缁撴潫------------ + } + //娓呮筏缁撴潫------------ + }catch(Exception e){ - /*gpsMap.putAll(result); + } + + gpsMap.putAll(result); String ancestors = (String) gpsMap.get("ancestors");//鑾峰彇鐖剁骇閮ㄩ棬 String[] ancestorsArray = ancestors.split(","); if(ancestorsArray.length == 1){//鏈�楂樼骇閮ㄩ棬 @@ -408,7 +411,31 @@ deptMapp.put((String)gpsMap.get("carId"),gpsMap); } } - }*/ + } + //鑻ユ湁鐢ㄦ埛闇�瑕佽拷韪溅杈嗭紝鍒欒绠楅浼颁綅缃� + if(PositionContainer.getUserPositionMap().size() != 0){ + for(String userId : PositionContainer.getUserPositionMap().keySet()){ + Map<String,Map<String,Object>> carIdCarMap = PositionContainer.getUserPositionMap().get(userId); + if(carIdCarMap != null){ + if(carIdCarMap.keySet().contains(carId)){ + if(PositionContainer.getCarPositionMap().get(carId) == null){ + gpsMap.put("elng",gpsMap.get("lng")); + gpsMap.put("elat",gpsMap.get("lat")); + }else{ + Double velocityOld = ((Integer) PositionContainer.getCarPositionMap().get(carId).get("speed")).doubleValue(); + Double velocityNew = ((Integer) gpsMap.get("speed")).doubleValue(); + Double acceleration = Double.valueOf(1000*(velocityNew - velocityOld)/3600); + Double distance = getDistance(velocityNew, acceleration ,"1.5"); + Double[] eposition = azimuth_offset(((BigDecimal)gpsMap.get("lng")).doubleValue(),((BigDecimal)gpsMap.get("lat")).doubleValue(),(Integer)gpsMap.get("drct"),distance); + gpsMap.put("elng",eposition[0]); + gpsMap.put("elat",eposition[1]); + } + } + } + } + } + //瀛樺叆瀹炴椂浣嶇疆瀹瑰櫒 + PositionContainer.getCarPositionMap().put(carId,gpsMap); //瀛樺叆鐢ㄦ埛瀹瑰櫒 if(PositionContainer.getUserPositionMap().size() != 0){ for(String userId : PositionContainer.getUserPositionMap().keySet()){ @@ -568,4 +595,35 @@ } } } + + public Double[] azimuth_offset(double origin_lon, double origin_lat, Integer direction,double distance){ + Double[] lonlat = new Double[2]; + if(direction != null && distance > 0){ + lonlat[0] = origin_lon + distance * Math.sin(direction* Math.PI / 180) * 180 / ( Math.PI * 6371229 * Math.cos(origin_lat * Math.PI / 180)); + lonlat[1] = origin_lat + distance * Math.cos(direction* Math.PI / 180) / ( Math.PI * 6371229 / 180); + }else{ + lonlat[0] = origin_lon; + lonlat[1] = origin_lat; + } + return lonlat; + } + + public Double getDistance(Double velocity ,Double acceleration ,String time){ + Double distance = velocity*Double.parseDouble(time) + 0.5*acceleration*Double.parseDouble(time)*Double.parseDouble(time); + return distance; + } + + /*public Double getVelocity(Double velocity ,Double acceleration ,String time){ + SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); + Long t = (long) 0; + try { + t = (new Date().getTime() - simpleDateFormat.parse(time).getTime())/1000; + } catch (Exception e) { + // TODO Auto-generated catch block + e.printStackTrace(); + } + Double velocityt = velocity + acceleration*t; + return velocityt; + }*/ + } -- Gitblit v1.9.3