Browse Source

add RGV驱动判断起点和任务失败原因

master
周俊杰 1 year ago
parent
commit
d2894bd7c4
  1. 220
      acs/nladmin-system/src/main/java/org/nl/acs/device_driver/lnsh/lnsh_rgv/LnshRGVDeviceDriver.java

220
acs/nladmin-system/src/main/java/org/nl/acs/device_driver/lnsh/lnsh_rgv/LnshRGVDeviceDriver.java

@ -12,8 +12,13 @@ import org.nl.acs.device.device_driver.standard_inspect.ReadUtil;
import org.nl.acs.device.service.DeviceService;
import org.nl.acs.device_driver.DeviceDriver;
import org.nl.acs.device_driver.RouteableDeviceDriver;
import org.nl.acs.device_driver.basedriver.standard_ordinary_site.StandardOrdinarySiteDeviceDriver;
import org.nl.acs.device_driver.driver.AbstractOpcDeviceDriver;
import org.nl.acs.device_driver.driver.ExecutableDeviceDriver;
import org.nl.acs.device_driver.lnsh.lnsh_Laminating_machine.LnshLaminatingMachineDeviceDriver;
import org.nl.acs.device_driver.lnsh.lnsh_package_site.LnshPackageSiteDeviceDriver;
import org.nl.acs.device_driver.lnsh.lnsh_palletizing_manipulator_site.LnshPalletizingManipulatorSiteDeviceDriver;
import org.nl.acs.device_driver.lnsh.lnsh_station.LnshStationDeviceDriver;
import org.nl.acs.instruction.service.InstructionService;
import org.nl.acs.instruction.service.dto.Instruction;
import org.nl.acs.log.service.DeviceExecuteLogService;
@ -296,38 +301,201 @@ public class LnshRGVDeviceDriver extends AbstractOpcDeviceDriver implements Devi
update_instruction_status();
}
//双任务下 后工位取货完成,然后给前工位下发取满盘任务取货命令
if (mode == 3 && action_2 == 2 && action_1 == 0 && move_2 != 0 && move_1 == 0 && task2 > 0 && to_task1 > 0 && to_task2 > 0) {
if (to_command1 != 1) {
writing("to_command1", "1");
}
}
//双任务下发 前后工位取货完成 给后工位放货命令
if (mode == 3 && action_2 == 2 && action_1 == 2 && move_2 != 0 && move_1 != 0 && task2 > 0 && task1 > 0) {
if (to_command2 != 2) {
writing("to_command2", "2");
//前工位取货时判断取货位光电信号
if (mode == 3 && error == 0 && status != 3 && action_1 == 1 && move_1 == 0 && task1 > 0 && action_2 != 1) {
Instruction inst1 = instructionService.findByCodeFromCache(String.valueOf(task1));
String start_device_code = inst1.getStart_device_code();
Device startDevice = deviceAppservice.findDeviceByCode(start_device_code);
if (startDevice.getDeviceDriver() instanceof LnshPalletizingManipulatorSiteDeviceDriver) {
LnshPalletizingManipulatorSiteDeviceDriver driver = (LnshPalletizingManipulatorSiteDeviceDriver) startDevice.getDeviceDriver();
if (driver.getMode() != 0
&& driver.getMove() != 0
&& (driver.getIo_action() == 3 || driver.getIo_action() == 1)
&& (driver.getAction() == 3 || driver.getAction() == 1)) {
this.writing("to_command1", "2");
driver.setMessage("");
logServer.deviceExecuteLog(startDevice.getDevice_code(), "", "", "允许RGV前工位取货。");
} else {
String msg = "";
if (driver.getMode() == 0) {
msg += "站点未联机,";
} else {
if (driver.getMove() == 0) {
msg += "站点无货,";
}
if (driver.getIo_action() != 3 && driver.getIo_action() != 1) {
msg += "站点不允许进入,";
}
if (driver.getAction() != 3 && driver.getAction() != 1) {
msg += "站点不允许取货,";
}
}
msg += "不允许RGV前工位取货。";
driver.setMessage(msg);
logServer.deviceExecuteLog(startDevice.getDevice_code(), "", "", msg);
}
} else if (startDevice.getDeviceDriver() instanceof StandardOrdinarySiteDeviceDriver) {
this.writing("to_command1", "2");
logServer.deviceExecuteLog(startDevice.getDevice_code(), "", "", "允许RGV前工位取货。");
}
}
//双任务下发 后工位放货完成 给前工位下发放货
if (mode == 3 && action_2 == 4 && action_1 == 2 && move_2 == 0 && move_1 != 0 && task2 > 0 && task1 > 0) {
if (to_command1 != 2) {
writing("to_command1", "2");
//前工位放货时判断放货位光电信号
if (mode == 3 && error == 0 && status != 3 && action_1 == 3 && move_1 != 0 && task1 > 0 && action_2 != 3) {
Instruction inst1 = instructionService.findByCodeFromCache(String.valueOf(task1));
String next_device_code = inst1.getNext_device_code();
Device nextDevice = deviceAppservice.findDeviceByCode(next_device_code);
if (nextDevice.getDeviceDriver() instanceof LnshStationDeviceDriver) {
LnshStationDeviceDriver driver = (LnshStationDeviceDriver) nextDevice.getDeviceDriver();
if (driver.getMode() != 0
&& driver.getMove() == 0
&& (driver.getAction() == 2 || driver.getAction() == 3)
&& (driver.getIo_action() == 1 || driver.getIo_action() == 3)) {
this.writing("to_command1", "3");
driver.setMessage("");
logServer.deviceExecuteLog(nextDevice.getDevice_code(), "", "", "允许RGV前工位放货。");
} else {
String msg = "";
if (driver.getMode() == 0) {
msg += "站点未联机,";
} else {
if (driver.getMove() != 0) {
msg += "站点有货,";
}
if (driver.getIo_action() != 1 && driver.getIo_action() != 3) {
msg += "站点不允许进入,";
}
if (driver.getAction() != 2 && driver.getAction() != 3) {
msg += "站点不允许放货,";
}
}
msg += "不允许RGV前工位放货。";
driver.setMessage(msg);
logServer.deviceExecuteLog(nextDevice.getDevice_code(), "", "", msg);
}
} else if (nextDevice.getDeviceDriver() instanceof LnshPackageSiteDeviceDriver) {
LnshPackageSiteDeviceDriver driver = (LnshPackageSiteDeviceDriver) nextDevice.getDeviceDriver();
if (driver.getMode() != 0
&& driver.getMove() == 0
&& (driver.getAction() == 2 || driver.getAction() == 3)
&& (driver.getIoaction() == 1 || driver.getIoaction() == 3)) {
this.writing("to_command1", "3");
driver.setMessage("");
logServer.deviceExecuteLog(nextDevice.getDevice_code(), "", "", "允许RGV前工位放货。");
} else {
String msg = "";
if (driver.getMode() == 0) {
msg += "站点未联机,";
} else {
if (driver.getMove() != 0) {
msg += "站点有货,";
}
if (driver.getIoaction() != 1 && driver.getIoaction() != 3) {
msg += "站点不允许进入,";
}
if (driver.getAction() != 2 && driver.getAction() != 3) {
msg += "站点不允许放货,";
}
}
msg += "不允许RGV前工位放货。";
driver.setMessage(msg);
logServer.deviceExecuteLog(nextDevice.getDevice_code(), "", "", msg);
}
}
}
//后工位单任务下发 空托或者半托缓存任务
if (mode == 3 && action_2 == 2 && action_1 == 0 && move_2 > 0 && move_1 == 0 && task2 > 0 && task1 == 0 && to_task1 == 0) {
if (to_command2 != 2) {
writing("to_command2", "2");
//后工位取货时判断取货位光电信号
if (mode == 3 && error == 0 && status != 3 && action_2 == 1 && move_2 == 0 && task2 > 0) {
Instruction inst1 = instructionService.findByCodeFromCache(String.valueOf(task2));
String start_device_code = inst1.getStart_device_code();
Device startDevice = deviceAppservice.findDeviceByCode(start_device_code);
if (startDevice.getDeviceDriver() instanceof LnshLaminatingMachineDeviceDriver) {
LnshLaminatingMachineDeviceDriver driver = (LnshLaminatingMachineDeviceDriver) startDevice.getDeviceDriver();
if (driver.getMode() != 0
&& driver.getMove() != 0) {
this.writing("to_command2", "2");
driver.setMessage("");
logServer.deviceExecuteLog(startDevice.getDevice_code(), "", "", "允许RGV后工位取货。");
} else {
String msg = "";
if (driver.getMode() == 0) {
msg += "站点未联机,";
} else {
if (driver.getMove() == 0) {
msg += "站点无货,";
}
}
msg += "不允许RGV后工位取货。";
driver.setMessage(msg);
logServer.deviceExecuteLog(startDevice.getDevice_code(), "", "", msg);
}
} else if (startDevice.getDeviceDriver() instanceof LnshStationDeviceDriver) {
LnshStationDeviceDriver driver = (LnshStationDeviceDriver) startDevice.getDeviceDriver();
if (driver.getMode() != 0
&& driver.getMove() != 0
&& (driver.getIo_action() == 3 || driver.getIo_action() == 1)
&& (driver.getAction() == 3 || driver.getAction() == 1)) {
this.writing("to_command2", "2");
driver.setMessage("");
logServer.deviceExecuteLog(startDevice.getDevice_code(), "", "", "允许RGV后工位取货。");
} else {
String msg = "";
if (driver.getMode() == 0) {
msg += "站点未联机,";
} else {
if (driver.getMove() == 0) {
msg += "站点无货,";
}
if (driver.getIo_action() != 3 && driver.getIo_action() != 1) {
msg += "站点不允许进入,";
}
if (driver.getAction() != 3 && driver.getAction() != 1) {
msg += "站点不允许取货,";
}
}
msg += "不允许RGV后工位取货。";
driver.setMessage(msg);
logServer.deviceExecuteLog(startDevice.getDevice_code(), "", "", msg);
}
}
}
//前工位单任务下发 强制包装的任务
if (mode == 3 && action_1 == 2 && action_2 == 0 && move_1 > 0 && move_2 == 0 && task1 > 0 && task2 == 0 && to_task2 == 0) {
if (to_command1 != 2) {
writing("to_command1", "2");
//后工位放货时判断放货位光电信号
if (mode == 3 && error == 0 && status != 3 && action_2 == 3 && move_2 != 0 && task2 > 0 && action_1 != 1) {
Instruction inst1 = instructionService.findByCodeFromCache(String.valueOf(task2));
String next_device_code = inst1.getNext_device_code();
Device nextDevice = deviceAppservice.findDeviceByCode(next_device_code);
if (nextDevice.getDeviceDriver() instanceof LnshPalletizingManipulatorSiteDeviceDriver) {
LnshPalletizingManipulatorSiteDeviceDriver driver = (LnshPalletizingManipulatorSiteDeviceDriver) nextDevice.getDeviceDriver();
if (driver.getMode() != 0
&& driver.getMove() == 0
&& (driver.getIo_action() == 1 || driver.getIo_action() == 3)
&& (driver.getAction() == 2 || driver.getAction() == 3)) {
this.writing("to_command2", "3");
driver.setMessage("");
logServer.deviceExecuteLog(nextDevice.getDevice_code(), "", "", "允许RGV后工位放货。");
} else {
String msg = "";
if (driver.getMode() == 0) {
msg += "站点未联机,";
} else {
if (driver.getMove() != 0) {
msg += "站点有货,";
}
if (driver.getIo_action() != 1 && driver.getIo_action() != 3) {
msg += "站点不允许进入,";
}
if (driver.getAction() != 2 && driver.getAction() != 3) {
msg += "站点不允许放货,";
}
}
msg += "不允许RGV后工位放货。";
driver.setMessage(msg);
logServer.deviceExecuteLog(device_code, "", "", msg);
}
} else if (nextDevice.getDeviceDriver() instanceof StandardOrdinarySiteDeviceDriver) {
this.writing("to_command2", "3");
logServer.deviceExecuteLog(nextDevice.getDevice_code(), "", "", "允许RGV后工位放货。");
}
}
@ -496,10 +664,16 @@ public class LnshRGVDeviceDriver extends AbstractOpcDeviceDriver implements Devi
sendHeadBackSignalType(instdto);
requireSucess1 = true;
logServer.deviceExecuteLog(this.device_code, "", "", "申请前后工位任务成功,requireSucess1" + requireSucess1 + ",指令号:" + instdto.getInstruction_code());
if(ObjectUtil.isNotEmpty(start_device_code)){
writing("to_command1", "1");
}
} else {
sendHeadSignalType(instdto);
requireSucess1 = true;
logServer.deviceExecuteLog(this.device_code, "", "", "申请后工位任务成功,requireSucess1" + requireSucess1 + ",指令号:" + instdto.getInstruction_code());
if(ObjectUtil.isNotEmpty(start_device_code)){
writing("to_command1", "1");
}
}
} else {
//申请后工位任务

Loading…
Cancel
Save