package com.mes.job;
|
|
import cn.hutool.json.JSONObject;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
import com.mes.common.S7object;
|
import com.mes.device.PlcParameterObject;
|
import com.mes.md.entity.GlassInfo;
|
import com.mes.md.entity.Machine;
|
import com.mes.md.entity.Tasking;
|
import com.mes.md.entity.WorkTaskDetail;
|
import com.mes.md.mapper.GlassInfoMapper;
|
import com.mes.md.mapper.MachineMapper;
|
import com.mes.md.mapper.TaskingMapper;
|
import com.mes.md.mapper.WorkTaskDetailMapper;
|
import com.mes.md.service.TaskingService;
|
import com.mes.service.ModbusTcp;
|
import com.mes.service.PlcAgreement;
|
import com.mes.service.PlcParameter;
|
import com.mes.tools.WebSocketServer;
|
import lombok.extern.slf4j.Slf4j;
|
import org.apache.commons.lang.StringUtils;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.scheduling.annotation.Scheduled;
|
import org.springframework.stereotype.Component;
|
|
import java.net.Socket;
|
import java.util.ArrayList;
|
import java.util.List;
|
import java.util.Map;
|
|
/**
|
* @Author : yanzhxiin
|
* @Date: 2024/8/20 11:19
|
* @Description:
|
*/
|
@Component
|
@Slf4j
|
public class MarkingTask {
|
|
public static String engineerId = "";
|
@Autowired
|
TaskingMapper taskingMapper;
|
@Autowired
|
MachineMapper machineMapper;
|
@Autowired
|
TaskingService taskingService;
|
|
// @Scheduled(fixedDelay = 1000)
|
public void plcMarkingTask(Long machineId) {
|
Machine machine=machineMapper.selectById(machineId);
|
PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject;
|
ModbusTcp modbusTcp =new ModbusTcp(machine.getIp(),machine.getPort());
|
PlcAgreement plcAgreement=modbusTcp.getPlcAgreement("DB14.0");
|
PlcParameter plcRequest =plcAgreement.getPlcParameter(0);//请求字
|
PlcParameter plcRequestID =plcAgreement.getPlcParameter(1);//请求ID
|
PlcParameter mesSend =plcAgreement.getPlcParameter(10);//发送字
|
PlcParameter mesSendID =plcAgreement.getPlcParameter(11);//发送ID
|
|
PlcParameter plcReport =plcAgreement.getPlcParameter(0);//汇报字
|
PlcParameter plcReportID =plcAgreement.getPlcParameter(1);//汇报ID
|
PlcParameter mesConfirm =plcAgreement.getPlcParameter(10);//确认字
|
PlcParameter mesConfirmID =plcAgreement.getPlcParameter(11);//确认ID
|
plcRequest.getReadValue();
|
if ("0".equals(plcRequest.getReadValue())) {
|
if ("0".equals(mesSend.getReadValue())) {
|
log.info("2、获取到的请求字为0,且发送字为0,不执行任务");
|
return;
|
}
|
log.info("2、获取到的请求字为0,将发送字改为0");
|
mesSend.setWriteValue("0");
|
modbusTcp.write(mesSend);//向PLC发送
|
return;
|
}
|
if (!"0".equals(mesSend.getReadValue())) {
|
log.info("2、获取到的请求字不为0,将发送字不为0,直接结束");
|
return;
|
}
|
if ("1".equals(mesConfirm.getReadValue())&&"0".equals(mesConfirm.getReadValue())) {
|
log.info("2、汇报请求,且确认字为0,完成打标任务");
|
plcReport(mesConfirm,machine);
|
}else if ("1".equals(plcRequest.getReadValue())) {
|
log.info("2、任务请求,执行发送任务");
|
plcRequest(mesSend,machine);
|
}
|
}
|
public void plcRequest(PlcParameter mesSend, Machine machine) {
|
//查找打标机任务
|
Tasking tasking=taskingService.startMachineTask(machine);
|
if(tasking!=null&&"开工".equals(machine.getState())){//有任务
|
log.info("发送任务:{}",tasking);
|
}else{
|
log.info("不满足发送条件:{}",tasking);
|
}
|
|
}
|
public void plcReport(PlcParameter mesConfirm, Machine machine) {
|
//查找打标机工作的任务
|
//查找打标机任务
|
int finishCount=taskingService.finishMachineTask(machine);
|
if(finishCount>0){//数据已标记完成
|
log.info("正常汇报:");
|
}else{
|
log.info("当前无共工作的任务,无效汇报完成!");
|
}
|
}
|
@Scheduled(fixedDelay = 1000)
|
public void markingTasks() {
|
JSONObject jsonObject = new JSONObject();
|
Machine machine=machineMapper.selectById(11L);
|
List<Tasking> taskingList=taskingService.findMachineTask(machine);
|
jsonObject.append("taskingList", taskingList);
|
jsonObject.append("machine", machine);
|
ArrayList<WebSocketServer> sendwServer = WebSocketServer.sessionMap.get("marking");
|
if (sendwServer != null) {
|
for (WebSocketServer webserver : sendwServer) {
|
if (webserver != null) {
|
webserver.sendMessage(jsonObject.toString());
|
List<String> messages = webserver.getMessages();
|
if (!messages.isEmpty()) {
|
// // 将最后一个消息转换为整数类型的列表
|
webserver.clearMessages();
|
}
|
} else {
|
log.info("Home is closed");
|
}
|
}
|
}
|
}
|
|
}
|