#
zzgtfwq
16 小时以前 de480b42a379d1cf23e1703977c0169e837fa786
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
package com.zy.core;
 
import com.zy.asrs.service.impl.MainServiceImpl;
import com.zy.core.properties.SystemProperties;
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;
 
/**
 * WCS主流程
 * Created by vincent on 2020/8/6
 */
@Data
@Slf4j
@Component
public class MainProcess {
 
    @Autowired
    private MainServiceImpl mainService;
    // 所属线程
    private Thread thread;
    private Thread rgvThread;
    private Thread licenseThread;
    // 频率
    private int i = 0;
    private int k = 0;
    private boolean rgcWrk = true;
 
    /**
     * =====>>  开始工作
     */
    public void start(){
        thread = new Thread(this::crnAndDevRun);
        thread.start();
        rgvThread = new Thread(this::rgvRun);
        rgvThread.start();
        licenseThread = new Thread(this::licenseThreadRun);
        licenseThread.start();
    }
    private void crnAndDevRun() {
        while (!Thread.currentThread().isInterrupted()) {
            try {
 
                // 间隔
                Thread.sleep(1000);
 
                // 系统运行状态判断
                if (!SystemProperties.WCS_RUNNING_STATUS.get()) {
                    continue;
                }
//                // 系统演示模式运行状态判断
//                if (SystemProperties.WCS_RUNNING_STATUS_DEMO.get()) {
//                    continue;
//                }
                // 入库  ===>> 入库站到堆垛机站,根据条码扫描生成入库工作档
                mainService.generateStoreWrkFile(); // 组托
                // 入库  ===>> 空栈板初始化入库
                mainService.storeEmptyPlt();
//                mainService.generateStoreWrkFileWalk(); // wms入库任务下发
                // 出库  ===>>  堆垛机出库站到出库站
                mainService.crnStnToOutStn();
                // 入出库  ===>>  堆垛机入出库作业下发
                mainService.crnIoExecute();
                // 入库  ===>> 执行对工作档的完成操作
                mainService.storeFinished();
                // 出库  ===>> 工作档信息写入led显示器
                mainService.ledExecute();
                // 其他  ===>> LED显示器复位,显示默认信息
                mainService.ledReset();
                // 出库  ===>>  堆垛机10分钟无任务则回到源点
                mainService.crnStnToOutStnSou();
 
 
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
    private void rgvRun() {
        while (!Thread.currentThread().isInterrupted()) {
            try {
 
                // 间隔
                Thread.sleep(1000);
 
                // 系统运行状态判断
                if (!SystemProperties.WCS_RUNNING_STATUS.get()) {
                    continue;
                }
                // 任务生成
                mainService.taskCreate();
                // 任务下发
                mainService.taskStart();
                // 任务删除
                mainService.taskCancel();
 
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
 
    private void licenseThreadRun(){
        int i = 0;
        while (true) {
            try{
                Thread.sleep(60*60*1000L);
 
                // 系统运行状态判断
                if (!SystemProperties.WCS_RUNNING_STATUS.get()) {
                    continue;
                }
 
                log.info("++++++++ 开始验证许可证 ++++++++");
                if (!mainService.licenseVerify()){
                    if (i>6){
                        SystemProperties.WCS_RUNNING_STATUS.set(Boolean.FALSE);
                        log.info("++++++++ 验证许可证失败 ++++++++");
                        i = 0;
                    } else {
                        i++;
                    }
                } else {
//                    SystemProperties.WCS_RUNNING_STATUS.set(Boolean.TRUE);
                    log.info("++++++++ 验证许可证成功 ++++++++");
                }
            } catch (Exception e) {}
        }
    }
 
    @PreDestroy
    public void shutDown(){
        if (thread != null) thread.interrupt();
        if (rgvThread != null) rgvThread.interrupt();
        if (licenseThread != null) licenseThread.interrupt();
    }
 
}