|  |  | 
 |  |  | import lombok.Data; | 
 |  |  | import lombok.extern.slf4j.Slf4j; | 
 |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
 |  |  | import org.springframework.beans.factory.annotation.Value; | 
 |  |  | import org.springframework.stereotype.Component; | 
 |  |  |  | 
 |  |  | import javax.annotation.PreDestroy; | 
 |  |  | import java.util.ArrayList; | 
 |  |  | import java.util.Date; | 
 |  |  |  | 
 |  |  | /** | 
 |  |  |  * WCS主流程 | 
 |  |  | 
 |  |  |     private MainServiceImpl mainService; | 
 |  |  |     // 所属线程 | 
 |  |  |     private Thread thread; | 
 |  |  |     // 频率 | 
 |  |  |     private int i = 0; | 
 |  |  |     private int j = 0; | 
 |  |  |     private int k = 0; | 
 |  |  |     private int l = 0; | 
 |  |  |     private int[] autoZ = new int[]{0,0,0,0,0,0,0}; | 
 |  |  |  | 
 |  |  |     /** | 
 |  |  |      * =====>>  开始工作 | 
 |  |  |      */ | 
 |  |  |     public void start(){ | 
 |  |  |         thread = new Thread(() -> { | 
 |  |  |             try{ | 
 |  |  |                 Thread.sleep(200); | 
 |  |  |                 log.info("++++++++ 开始验证许可证 ++++++++"); | 
 |  |  |                 if (!mainService.licenseVerify()){ | 
 |  |  |                     SystemProperties.WCS_RUNNING_STATUS.set(Boolean.FALSE); | 
 |  |  |                     log.info("++++++++ 验证许可证失败 ++++++++"); | 
 |  |  |                 } else { | 
 |  |  |                     SystemProperties.WCS_RUNNING_STATUS.set(Boolean.TRUE); | 
 |  |  |                     log.info("++++++++ 验证许可证成功 ++++++++"); | 
 |  |  |                 } | 
 |  |  |             } catch (Exception e) {} | 
 |  |  |             while (!Thread.currentThread().isInterrupted()) { | 
 |  |  |                 try { | 
 |  |  |  | 
 |  |  |                     // 间隔 | 
 |  |  |                     Thread.sleep(1000); | 
 |  |  |                     Thread.sleep(200); | 
 |  |  |                     System.out.println("开始:"+new Date().getTime()); | 
 |  |  |  | 
 |  |  |                     // 系统运行状态判断 | 
 |  |  |                     if (!SystemProperties.WCS_RUNNING_STATUS.get()) { | 
 |  |  |                         continue; | 
 |  |  |                     } | 
 |  |  |  | 
 |  |  |                     // 入库  ===>> 入库站到堆垛机站,根据条码扫描生成入库工作档 | 
 |  |  |                     mainService.generateStoreWrkFile(); | 
 |  |  | //                    mainService.generateStoreWrkFile2(); | 
 |  |  |                     // 拣料、并板、盘点再入库 | 
 |  |  |                     mainService.stnToCrnStnPick(); | 
 |  |  |                     // 出库  ===>>  堆垛机出库站到出库站 | 
 |  |  |                     mainService.crnStnToOutStn(); | 
 |  |  |                     // 入出库  ===>>  堆垛机入出库作业下发 | 
 |  |  |                     mainService.crnIoExecute(); | 
 |  |  |                     // 入库  ===>> 执行对工作档的完成操作 | 
 |  |  |                     mainService.storeFinished(); | 
 |  |  |                     // 堆垛机异常信息记录 | 
 |  |  |                     mainService.recCrnErr(); | 
 |  |  |                     // 入库  ===>> 空栈板初始化入库,叉车入库站放货 | 
 |  |  |                     mainService.storeEmptyPlt(); | 
 |  |  |                     // 出库  ===>> 工作档信息写入led显示器 | 
 |  |  |                     mainService.ledExecute(); | 
 |  |  |                     // 其他  ===>> LED显示器复位,显示默认信息 | 
 |  |  |                     mainService.ledReset(); | 
 |  |  |                     //更新位置信息 | 
 |  |  |                     mainService.updateStePositionNearby(); | 
 |  |  |                     //更新位置信息 | 
 |  |  |                     mainService.updateStePosition(); | 
 |  |  |                     // 任务下发 | 
 |  |  |                     mainService.DevpTaskNoRun(); | 
 |  |  |                     // 任务完成 | 
 |  |  |                     mainService.rgvCompleteWrkMastSta(autoZ); | 
 |  |  |                     //更新位置信息 | 
 |  |  |                     mainService.updateStePosition(); | 
 |  |  |                     System.out.println("结束:"+new Date().getTime()); | 
 |  |  |  | 
 |  |  |  | 
 |  |  |                 } catch (Exception e) { | 
 |  |  |                     e.printStackTrace(); |