From 21d0e7ab9d5c7316225a3e9eecf465cd37c9bd85 Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期四, 05 六月 2025 14:15:07 +0800 Subject: [PATCH] 123 --- src/main/java/com/zy/asrs/utils/Utils.java | 194 ++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 187 insertions(+), 7 deletions(-) diff --git a/src/main/java/com/zy/asrs/utils/Utils.java b/src/main/java/com/zy/asrs/utils/Utils.java index 1149736..cd0417e 100644 --- a/src/main/java/com/zy/asrs/utils/Utils.java +++ b/src/main/java/com/zy/asrs/utils/Utils.java @@ -488,8 +488,8 @@ add(zerofill(String.valueOf(3), 2) + locNo.substring(2)); }}; case 3: - return new ArrayList<>(); case 4: + return new ArrayList<>(); case 5: return new ArrayList<String>() {{ add(zerofill(String.valueOf(4), 2) + locNo.substring(2)); @@ -521,8 +521,8 @@ add(zerofill(String.valueOf(11), 2) + locNo.substring(2)); }}; case 11: - return new ArrayList<>(); case 12: + return new ArrayList<>(); case 13: return new ArrayList<String>() {{ add(zerofill(String.valueOf(12), 2) + locNo.substring(2)); @@ -548,8 +548,8 @@ add(zerofill(String.valueOf(18), 2) + locNo.substring(2)); }}; case 18: - return new ArrayList<>(); case 19: + return new ArrayList<>(); case 20: return new ArrayList<String>() {{ add(zerofill(String.valueOf(19), 2) + locNo.substring(2)); @@ -740,6 +740,68 @@ } } + public static List<String> getGroupOutsideLoc(String locNo){ + int row = getRow(locNo); + switch (row) { + case 1: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(2), 2) + locNo.substring(2)); + }}; + case 2: + case 3: + case 4: + case 5: + return new ArrayList<>(); + case 6: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(5), 2) + locNo.substring(2)); + }}; + case 7: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(6), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(5), 2) + locNo.substring(2)); + }}; + case 8: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(9), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(10), 2) + locNo.substring(2)); + }}; + case 9: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(10), 2) + locNo.substring(2)); + }}; + case 10: + case 11: + case 12: + case 13: + return new ArrayList<>(); + case 14: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(13), 2) + locNo.substring(2)); + }}; + case 15: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(16), 2) + locNo.substring(2)); + add(zerofill(String.valueOf(17), 2) + locNo.substring(2)); + }}; + case 16: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(17), 2) + locNo.substring(2)); + }}; + case 17: + case 18: + case 19: + case 20: + return new ArrayList<>(); + case 21: + return new ArrayList<String>() {{ + add(zerofill(String.valueOf(20), 2) + locNo.substring(2)); + }}; + default: + throw new RuntimeException("搴撲綅瑙f瀽寮傚父"); + } + } + public Map<Integer, List<Integer>> getRowSeqHasSortOfPakin(int start, int end) { Map<Integer, List<Integer>> result = new HashMap<>(); for (int i = start ; i <= end; i++) { @@ -799,6 +861,25 @@ } } return false; + } + + /** + * 妫�娴嬪綋鍓嶅簱浣嶅渚у叾浠栧簱浣嶆槸鍚︿负O + * 杩斿洖true琛ㄧず澶栦晶搴撲綅鏄疧锛岃繑鍥瀎alse琛ㄧず鍐呬晶搴撲綅涓嶆槸O + */ + public static boolean checkOutsideLocIsDFX(String locNo) { + LocMastService locMastService = SpringUtils.getBean(LocMastService.class); + List<String> insideLoc = Utils.getGroupOutsideLoc(locNo); + if (insideLoc.size() > 0) { + List<LocMast> insideLocMast = locMastService.selectByLocNos(insideLoc); + for (LocMast mast : insideLocMast) { + if (!mast.getLocSts().equals("O")) { + //锛丱(涓嶈兘閫夊畾杩欎釜澶栦晶搴撲綅) + return false; + } + } + } + return true; } /** @@ -868,10 +949,10 @@ return randomCrnNo; } - public static void main(String[] args) { - List<String> groupLoc = Utils.getGroupLoc("1300801"); - System.out.println(groupLoc); - } + //public static void main(String[] args) { + // List<String> groupLoc = Utils.getGroupLoc("1300801"); + // System.out.println(groupLoc); + //} public static Double getIoPri(String locNo){ switch (Utils.getRow(locNo)){ @@ -997,4 +1078,103 @@ } } + public static void main(String[] args) { + ArrayList<String> locS = new ArrayList<String>(); + locS.add("1902501"); + locS.add("2102501"); + locS.add("1802301"); + locS.add("1800101"); + locS.add("0300102"); + locS.add("0100102"); + List<String> innermostSideLoc = getInnermostSideLoc(locS, true); + System.out.println(innermostSideLoc); + } + + public static List<String> getInnermostSideLoc(List<String> locS, boolean pakin){ + ArrayList<String> listLoc = new ArrayList<>(); + ArrayList<String> listLocRBL = new ArrayList<>(); + for (String locNo : locS){ + if (!listLocRBL.contains(Utils.getInnermostSideLocRBL(locNo, pakin))){ + listLocRBL.add(Utils.getInnermostSideLocRBL(locNo, pakin)); + listLoc.add(locNo); + }else { + for (String loc1 : listLoc){ + if (Utils.getInnermostSideLocRBL(locNo, pakin).equals(Utils.getInnermostSideLocRBL(loc1, pakin))){ + if (!pakin){ + if (Utils.getRow(loc1)>17 && Utils.getRow(locNo)>Utils.getRow(loc1) ){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + }else if ( Utils.getRow(loc1)<18 && Utils.getRow(locNo)<Utils.getRow(loc1)){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + } + }else { + if ( Utils.getRow(loc1)<4 && Utils.getRow(locNo)>Utils.getRow(loc1)){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + } else if (Utils.getRow(loc1)>3 && Utils.getRow(loc1)<8 && Utils.getRow(locNo)<Utils.getRow(loc1) ){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + } else if (Utils.getRow(loc1)>7 && Utils.getRow(loc1)<12 && Utils.getRow(locNo)>Utils.getRow(loc1) ){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + } else if (Utils.getRow(loc1)>11 && Utils.getRow(loc1)<15 && Utils.getRow(locNo)<Utils.getRow(loc1) ){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + } else if (Utils.getRow(loc1)>14 && Utils.getRow(loc1)<19 && Utils.getRow(locNo)>Utils.getRow(loc1) ){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + } else if ( Utils.getRow(loc1)>18 && Utils.getRow(locNo)<Utils.getRow(loc1)){ + listLoc.remove(loc1); + listLoc.add(locNo); + break; + } + } + } + } + } + } + return listLoc; + } + + public static String getInnermostSideLocRBL(String locNo, boolean pakin){ + int row = Utils.getRow(locNo); + if (row <= 3) { + row = 3; + } else if (row <= 7) { + row = 4; + } else if (row <= 11) { + row = 11; + } else if (row <= 14) { + row = 12; + } else if (row <= 18) { + row = 18; + } else { + row = 19; + } + return ""+row+Utils.getBay(locNo)+Utils.getLev(locNo); + + //if (row <3){ + // return ""+33+Utils.getBay(locNo)+Utils.getLev(locNo); + //}else if (row>30){ + // return ""+31+Utils.getBay(locNo)+Utils.getLev(locNo); + //} + //if (row<18 && row>1){ + // row=1; + //}else if (row < 31 && row>17){ + // row=2; + //} + //if (pakin){ + // row=3-row; + //} + //return ""+row+Utils.getBay(locNo)+Utils.getLev(locNo); + + } } -- Gitblit v1.9.1