From 61eeadd816f66802fa25b226a928e7d9af68e4e5 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期五, 06 十月 2023 11:54:38 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java |   67 +++++++++++++++++++++++++--------
 1 files changed, 51 insertions(+), 16 deletions(-)

diff --git a/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java b/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java
index 6fdcd57..cf52c25 100644
--- a/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java
+++ b/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java
@@ -19,30 +19,64 @@
      * @param shuttleNo 灏忚溅鍙�
      * @param wrkNo 宸ヤ綔鍙�
      * @param startPoint 璧风偣锛堝皬杞﹀綋鍓嶄綅缃級
+     * @param targetPoint 鐩爣鐐癸紙璐х墿鐩爣浣嶇疆锛�
+     */
+    public static NyShuttleOperaResult getShuttleTransportCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String targetPoint) {
+        //琛岃蛋璺緞
+        ArrayList<NavigateNode> nodes = new ArrayList<>();
+        //鍛戒护闆嗗悎
+        ArrayList<NyShuttleHttpCommand> commands = new ArrayList<>();
+
+        //璁$畻璧风偣鍒扮洰鏍囩偣鍛戒护
+        NyShuttleOperaResult result = getStartToTargetCommands(shuttleNo, wrkNo, startPoint, targetPoint, NavigationMapType.DFX.id);
+        if (result == null) {
+            //璁$畻缁撴灉蹇呴』涓嶄负绌猴紝鍚﹀垯璁$畻澶辫触
+            return null;
+        }
+        nodes.addAll(result.getNodes());
+        //璧风偣浣嶇疆涓嬪彂涓�鏉¢《鍗囧懡浠ゅ皢璐х墿杩涜鎼繍
+        commands.add(NyHttpUtils.getPalletLiftCommand(shuttleNo, wrkNo, true));
+        commands.addAll(result.getCommands());//璧风偣鍒扮洰鏍囩偣绉诲姩鍛戒护
+        //褰撳皬杞﹁璧板埌鐩爣鐐瑰悗锛岄渶瑕佷笅鍙戜竴鏉′笅闄嶅懡浠ゅ皢璐х墿鏀剧疆
+        commands.add(NyHttpUtils.getPalletLiftCommand(shuttleNo, wrkNo, false));
+        return result(commands, nodes);
+    }
+
+    /**
+     * 璁$畻骞惰幏鍙栧皬杞︿粠璧风偣鈥斺�斾腑闂寸偣鈥斺�旂洰鏍囩偣涔嬮棿鎼繍璐х墿鍔ㄤ綔鍛戒护
+     * @param shuttleNo 灏忚溅鍙�
+     * @param wrkNo 宸ヤ綔鍙�
+     * @param startPoint 璧风偣锛堝皬杞﹀綋鍓嶄綅缃級
      * @param middlePoint 涓棿鐐癸紙璐х墿浣嶇疆锛�
      * @param targetPoint 鐩爣鐐癸紙璐х墿鐩爣浣嶇疆锛�
      */
     public static NyShuttleOperaResult getShuttleTransportCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String middlePoint, String targetPoint) {
-        //璁$畻璧风偣鍒颁腑闂寸偣鍛戒护
-        NyShuttleOperaResult result1 = getStartToTargetCommands(shuttleNo, wrkNo, startPoint, middlePoint);
-        //璁$畻涓棿鐐瑰埌鐩爣鐐瑰懡浠�
-        NyShuttleOperaResult result2 = getStartToTargetCommands(shuttleNo, wrkNo, middlePoint, targetPoint);
-        if (result1 == null || result2 == null) {
-            //涓や釜璁$畻缁撴灉蹇呴』涓嶄负绌猴紝鍚﹀垯璁$畻澶辫触
-            return null;
-        }
-
         //琛岃蛋璺緞
         ArrayList<NavigateNode> nodes = new ArrayList<>();
-        nodes.addAll(result1.getNodes());
-        nodes.addAll(result2.getNodes());
-
         //鍛戒护闆嗗悎
         ArrayList<NyShuttleHttpCommand> commands = new ArrayList<>();
-        commands.addAll(result1.getCommands());
+
+        if (!startPoint.equals(middlePoint)) {//璧风偣鍜屼腑闂寸偣涓嶄竴鑷达紝闇�瑕佽绠楄捣鐐瑰埌涓棿鐐硅矾寰�
+            //璁$畻璧风偣鍒颁腑闂寸偣鍛戒护
+            NyShuttleOperaResult result1 = getStartToTargetCommands(shuttleNo, wrkNo, startPoint, middlePoint, NavigationMapType.NORMAL.id);
+            if (result1 == null) {
+                //璁$畻缁撴灉蹇呴』涓嶄负绌猴紝鍚﹀垯璁$畻澶辫触
+                return null;
+            }
+            nodes.addAll(result1.getNodes());
+            commands.addAll(result1.getCommands());
+        }
+
+        //璁$畻涓棿鐐瑰埌鐩爣鐐瑰懡浠�
+        NyShuttleOperaResult result2 = getStartToTargetCommands(shuttleNo, wrkNo, middlePoint, targetPoint, NavigationMapType.DFX.id);
+        if (result2 == null) {
+            //璁$畻缁撴灉蹇呴』涓嶄负绌猴紝鍚﹀垯璁$畻澶辫触
+            return null;
+        }
+        nodes.addAll(result2.getNodes());
         //褰撳皬杞﹁璧板埌涓棿鐐瑰悗锛岄渶瑕佷笅鍙戜竴鏉¢《鍗囧懡浠ゅ皢璐х墿杩涜鎼繍
         commands.add(NyHttpUtils.getPalletLiftCommand(shuttleNo, wrkNo, true));
-        commands.addAll(result2.getCommands());
+        commands.addAll(result2.getCommands());//涓棿鐐瑰埌鐩爣鐐圭Щ鍔ㄥ懡浠�
         //褰撳皬杞﹁璧板埌鐩爣鐐瑰悗锛岄渶瑕佷笅鍙戜竴鏉′笅闄嶅懡浠ゅ皢璐х墿鏀剧疆
         commands.add(NyHttpUtils.getPalletLiftCommand(shuttleNo, wrkNo, false));
         return result(commands, nodes);
@@ -51,9 +85,9 @@
     /**
      * 鑾峰彇璧风偣鍒扮洰鏍囩偣琛岃蛋鍛戒护
      */
-    public static NyShuttleOperaResult getStartToTargetCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String targetPoint) {
+    public static NyShuttleOperaResult getStartToTargetCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String targetPoint, Integer mapType) {
         //璁$畻璧风偣鍒扮洰鏍囩偣琛岃蛋鑺傜偣
-        List<NavigateNode> calc = NavigateUtils.calc(startPoint, targetPoint, NavigationMapType.NORMAL.id, Utils.getShuttlePoints(shuttleNo, Utils.getLev(startPoint)));
+        List<NavigateNode> calc = NavigateUtils.calc(startPoint, targetPoint, mapType, Utils.getShuttlePoints(shuttleNo, Utils.getLev(startPoint)));
         if (calc == null) {
             return null;
         }
@@ -71,6 +105,7 @@
             NavigateNode targetPath = nodes.get(nodes.size() - 1);
             //鑾峰彇绉诲姩鍛戒护
             NyShuttleHttpCommand moveCommand = NyHttpUtils.getMoveCommand(shuttleNo, wrkNo, startPath, targetPath);
+            moveCommand.setNodes(nodes);//灏嗚璧拌妭鐐规坊鍔犲埌姣忎竴姝ュ懡浠や腑
             commands.add(moveCommand);
         }
 

--
Gitblit v1.9.1