From 0d04bc5d8080b82338302fba0a59fccff2eaedfc Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期日, 06 七月 2025 11:28:29 +0800
Subject: [PATCH] #

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/NavigateMapUtils.java |   98 +++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 86 insertions(+), 12 deletions(-)

diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/NavigateMapUtils.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/NavigateMapUtils.java
index 00a447e..6c72996 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/NavigateMapUtils.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/NavigateMapUtils.java
@@ -1,12 +1,16 @@
 package com.zy.asrs.wcs.core.utils;
 
 import com.alibaba.fastjson.JSON;
-import com.zy.asrs.common.wms.entity.BasMap;
-import com.zy.asrs.framework.common.SpringUtils;
+import com.alibaba.fastjson.serializer.SerializerFeature;
+import com.fasterxml.jackson.core.JsonProcessingException;
+import com.fasterxml.jackson.core.type.TypeReference;
+import com.fasterxml.jackson.databind.ObjectMapper;
+import com.zy.asrs.wcs.core.domain.dto.RedisMapDto;
 import com.zy.asrs.wcs.core.model.MapNode;
 import com.zy.asrs.wcs.core.model.NavigateNode;
 import com.zy.asrs.wcs.core.model.enums.NavigationMapType;
 import com.zy.asrs.wcs.rcs.constant.DeviceRedisConstant;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 
 import java.util.ArrayList;
@@ -16,19 +20,24 @@
 @Component
 public class NavigateMapUtils {
 
+    @Autowired
+    private NavigateMapData navigateMapData;
+    @Autowired
+    private RedisUtil redisUtil;
+    @Autowired
+    private ObjectMapper objectMapper;
+
     /**
      * 鍐欏叆璺緞鑺傜偣鏁版嵁鍒皉edis鍦板浘涓�
      * lock涓簍rue 绂佺敤搴撲綅锛宭ock涓篺alse鎭㈠搴撲綅
      */
     public synchronized boolean writeNavigateNodeToRedisMap(Integer lev, Integer shuttleNo, List<NavigateNode> nodes, boolean lock) {
-        RedisUtil redisUtil = SpringUtils.getBean(RedisUtil.class);
         try {
             if (nodes.isEmpty()) {
                 return true;
             }
 
-            NavigateMapData navigateMapData = new NavigateMapData(lev);
-
+            navigateMapData.setLev(lev);
             Object o = redisUtil.get(DeviceRedisConstant.MAP + lev);
             if (o == null) {
                 return false;
@@ -37,8 +46,8 @@
             //鑾峰彇灏忚溅鑺傜偣
             List<int[]> shuttlePoints = Utils.getShuttlePoints(shuttleNo, lev);
 
-            BasMap basMap = JSON.parseObject(o.toString(), BasMap.class);
-            ArrayList arrayList = JSON.parseObject(basMap.getData(), ArrayList.class);
+            RedisMapDto redisMap = JSON.parseObject(o.toString(), RedisMapDto.class);
+            ArrayList arrayList = JSON.parseObject(redisMap.getData(), ArrayList.class);
             //甯﹀皬杞﹀湴鍥�
             List<List<MapNode>> listsHasShuttle = navigateMapData.filterMap(NavigationMapType.NONE.id, arrayList, lev, null, shuttlePoints);//鑾峰彇甯﹀皬杞﹀湴鍥炬暟鎹�
             List<List<MapNode>> lists = navigateMapData.filterMap(NavigationMapType.NONE.id, arrayList, lev, null, null);//鑾峰彇鍏ㄩ儴鍦板浘鏁版嵁
@@ -58,8 +67,8 @@
             }
 
             //灏濊瘯閿佸畾/瑙i攣璺緞
-            NavigateMapData mapData = new NavigateMapData(nodes.get(0).getZ());
-            List<List<MapNode>> realMap = mapData.getJsonData(-1, null, null);//鑾峰彇瀹屾暣鍦板浘(鍖呮嫭鍏ュ簱鍑哄簱)
+            navigateMapData.setLev(nodes.get(0).getZ());
+            List<List<MapNode>> realMap = navigateMapData.getJsonDataFromDict(-1, null, null);//鑾峰彇瀹屾暣鍦板浘(鍖呮嫭鍏ュ簱鍑哄簱)
             for (NavigateNode node : nodes) {
                 if (node.getZ() != lev) {
                     continue;
@@ -79,10 +88,13 @@
                 listX.set(node.getY(), mapNode);
                 lists.set(node.getX(), listX);
             }
-            basMap.setData(JSON.toJSONString(lists));
-            basMap.setUpdateTime(new Date());
+            redisMap.setData(JSON.toJSONString(lists));
+            redisMap.setUpdateTime(new Date());
             //灏嗘暟鎹簱鍦板浘鏁版嵁瀛樺叆redis
-            redisUtil.set(DeviceRedisConstant.MAP + lev, JSON.toJSONString(basMap));
+            redisUtil.set(DeviceRedisConstant.MAP + lev, JSON.toJSONString(redisMap, SerializerFeature.DisableCircularReferenceDetect));
+
+            //淇濆瓨璺緞閿佽妭鐐�
+            saveLockPath(lev, nodes, lock);
             return true;
         } catch (Exception e) {
             e.printStackTrace();
@@ -90,4 +102,66 @@
         return false;
     }
 
+    //淇濆瓨璺緞閿佽妭鐐�
+    public void saveLockPath(Integer lev, List<NavigateNode> nodes, boolean lock) {
+        Object o = redisUtil.get(DeviceRedisConstant.LOCK_PATH + lev);
+        List<NavigateNode> navigateNodes = new ArrayList<>();
+        if (o != null) {
+            try {
+                navigateNodes = objectMapper.readValue(o.toString(), new TypeReference<List<NavigateNode>>() {});
+            } catch (JsonProcessingException e) {
+                throw new RuntimeException(e);
+            }
+        }
+
+        String nodeStr = null;
+        if (lock) {
+            navigateNodes.addAll(nodes);
+            try {
+                nodeStr = objectMapper.writeValueAsString(navigateNodes);
+            } catch (JsonProcessingException e) {
+                throw new RuntimeException(e);
+            }
+            redisUtil.set(DeviceRedisConstant.LOCK_PATH + lev, nodeStr);
+        }else {
+            List<NavigateNode> tmp = new ArrayList<>();
+            for (NavigateNode navigateNode : navigateNodes) {
+                boolean flag = true;
+                for (NavigateNode node : nodes) {
+                    if (navigateNode.getX() == node.getX()
+                            && navigateNode.getY() == node.getY()
+                            && navigateNode.getZ() == node.getZ()) {
+                        flag = false;
+                        break;
+                    }
+                }
+
+                if (flag) {
+                    tmp.add(navigateNode);
+                }
+            }
+
+            try {
+                nodeStr = objectMapper.writeValueAsString(tmp);
+            } catch (JsonProcessingException e) {
+                throw new RuntimeException(e);
+            }
+            redisUtil.set(DeviceRedisConstant.LOCK_PATH + lev, nodeStr);
+        }
+    }
+
+    //鑾峰彇璺緞閿佽妭鐐�
+    public List<NavigateNode> getLockPath(Integer lev) {
+        Object obj = redisUtil.get(DeviceRedisConstant.LOCK_PATH + lev);
+        List<NavigateNode> navigateNodes = new ArrayList<>();
+        if (obj != null) {
+            try {
+                navigateNodes = objectMapper.readValue(obj.toString(), new TypeReference<List<NavigateNode>>() {});
+            } catch (JsonProcessingException e) {
+                throw new RuntimeException(e);
+            }
+        }
+        return navigateNodes;
+    }
+
 }

--
Gitblit v1.9.1