From 2d6cdc6d4a4feac22724b516ffbaec629896255c Mon Sep 17 00:00:00 2001 From: whycq <913841844@qq.com> Date: 星期四, 19 九月 2024 20:30:56 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/AgvLocMastServiceImpl.java | 343 ++++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 301 insertions(+), 42 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/AgvLocMastServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/AgvLocMastServiceImpl.java index 9df60a7..d8e44fe 100644 --- a/src/main/java/com/zy/asrs/service/impl/AgvLocMastServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/AgvLocMastServiceImpl.java @@ -26,28 +26,17 @@ } public void initLocFloor1() { - //1妤� 13鎺� 86鍒� 12灞� - List<AgvLocMast> agvLocMastList = getLocMastList(1,13,1,86,1,12,1); - this.insertBatch(agvLocMastList); + this.insertBatch(getLocMastList(1, 22, 1, 39, 2, 2, 1)); } + public void initLocFloor2() { + //2妤� 1-25鎺� 1-33鍒� 1灞� + this.insertBatch(getLocMastList(1, 25, 1, 33, 1, 1, 2)); + } public void initLocFloor3() { - //3妤� 1-33鎺� 1-14鍒� 8灞� ------> 1-33鎺� 1-17鍒� 8灞� -// this.insertBatch(getLocMastList(1, 33, 1, 17, 1, 8, 3)); -// -// //3妤� 1-27鎺� 15-34鍒� 8灞� ------> 1-26鎺� 18-25鍒� 8灞� -// this.insertBatch(getLocMastList(1, 27, 18, 25, 1, 8, 3)); -// -// //3妤� 1-25鎺� 35-46鍒� 8灞� ------> 1-25鎺� 26-35鍒� 8灞� -// this.insertBatch(getLocMastList(1, 25, 26, 35, 1, 8, 3)); -// -// //3妤� 3-25鎺� 47-60鍒� 8灞� ------> 1-23鎺� 36-70鍒� 8灞� -// this.insertBatch(getLocMastList(1, 23, 36, 70, 1, 8, 3)); - - //3妤� 3-23鎺� 71-72鍒� 8灞� - this.insertBatch(getLocMastList(3, 23, 71, 72, 1, 8, 3)); - + //2妤� 1-25鎺� 1-33鍒� 1灞� + this.insertBatch(getLocMastList(1, 26, 1, 34, 1, 1, 3)); } //鏍规嵁鎺掑垪灞傝幏鍙朅GV搴撲綅鍒楄〃 @@ -58,26 +47,15 @@ for (int bay = bayIndex; bay <= bayMax; bay++) { for (int lev = levIndex; lev <= levMax; lev++) { - if(!checkLocExist(row,bay,floor)){ + if(!checkLocExistFloor1_2(row,bay)){ continue; } -// if(floor == 1 && (row == 8 || row == 9)){ -// if((bay >=8 && bay <=11) -// || (bay >= 20 && bay <=23) -// || (bay>=37 && bay <=39) -// || (bay>=50 && bay <=52) -// || (bay>=63 && bay <=64) -// || (bay>=79 && bay <=80)){ -// continue; -// } -// } - AgvLocMast loc = new AgvLocMast(); - String locRow = row < 10 ? "-00" + row : "-0" + row; - String locBay = bay < 10 ? "-00" + bay : "-0" + bay; - String locLev = lev < 10 ? "-0" + lev : "-" + lev; - String locNo = "SK" + locRow + locBay + locLev + "@" + floor; + String locRow = row < 10 ? "_00" + row : "_0" + row; + String locBay = bay < 10 ? "_00" + bay : "_0" + bay; + String locLev = lev < 10 ? "_0" + lev : "_" + lev; + String locNo = "YZ" + locRow + locBay + locLev + "F" + floor; loc.setLocNo(locNo); loc.setLocSts("O"); loc.setRow1(row); @@ -87,6 +65,8 @@ loc.setModiTime(now); loc.setFirstTime(now); loc.setAppeTime(now); + loc.setLocType1((short)3); + // loc.setLocType1(initLocMastSts3(row,bay)); agvLocMastList.add(loc); } } @@ -95,15 +75,263 @@ return agvLocMastList; } + private boolean checkLocExistFloor1_2(int row, int bay){ + if(row == 4 && bay == 19){ + return false; + } + + if(row == 5 && (bay == 3 || bay == 8 || bay == 13 || bay == 18 || bay == 19 || bay == 24 || bay == 29)){ + return false; + } + + if((row == 6 || row == 7) && bay == 39){ + return false; + } + + if((row == 9 || row == 10 || row == 14 || row == 18) && (bay == 3 || bay == 8 || bay == 13 || bay == 14 || bay == 19 || bay == 24 || bay == 29 || bay == 30)){ + return false; + } + if ((row == 10 || row == 11) && (bay == 7 || bay == 12 || bay == 23 || bay == 28 )) { + return false; + } + if ((row == 9 || row == 13) && bay == 35 ) { + return false; + } + if(row == 13 && (bay == 18 || bay == 19 || bay == 20)){ + return false; + } + if(row == 9 && bay == 18){ + return false; + } + if((row == 14 || row == 15) && bay > 37){ + return false; + } + if(row >= 16 && bay >= 35){ + return false; + } + if((row >= 2 && row <= 21) && bay == 17){ + return false; + } + + if(bay >= 33 && bay <= 34){ + return false; + } + + return true; + } + private boolean checkLocExistFloor1_1(int row, int bay){ + if(row <= 2 && bay >= 20){ + return false; + } + if ((row == 4 || row == 9 || row == 14 || row == 20 || row == 25 || row == 30) && (bay == 7 || bay == 11 || bay == 12 || bay == 16 )) { + return false; + } + if ((row == 7 || row == 13 || row == 21 || row == 26) && (bay == 12 || bay == 13 )) { + return false; + } + if (row >= 10 && bay == 1) { + return false; + } + if (row == 18 && bay <= 19) { + return false; + } + if (row == 25 && bay == 20) { + return false; + } + if ((row >= 26 && row <=27) && (bay >=18 && bay <= 19)) { + return false; + } + if (row >= 28 && bay == 20) { + return false; + } + + return true; + } + + private boolean checkLocExistFloor2(int row, int bay){ + if(row <= 4 && bay >= 13){ + return false; + } + + if(row <= 7 && bay >= 25){ + return false; + } + + if(row >= 24 && bay >= 29){ + return false; + } + + if((row != 20 && row != 25) && (bay ==8 || bay ==22)){ + return false; + } + + if((row == 3 || row == 12 || row == 16 || row == 21) && (bay ==4 || bay ==9 || bay == 14 || bay == 20 || bay == 25 || bay ==30 || bay == 31)){ + return false; + } + + if(row == 21 && bay == 15){ + return false; + } + + if(row == 23 && bay == 29){ + return false; + } + + return true; + } + + private short initLocMastSts(int row, int bay){ + + if(row <= 11 && bay <= 14){ + return 1; + } + + if(row <= 7){ + return 1; + } + + if(row >= 21){ + return 3; + } + + return 2; + } + private boolean checkLocExistFloor3(int row, int bay){ + if(row == 1 && (bay <= 15 || bay >= 30)){ + return false; + } + + if(row <= 6 && bay >= 30){ + return false; + } + + if((row >= 9 && row <= 16) && (bay <= 4 || bay >= 33)){ + return false; + } + if(row == 17 && (bay <= 3 || bay >= 33)){ + return false; + } + + if(row <= 21 && row != 7 && row != 8 && bay >= 33){ + return false; + } + if((row <= 24 && row != 7 && row != 8) && bay >= 34){ + return false; + } + if(row >= 25 && row <= 26 && bay >= 29){ + return false; + } + + + if((row != 8 && row != 21 && row != 23 && row != 24 && row != 25 && row != 26) && bay == 15){ + return false; + } + + if((row >= 22 && row != 26 ) && bay == 16){ + return false; + } + + if (row == 4 && (bay == 3 || bay == 4 || bay == 9 || bay == 14 || bay == 19 || bay == 20 || bay == 25)) { + return false; + } + + if ((row == 13 || row == 17) && (bay == 8 || bay == 14 || bay == 19 || bay == 24 )) { + return false; + } + if (row == 22 && (bay == 4 || bay == 9 || bay == 14 || bay == 20 || bay == 25 )) { + return false; + } + + return true; + } + + private short initLocMastSts3(int row, int bay){ + + if(row <= 8){ + return 1; + } + + if(row <= 17){ + return 2; + } + + if(row <= 18 && bay >= 9){ + return 2; + } + + if(row <= 21){ + return 4; + } + + if(row >= 22){ + return 3; + } + + return 2; + } + private boolean checkLocExist(int row, int bay, int floor){ - if(floor == 1 && (row == 8 || row == 9)){ - if((bay >=8 && bay <=11) - || (bay >= 20 && bay <=23) - || (bay>=37 && bay <=39) - || (bay>=50 && bay <=52) - || (bay>=63 && bay <=64) - || (bay>=79 && bay <=80)){ + //if(floor == 1 && (row == 2)){ + // if((bay >=8 && bay <=11) + // || (bay >= 20 && bay <=23) + // || (bay>=37 && bay <=39) + // || (bay>=50 && bay <=52) + // || (bay>=63 && bay <=64) + // || (bay>=79 && bay <=80)){ + // return false; + // } + //} + if (floor == 1) { + if (row == 2 || row == 5 || row == 8 || row == 11 + || row == 14 || row == 17 || row == 19 || row == 22 || row == 25 + || row == 28 || (row >29 && row <39)|| row == 41|| row == 44) { return false; + } else if (row == 1) { + if (bay < 19) { + return false; + } + } else if (row == 3 || row == 4) { + if (bay < 19 || bay == 26) { + return false; + } + } else if (row == 6) { + if (bay < 20 || bay == 26 || bay == 30) { + return false; + } + } else if (row == 7) { + if (bay < 4 || bay == 26) { + return false; + } + } else if (row == 9 || row ==10 ) { + if (bay < 4 || bay == 12 || bay == 26) { + return false; + } + } else if (row == 12) { + if (bay < 4) { + return false; + } + } else if (row == 15 || row == 18 || row == 20 || row == 21 || row == 24 || row == 26 || row == 27 || row == 40) { + if (bay == 12 || bay == 26) { + return false; + } + } else if (row == 16 || row == 23 || row == 39) { + if (bay == 3 || bay == 4 || bay == 9 || bay == 12 || bay == 14 || bay == 20 || bay == 25 || bay == 26) { + return false; + } + } else if (row == 42) { + if (bay == 5 || bay == 12 || bay == 26) { + return false; + } + } else if (row == 43) { + if (bay < 6 || bay == 12 || bay == 26) { + return false; + } + } else if (row == 45) { + if (bay < 6) { + return false; + } + } else { + return true; } } @@ -137,10 +365,22 @@ this.baseMapper.updateLocType2(locType2,locRule.getRowBeg(),locRule.getRowEnd(),locRule.getBayBeg(),locRule.getBayEnd(),locRule.getLevBeg(),locRule.getLevEnd(),locRule.getFloor()); } - public void updateLocStsByLocNo(String locNo, String locSts, String barcode) { + public void updateLocStsByLocNo(String locNo, String locSts, String barcode,Short containerType) { AgvLocMast agvLocMast = this.selectById(locNo); agvLocMast.setLocSts(locSts); agvLocMast.setBarcode(barcode); + agvLocMast.setLocType2(containerType); + agvLocMast.setModiTime(new Date()); + this.updateById(agvLocMast); + } + public void updateLocStsByLocNo(String locNo, String locSts, String barcode,Short containerType,String locType,Short locType3) { + AgvLocMast agvLocMast = this.selectById(locNo); + agvLocMast.setLocSts(locSts); + agvLocMast.setBarcode(barcode); + agvLocMast.setLocType2(containerType); + agvLocMast.setLocType(locType); + agvLocMast.setLocType3(locType3); + agvLocMast.setModiTime(new Date()); this.updateById(agvLocMast); } @@ -155,4 +395,23 @@ //return this.agvLocMastMapper.selectLocByLevAndFloor(lev,floor); } + @Override + public AgvLocMast selectEmptyZpallet(int type, int floor) { + + return this.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_sts","D").eq("loc_type2",type).eq("floor",floor)); + + } + + @Override + public AgvLocMast selectEmptyZpalletByLocType1(int type) { + + return this.selectOne(new EntityWrapper<AgvLocMast>().eq("loc_sts","D").eq("loc_type1",type)); + + } + + @Override + public List<String> queryContainerTypeByLocType1(Short locType1) { + return this.baseMapper.queryContainerTypeByLocType1(locType1); + } + } -- Gitblit v1.9.1