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 |  104 ++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 93 insertions(+), 11 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 00765d5..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
@@ -12,13 +12,17 @@
 import com.gps31.push.netty.PushMsg;
 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>
@@ -64,13 +68,91 @@
 
         }else if("8003".equals(pushMsg.getCmd())){//璁㈤槄鍔ㄦ�佹秷鎭簲绛�
             String rspResult = MapUtil.getStrVal(pushMsg.getJsonMap(),"rspResult","1");
-            log.error(String.format("    璁㈤槄搴旂瓟:%s", "0".equals(rspResult)?"鎴愬姛":"澶辫触"));
+            //log.error(String.format("    璁㈤槄搴旂瓟:%s", "0".equals(rspResult)?"鎴愬姛":"澶辫触"));
         }else if("0200".equals(pushMsg.getCmd())) {//瀹氫綅淇℃伅
             Map<String,Object> gpsMap = pushMsg.getJsonMap();
-            String carName = MapUtil.getStrVal(gpsMap, "carName","");//鑾峰彇杞︾墝鍙�
+            /*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(",");
+                if(ancestorsArray.length == 1){//鏈�楂樼骇閮ㄩ棬
+                    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);
+                    }
+                }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);
+                    }
+                    //鍔犲叆鐖剁骇閮ㄩ棬瀹瑰櫒
+                    for(int i = 1;i <= ancestorsArray.length - 1;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);
+                        }
+                    }
+                }
+                //瀛樺叆鐢ㄦ埛瀹瑰櫒
+                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);
+                            }
+                        }
+                    }
+                }
+            }
             /**
              *
              * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
@@ -79,7 +161,7 @@
         }else if("0300".equals(pushMsg.getCmd())) {//鎶ヨ娑堟伅
             Map<String,Object> alarmMap = pushMsg.getJsonMap();
             String carName = MapUtil.getStrVal(alarmMap, "carName","");//鑾峰彇杞︾墝鍙�
-            log.error(String.format("   ---->鏀跺埌鎶ヨ鏁版嵁:%s",JSON.toJSONString(alarmMap)));
+            //log.error(String.format("   ---->鏀跺埌鎶ヨ鏁版嵁:%s",JSON.toJSONString(alarmMap)));
             /**
              *
              * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
@@ -88,7 +170,7 @@
         }else if("0401".equals(pushMsg.getCmd())) {//閫忎紶娑堟伅
             Map<String,Object> dataMap = pushMsg.getJsonMap();
             String carName = MapUtil.getStrVal(dataMap, "carName","");//鑾峰彇杞︾墝鍙�
-            log.error(String.format("   ---->鏀跺埌閫忎紶鏁版嵁:%s",JSON.toJSONString(dataMap)));
+            //log.error(String.format("   ---->鏀跺埌閫忎紶鏁版嵁:%s",JSON.toJSONString(dataMap)));
             /**
              *
              * 璇峰姞鍏ヤ笁鏂归泦鎴愭柟鐨勪笟鍔¢�昏緫
@@ -100,7 +182,7 @@
     public void sendMassage() {
         try {
             PushClientImplPosition client = new PushClientImplPosition();
-            client.setLog(true);//鏄惁鎵撳嵃鏄庢枃
+            client.setLog(false);//鏄惁鎵撳嵃鏄庢枃
             client.setHost(this.ip);//鏈嶅姟鍣↖P
             client.setPort(10100);//鏈嶅姟鍣ㄧ鍙�
             client.setUserName(this.userId);//绯荤粺鐢ㄦ埛鍚�

--
Gitblit v1.9.3