From 2bdbfd1ac24d4e9a87daf6fb8b99ec32264d5752 Mon Sep 17 00:00:00 2001 From: luxiaotao1123 <t1341870251@163.com> Date: 星期六, 21 十二月 2024 11:25:27 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/KernelScheduler.java | 23 ++++++++++++++++------- 1 files changed, 16 insertions(+), 7 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/KernelScheduler.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/KernelScheduler.java index 24d04a8..9fde6cc 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/KernelScheduler.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/KernelScheduler.java @@ -37,6 +37,8 @@ private final ReentrantLock lock = new ReentrantLock(Boolean.TRUE); @Autowired + private AgvService agvService; + @Autowired private BusService busService; @Autowired private TaskService taskService; @@ -154,23 +156,30 @@ @Scheduled(cron = "0/1 * * * * ? ") private void autoLocToLoc() { if (!configService.getVal("TaskAssignMode", Boolean.class)) { return; } - int numOfAgv = 2; - int maxCapacity = 1 * numOfAgv; + + // 鏈�澶氫袱缁刡us杩愯 +// if (1 < busService.count(new LambdaQueryWrapper<Bus>().in(Bus::getBusSts, BusStsType.RECEIVE.val(), BusStsType.PROGRESS.val()))) { +// return; +// } + + int agvCount = agvService.count(new LambdaQueryWrapper<Agv>().eq(Agv::getStatus, StatusType.ENABLE.val)); AgvModel agvModel = agvModelService.getOne(new LambdaQueryWrapper<AgvModel>().eq(AgvModel::getType, AgvModelType.CTU_BOX_TRANSPORT_AGV.toString())); - if (null != agvModel) { - maxCapacity = agvModel.getBackpack() * numOfAgv; + if (null == agvModel || 0 == agvCount) { + return; } - int numOfStockLocList; +// int maxCapacity = agvModel.getBackpack() * agvCount; + int maxCapacity = agvModel.getBackpack(); + // STOCK List<Loc> stockList = locService.list(new LambdaQueryWrapper<Loc>().eq(Loc::getLocSts, LocStsType.STOCK.val())); - if (Cools.isEmpty(stockList)) { + if (Cools.isEmpty(stockList) || stockList.size() < agvModel.getBackpack()) { return; } Collections.shuffle(stockList); if (stockList.size() > maxCapacity) { stockList = stockList.subList(0, maxCapacity); } - numOfStockLocList = stockList.size(); + int numOfStockLocList = stockList.size(); // IDLE List<Loc> idleList = locService.list(new LambdaQueryWrapper<Loc>().eq(Loc::getLocSts, LocStsType.IDLE.val())); -- Gitblit v1.9.1