|  |  | 
 |  |  | import lombok.extern.slf4j.Slf4j; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | import org.springframework.beans.factory.annotation.Value; | 
 |  |  | import org.springframework.scheduling.annotation.Async; | 
 |  |  | import org.springframework.stereotype.Service; | 
 |  |  | import org.springframework.transaction.annotation.Transactional; | 
 |  |  | import org.springframework.transaction.interceptor.TransactionAspectSupport; | 
 |  |  | 
 |  |  |      * 组托 | 
 |  |  |      * 入库站,根据条码扫描生成入库工作档,工作状态 2 | 
 |  |  |      */ | 
 |  |  |     public void generateStoreWrkFile() { | 
 |  |  |     public synchronized void generateStoreWrkFile() { | 
 |  |  |         // 根据输送线plc遍历 | 
 |  |  |         for (DevpSlave devp : slaveProperties.getDevp()) { | 
 |  |  |             // 遍历入库口 | 
 |  |  | 
 |  |  |      * wms入库 | 
 |  |  |      * 入库站,根据条码扫描生成入库工作档,工作状态 1 ==>> 2 | 
 |  |  |      */ | 
 |  |  |     public void generateStoreWrkFile0() { | 
 |  |  |     public synchronized void generateStoreWrkFile0() { | 
 |  |  |         // 根据输送线plc遍历 | 
 |  |  |         for (DevpSlave devp : slaveProperties.getDevp()) { | 
 |  |  |             // 遍历入库口 | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 堆垛机站出库到出库站 | 
 |  |  |      */ | 
 |  |  |     @Async | 
 |  |  |     public void crnStnToOutStn() { | 
 |  |  |     public synchronized void crnStnToOutStn() { | 
 |  |  |         for (CrnSlave crnSlave : slaveProperties.getCrn()) { | 
 |  |  |             // 遍历堆垛机出库站 | 
 |  |  |             for (CrnSlave.CrnStn crnStn : crnSlave.getCrnOutStn()) { | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 入库  ===>>  堆垛机站到库位 | 
 |  |  |      */ | 
 |  |  |     public void crnStnToLoc(CrnSlave slave, CrnProtocol crnProtocol) { | 
 |  |  |     public synchronized void crnStnToLoc(CrnSlave slave, CrnProtocol crnProtocol) { | 
 |  |  |         for (CrnSlave.CrnStn crnStn : slave.getCrnInStn()) { | 
 |  |  |             boolean flag = false; | 
 |  |  |             // 获取堆垛机入库站信息 | 
 |  |  | 
 |  |  |      * 出库  ===>>  库位到堆垛机站 | 
 |  |  |      * 2022-06-09 TQS修改,查询工作档LIST,遍历下发,防止第一个任务堵塞出库 | 
 |  |  |      */ | 
 |  |  |     public void locToCrnStn(CrnSlave slave, CrnProtocol crnProtocol) { | 
 |  |  |     public synchronized void locToCrnStn(CrnSlave slave, CrnProtocol crnProtocol) { | 
 |  |  |         for (CrnSlave.CrnStn crnStn : slave.getCrnOutStn()) { | 
 |  |  |             // 获取工作状态为11(生成出库ID)的出库工作档 | 
 |  |  | //            WrkMast wrkMast = wrkMastMapper.selectPakOutStep1(slave.getId(), crnStn.getStaNo()); | 
 |  |  | 
 |  |  |                             log.error("{}任务出库失败,浅库位堵塞!浅库位号:{}", wrkMast.getWrkNo(), shallowLocNo); | 
 |  |  |                             continue; | 
 |  |  |                         } else if (shallowLoc.getLocSts().equals("Q") || shallowLoc.getLocSts().equals("S")) { | 
 |  |  |                             WrkMast waitWrkMast = wrkMastMapper.selectByLocNo(shallowLocNo); | 
 |  |  |                             WrkMast waitWrkMast = wrkMastMapper.selectByLocNo1(shallowLocNo); | 
 |  |  |                             if (null != waitWrkMast && waitWrkMast.getWrkSts() == 4) { | 
 |  |  |                                 continue; | 
 |  |  |                             } | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 库位移转 | 
 |  |  |      */ | 
 |  |  |     public void locToLoc(CrnSlave slave, CrnProtocol crnProtocol) { | 
 |  |  |     public synchronized void locToLoc(CrnSlave slave, CrnProtocol crnProtocol) { | 
 |  |  |         // 获取工作档信息 | 
 |  |  |         WrkMast wrkMast = wrkMastMapper.selectLocMove(slave.getId()); | 
 |  |  |         if (null == wrkMast) { | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 执行对工作档的完成操作 | 
 |  |  |      */ | 
 |  |  |     @Async | 
 |  |  |     public void storeFinished() { | 
 |  |  |     public synchronized void storeFinished() { | 
 |  |  |         for (CrnSlave crn : slaveProperties.getCrn()) { | 
 |  |  |             // 获取堆垛机信息 | 
 |  |  |             CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId()); | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 堆垛机异常信息记录 | 
 |  |  |      */ | 
 |  |  |     @Async | 
 |  |  |     public void recCrnErr() { | 
 |  |  |     public synchronized void recCrnErr() { | 
 |  |  |         Date now = new Date(); | 
 |  |  |         for (CrnSlave crn : slaveProperties.getCrn()) { | 
 |  |  |             // 获取堆垛机信息 | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 空栈板初始化入库,叉车入库站放货 | 
 |  |  |      */ | 
 |  |  |     @Async | 
 |  |  |     public void storeEmptyPlt() { | 
 |  |  |     public synchronized void storeEmptyPlt() { | 
 |  |  |         for (DevpSlave devp : slaveProperties.getDevp()) { | 
 |  |  |             // 遍历空板入库口 | 
 |  |  |             for (DevpSlave.Sta emptyInSta : devp.getEmptyInSta()) { | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 出库  ===>> 工作档信息写入led显示器 | 
 |  |  |      */ | 
 |  |  |     @Async | 
 |  |  |     public void ledExecute() { | 
 |  |  |     public synchronized void ledExecute() { | 
 |  |  |         for (LedSlave led : slaveProperties.getLed()) { | 
 |  |  |             // 获取输送线plc线程 | 
 |  |  |             DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, led.getDevpPlcId()); | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 其他  ===>> LED显示器复位,显示默认信息 | 
 |  |  |      */ | 
 |  |  |     @Async | 
 |  |  |     public void ledReset() { | 
 |  |  |     public synchronized void ledReset() { | 
 |  |  | //        for (LedSlave led : slaveProperties.getLed()) { | 
 |  |  | //            // 获取输送线plc线程 | 
 |  |  | //            DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, led.getDevpPlcId()); | 
 |  |  | 
 |  |  |      * 因双深库位阻塞,对浅库位进行移转(立即执行版) | 
 |  |  |      * tip:同步 | 
 |  |  |      */ | 
 |  |  |     private void moveLocForDeepLoc(CrnSlave crn, LocMast shallowLoc) { | 
 |  |  |     private synchronized void moveLocForDeepLoc(CrnSlave crn, LocMast shallowLoc) { | 
 |  |  |         try { | 
 |  |  |             List<Integer> rows = locMastService.queryDistinctRow(crn.getId()); | 
 |  |  |             LocMast loc = null; | 
 |  |  | 
 |  |  |     /** | 
 |  |  |      * 入出库模式切换函数 | 
 |  |  |      */ | 
 |  |  |     public void ioConvert() { | 
 |  |  |     public synchronized void ioConvert() { | 
 |  |  |         try { | 
 |  |  |             // 根据输送线plc遍历 | 
 |  |  |             for (DevpSlave devp : slaveProperties.getDevp()) { | 
 |  |  | 
 |  |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public void outOfDevp() { | 
 |  |  |     public synchronized void outOfDevp() { | 
 |  |  |         List<WrkMast> wrkMasts = wrkMastMapper.selectPick(); | 
 |  |  |         for (WrkMast wrkMast : wrkMasts) { | 
 |  |  |             if (basDevpService.selectCount(new EntityWrapper<BasDevp>().eq("wrk_no", wrkMast.getWrkNo())) == 0) { | 
 |  |  | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |  | 
 |  |  |     public void autoEmptyOut() { | 
 |  |  |     public synchronized void autoEmptyOut() { | 
 |  |  |         DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, 1); | 
 |  |  |         Integer autoOutSite = 12; | 
 |  |  |         //如果站点可出禁用,则不生成空盘出库任务 | 
 |  |  | 
 |  |  |         } | 
 |  |  |     } | 
 |  |  |  | 
 |  |  |     public void autoEmptyIn() { | 
 |  |  |     public synchronized void autoEmptyIn() { | 
 |  |  |         DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, 1); | 
 |  |  |         Integer autoInSite = 12; | 
 |  |  |         StaProtocol staProtocol = devpThread.getStation().get(autoInSite); |