From 090b09847dc5317c2252c277fa39647e7e787988 Mon Sep 17 00:00:00 2001 From: zjj <3272660260@qq.com> Date: 星期六, 22 六月 2024 18:20:22 +0800 Subject: [PATCH] # --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/ShuttleDispatcher.java | 20 ++++++++++++-------- 1 files changed, 12 insertions(+), 8 deletions(-) diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/ShuttleDispatcher.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/ShuttleDispatcher.java index 1ac081c..9648ec7 100644 --- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/ShuttleDispatcher.java +++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/utils/ShuttleDispatcher.java @@ -302,20 +302,24 @@ } int lev = Utils.getLev(locNo);//褰撳墠妤煎眰 - JSONArray standbyLoc = JSON.parseArray(idleLoc); - if (lev > standbyLoc.size()) { + List<String> standbyLoc = JSON.parseArray(idleLoc, String.class); + if (standbyLoc.isEmpty()) { throw new CoolException("閬胯鏁版嵁寮傚父"); } - - Object object = standbyLoc.get(lev - 1); - List<String> locs = JSON.parseArray(object.toString(), String.class); - if (locs.isEmpty()) { - throw new CoolException("閬胯鏁版嵁涓虹┖"); + //鑾峰彇褰撳墠灞傞伩璁╀綅缃� + List<String> currentLevStandByLoc = new ArrayList<>(); + for (String loc : standbyLoc) { + if (Utils.getLev(loc) == lev) { + currentLevStandByLoc.add(loc); + } + } + if (currentLevStandByLoc.isEmpty()) { + throw new CoolException("褰撳墠灞傛棤閬胯浣嶇疆"); } Integer finalDistance = ShuttleDispatcher.INF; String recentLoc = null; - for (String loc : locs) { + for (String loc : currentLevStandByLoc) { //褰撳墠绌挎杞﹀埌閬胯浣嶈绠� List<NavigateNode> currentShuttlePath = NavigateUtils.calc( locNo -- Gitblit v1.9.1