From fb486d8c2447a9a18eb929d81094bfd46c78fe27 Mon Sep 17 00:00:00 2001
From: zhangnaisong <2434969829@qq.com>
Date: 星期二, 06 八月 2024 08:09:52 +0800
Subject: [PATCH] 电磁锁加入电子围栏自动开关提交

---
 ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankWallLock.java                        |   10 +
 ard-work/src/main/java/com/ruoyi/sy/mapper/ArdTankLockMapper.java                      |    2 
 ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankLock.java                            |   10 +
 ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml                            |   62 ++++++++++
 ard-work/src/main/java/com/ruoyi/sy/service/impl/ArdTankLockProcessLogServiceImpl.java |  258 ++++++++++++++++++++++++++++++++----------
 5 files changed, 281 insertions(+), 61 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankLock.java b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankLock.java
index d964901..f41d496 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankLock.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankLock.java
@@ -56,6 +56,8 @@
 
     private List<ArdTankLockPassword> ardTankLockPasswords;
 
+    private List<ArdTankWallLock> ardTankWallLockList;
+
     public void setId(String id) 
     {
         this.id = id;
@@ -154,6 +156,14 @@
         this.ardTankLockPasswords = ardTankLockPasswords;
     }
 
+    public List<ArdTankWallLock> getArdTankWallLockList() {
+        return ardTankWallLockList;
+    }
+
+    public void setArdTankWallLockList(List<ArdTankWallLock> ardTankWallLockList) {
+        this.ardTankWallLockList = ardTankWallLockList;
+    }
+
     @Override
     public String toString() {
         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)
diff --git a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankWallLock.java b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankWallLock.java
index 5ce2aba..70c8eae 100644
--- a/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankWallLock.java
+++ b/ard-work/src/main/java/com/ruoyi/sy/domain/ArdTankWallLock.java
@@ -30,6 +30,8 @@
     @Excel(name = "閿佷富閿�")
     private String lockId;
 
+    private ArdTankWall ardTankWall;
+
     public void setProcessType(String processType) 
     {
         this.processType = processType;
@@ -67,6 +69,14 @@
         return lockId;
     }
 
+    public ArdTankWall getArdTankWall() {
+        return ardTankWall;
+    }
+
+    public void setArdTankWall(ArdTankWall ardTankWall) {
+        this.ardTankWall = ardTankWall;
+    }
+
     @Override
     public String toString() {
         return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)
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 724c442..5e86eba 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
@@ -93,4 +93,6 @@
     public List<ArdTankLock> getArdTankLockWithStateByCarId(String carId);
 
     public int updateLockEnableByCarId(@Param("carId")String carId, @Param("enable") String enable);
+
+    public List<ArdTankLock> selectArdTankLockWithWallAndStateByCarId(String carId);
 }
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 14c3c3c..d1d5335 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
@@ -217,64 +217,69 @@
             return AjaxResult.error("褰撳墠杞﹁締姝e鍦ㄧ數瀛愬洿鏍忓");
         }else{
             try{
-                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(process, 16));//鎿嶄綔
-                if(checkNum.length() == 1){
-                    checkNum = "0" + checkNum;
-                }
-                if(checkNum.length() > 2){
-                    checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length());
-                }
-
-                String paramsStr = lockNum + "02" + process + checkNum;
-                paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + paramsStr + "%22%7D";
-                PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒
-                Map<String,Object> result = sendCmd(syURL, ardSyUser.getUserId(), carId, 199, "DataDownTransfer", paramsStr, sessionId);
-                PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).remove("lockProcess");//绉婚櫎瀹瑰櫒
-                if(((String)result.get("rspCode")).equals("0")){
-                    ArdTankLockProcessLog ardTankLockProcessLog = new ArdTankLockProcessLog();
-                    ardTankLockProcessLog.setId(IdUtils.simpleUUID());
-                    ardTankLockProcessLog.setLockId(lockId);
-                    ardTankLockProcessLog.setLockNum(lockNum);
-                    ardTankLockProcessLog.setCarId(carId);
-                    ardTankLockProcessLog.setCarPlate(carPlate);
-                    ardTankLockProcessLog.setUserId(userId);
-                    ardTankLockProcessLog.setUserName(username);
-                    if(process.equals("01")){
-                        ardTankLockProcessLog.setProcess("寮�鍔ㄤ綔");
-                    }else if(process.equals("02")){
-                        ardTankLockProcessLog.setProcess("鍏冲姩浣�");
+                if(PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).get("lockProcess") != null){
+                    PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒
+                    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(process, 16));//鎿嶄綔
+                    if(checkNum.length() == 1){
+                        checkNum = "0" + checkNum;
                     }
-                    ardTankLockProcessLog.setProcessReason(processReason);
-                    ardTankLockProcessLog.setLongitude(lng);
-                    ardTankLockProcessLog.setLatitude(lat);
-                    ardTankLockProcessLog.setProcessTime(this.sdf.format(new Date()));
-                    ardTankLockProcessLogMapper.insertArdTankLockProcessLog(ardTankLockProcessLog);
-                    return AjaxResult.success("鍙戦�佹垚鍔�");
-                }else if(((String)result.get("rspCode")).equals("-6")){
-                    return AjaxResult.error("鎵句笉鍒拌溅杈�");
-                }else if(((String)result.get("rspCode")).equals("-5")){
-                    return AjaxResult.error("鎵句笉鍒扮敤鎴�");
-                }else if(((String)result.get("rspCode")).equals("-4")){
-                    return AjaxResult.error("鎵句笉鍒版寚浠�");
-                }else if(((String)result.get("rspCode")).equals("-3")){
-                    return AjaxResult.error("鎸囦护鍙戦�佽秴鏃�");
-                }else if(((String)result.get("rspCode")).equals("-2")){
-                    return AjaxResult.error("绂荤嚎寰呭彂");
-                }else if(((String)result.get("rspCode")).equals("-1")){
-                    return AjaxResult.error("杞﹁締绂荤嚎");
-                }else if(((String)result.get("rspCode")).equals("1")){
-                    return AjaxResult.error("鍙戦�佸け璐�");
-                }else if(((String)result.get("rspCode")).equals("2")){
-                    return AjaxResult.error("娑堟伅鏈夎");
-                }else if(((String)result.get("rspCode")).equals("3")){
-                    return AjaxResult.error("涓嶆敮鎸�");
+                    if(checkNum.length() > 2){
+                        checkNum = checkNum.substring(checkNum.length() - 2,checkNum.length());
+                    }
+
+                    String paramsStr = lockNum + "02" + process + checkNum;
+                    paramsStr = "%7B%22type%22%3A%22ff%22%2C%22dataCnt%22%3A%22" + paramsStr + "%22%7D";
+                    //PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒
+                    Map<String,Object> result = sendCmd(syURL, ardSyUser.getUserId(), carId, 199, "DataDownTransfer", paramsStr, sessionId);
+                    PositionContainer.getCarLockProcessThreadMap().get(carId).get(lockNum).remove("lockProcess");//绉婚櫎瀹瑰櫒
+                    if(((String)result.get("rspCode")).equals("0")){
+                        ArdTankLockProcessLog ardTankLockProcessLog = new ArdTankLockProcessLog();
+                        ardTankLockProcessLog.setId(IdUtils.simpleUUID());
+                        ardTankLockProcessLog.setLockId(lockId);
+                        ardTankLockProcessLog.setLockNum(lockNum);
+                        ardTankLockProcessLog.setCarId(carId);
+                        ardTankLockProcessLog.setCarPlate(carPlate);
+                        ardTankLockProcessLog.setUserId(userId);
+                        ardTankLockProcessLog.setUserName(username);
+                        if(process.equals("01")){
+                            ardTankLockProcessLog.setProcess("寮�鍔ㄤ綔");
+                        }else if(process.equals("02")){
+                            ardTankLockProcessLog.setProcess("鍏冲姩浣�");
+                        }
+                        ardTankLockProcessLog.setProcessReason(processReason);
+                        ardTankLockProcessLog.setLongitude(lng);
+                        ardTankLockProcessLog.setLatitude(lat);
+                        ardTankLockProcessLog.setProcessTime(this.sdf.format(new Date()));
+                        ardTankLockProcessLogMapper.insertArdTankLockProcessLog(ardTankLockProcessLog);
+                        return AjaxResult.success("鍙戦�佹垚鍔�");
+                    }else if(((String)result.get("rspCode")).equals("-6")){
+                        return AjaxResult.error("鎵句笉鍒拌溅杈�");
+                    }else if(((String)result.get("rspCode")).equals("-5")){
+                        return AjaxResult.error("鎵句笉鍒扮敤鎴�");
+                    }else if(((String)result.get("rspCode")).equals("-4")){
+                        return AjaxResult.error("鎵句笉鍒版寚浠�");
+                    }else if(((String)result.get("rspCode")).equals("-3")){
+                        return AjaxResult.error("鎸囦护鍙戦�佽秴鏃�");
+                    }else if(((String)result.get("rspCode")).equals("-2")){
+                        return AjaxResult.error("绂荤嚎寰呭彂");
+                    }else if(((String)result.get("rspCode")).equals("-1")){
+                        return AjaxResult.error("杞﹁締绂荤嚎");
+                    }else if(((String)result.get("rspCode")).equals("1")){
+                        return AjaxResult.error("鍙戦�佸け璐�");
+                    }else if(((String)result.get("rspCode")).equals("2")){
+                        return AjaxResult.error("娑堟伅鏈夎");
+                    }else if(((String)result.get("rspCode")).equals("3")){
+                        return AjaxResult.error("涓嶆敮鎸�");
+                    }else{
+                        return AjaxResult.error("鍏朵粬鍘熷洜鍙戦�佸け璐�");
+                    }
                 }else{
-                    return AjaxResult.error("鍏朵粬鍘熷洜鍙戦�佸け璐�");
+                    return AjaxResult.error("鍏朵粬鎿嶆帶姝e湪杩涜涓�,璇风◢鍚�");
                 }
             }catch(Exception e){
                 e.printStackTrace();
@@ -315,9 +320,10 @@
             for(ArdTankLock ardTankLock : ardTankLockResult){
                 ArdTankLockState ardTankLockState = ardTankLock.getArdTankLockState();
                 if(ardTankLockState != null){
-                    if(ardTankLockState.getLockState().equals("寮�閿佺姸鎬�")){
+                    if(ardTankLockState.getLockState().equals("寮�閿佺姸鎬�") || ardTankLockState.getLockState().equals("寮傚父鐘舵��")){
                         String lockNum = ardTankLock.getLockNum();
                         if(PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum) == null){
+                            PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒
                             String lockNumHead = lockNum.substring(0,2);
                             String lockNumTail = lockNum.substring(2,4);
                             String checkNum = Integer.toHexString(Integer.parseInt(lockNumHead, 16)//閿佺紪鍙烽珮8浣�
@@ -333,8 +339,7 @@
 
                             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";
+                            //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");
@@ -388,9 +393,10 @@
                         for(ArdTankLock ardTankLock : ardTankLockResult){
                             ArdTankLockState ardTankLockState = ardTankLock.getArdTankLockState();
                             if(ardTankLockState != null){
-                                if(ardTankLockState.getLockState().equals("鍏抽攣鐘舵��")){
+                                if(ardTankLockState.getLockState().equals("鍏抽攣鐘舵��") || ardTankLockState.getLockState().equals("寮傚父鐘舵��")){
                                     String lockNum = ardTankLock.getLockNum();
                                     if(PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).get("lockProcess") == null){
+                                        PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒
                                         String lockNumHead = lockNum.substring(0,2);
                                         String lockNumTail = lockNum.substring(2,4);
                                         String checkNum = Integer.toHexString(Integer.parseInt(lockNumHead, 16)//閿佺紪鍙烽珮8浣�
@@ -406,7 +412,7 @@
 
                                         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());//鍔犲叆瀹瑰櫒
+                                        //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");
@@ -444,11 +450,141 @@
                                 continue;
                             }
                         }
+                        break;//澶勫湪浠绘剰鐢靛瓙鍥存爮涓�
                     }
                 }
             }
             //鐢靛瓙鍥存爮閫昏緫
+            Point2D.Double point = new Point2D.Double(((Number) gpsMap.get("lng")).doubleValue(), ((Number) gpsMap.get("lat")).doubleValue());//杞﹁締褰撳墠浣嶇疆
+            List<ArdTankLock> ardTankLockList = ardTankLockMapper.selectArdTankLockWithWallAndStateByCarId((String) gpsMap.get("carId"));
+            for(ArdTankLock ardTankLock : ardTankLockList){
+                ArdTankLockState ardTankLockState = ardTankLock.getArdTankLockState();
+                if(ardTankLockState == null){
+                    break;
+                }
+                String lockState = ardTankLockState.getLockState();
 
+                String lockNum = ardTankLock.getLockNum();
+
+                List<ArdTankWallLock> ardTankWallLockList = ardTankLock.getArdTankWallLockList();//涓棿琛�
+                if(ardTankWallLockList.isEmpty()){//娌℃湁鎸傛帴鐢靛瓙鍥存爮
+                    break;
+                }
+                for(ArdTankWallLock ardTankWallLock : ardTankWallLockList){
+                    ArdTankWall ardTankWall = ardTankWallLock.getArdTankWall();//鐢靛瓙鍥存爮
+
+                    List<Point2D.Double> pts = new ArrayList<Point2D.Double>();
+                    String[] wallpoiArro = ardTankWall.getWallPoi().split(",");
+                    for (int j = 0; j < wallpoiArro.length; j = j + 3) {//鏋勫缓澶氳竟褰�
+                        pts.add(new Point2D.Double(Double.parseDouble(wallpoiArro[j]), Double.parseDouble(wallpoiArro[j+1])));
+                    }
+                    if(GeoTools.IsPtInPoly(point, pts)){//鍦ㄧ數瀛愬洿鏍忓唴
+                        if(ardTankWallLock.getProcessType().equals("1")){//鐢靛瓙鍥存爮鎿嶄綔鏄惁涓哄紑閿�
+                            if(lockState.equals("鍏抽攣鐘舵��") || lockState.equals("寮傚父鐘舵��")){
+                                //鎵ц寮�閿佸姩浣�
+                                if(PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).get("lockProcess") == null){
+                                    PositionContainer.getCarLockProcessThreadMap().get((String) gpsMap.get("carId")).get(lockNum).put("lockProcess",new Thread());//鍔犲叆瀹瑰櫒
+                                    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(ardTankWall.getId());
+                                            ardTankLockAutoProcessLog.setWallName(ardTankWall.getWallName());
+                                            ardTankLockAutoProcessLog.setWallType("姘镐箙");
+                                            ardTankLockAutoProcessLog.setProcess("寮�鍔ㄤ綔");
+                                            ardTankLockAutoProcessLog.setProcessReason("閫熷害灏忎簬" + electromagneticLockVelocity +",骞惰繘鍏ョ數瀛愬洿鏍�'" + ardTankWall.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 if(ardTankWallLock.getProcessType().equals("-1")){//鐢靛瓙鍥存爮鎿嶄綔鏄惁涓哄叧閿�
+                            if(lockState.equals("寮�閿佺姸鎬�") || lockState.equals("寮傚父鐘舵��")){
+                                //鎵ц鍏抽攣鍔ㄤ綔
+                                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("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 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(ardTankWall.getId());
+                                            ardTankLockAutoProcessLog.setWallName(ardTankWall.getWallName());
+                                            ardTankLockAutoProcessLog.setWallType("姘镐箙");
+                                            ardTankLockAutoProcessLog.setProcess("鍏冲姩浣�");
+                                            ardTankLockAutoProcessLog.setProcessReason("閫熷害灏忎簬" + electromagneticLockVelocity +",骞惰繘鍏ョ數瀛愬洿鏍�'" + ardTankWall.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");//绉婚櫎瀹瑰櫒
+                                }
+                            }
+                        }
+                        break;//澶勫湪浠绘剰鐢靛瓙鍥存爮涓�
+                    }else{
+                        continue;
+                    }
+                }
+            }
         }
     }
 
diff --git a/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml b/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml
index 0a21a5e..4d5bebe 100644
--- a/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml
+++ b/ard-work/src/main/resources/mapper/sy/ArdTankLockMapper.xml
@@ -62,6 +62,44 @@
         </collection>
     </resultMap>
 
+    <resultMap type="ArdTankLock" id="ArdTankLockWithWallAndStateResult">
+        <result property="id"    column="id"    />
+        <result property="lockNum"    column="lock_num"    />
+        <result property="lockName"    column="lock_name"    />
+        <result property="imgPositionTop"    column="img_position_top"    />
+        <result property="imgPositionLeft"    column="img_position_left"    />
+        <result property="carId"    column="car_id"    />
+        <result property="enable"    column="enable"    />
+        <result property="restartState"    column="restart_state"    />
+        <result property="onlineTime"    column="online_time"    />
+        <association property="ardTankLockState" javaType="com.ruoyi.sy.domain.ArdTankLockState">
+            <result property="id"    column="sid"    />
+            <result property="lockId"    column="slock_id"    />
+            <result property="lockNum"    column="slock_num"    />
+            <result property="lockState"    column="lock_state"    />
+            <result property="lockPositionState"    column="lock_position_state"    />
+            <result property="lockShellState"    column="lock_shell_state"    />
+            <result property="restartState"    column="srestart_state"    />
+            <result property="batterVoltage"    column="batter_voltage"    />
+            <result property="powerVoltage"    column="power_voltage"    />
+            <result property="uploadTime"    column="upload_time"    />
+            <result property="uniqueMark"    column="unique_mark"    />
+            <result property="lockStateMark"    column="lock_state_mark"    />
+        </association>
+        <collection property="ardTankWallLockList" ofType="com.ruoyi.sy.domain.ArdTankWallLock">
+            <result property="processType"    column="process_type"    />
+            <result property="id"    column="mid"    />
+            <result property="wallId"    column="wall_id"    />
+            <result property="lockId"    column="lock_id"    />
+            <association property="ardTankWall" javaType="com.ruoyi.sy.domain.ArdTankWall">
+                <result property="id"    column="wid"    />
+                <result property="wallName"    column="wall_name"    />
+                <result property="wallPoi"    column="wall_poi"    />
+                <result property="wallType"    column="wall_type"    />
+            </association>
+        </collection>
+    </resultMap>
+
     <sql id="selectArdTankLockVo">
         select id, lock_num, lock_name, img_position_top, img_position_left, car_id, enable, restart_state, online_time from ard_tank_lock
     </sql>
@@ -290,4 +328,28 @@
         update ard_tank_lock set enable = #{enable}
         where car_id = #{carId}
     </update>
+
+    <select id="selectArdTankLockWithWallAndStateByCarId" resultMap="ArdTankLockWithWallAndStateResult" >
+        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.mid,t.wall_id,t.lock_id,
+        t.process_type,t.wid,t.wall_name,t.wall_poi,t.wall_type,t.sid,t.slock_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.id,atl.lock_num,atl.lock_name,atl.img_position_top,
+        atl.img_position_left,atl.car_id,atl.enable,atl.restart_state,
+        coalesce(atl.online_time,'') as online_time,atwl.id as mid,
+        atwl.wall_id,atwl.lock_id,atwl.process_type,atw.id as wid,
+        atw.wall_name,atw.wall_poi,atw.wall_type,coalesce(atls.id,'') as sid,
+        coalesce(atls.lock_id,'') as slock_id,coalesce(atls.lock_num,'') as slock_num,
+        coalesce(atls.lock_state,'') as lock_state,coalesce(atls.lock_position_state,'') as lock_position_state,
+        coalesce(atls.lock_shell_state,'') as lock_shell_state,coalesce(atls.restart_state,'') as srestart_state,
+        coalesce(atls.batter_voltage,'') as batter_voltage,coalesce(atls.power_voltage,'') as power_voltage,
+        coalesce(atls.upload_time,'') as upload_time,coalesce(atls.unique_mark,'') as unique_mark,
+        rank() over(partition by atl.lock_num order by atls.upload_time desc,atl.lock_num) rn
+        from ard_tank_lock atl
+        inner join ard_tank_wall_lock atwl on atl.id = atwl.lock_id
+        inner join ard_tank_wall atw on atwl.wall_id = atw.id
+        left join ard_tank_lock_state atls on atl."id" = atls.lock_id
+        where atl.car_id = #{carId} and atwl.process_type != '0')t where t.rn = 1
+    </select>
 </mapper>
\ No newline at end of file

--
Gitblit v1.9.3