From d7586e563701a4cb65065be3c4c3e4e66220222d Mon Sep 17 00:00:00 2001 From: L <L@123> Date: 星期四, 25 九月 2025 10:00:38 +0800 Subject: [PATCH] * --- src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java | 99 ++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 84 insertions(+), 15 deletions(-) diff --git a/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java b/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java index 465a3e5..c554e12 100644 --- a/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java +++ b/src/main/java/com/zy/asrs/task/OrderToSortLineScheduler.java @@ -40,6 +40,7 @@ // log.info("鏈湁鏂拌鍗�"); return; } + //閬嶅巻鍗曟嵁 for (String orderNo : orderNos) { List<OrderDetl> orderDetls = orderDetlService.selectByOrderNo(orderNo); @@ -50,8 +51,22 @@ Long bindingTag = System.currentTimeMillis();//娣锋惌鏍囪 List<OrderToLine.MatList> matLists = new ArrayList<>(); + List<OrderToLine.MatList> matListsRemainder = new ArrayList<>(); + List<OrderDetl> orderDetlsRemainder = new ArrayList<>(); + for (OrderDetl orderDetl : orderDetls) { Integer number = basArmRulesService.getNumber(orderDetl.getWeight(),orderDetl.getVolume(),orderDetl.getManLength(),orderDetl.getWidth(),orderDetl.getHeight()); + if (number == null) { + BasArmRules basArmRules = new BasArmRules(); + basArmRules.setMaterialHeight(orderDetl.getHeight()); + basArmRules.setMaterialWeight(orderDetl.getWeight()); + basArmRules.setMaterialLength(orderDetl.getManLength()); + basArmRules.setMaterialWidth(orderDetl.getWidth()); + basArmRulesService.insert(basArmRules); + return; + } else if (number == 0){ + return; + } Double anfme = orderDetl.getAnfme(); Double remainder = anfme % number; //鍙栦綑 浣欐暟娣锋惌 if(remainder != 0){ @@ -59,27 +74,34 @@ OrderToLine.MatList matMix = new OrderToLine.MatList( orderDetl.getMatnr(), // matnr -> sku orderDetl.getSupp(), // supp -> po - remainder, // 浣欐枡 -> 鍓╀綑浣欐枡缁熶竴鏃堕棿鎴虫爣璁� - orderDetl.getBarcode(), //barcode -> upc 鏉$爜 + orderDetl.getAnfme(), // 浣欐枡 -> 鍓╀綑浣欐枡缁熶竴鏃堕棿鎴虫爣璁� + orderDetl.getSku(), //barcode -> upc 鏉$爜 1, - orderDetl.getOrigin(), //origin -> supplier 璐ф簮 + null, //origin -> supplier 璐ф簮 bindingTag //浣欐枡鏍囪鐩稿悓 ); +// matListsRemainder.add(matMix); +// orderDetlsRemainder.add(orderDetl); matLists.add(matMix); + } else { + Double ctns = anfme - remainder; + // 缁勮鐗╂枡淇℃伅 + OrderToLine.MatList mat = new OrderToLine.MatList( + orderDetl.getMatnr(), // matnr -> sku + orderDetl.getSupp(), // supp -> po + orderDetl.getAnfme(), //鏁存枡 + orderDetl.getSku(), //barcode -> upc + 1, + null, //origin -> supplier 璐ф簮 + System.currentTimeMillis() + ); + matLists.add(mat); } - Double ctns = anfme - remainder; - // 缁勮鐗╂枡淇℃伅 - OrderToLine.MatList mat = new OrderToLine.MatList( - orderDetl.getMatnr(), // matnr -> sku - orderDetl.getSupp(), // supp -> po - ctns, //鏁存枡 - orderDetl.getBarcode(), //barcode -> upc - 1, - orderDetl.getOrigin(), //origin -> supplier 璐ф簮 - System.currentTimeMillis() - ); - matLists.add(mat); } +// // 鏅鸿兘鍒嗙粍浣欐枡 +// if (matListsRemainder.size() > 0) { +// groupRemainders(orderDetlsRemainder, orderDetlsRemainder.size(), orderDetls.size(), matLists); +// } orderToLine.setMatList(matLists); try{ ReturnT<String> returnT = orderToLineHandler.start(orderToLine); @@ -94,4 +116,51 @@ } + + private void groupRemainders(List<OrderDetl> sameMaterialList, double totalRemainder, + int number, List<OrderToLine.MatList> matLists) { + // 绛栫暐1: 濡傛灉浣欐枡鎬婚噺杈冨ぇ锛屽皾璇曞垎鎴愬涓悎鐞嗗ぇ灏忕殑缁� + if (totalRemainder > number * 0.6) { + // 鍙互鍒嗘垚2缁勬垨鏇村缁� + int suggestedGroups = (int) Math.ceil(totalRemainder / (number * 0.8)); + distributeRemainders(sameMaterialList, totalRemainder, suggestedGroups, matLists); + } else { + // 灏忎綑鏂欏崟缁勫鐞� + Long bindingTag = System.currentTimeMillis(); + matLists.add(createMatListItem(sameMaterialList.get(0), totalRemainder, bindingTag, true)); + } + } + + + private void distributeRemainders(List<OrderDetl> sameMaterialList, double totalRemainder, + int groupCount, List<OrderToLine.MatList> matLists) { + double average = totalRemainder / groupCount; + + for (int i = 0; i < groupCount; i++) { + double groupQuantity; + if (i == groupCount - 1) { + // 鏈�鍚庝竴缁勫彇鍓╀綑鎵�鏈� + groupQuantity = totalRemainder - (average * (groupCount - 1)); + } else { + groupQuantity = average; + } + + // 涓烘瘡缁勭敓鎴愬敮涓�鏍囪 + Long groupTag = System.currentTimeMillis() + i; + matLists.add(createMatListItem(sameMaterialList.get(0), groupQuantity, groupTag, true)); + } + } + + private OrderToLine.MatList createMatListItem(OrderDetl orderDetl, Double quantity, Long bindingTag, boolean isRemainder) { + return new OrderToLine.MatList( + orderDetl.getMatnr(), + orderDetl.getSupp(), + quantity, + orderDetl.getBarcode(), + 1, + isRemainder ? null : orderDetl.getOrigin(), + isRemainder ? bindingTag : System.currentTimeMillis() + ); + } + } -- Gitblit v1.9.1