|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.PreDestroy; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.Date; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | * WCS主流程 | 
|---|
|  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //初始化RGV地图 | 
|---|
|  |  |  | //                    mainService.initRgvMap(); | 
|---|
|  |  |  | //刷新RGV地图 | 
|---|
|  |  |  | //                    mainService.refreshRgvMap(); | 
|---|
|  |  |  | // 演示 | 
|---|
|  |  |  | //                    mainService.crnDemoOfLocMove1(); | 
|---|
|  |  |  | // 入出库模式切换函数 | 
|---|
|  |  |  | //                    mainService.ioConvert(); | 
|---|
|  |  |  | // 入库  ===>> 入库站到堆垛机站,根据条码扫描生成入库工作档 | 
|---|
|  |  |  | mainService.generateStoreWrkFile(); // 组托 | 
|---|
|  |  |  | mainService.generateStoreWrkFileSingle(); // 组托  双工位单伸   小料箱 | 
|---|
|  |  |  | mainService.generateStoreWrkFileLarge(); // 组托  双工位单伸   大料箱 | 
|---|
|  |  |  | mainService.generateStoreWrkFile0(); // WMS入库 | 
|---|
|  |  |  | // 出库  ===>>  堆垛机出库站到出库站 | 
|---|
|  |  |  | mainService.crnStnToOutStn(); | 
|---|
|  |  |  | // 出库  ===>>  堆垛机出库站到出库站  工位2 | 
|---|
|  |  |  | mainService.crnStnToOutStnTwo(); | 
|---|
|  |  |  | // 入出库  ===>>  堆垛机入出库作业下发 | 
|---|
|  |  |  | mainService.crnIoExecute(); | 
|---|
|  |  |  | // 入出库  ===>>  堆垛机入出库作业下发  双工位堆垛机 | 
|---|
|  |  |  | mainService.crnIoExecuteTwo(); | 
|---|
|  |  |  | // 入出库  ===>>  堆垛机入出库作业下发  双工位堆垛机  拆分执行任务下发 | 
|---|
|  |  |  | mainService.crnIoExecuteTwoExecute(i);//Execute | 
|---|
|  |  |  | if (i%2==0){ | 
|---|
|  |  |  | // 入库  ===>> 执行对工作档的完成操作 | 
|---|
|  |  |  | mainService.storeFinished(); | 
|---|
|  |  |  | }else { | 
|---|
|  |  |  | // 入库  ===>> 执行对工作档的完成操作  工位2 | 
|---|
|  |  |  | mainService.storeFinishedTwo(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //                    // 异常信息记录 | 
|---|
|  |  |  | //                    mainService.recErr(); | 
|---|
|  |  |  | // 入库  ===>> 空栈板初始化入库 | 
|---|
|  |  |  | mainService.storeEmptyPlt(); | 
|---|
|  |  |  | // 入库  ===>> 空栈板初始化入库  双工位单伸   小料箱 | 
|---|
|  |  |  | mainService.storeEmptyPltSingle(); | 
|---|
|  |  |  | // 入库  ===>> 空栈板初始化入库  双工位单伸   大料箱 | 
|---|
|  |  |  | mainService.storeEmptyPltLarge(); | 
|---|
|  |  |  | // 出库  ===>> 工作档信息写入led显示器 | 
|---|
|  |  |  | mainService.ledExecute(); | 
|---|
|  |  |  | // 其他  ===>> LED显示器复位,显示默认信息 | 
|---|
|  |  |  | mainService.ledReset(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /************************************JAR调度************************************/ | 
|---|
|  |  |  | mainService.jarGenerateWrkMastSta(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | /************************************JAR调度************************************/ | 
|---|
|  |  |  | //更新位置信息 | 
|---|
|  |  |  | mainService.updateStePositionNearby(); | 
|---|
|  |  |  | //更新位置信息 | 
|---|
|  |  |  | mainService.updateStePosition(); | 
|---|
|  |  |  | // 任务下发 | 
|---|
|  |  |  | mainService.DevpTaskNoRun(); | 
|---|
|  |  |  | // 任务完成 | 
|---|
|  |  |  | mainService.rgvCompleteWrkMastSta(autoZ); | 
|---|
|  |  |  | //更新位置信息 | 
|---|
|  |  |  | mainService.updateStePosition(); | 
|---|
|  |  |  | System.out.println("结束:"+new Date().getTime()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } catch (Exception e) { | 
|---|