From 32f3f3e2e358e87d4c4e7edb142943f107a0cccf Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期五, 10 十一月 2023 15:02:51 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/thread/NyShuttleThread.java |  101 ++++++++++++++++++++++++++------------------------
 1 files changed, 53 insertions(+), 48 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/NyShuttleThread.java b/src/main/java/com/zy/core/thread/NyShuttleThread.java
index 3773fc7..6d381d2 100644
--- a/src/main/java/com/zy/core/thread/NyShuttleThread.java
+++ b/src/main/java/com/zy/core/thread/NyShuttleThread.java
@@ -10,7 +10,6 @@
 
 import com.zy.asrs.utils.Utils;
 import com.zy.common.model.NavigateNode;
-import com.zy.common.model.NyShuttleOperaResult;
 import com.zy.common.service.CommonService;
 import com.zy.common.utils.*;
 import com.zy.core.News;
@@ -29,7 +28,6 @@
 import lombok.Data;
 import lombok.extern.slf4j.Slf4j;
 
-import javax.swing.*;
 import java.io.IOException;
 import java.net.Socket;
 import java.text.MessageFormat;
@@ -358,7 +356,7 @@
         shuttleProtocol.setAssignCommand(assignCommand);
         shuttleProtocol.setProtocolStatus(ShuttleProtocolStatusType.WORKING);
         //浠诲姟鏁版嵁淇濆瓨鍒皉edis
-        redisUtil.set("shuttle_wrk_no_" + assignCommand.getTaskNo(), JSON.toJSONString(redisCommand));
+        redisUtil.set(RedisKeyType.SHUTTLE.key + assignCommand.getTaskNo(), JSON.toJSONString(redisCommand));
         //鎵ц涓嬪彂浠诲姟
         executeWork(assignCommand.getTaskNo());
     }
@@ -370,10 +368,11 @@
             return false;
         }
 
+        NavigateMapUtils navigateMapUtils = SpringUtils.getBean(NavigateMapUtils.class);
         WrkMastMapper wrkMastMapper = SpringUtils.getBean(WrkMastMapper.class);
         WrkMast wrkMast = wrkMastMapper.selectByWorkNo(wrkNo.intValue());
 
-        Object o = redisUtil.get("shuttle_wrk_no_" + wrkNo);
+        Object o = redisUtil.get(RedisKeyType.SHUTTLE.key + wrkNo);
         if (o == null) {
             return false;
         }
@@ -388,8 +387,6 @@
         }
 
         checkIOSta(commands, commandStep);//妫�娴嬪皬杞︽槸鍚﹁繘鍑烘彁鍗囨満杈撻�佺珯
-
-        NavigateMapData navigateMapData = new NavigateMapData(Utils.getLev(shuttleProtocol.getCurrentLocNo()));
 
         boolean isLock = false;//鏄惁瑙i攣璺緞
         //鍙栧嚭鍛戒护
@@ -414,7 +411,15 @@
 //                        nodes.addAll(command.getNodes());
 //                    }
                     if (nodes != null) {
-                        navigateMapData.writeNavigateNodeToRedisMap(nodes, false);//瑙i攣璺緞
+                        NavigateNode targetNode = assignCommand.getNodes().get(assignCommand.getNodes().size() - 1);//鏈�缁堣妭鐐�
+                        NavigateNode node = nodes.get(nodes.size() - 1);
+                        if (!(targetNode.getX() == node.getX() && targetNode.getY() == node.getY())) {
+                            nodes.remove(nodes.size() - 1);//鍓旈櫎灏捐妭鐐�
+                        }
+                        boolean result = navigateMapUtils.writeNavigateNodeToRedisMap(Utils.getLev(shuttleProtocol.getCurrentLocNo()), nodes, false);//瑙i攣璺緞
+                        if (!result) {
+                            return false;//瑙i攣澶辫触
+                        }
                         isLock = true;//瑙i攣杩囪矾寰�
                     }
                 }
@@ -422,7 +427,7 @@
                 lastCommand.setComplete(true);//鍏朵粬鍛戒护榛樿璁や负瀹屾垚
             }
             //浠诲姟鏁版嵁淇濆瓨鍒皉edis
-            redisUtil.set("shuttle_wrk_no_" + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
+            redisUtil.set(RedisKeyType.SHUTTLE.key + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
 
             if (!lastCommand.getComplete()) {
                 //涓婁竴鏉′换鍔℃湭瀹屾垚锛岀姝笅鍙戝懡浠�
@@ -433,7 +438,7 @@
             NyShuttleHttpCommand endCommand = commands.get(commands.size() - 1);
             if (endCommand.getComplete()) {
                 //鍒犻櫎redis
-                redisUtil.del("shuttle_wrk_no_" + redisCommand.getWrkNo());
+                redisUtil.del(RedisKeyType.SHUTTLE.key + redisCommand.getWrkNo());
 
                 if (!assignCommand.getCharge()) {
                     //瀵逛富绾跨▼鎶涘嚭绛夊緟纭鐘舵�亀aiting
@@ -471,41 +476,41 @@
             return false;
         }
 
-        if (command.getRequest().getBody().get("requestType").equals("move")) {
-            ArrayList<int[]> whiteList = new ArrayList<>();//璁剧疆鑺傜偣鐨勭櫧鍚嶅崟
-            if (wrkMast != null && ((wrkMast.getIoType() > 100 && wrkMast.getIoType() < 200) || wrkMast.getIoType() == 11)) {
-                //鍑哄簱浠诲姟锛屼笉妫�娴嬮鑺傜偣
-                int[] startArr = NavigatePositionConvert.positionToXY(wrkMast.getSourceLocNo());//寮�濮嬭妭鐐�
-                whiteList.add(startArr);
-            }
-
-            //瑙i攣杩囪矾寰勶紝鍙娴嬩笅涓�娈佃矾寰勬槸鍚﹀彲璧�(褰撳墠璺緞宸茬粡琚攣瀹氭棤闇�鍐嶆娴�)
-            if (isLock) {
-                //鍙娴嬩笅涓�娈佃矾寰勬槸鍚﹀彲璧�(褰撳墠璺緞宸茬粡琚攣瀹氭棤闇�鍐嶆娴�)
-                //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋
-                if (!checkPath(nextNodes == null ? command.getNodes() : nextNodes, null, whiteList)) {
-                    return false;
-                }
-            }else {
-                //妫�娴嬪綋鍓嶈矾寰勫拰涓嬩竴娈佃矾寰�
-                //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋
-                if (!checkPath(command.getNodes(), nextNodes, whiteList)) {
-                    return false;
-                }
-            }
-
-            //閿佸畾璺緞锛岄攣瀹氬綋鍓嶈矾寰勫拰涓嬩竴姝ヨ矾寰�
-            List<NavigateNode> nodes = command.getNodes();
-            if (nextNodes != null) {
-                nodes.addAll(nextNodes);
-            }
-            if (nodes != null) {
-                boolean result = navigateMapData.writeNavigateNodeToRedisMap(nodes, true);//鎵�浣跨敤鐨勮矾寰勮繘琛岄攣瀹氱鐢�
-                if (!result) {
-                    return false;//璺緞閿佸畾澶辫触
-                }
-            }
-        }
+//        if (command.getRequest().getBody().get("requestType").equals("move")) {
+//            ArrayList<int[]> whiteList = new ArrayList<>();//璁剧疆鑺傜偣鐨勭櫧鍚嶅崟
+//            if (wrkMast != null && ((wrkMast.getIoType() > 100 && wrkMast.getIoType() < 200) || wrkMast.getIoType() == 11)) {
+//                //鍑哄簱浠诲姟锛屼笉妫�娴嬮鑺傜偣
+//                int[] startArr = NavigatePositionConvert.positionToXY(wrkMast.getSourceLocNo());//寮�濮嬭妭鐐�
+//                whiteList.add(startArr);
+//            }
+//
+//            //瑙i攣杩囪矾寰勶紝鍙娴嬩笅涓�娈佃矾寰勬槸鍚﹀彲璧�(褰撳墠璺緞宸茬粡琚攣瀹氭棤闇�鍐嶆娴�)
+//            if (isLock) {
+//                //鍙娴嬩笅涓�娈佃矾寰勬槸鍚﹀彲璧�(褰撳墠璺緞宸茬粡琚攣瀹氭棤闇�鍐嶆娴�)
+//                //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋
+//                if (!checkPath(nextNodes == null ? command.getNodes() : nextNodes, null, whiteList)) {
+//                    return false;
+//                }
+//            }else {
+//                //妫�娴嬪綋鍓嶈矾寰勫拰涓嬩竴娈佃矾寰�
+//                //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋
+//                if (!checkPath(command.getNodes(), nextNodes, whiteList)) {
+//                    return false;
+//                }
+//            }
+//
+//            //閿佸畾璺緞锛岄攣瀹氬綋鍓嶈矾寰勫拰涓嬩竴姝ヨ矾寰�
+//            List<NavigateNode> nodes = command.getNodes();
+//            if (nextNodes != null) {
+//                nodes.addAll(nextNodes);
+//            }
+//            if (nodes != null) {
+//                boolean result = navigateMapUtils.writeNavigateNodeToRedisMap(Utils.getLev(shuttleProtocol.getCurrentLocNo()), nodes, true);//鎵�浣跨敤鐨勮矾寰勮繘琛岄攣瀹氱鐢�
+//                if (!result) {
+//                    return false;//璺緞閿佸畾澶辫触
+//                }
+//            }
+//        }
 
         //鍙墽琛屽懡浠�
         if (!write(command, assignCommand)) {
@@ -527,7 +532,7 @@
         //鏇存柊redis鏁版嵁
         redisCommand.setCommandStep(commandStep);
         //浠诲姟鏁版嵁淇濆瓨鍒皉edis
-        redisUtil.set("shuttle_wrk_no_" + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
+        redisUtil.set(RedisKeyType.SHUTTLE.key + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
 
         return true;
     }
@@ -539,7 +544,7 @@
             return false;
         }
 
-        Object o = redisUtil.get("shuttle_wrk_no_" + wrkNo);
+        Object o = redisUtil.get(RedisKeyType.SHUTTLE.key + wrkNo);
         if (o == null) {
             return false;
         }
@@ -623,7 +628,7 @@
             return false;
         }
 
-        Object o = redisUtil.get("shuttle_wrk_no_" + wrkNo);
+        Object o = redisUtil.get(RedisKeyType.SHUTTLE.key + wrkNo);
         if (o == null) {
             return false;
         }
@@ -709,7 +714,7 @@
 //            assignCommand.setCommands(commands);
 //            redisCommand.setAssignCommand(assignCommand);
 //            //浠诲姟鏁版嵁淇濆瓨鍒皉edis
-//            redisUtil.set("shuttle_wrk_no_" + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
+//            redisUtil.set(RedisKeyType.SHUTTLE.key + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
 //            return false;//褰撳墠涓嶅彲琛岃蛋锛岀瓑寰呬笅涓�娆℃墽琛岃蛋鏂拌矾寰�
 //        }
 

--
Gitblit v1.9.1