|  |  |  | 
|---|
|  |  |  | 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()); | 
|---|
|  |  |  | 
|---|
|  |  |  | //    /** | 
|---|
|  |  |  | //     * 出库  ===>>  库位到堆垛机站 | 
|---|
|  |  |  | //     */ | 
|---|
|  |  |  | //    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()); | 
|---|
|  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * 库位移转 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | 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); | 
|---|