From c1d30e0e96f9fc0d32a9a5007977ce305e0d22c5 Mon Sep 17 00:00:00 2001 From: yxFwq <1> Date: 星期三, 01 一月 2025 17:56:11 +0800 Subject: [PATCH] # --- src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java | 188 ++++++++++++++++++++++++++++++++++------------ 1 files changed, 137 insertions(+), 51 deletions(-) diff --git a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java index 3021a32..2e7b800 100644 --- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java +++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java @@ -1135,7 +1135,7 @@ String barcode = wrkMast.getBarcode(); if(!Cools.isEmpty(barcode)) { - if("NG".endsWith(barcode) || "NoRead".equals(barcode) || "empty".equals(barcode)) { + if("NG".endsWith(barcode) || "NoRead".equals(barcode) || "00000000".equals(barcode) || "empty".equals(barcode)) { continue; } } else { @@ -4053,7 +4053,7 @@ String barcode = staProtocol.getBarcode(); if (!Cools.isEmpty(barcode)) { // log.info("{}鍙锋潯鐮佹壂鎻忓櫒妫�娴嬫潯鐮佷俊鎭細{}", inSta.getBarcode(), barcode); - if ("NG".endsWith(barcode) || "NoRead".equals(barcode) || !CodeDetectionUtil.barcodeDetection(barcode)) { + if ("NG".endsWith(barcode) || "NoRead".equals(barcode) || "00000000".equals(barcode) || !CodeDetectionUtil.barcodeDetection(barcode)) { continue; } } else { @@ -5158,7 +5158,7 @@ if (jarMaxLoc == 0 || basJarOther.getJarCount() == 0) { break; } - int count = basJarMastService.selectCount(new EntityWrapper<BasJarMast>().eq("jar_regin", basJar.getRegion()).lt("status", 17).gt("status", 6)); + int count = basJarMastService.selectCount(new EntityWrapper<BasJarMast>().eq("jar_regin", basJar.getRegion()).lt("status", 17).gt("status", 5)); if (count>0){ break; } @@ -5367,8 +5367,8 @@ case 3: case 4: signExecute = jarWrkMastExecuteGenerateJar(signExecute,sign);//纭寲缃愪换鍔� - case 5: - signExecute = jarWrkMastExecuteGenerateBurial(signExecute, sign);//鍐峰嵈妲藉彇杈撻�佺嚎 +// case 5: +// signExecute = jarWrkMastExecuteGenerateBurial(signExecute, sign);//鍐峰嵈妲藉幓杈撻�佺嚎 default: jarWrkMastExecuteGenerateSte(signExecute,sign);//灏忚溅绉诲姩 // signExecute = jarWrkMastExecuteGenerateBurial(signExecute, sign);//鍐峰嵈妲藉彇杈撻�佺嚎 @@ -5967,9 +5967,9 @@ if (!basJarMastListOther.isEmpty() && basJarMastListOther.size() < basJarOther.getJarCount()){ return false; } - if (basJarMastService.selectJarMastOperation(jarSlave.getJarOtherId(),4)!=0 && !basJarMastService.selectJarMastOperation(jarSlave.getJarOtherId(), 4).equals(basJarOther.getJarCount() )){ - return false; - } +// if (basJarMastService.selectJarMastOperation(jarSlave.getJarOtherId(),4)!=0 && !basJarMastService.selectJarMastOperation(jarSlave.getJarOtherId(), 4).equals(basJarOther.getJarCount() )){ +// return false; +// } // //涓存椂 // if (basJar.getJarCode()==1){ @@ -6462,12 +6462,12 @@ if (jarWrkMastExecuteActionExecute5Three(wrkMastExecute,sign)){ break; } - return; + continue; case 6: if (jarWrkMastExecuteActionExecute6Three(wrkMastExecute,sign)){ break; } - return; + continue; } } } catch (Exception e){ @@ -7202,7 +7202,7 @@ return false; } //璋冭溅 == > 鍙栬揣 - if (!jarSteTake(wrkMastExecute,SteLocaType.POINT23.id,SteLocaType.POINT25.id,SteTaskModeType.STE_WFFH_13,false,SteAndJarUtil.getBJarNo(wrkMastExecute.getJarId()))){ + if (!jarSteTake(wrkMastExecute,SteLocaType.POINT23.id,SteLocaType.POINT26.id,SteTaskModeType.STE_WFFH_13,false,SteAndJarUtil.getBJarNo(wrkMastExecute.getJarId()))){ log.error("绌挎鏉縎te鍛戒护涓嬪彂澶辫触锛宻te鍙�={},浠诲姟鏁版嵁={},纭寲缃愭暟鎹�={},sign={}", wrkMastExecute.getJarId(), JSON.toJSONString(wrkMastExecute), JSON.toJSONString(jarProtocol),sign); } @@ -7927,26 +7927,88 @@ switch (sign){ case 1: if (jarWrkMastExecuteGenerateSteComplete(sign)){ - break; + return; } case 2: if (jarWrkMastExecuteGenerateJarComplete(sign)){ - break; + return; } case 3: if (jarWrkMastExecuteGenerateRgvComplete1(sign)){ - break; + return; } case 4: if (jarWrkMastExecuteGenerateRgvComplete2(sign)){ - break; + return; } default: - return; + break; } + jarWrkMastExecuteGenerateDevComplete(sign); }catch (Exception e){ log.error("JarWrkMastExecute浠诲姟瀹屾垚鎶ラ敊锛�"+e); } + } + + /** + * JarWrkMastExecute浠诲姟瀹屾垚 ===>Devp //瀹屾垚 + */ + public synchronized boolean jarWrkMastExecuteGenerateDevComplete(Integer sign) { + try{ + // 鏍规嵁杈撻�佺嚎plc閬嶅巻 + for (DevpSlave devp : slaveProperties.getDevp()) { + // 閬嶅巻鍏ュ簱鍙� + for (DevpSlave.Sta inSta : devp.getOutJarInSta()) { + SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId()); + StaProtocol staProtocol = devpThread.getStation().get(inSta.getStaNo()); + if (staProtocol == null) { + continue; + } else { + staProtocol = staProtocol.clone(); + } + // 鍒ゆ柇鏄惁婊¤冻鏉′欢 + if (staProtocol.isAutoing() + && staProtocol.isLoading() + && staProtocol.isInEnable() + && staProtocol.getWorkNo() == 0 + && staProtocol.isPakMk()) { + for (DevpSlave.Jar jar : inSta.getJarList()) { + // 鍒ゆ柇閲嶅宸ヤ綔妗� + List<BasJarMast> basJarMastList = basJarMastService.getJarMastByJarIdAndStatusListB(jar.getBurial(), new ArrayList<Integer>() {{ + add(9); + add(11); + }}); + if (basJarMastList.isEmpty()){ + continue; + } + BasJarMast jarMastByWrkNo = basJarMastList.get(0); + jarMastByWrkNo.setStatus(jarMastByWrkNo.getStatusComplete(6)); + + + StaProtocol staProtocolNew = new StaProtocol(); + staProtocolNew.setSiteId(staProtocol.getSiteId()); + staProtocolNew.setWorkNo(basJarMastList.get(0).getWrkNo().intValue()); + staProtocolNew.setStaNo(jar.getEndStaNo()); + devpThread.setPakMk(staProtocolNew.getSiteId(), false,7989); + boolean result = MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocolNew)); + if (!result) { + LedErrorThreadUtil.ledErrorThread("鏇存柊plc绔欑偣淇℃伅澶辫触!绔欑偣鍙凤細"+inSta.getStaNo(),inSta.getLed(), LedErrorAreaType.ONE_OTHER.getDesc()); + throw new CoolException("鏇存柊plc绔欑偣淇℃伅澶辫触"); + } + if (!basJarMastService.updateById(jarMastByWrkNo)){ + log.error("纭寲鍖哄煙鍒嗘浠诲姟瀹屾垚寮傚父,BasJarMast={},寮傚父淇℃伅={}",JSON.toJSONString(jarMastByWrkNo),"鏇存柊basJarMast澶辫触"); + throw new CoolException("鏇存柊basJarMast澶辫触"); + } + break; + } + } + } + } + return true; + }catch (Exception e){ + log.error("JarWrkMastExecute浠诲姟瀹屾垚 ===>Ste鎶ラ敊锛�"+e); + } + return false; } /** @@ -8089,6 +8151,30 @@ if (Cools.isEmpty(basJar)){ log.error("{}鍙风~鍖栫綈鏌ヨ璁惧妗f鏃犱俊鎭紒锛侊紒",jarProtocol.getJarNo()); continue; + } + if (jarProtocol.getJarErr()==0 && (jarProtocol.getStatusType().equals(JarStatusType.WAITING1) || jarProtocol.getStatusType().equals(JarStatusType.MOVING)) + && jarProtocol.isRightDoor() && jarProtocol.isLeftDoor() + && jarProtocol.leftDoorOpen==0 && jarProtocol.leftDoorClose==0 && jarProtocol.rightDoorOpen==0 && jarProtocol.rightDoorClose==0 + ){ + List<BasJarMast> basJarMastList = basJarMastService.getJarMastByJarIdAndStatusList(jarSlave.getId(), new ArrayList<Integer>() {{ + add(6);//纭寲瀹屾垚 + }}); + if (!basJarMastList.isEmpty()){ + WrkMastExecute wrkMastExecuteSou = new WrkMastExecute(); + wrkMastExecuteSou.setWrkSts(3); + List<WrkMastExecute> wrkMastExecuteList = wrkMastExecuteService.selectWrkMastExecuteByWrk(wrkMastExecuteSou); + for (WrkMastExecute wrkMastExecute : wrkMastExecuteList){ + if (wrkMastExecute.getIoType() == 3){ + wrkMastExecute.setWrkSts(4); + if (!wrkMastExecuteService.updateById(wrkMastExecute)){ + log.error("纭寲缃怞ar鍛戒护淇敼澶辫触===>鏇存柊wrkMastExecute澶辫触锛宩ar鍙�={},浠诲姟鏁版嵁={},纭寲缃愭暟鎹�={},sign={}", + wrkMastExecute.getSteId(), JSON.toJSON(wrkMastExecute), JSON.toJSON(jarProtocol),sign); + return false; + } + return true; + } + } + } } //WAITING2(4, "纭寲瀹屾垚"), if (jarProtocol.getJarErr()==0 && jarProtocol.getStatusType().equals(JarStatusType.WAITING2) @@ -8708,7 +8794,7 @@ String barcode = staProtocol607.getBarcode(); if (!Cools.isEmpty(barcode)) { // log.info("{}鍙锋潯鐮佹壂鎻忓櫒妫�娴嬫潯鐮佷俊鎭細{}", inSta.getBarcode(), barcode); - if ("NG".endsWith(barcode) || "NoRead".equals(barcode) || !CodeDetectionUtil.barcodeDetection(barcode)) { + if ("NG".endsWith(barcode) || "NoRead".equals(barcode) || "00000000".equals(barcode) || !CodeDetectionUtil.barcodeDetection(barcode)) { return; } } else { @@ -8718,9 +8804,13 @@ && staProtocol607.getStaNo() == 0 && staProtocol607.isInEnable()){ WrkMast wrkMast = wrkMastMapper.selectByBarcodeTwo(barcode); if (!Cools.isEmpty(wrkMast)){ - staProtocol607.setWorkNo(wrkMast.getWrkNo()); - staProtocol607.setStaNo(staNo1); - boolean result2 = MessageQueue.offer(SlaveType.Devp, 2, new Task(2, staProtocol607)); + + StaProtocol staProtocolNew = new StaProtocol(); + staProtocolNew.setSiteId(staProtocol607.getSiteId()); + staProtocolNew.setWorkNo(wrkMast.getWrkNo()); + staProtocolNew.setStaNo(staNo1); +// devpThread.setPakMk(staProtocolNew.getSiteId(), false,7989); + boolean result = MessageQueue.offer(SlaveType.Devp, 2, new Task(2, staProtocolNew)); } } } else { @@ -8738,38 +8828,34 @@ } } - -// try{ -// for (int idi = 1;idi<5;idi++){ -// LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, idi); -// -// if (ledThread != null) { -// ErrMsg errMsg1 = new ErrMsg(); -// errMsg1.setErrMsg("娴嬭瘯锛�"+idi); -// errMsg1.setArea("1"); -// MessageQueue.offer(SlaveType.Led, idi, new Task(5, errMsg1)); -// } try { -// Thread.sleep(500); -// } catch (Exception e){ -// -// } -// } -// LedThread ledThread3 = (LedThread) SlaveConnection.get(SlaveType.Led, 3); -// -// if (ledThread3 != null) { -// ErrMsg errMsg1 = new ErrMsg(); -// errMsg1.setErrMsg("娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯娴嬭瘯锛�"+3); -// errMsg1.setArea("1"); -// MessageQueue.offer(SlaveType.Led, 3, new Task(5, errMsg1)); -// } try { -// Thread.sleep(500); -// } catch (Exception e){ -// -// } -// } catch (Exception e){ } - - } + public synchronized void stackingCompletionDriveTray2() { + SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, 2); + StaProtocol staProtocol = devpThread.getStation().get(518); + String barcode = staProtocol.getBarcode(); + if (!Cools.isEmpty(barcode)) { + if ("NG".endsWith(barcode) || "NoRead".equals(barcode) || "00000000".equals(barcode) || !CodeDetectionUtil.barcodeDetection(barcode)) { + return; + } + } else { + return; + } + if (staProtocol.getWorkNo()==0 && staProtocol.isLoading() && staProtocol.isAutoing() + && staProtocol.getStaNo() == 0 && staProtocol.isInEnable()){ + WrkMast wrkMast = wrkMastMapper.selectByBarcodeTwo(barcode); + if (!Cools.isEmpty(wrkMast)){ + StaProtocol staProtocolNew = new StaProtocol(); + staProtocolNew.setSiteId(staProtocol.getSiteId()); + staProtocolNew.setWorkNo(wrkMast.getWrkNo()); + staProtocolNew.setStaNo(wrkMast.getStaNo()); + devpThread.setPakMk(staProtocolNew.getSiteId(), false,7989); + boolean result = MessageQueue.offer(SlaveType.Devp, 2, new Task(2, staProtocolNew)); + } + } + } + + + public synchronized Integer jarGetStartStaNo(Integer staNo) { try { int[] jarNos=new int[]{3,1,4,2};//(607鍒嗛厤纭寲缃�) -- Gitblit v1.9.1