From 1be269037e8cff8043b8f046fec70509ebfd951c Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期一, 21 八月 2023 14:41:58 +0800
Subject: [PATCH] 小车手动管制操作

---
 src/main/java/com/zy/core/thread/NyShuttleThread.java |   72 ++++++++++++++++++++++++++++++++---
 1 files changed, 65 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/NyShuttleThread.java b/src/main/java/com/zy/core/thread/NyShuttleThread.java
index f829281..1ab039c 100644
--- a/src/main/java/com/zy/core/thread/NyShuttleThread.java
+++ b/src/main/java/com/zy/core/thread/NyShuttleThread.java
@@ -10,6 +10,7 @@
 
 import com.zy.asrs.utils.Utils;
 import com.zy.common.model.NavigateNode;
+import com.zy.common.model.NyShuttleOperaResult;
 import com.zy.common.utils.*;
 import com.zy.core.News;
 import com.zy.core.ThreadHandler;
@@ -298,15 +299,16 @@
             return false;
         }
 
-        WrkMastService wrkMastService = SpringUtils.getBean(WrkMastService.class);
+        WrkMastMapper wrkMastMapper = SpringUtils.getBean(WrkMastMapper.class);
 
         Object o = redisUtil.get("shuttle_wrk_no_" + wrkNo);
         if (o == null) {
             return false;
         }
+
         ShuttleRedisCommand redisCommand = JSON.parseObject(o.toString(), ShuttleRedisCommand.class);
-        List<NyShuttleHttpCommand> commands = redisCommand.getAssignCommand().getCommands();
         ShuttleAssignCommand assignCommand = redisCommand.getAssignCommand();
+        List<NyShuttleHttpCommand> commands = redisCommand.getAssignCommand().getCommands();
         //褰撳墠姝ュ簭
         int commandStep = redisCommand.getCommandStep();
         if (commands.size() == 0) {
@@ -363,13 +365,11 @@
             return false;
         }
 
-        //妫�鏌ヨ矾寰勬槸鍚﹀彲琛岃蛋(妫�鏌ヨ矾寰勯攣瀹氱姸鎬侊紝妫�娴嬭矾寰勬槸鍚︽湁鍏朵粬灏忚溅)
-        //妫�娴嬪綋鍓嶈璧拌矾寰勶紝鍜屼笅涓�姝ヨ矾寰�
-        boolean checkPathIsAvailable = NavigateUtils.checkPathIsAvailable(command.getNodes(), shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo()));
-        boolean checkPathIsAvailable2 = NavigateUtils.checkPathIsAvailable(nextNodes, shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo()));
-        if (!checkPathIsAvailable && !checkPathIsAvailable2) {
+        //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋
+        if (!checkPath(command.getNodes(), nextNodes, redisCommand)) {
             return false;
         }
+
         //閿佸畾璺緞锛岄攣瀹氬綋鍓嶈矾寰勫拰涓嬩竴姝ヨ矾寰�
         List<NavigateNode> nodes = command.getNodes();
         nodes.addAll(nextNodes);
@@ -442,6 +442,8 @@
             return false;
         }
 
+        WrkMastMapper wrkMastMapper = SpringUtils.getBean(WrkMastMapper.class);
+
         ShuttleRedisCommand redisCommand = JSON.parseObject(o.toString(), ShuttleRedisCommand.class);
         //褰撳墠姝ュ簭
         int commandStep = redisCommand.getCommandStep();
@@ -482,6 +484,12 @@
 
         if (liftProtocol.getLev().intValue() == Utils.getLev(shuttleProtocol.getCurrentLocNo())) {
             return true;//鎻愬崌鏈鸿揪鍒板皬杞︽ゼ灞傦紝鏀捐
+        }
+
+        //鎼滅储鏄惁鏈夊叾浠栦换鍔″崰鐢ㄤ簡鎻愬崌鏈猴紝濡傛灉鍗犵敤鎻愬崌鏈虹殑浠诲姟鍜屽綋鍓嶄换鍔$浉鍚岋紝鍒欒繍琛屾墽琛�
+        WrkMast wrkMast1 = wrkMastMapper.selectLiftWrkMast(liftProtocol.getLiftNo().intValue());
+        if (wrkMast1 != null && wrkMast1.getWrkNo() != wrkNo.intValue()) {
+            return false;
         }
 
         //鎻愬崌鏈烘湭鍒拌揪灏忚溅妤煎眰锛屽懠鍙彁鍗囨満
@@ -545,4 +553,54 @@
         return false;//榛樿涓嶆斁琛�
     }
 
+    /**
+     * 妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋
+     * 濡傛灉璺緞涓虹洰鏍囧簱浣嶏紝浣嗕笉鍙璧帮紝绯荤粺灏嗗皾璇曢噸鏂拌绠楄矾寰�
+     */
+    private boolean checkPath(List<NavigateNode> currentNodes, List<NavigateNode> nextNodes, ShuttleRedisCommand redisCommand) {
+        //妫�娴嬭矾寰勬槸鍚﹀彲琛岃蛋(妫�鏌ヨ矾寰勯攣瀹氱姸鎬侊紝妫�娴嬭矾寰勬槸鍚︽湁鍏朵粬灏忚溅)
+        //妫�娴嬪綋鍓嶈璧拌矾寰勶紝鍜屼笅涓�姝ヨ矾寰�
+        boolean checkPathIsAvailable = NavigateUtils.checkPathIsAvailable(currentNodes, shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo()));
+        boolean checkPathIsAvailable2 = NavigateUtils.checkPathIsAvailable(nextNodes, shuttleProtocol.getShuttleNo().intValue(), Utils.getLev(shuttleProtocol.getCurrentLocNo()));
+        if (checkPathIsAvailable && checkPathIsAvailable2) {
+            return true;//鍙璧�
+        }
+
+        ShuttleAssignCommand assignCommand = redisCommand.getAssignCommand();
+        NavigateNode currentTarget = currentNodes.get(currentNodes.size() - 1);
+        String currentLocNo = NavigatePositionConvert.nodeToLocNo(currentTarget);
+        NavigateNode nextTarget = nextNodes.get(nextNodes.size() - 1);
+        String nextLocNo = NavigatePositionConvert.nodeToLocNo(nextTarget);
+        if (assignCommand.getLocNo().equals(currentLocNo) || assignCommand.getLocNo().equals(nextLocNo)) {
+            //褰撳墠璺緞鏈�鍚庝竴涓妭鐐规槸鐩爣搴撲綅锛岃繘琛岃矾寰勬娴嬶紝濡傛灉涓嶅彲琛岃蛋锛岄噸鏂拌绠楄矾寰�
+            //涓嶅彲琛岃蛋锛岄噸鏂拌绠楄矾寰�
+            NyShuttleOperaResult result = NyShuttleOperaUtils.getStartToTargetCommands(shuttleProtocol.getShuttleNo().intValue(), shuttleProtocol.getTaskNo(), shuttleProtocol.getCurrentLocNo(), assignCommand.getLocNo());
+            if (result == null) {
+                return false;//璺緞璁$畻澶辫触锛屼笉鍙璧�
+            }
+
+            List<NyShuttleHttpCommand> newCommands = result.getCommands();//鏂拌矾寰�
+
+            //褰撳墠姝ュ簭
+            int commandStep = redisCommand.getCommandStep();
+            List<NyShuttleHttpCommand> commands = assignCommand.getCommands();
+
+            commands.remove(commandStep);//绉婚櫎褰撳墠姝ュ簭鎸囦护
+            if (assignCommand.getLocNo().equals(currentLocNo)) {
+                //褰撳墠璺緞锛岄渶瑕佸啀澶氱Щ闄や笅涓�姝ユ寚浠�
+                commands.remove(commandStep + 1);
+            }
+
+            //灏嗘柊璺緞娣诲姞杩涙寚浠ら泦鍚�
+            commands.addAll(commandStep, newCommands);
+            assignCommand.setCommands(commands);
+            redisCommand.setAssignCommand(assignCommand);
+            //浠诲姟鏁版嵁淇濆瓨鍒皉edis
+            redisUtil.set("shuttle_wrk_no_" + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
+            return false;//褰撳墠涓嶅彲琛岃蛋锛岀瓑寰呬笅涓�娆℃墽琛岃蛋鏂拌矾寰�
+        }
+
+        return false;//涓嶅彲琛岃蛋
+    }
+
 }

--
Gitblit v1.9.1