From e039dbc9aa07fabb13be9673cbb7dfccfecda870 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期六, 23 十一月 2024 08:14:28 +0800
Subject: [PATCH] #读取地图文件优化

---
 src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java |   76 ++++++++++++++++++++++++++++++++++---
 1 files changed, 69 insertions(+), 7 deletions(-)

diff --git a/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java b/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java
index cc59243..fc00b05 100644
--- a/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java
+++ b/src/main/java/com/zy/common/utils/NyShuttleOperaUtils.java
@@ -1,5 +1,6 @@
 package com.zy.common.utils;
 
+import com.core.common.SpringUtils;
 import com.zy.asrs.utils.Utils;
 import com.zy.common.model.NavigateNode;
 import com.zy.common.model.NyShuttleOperaResult;
@@ -21,14 +22,14 @@
      * @param startPoint 璧风偣锛堝皬杞﹀綋鍓嶄綅缃級
      * @param targetPoint 鐩爣鐐癸紙璐х墿鐩爣浣嶇疆锛�
      */
-    public static NyShuttleOperaResult getShuttleTransportCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String targetPoint) {
+    public static synchronized 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);
+        NyShuttleOperaResult result = getStartToTargetCommands(shuttleNo, wrkNo, startPoint, targetPoint, NavigationMapType.DFX.id);
         if (result == null) {
             //璁$畻缁撴灉蹇呴』涓嶄负绌猴紝鍚﹀垯璁$畻澶辫触
             return null;
@@ -50,7 +51,7 @@
      * @param middlePoint 涓棿鐐癸紙璐х墿浣嶇疆锛�
      * @param targetPoint 鐩爣鐐癸紙璐х墿鐩爣浣嶇疆锛�
      */
-    public static NyShuttleOperaResult getShuttleTransportCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String middlePoint, String targetPoint) {
+    public static synchronized NyShuttleOperaResult getShuttleTransportCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String middlePoint, String targetPoint) {
         //琛岃蛋璺緞
         ArrayList<NavigateNode> nodes = new ArrayList<>();
         //鍛戒护闆嗗悎
@@ -58,7 +59,7 @@
 
         if (!startPoint.equals(middlePoint)) {//璧风偣鍜屼腑闂寸偣涓嶄竴鑷达紝闇�瑕佽绠楄捣鐐瑰埌涓棿鐐硅矾寰�
             //璁$畻璧风偣鍒颁腑闂寸偣鍛戒护
-            NyShuttleOperaResult result1 = getStartToTargetCommands(shuttleNo, wrkNo, startPoint, middlePoint);
+            NyShuttleOperaResult result1 = getStartToTargetCommands(shuttleNo, wrkNo, startPoint, middlePoint, NavigationMapType.NORMAL.id);
             if (result1 == null) {
                 //璁$畻缁撴灉蹇呴』涓嶄负绌猴紝鍚﹀垯璁$畻澶辫触
                 return null;
@@ -68,7 +69,7 @@
         }
 
         //璁$畻涓棿鐐瑰埌鐩爣鐐瑰懡浠�
-        NyShuttleOperaResult result2 = getStartToTargetCommands(shuttleNo, wrkNo, middlePoint, targetPoint);
+        NyShuttleOperaResult result2 = getStartToTargetCommands(shuttleNo, wrkNo, middlePoint, targetPoint, NavigationMapType.DFX.id);
         if (result2 == null) {
             //璁$畻缁撴灉蹇呴』涓嶄负绌猴紝鍚﹀垯璁$畻澶辫触
             return null;
@@ -85,15 +86,17 @@
     /**
      * 鑾峰彇璧风偣鍒扮洰鏍囩偣琛岃蛋鍛戒护
      */
-    public static NyShuttleOperaResult getStartToTargetCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String targetPoint) {
+    public static synchronized NyShuttleOperaResult getStartToTargetCommands(Integer shuttleNo, Integer wrkNo, String startPoint, String targetPoint, Integer mapType) {
+        NavigateMapUtils navigateMapUtils = SpringUtils.getBean(NavigateMapUtils.class);
         //璁$畻璧风偣鍒扮洰鏍囩偣琛岃蛋鑺傜偣
-        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)), null);
         if (calc == null) {
             return null;
         }
 
         //鍛戒护闆嗗悎
         ArrayList<NyShuttleHttpCommand> commands = new ArrayList<>();
+        List<NavigateNode> allNode = new ArrayList<>();
 
         //鑾峰彇鍒嗘璺緞
         ArrayList<ArrayList<NavigateNode>> data = NavigateUtils.getSectionPath(calc);
@@ -107,8 +110,67 @@
             NyShuttleHttpCommand moveCommand = NyHttpUtils.getMoveCommand(shuttleNo, wrkNo, startPath, targetPath);
             moveCommand.setNodes(nodes);//灏嗚璧拌妭鐐规坊鍔犲埌姣忎竴姝ュ懡浠や腑
             commands.add(moveCommand);
+
+            allNode.addAll(nodes);
         }
 
+        boolean result = navigateMapUtils.writeNavigateNodeToRedisMap(Utils.getLev(startPoint), shuttleNo, allNode, true);//閿佸畾璺緞
+        if (!result) {
+            return null;//璺緞閿佸畾澶辫触
+        }
+        return result(commands, calc);
+    }
+
+    /**
+     * 鑾峰彇璧风偣鍒扮洰鏍囩偣琛岃蛋鍛戒护(鍙紶鐧藉悕鍗�)
+     */
+    public static synchronized NyShuttleOperaResult getStartToTargetCommandsByWhites(Integer shuttleNo, Integer wrkNo, String startPoint, String targetPoint, Integer mapType, List<int[]> whites) {
+        NavigateMapUtils navigateMapUtils = SpringUtils.getBean(NavigateMapUtils.class);
+        //璁$畻璧风偣鍒扮洰鏍囩偣琛岃蛋鑺傜偣
+        List<NavigateNode> calc = NavigateUtils.calc(startPoint, targetPoint, mapType, Utils.getShuttlePoints(shuttleNo, Utils.getLev(startPoint)), whites);
+        if (calc == null) {
+            return null;
+        }
+
+        //鍛戒护闆嗗悎
+        ArrayList<NyShuttleHttpCommand> commands = new ArrayList<>();
+        List<NavigateNode> allNode = new ArrayList<>();
+
+        //鑾峰彇鍒嗘璺緞
+        ArrayList<ArrayList<NavigateNode>> data = NavigateUtils.getSectionPath(calc);
+        //灏嗘瘡涓�娈佃矾寰勫垎鎴恈ommand鎸囦护
+        for (ArrayList<NavigateNode> nodes : data) {
+            //寮�濮嬭矾寰�
+            NavigateNode startPath = nodes.get(0);
+            //鐩爣璺緞
+            NavigateNode targetPath = nodes.get(nodes.size() - 1);
+            //鑾峰彇绉诲姩鍛戒护
+            NyShuttleHttpCommand moveCommand = NyHttpUtils.getMoveCommand(shuttleNo, wrkNo, startPath, targetPath);
+            moveCommand.setNodes(nodes);//灏嗚璧拌妭鐐规坊鍔犲埌姣忎竴姝ュ懡浠や腑
+            commands.add(moveCommand);
+
+            allNode.addAll(nodes);
+        }
+
+        //閿佸畾璺緞鏃跺墧闄ょ櫧鍚嶅崟鑺傜偣
+        ArrayList<NavigateNode> nodes = new ArrayList<>();
+        for (NavigateNode node : allNode) {
+            boolean flag = false;
+            for (int[] white : whites) {
+                if (node.getX() == white[0] && node.getY() == white[1]) {
+                    flag = true;//瀛樺湪鐧藉悕鍗曡妭鐐�
+                    break;//璺宠繃鐧藉悕鍗曡妭鐐�
+                }
+            }
+
+            if (!flag) {
+                nodes.add(node);
+            }
+        }
+        boolean result = navigateMapUtils.writeNavigateNodeToRedisMap(Utils.getLev(startPoint), shuttleNo, nodes, true);//閿佸畾璺緞
+        if (!result) {
+            return null;//璺緞閿佸畾澶辫触
+        }
         return result(commands, calc);
     }
 

--
Gitblit v1.9.1