From 0f69561e397093b5165c4aac58530721d5c62178 Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期一, 25 十一月 2024 11:03:16 +0800
Subject: [PATCH] #led

---
 zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java |   20 +++++++++++++++++---
 1 files changed, 17 insertions(+), 3 deletions(-)

diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java
index 388135e..2290603 100644
--- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java
+++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java
@@ -3,16 +3,22 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.zy.asrs.framework.common.Cools;
 import com.zy.asrs.framework.common.SpringUtils;
+import com.zy.asrs.wcs.core.entity.BasLift;
 import com.zy.asrs.wcs.core.entity.Loc;
+import com.zy.asrs.wcs.core.service.BasLiftService;
 import com.zy.asrs.wcs.core.service.LocService;
 import com.zy.asrs.wcs.core.utils.RedisUtil;
+import com.zy.asrs.wcs.core.utils.Utils;
+import com.zy.asrs.wcs.rcs.cache.SlaveConnection;
 import com.zy.asrs.wcs.rcs.constant.DeviceRedisConstant;
 import com.zy.asrs.wcs.rcs.entity.BasShuttleErr;
 import com.zy.asrs.wcs.rcs.model.enums.ShuttleProtocolStatusType;
 import com.zy.asrs.wcs.rcs.entity.Device;
 import com.zy.asrs.wcs.rcs.entity.ShuttleDeviceStatus;
+import com.zy.asrs.wcs.rcs.model.enums.SlaveType;
 import com.zy.asrs.wcs.rcs.service.BasShuttleErrService;
 import com.zy.asrs.wcs.rcs.service.ShuttleDeviceStatusService;
+import com.zy.asrs.wcs.rcs.thread.LiftThread;
 import lombok.Data;
 import lombok.extern.slf4j.Slf4j;
 
@@ -227,7 +233,6 @@
         BasShuttleErrService basShuttleErrService = SpringUtils.getBean(BasShuttleErrService.class);
         BasShuttleErr shuttleErr = basShuttleErrService.getOne(new LambdaQueryWrapper<BasShuttleErr>()
                 .eq(BasShuttleErr::getErrorCode, this.errorCode)
-                .eq(BasShuttleErr::getHostId, this.device.getHostId())
                 .eq(BasShuttleErr::getDevicePlc, this.device.getDevicePlc()));
         if (shuttleErr != null) {
             return this.errorCode + "-" + shuttleErr.getErrName();
@@ -257,7 +262,8 @@
     //閫氳繃褰撳墠浜岀淮鐮佽幏鍙栧綋鍓嶅簱浣嶅彿
     public String getCurrentLocNo() {
         LocService locService = SpringUtils.getBean(LocService.class);
-        if (locService == null) {
+        BasLiftService basLiftService = SpringUtils.getBean(BasLiftService.class);
+        if (locService == null || basLiftService == null) {
             return null;
         }
         if (this.currentCode == null) {
@@ -270,9 +276,17 @@
                 .eq(Loc::getHostId, this.device.getHostId());
         Loc currentLoc = locService.getOne(wrapper);
         if (currentLoc == null) {
+            //鍙兘鏄彁鍗囨満鏉$爜
+            BasLift basLift = basLiftService.getOne(new LambdaQueryWrapper<BasLift>().eq(BasLift::getCode, this.currentCode).eq(BasLift::getStatus, 1));
+            if(basLift != null) {
+                LiftThread liftThread = (LiftThread) SlaveConnection.get(SlaveType.Lift, basLift.getDeviceId().intValue());
+                if (liftThread != null) {
+                    LiftProtocol liftProtocol = liftThread.getStatus();
+                    return Utils.getLocNo(basLift.getRow(), basLift.getBay(), liftProtocol.getLev());
+                }
+            }
             return null;
         }
-
         return currentLoc.getLocNo();
     }
 

--
Gitblit v1.9.1