From 7635dc25bd2a4d565df496b2d96354639966768d Mon Sep 17 00:00:00 2001
From: Junjie <xjj@123>
Date: 星期四, 25 九月 2025 11:09:44 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/common/utils/NavigatePositionConvert.java |   65 ++++++++++++++++++++++++--------
 1 files changed, 49 insertions(+), 16 deletions(-)

diff --git a/src/main/java/com/zy/common/utils/NavigatePositionConvert.java b/src/main/java/com/zy/common/utils/NavigatePositionConvert.java
index 76a2bfd..b6a473c 100644
--- a/src/main/java/com/zy/common/utils/NavigatePositionConvert.java
+++ b/src/main/java/com/zy/common/utils/NavigatePositionConvert.java
@@ -6,6 +6,9 @@
 import com.zy.asrs.service.LocMastService;
 import com.zy.asrs.utils.Utils;
 import com.zy.common.model.NavigateNode;
+import com.zy.core.enums.RedisKeyType;
+
+import java.util.HashMap;
 
 /**
  * 搴撲綅缂栧彿鍜孉*绠楁硶鐨剎y杞磋浆鎹㈠伐鍏风被
@@ -14,29 +17,53 @@
 
     public static String xyToPosition(int x, int y, int z) {
         String locNo = Utils.getLocNo(x, y, z);
+        String code = null;
 
-        //搴撲綅鍙疯浆灏忚溅浜岀淮鐮�
-        LocMastService locMastService = SpringUtils.getBean(LocMastService.class);
-        LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>()
-                .eq("loc_no", locNo)
-                .eq("status", 1));
-        if (locMast == null) {
-            return null;
+        RedisUtil redisUtil = SpringUtils.getBean(RedisUtil.class);
+        Object object = redisUtil.get(RedisKeyType.POINT_MAP.key);
+
+        if(object == null) {
+            //搴撲綅鍙疯浆灏忚溅浜岀淮鐮�
+            LocMastService locMastService = SpringUtils.getBean(LocMastService.class);
+            LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>()
+                    .eq("loc_no", locNo)
+                    .eq("status", 1));
+            if (locMast == null) {
+                return null;
+            }
+
+            code = locMast.getQrCodeValue();
+        }else {
+            HashMap<String, String> cache = (HashMap<String, String>) object;
+            code = cache.get(locNo);
         }
-        return locMast.getQrCodeValue();
+        return code;
     }
 
     //灏忚溅鏉″舰鐮佽浆璺緞绠楁硶鑺傜偣
     public static NavigateNode codeToNode(String code) {
-        LocMastService locMastService = SpringUtils.getBean(LocMastService.class);
-        LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>()
-                .eq("qr_code_value", code)
-                .eq("status", 1));
-        if (locMast == null) {
-            return null;
+        NavigateNode node = null;
+
+        RedisUtil redisUtil = SpringUtils.getBean(RedisUtil.class);
+        Object object = redisUtil.get(RedisKeyType.LOC_MAP.key);
+
+        if (object == null) {
+            LocMastService locMastService = SpringUtils.getBean(LocMastService.class);
+            LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>()
+                    .eq("qr_code_value", code)
+                    .eq("status", 1));
+            if (locMast == null) {
+                return null;
+            }
+            node = new NavigateNode(locMast.getRow1(), locMast.getBay1());
+            node.setZ(locMast.getLev1());
+        } else {
+            HashMap<String, String> cache = (HashMap<String, String>) object;
+            String locNo = cache.get(code);
+
+            node = new NavigateNode(Utils.getRow(locNo), Utils.getBay(locNo));
+            node.setZ(Utils.getLev(locNo));
         }
-        NavigateNode node = new NavigateNode(locMast.getRow1(), locMast.getBay1());
-        node.setZ(locMast.getLev1());
         return node;
     }
 
@@ -100,4 +127,10 @@
         return new int[]{col, row};
     }
 
+    public static boolean equalsNode(NavigateNode node1, NavigateNode node2) {
+        if(node1.getX() ==  node2.getX() && node1.getY() == node2.getY() && node1.getZ() == node2.getZ()) {
+            return true;
+        }
+        return false;
+    }
 }

--
Gitblit v1.9.1