From cf695c6db30c07e2ea9783f31660936787f67eb9 Mon Sep 17 00:00:00 2001 From: aijinhui <aijinhui> Date: 星期六, 21 十月 2023 14:06:56 +0800 Subject: [PATCH] 推送入栏 --- ard-work/src/main/java/com/ruoyi/sy/gps31/PushClientImplPosition.java | 73 +++++++++++++++++++++++++++++------- 1 files changed, 59 insertions(+), 14 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 a08974d..cf6e07b 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 @@ -13,14 +13,16 @@ import com.gps31.push.netty.client.TcpClient; import com.gps31.push.util.MapUtil; import com.ruoyi.common.utils.spring.SpringUtils; +import com.ruoyi.sy.domain.ArdOilWall; +import com.ruoyi.sy.service.impl.ArdOilWallServiceImpl; +import com.ruoyi.sy.service.impl.ArdSyCarDayServiceImpl; import com.ruoyi.sy.service.impl.ArdSyCarServiceImpl; +import com.ruoyi.utils.gps.GeoTools; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; -import java.text.SimpleDateFormat; -import java.util.Date; -import java.util.HashMap; -import java.util.Map; +import java.awt.geom.Point2D; +import java.util.*; /** * <p>Description: </p> @@ -71,11 +73,37 @@ Map<String,Object> gpsMap = pushMsg.getJsonMap(); /*String carName = MapUtil.getStrVal(gpsMap, "carName","");//鑾峰彇杞︾墝鍙� SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); - System.out.println(sdf.format(new Date())); - log.error(String.format(" ---->鏀跺埌瀹氫綅鏁版嵁:%s",JSON.toJSONString(gpsMap)));*/ + System.out.println(sdf.format(new Date()));*/ +// log.error(String.format(" ---->鏀跺埌瀹氫綅鏁版嵁:%s",JSON.toJSONString(gpsMap))); String carId = (String)gpsMap.get("carId"); + ((ArdSyCarDayServiceImpl)SpringUtils.getBean("ardSyCarDayServiceImpl")).insertArdSyCarDay(carId);//鏂板杞﹁締涓婃姤鏃堕棿 Map<String,Object> result = ((ArdSyCarServiceImpl)SpringUtils.getBean("ardSyCarServiceImpl")).getArdSyCarAndDeptByCarId(carId);//鏌ヨ杞﹁締鍙婇儴闂� +// log.error("---------------------"+result); if(result != null){ + //娓呮筏瀹氫綅 + String lng = (String) gpsMap.get("lng");//鑾峰彇缁忓害 + String lat = (String) gpsMap.get("lat");//鑾峰彇绾害 + String carName = (String) gpsMap.get("carName");//鑾峰彇杞︾墝鍙� + String time = (String) gpsMap.get("result");//瀹氫綅鏃堕棿 + String deptNum = (String) result.get("deptId");//鑾峰彇閮ㄩ棬ID + String deptName = (String) result.get("deptName");//鑾峰彇閮ㄩ棬鍚嶇О + //瀹氫箟2缁寸┖闂� + Point2D.Double point = new Point2D.Double(Double.parseDouble(lng), Double.parseDouble(lat)); + List<Point2D.Double> pts = new ArrayList<Point2D.Double>(); + //鍖归厤鍏ㄩ儴鍥存爮 + List<ArdOilWall> ardOilWalls = ((ArdOilWallServiceImpl)SpringUtils.getBean("ArdOilWallServiceImpl")).all(); + 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)){ + //杩涘叆浜嗗洿鏍忓叆搴� + + } + } gpsMap.putAll(result); String ancestors = (String) gpsMap.get("ancestors");//鑾峰彇鐖剁骇閮ㄩ棬 String[] ancestorsArray = ancestors.split(","); @@ -84,27 +112,44 @@ Map<String,Map<String,Object>> deptMap = PositionContainer.getDeptPositionMap().get(deptId); if(deptMap == null){ deptMap = new HashMap(); + deptMap.put((String)gpsMap.get("carId"),gpsMap); + PositionContainer.getDeptPositionMap().put(deptId,deptMap); + }else{ + deptMap.put((String)gpsMap.get("carId"),gpsMap); } - deptMap.put((String)gpsMap.get("carId"),gpsMap);//棣栨鍔犲叆瀹瑰櫒锛屽啀娆″幓閲� - PositionContainer.getDeptPositionMap().put(deptId,deptMap); - }else{ + }else{//鍏朵粬閮ㄩ棬 //鍔犲叆鏈儴闂ㄥ鍣� String deptId = String.valueOf(gpsMap.get("deptId")); Map<String,Map<String,Object>> deptMap = PositionContainer.getDeptPositionMap().get(deptId); if(deptMap == null){ deptMap = new HashMap(); + deptMap.put((String)gpsMap.get("carId"),gpsMap); + PositionContainer.getDeptPositionMap().put(deptId,deptMap); + }else{ + deptMap.put((String)gpsMap.get("carId"),gpsMap); } - deptMap.put((String)gpsMap.get("carId"),gpsMap);//棣栨鍔犲叆瀹瑰櫒锛屽啀娆″幓閲� - PositionContainer.getDeptPositionMap().put(deptId,deptMap); //鍔犲叆鐖剁骇閮ㄩ棬瀹瑰櫒 for(int i = 1;i <= ancestorsArray.length - 1;i++){ - String deptIdp = String.valueOf(gpsMap.get(ancestorsArray[i])); + String deptIdp = ancestorsArray[i]; Map<String,Map<String,Object>> deptMapp = PositionContainer.getDeptPositionMap().get(deptIdp); if(deptMapp == null){ deptMapp = new HashMap(); + deptMapp.put((String)gpsMap.get("carId"),gpsMap); + PositionContainer.getDeptPositionMap().put(deptIdp,deptMapp); + }else{ + deptMapp.put((String)gpsMap.get("carId"),gpsMap); } - deptMapp.put((String)gpsMap.get("carId"),gpsMap);//棣栨鍔犲叆瀹瑰櫒锛屽啀娆″幓閲� - PositionContainer.getDeptPositionMap().put(deptIdp,deptMap); + } + } + //瀛樺叆鐢ㄦ埛瀹瑰櫒 + 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)){ + PositionContainer.getUserPositionMap().get(userId).put(carId,gpsMap); + } + } } } } -- Gitblit v1.9.3