From d59d4495574968e23e520da71f89790f0ad09df0 Mon Sep 17 00:00:00 2001 From: vincentlu <t1341870251@gmail.com> Date: 星期二, 01 四月 2025 11:06:09 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java | 114 ++++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 77 insertions(+), 37 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java index 2496c26..e49c524 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MainService.java @@ -35,7 +35,7 @@ import com.zy.acs.manager.system.service.ConfigService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.stereotype.Component; +import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Propagation; import org.springframework.transaction.annotation.Transactional; import org.springframework.transaction.interceptor.TransactionAspectSupport; @@ -47,7 +47,7 @@ * Created by vincent on 2023/6/14 */ @Slf4j -@Component("mainService") +@Service("mainService") public class MainService { @Autowired @@ -96,7 +96,6 @@ private LaneService laneService; @Autowired private ActionSorter actionSorter; - @SuppressWarnings("all") @Transactional @@ -175,8 +174,28 @@ if (!locService.updateById(oriLoc)) { throw new BusinessException("oriLoc锛�" + task.getOriLoc$() + " failed to update"); } + + destSta = staService.getById(task.getDestSta()); + if (!destSta.getStaSts().equals(StaStsType.IDLE.val())) { + throw new BusinessException("destSta锛�" + task.getDestSta$() + " is not in IDLE status"); + } + destSta.setStaSts(StaStsType.PAKIN.val()); + destSta.setUpdateTime(now); + if (!staService.updateById(destSta)) { + throw new BusinessException("destSta锛�" + task.getDestSta$() + " failed to update"); + } break; case STA_TO_LOC: + oriSta = staService.getById(task.getOriSta()); + if (!oriSta.getStaSts().equals(StaStsType.STOCK.val())) { + throw new BusinessException("oriSta锛�" + task.getOriSta$() + " is not in STOCK status"); + } + oriSta.setStaSts(StaStsType.PAKOUT.val()); + oriSta.setUpdateTime(now); + if (!staService.updateById(oriSta)) { + throw new BusinessException("oriSta锛�" + task.getOriSta$() + " failed to update"); + } + destLoc = locService.getById(task.getDestLoc()); if (!destLoc.getLocSts().equals(LocStsType.IDLE.val())) { throw new BusinessException("destLoc锛�" + task.getDestLoc$() + " is not in IDLE status"); @@ -188,6 +207,25 @@ } break; case STA_TO_STA: + oriSta = staService.getById(task.getOriSta()); + if (!oriSta.getStaSts().equals(StaStsType.STOCK.val())) { + throw new BusinessException("oriSta锛�" + task.getOriSta$() + " is not in STOCK status"); + } + oriSta.setStaSts(StaStsType.PAKOUT.val()); + oriSta.setUpdateTime(now); + if (!staService.updateById(oriSta)) { + throw new BusinessException("oriSta锛�" + task.getOriSta$() + " failed to update"); + } + + destSta = staService.getById(task.getDestSta()); + if (!destSta.getStaSts().equals(StaStsType.IDLE.val())) { + throw new BusinessException("destSta锛�" + task.getDestSta$() + " is not in IDLE status"); + } + destSta.setStaSts(StaStsType.PAKIN.val()); + destSta.setUpdateTime(now); + if (!staService.updateById(destSta)) { + throw new BusinessException("destSta锛�" + task.getDestSta$() + " failed to update"); + } break; default: break; @@ -223,7 +261,7 @@ for (Task task : taskList) { Agv agv = allocateService.execute(task); if (null == agv) { -// log.warn("Task[{}] has an issue锛� because it failed to checkout agv which is idle...", task.getSeqNum()); +// log.warn("Task[{}] has an issue锛� because it failed to check out agv which is idle...", task.getSeqNum()); continue; } task.setAgvId(agv.getId()); @@ -827,23 +865,24 @@ assert backpackType != null; // 妫�楠屾柟鍚� if (!lastDirection.equals(workDirection)) { + throw new CoolException(agvNo + "鍙峰皬杞︽柟鍚戦敊璇紝璇锋帹鑷宠浆寮偣鎵嬪姩璋冩暣"); // turn - actionList.add(new Action( - null, // 缂栧彿 - task.getBusId(), // 鎬荤嚎 - task.getId(), // 浠诲姟 - null, // 鍔ㄤ綔鍙� - null, // 浼樺厛绾� - ActionTypeType.TurnCorner.desc, // 鍚嶇О - mapService.isTurnCorner(lastCode.getData()) ? 1D : 0D, // 灞炴�у�� - lastCode.getData(), // 鍦伴潰鐮� - String.valueOf(workDirection), // 鍔ㄤ綔鍙傛暟 - ActionTypeType.TurnCorner.val(), // 鍔ㄤ綔绫诲瀷 - actionPrepareSts, // 鍔ㄤ綔杩涘害 - agvId, // AGV - now // 宸ヤ綔鏃堕棿 - )); - lastDirection = workDirection; +// actionList.add(new Action( +// null, // 缂栧彿 +// task.getBusId(), // 鎬荤嚎 +// task.getId(), // 浠诲姟 +// null, // 鍔ㄤ綔鍙� +// null, // 浼樺厛绾� +// ActionTypeType.TurnCorner.desc, // 鍚嶇О +// mapService.isTurnCorner(lastCode.getData()) ? 1D : 0D, // 灞炴�у�� +// lastCode.getData(), // 鍦伴潰鐮� +// String.valueOf(workDirection), // 鍔ㄤ綔鍙傛暟 +// ActionTypeType.TurnCorner.val(), // 鍔ㄤ綔绫诲瀷 +// actionPrepareSts, // 鍔ㄤ綔杩涘害 +// agvId, // AGV +// now // 宸ヤ綔鏃堕棿 +// )); +// lastDirection = workDirection; } // 璐ф灦鍙栬揣 Loc oriLoc = locService.getById(task.getOriLoc()); @@ -885,23 +924,24 @@ assert backpackType != null; // 妫�楠屾柟鍚� if (!lastDirection.equals(workDirection)) { - // turn - actionList.add(new Action( - null, // 缂栧彿 - task.getBusId(), // 鎬荤嚎 - task.getId(), // 浠诲姟 - null, // 鍔ㄤ綔鍙� - null, // 浼樺厛绾� - ActionTypeType.TurnCorner.desc, // 鍚嶇О - mapService.isTurnCorner(lastCode.getData()) ? 1D : 0D, // 灞炴�у�� - lastCode.getData(), // 鍦伴潰鐮� - String.valueOf(workDirection), // 鍔ㄤ綔鍙傛暟 - ActionTypeType.TurnCorner.val(), // 鍔ㄤ綔绫诲瀷 - actionPrepareSts, // 鍔ㄤ綔杩涘害 - agvId, // AGV - now // 宸ヤ綔鏃堕棿 - )); - lastDirection = workDirection; + throw new CoolException(agvNo + "鍙峰皬杞︽柟鍚戦敊璇紝璇锋帹鑷宠浆寮偣鎵嬪姩璋冩暣"); +// // turn +// actionList.add(new Action( +// null, // 缂栧彿 +// task.getBusId(), // 鎬荤嚎 +// task.getId(), // 浠诲姟 +// null, // 鍔ㄤ綔鍙� +// null, // 浼樺厛绾� +// ActionTypeType.TurnCorner.desc, // 鍚嶇О +// mapService.isTurnCorner(lastCode.getData()) ? 1D : 0D, // 灞炴�у�� +// lastCode.getData(), // 鍦伴潰鐮� +// String.valueOf(workDirection), // 鍔ㄤ綔鍙傛暟 +// ActionTypeType.TurnCorner.val(), // 鍔ㄤ綔绫诲瀷 +// actionPrepareSts, // 鍔ㄤ綔杩涘害 +// agvId, // AGV +// now // 宸ヤ綔鏃堕棿 +// )); +// lastDirection = workDirection; } // 鏆傚瓨鐐瑰彇璐ц揣 actionList.add(new Action( -- Gitblit v1.9.1