|
|
@ -162,14 +162,13 @@ public class NDCSocketConnectionAutoRun extends AbstractAutoRunnable { |
|
|
|
|
|
|
|
try { |
|
|
|
if (phase == 0x01) { |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index); |
|
|
|
if (!ObjectUtil.isEmpty(inst)) { |
|
|
|
inst.setInstruction_status("1"); |
|
|
|
inst.setAgv_jobno(String.valueOf(index)); |
|
|
|
inst.setSend_status("1"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} |
|
|
|
//分配 车id
|
|
|
@ -221,22 +220,34 @@ public class NDCSocketConnectionAutoRun extends AbstractAutoRunnable { |
|
|
|
//检测站点smart200
|
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteSmartDeviceDriver) { |
|
|
|
standardInspectSiteSmartDeviceDriver = (StandardInspectSiteSmartDeviceDriver) device.getDeviceDriver(); |
|
|
|
if (StrUtil.equals(acsConfigService.findConfigFromCache().get(AcsConfig.IGNOREHASGOODS), "1")) { |
|
|
|
inst.setExecute_status("1"); |
|
|
|
inst.setExecute_status("1"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
// 取货完成请求离开
|
|
|
|
else if (phase == 0x05) { |
|
|
|
if (ObjectUtil.isEmpty(inst)) { |
|
|
|
logServer.deviceExecuteLog("未找到指令号对应的指令:", "", "", String.valueOf(ikey)); |
|
|
|
break; |
|
|
|
} |
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteDeviceDriver) { |
|
|
|
standardInspectSiteDeviceDriver = (StandardInspectSiteDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardInspectSiteDeviceDriver.writing(3); |
|
|
|
if (standardInspectSiteDeviceDriver.getMode() != 0 |
|
|
|
&& standardInspectSiteDeviceDriver.getMove() == 0) { |
|
|
|
inst.setExecute_status("5"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} else { |
|
|
|
if (device.getHas_goods() != 0) { |
|
|
|
inst.setExecute_status("1"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV请求取货设备{}无货,无法反馈"); |
|
|
|
} |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV取货完成请求离开设备{}有货,无法反馈"); |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
//检测站点smart200
|
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteSmartDeviceDriver) { |
|
|
|
standardInspectSiteSmartDeviceDriver = (StandardInspectSiteSmartDeviceDriver) device.getDeviceDriver(); |
|
|
|
//如果是混料区则上送LMS当前点位的字段,同步到st_ivt_structivt仓位库存表
|
|
|
|
JSONObject jsonObject = new JSONObject(); |
|
|
|
jsonObject.put("device_code", device_code); |
|
|
@ -245,49 +256,28 @@ public class NDCSocketConnectionAutoRun extends AbstractAutoRunnable { |
|
|
|
jsonObject.put("batch_code", standardInspectSiteSmartDeviceDriver.getBatch_code()); |
|
|
|
jsonObject.put("product_specifications", standardInspectSiteSmartDeviceDriver.getProduct_specifications()); |
|
|
|
jsonObject.put("time", standardInspectSiteSmartDeviceDriver.getTime()); |
|
|
|
jsonObject.put("type","9"); |
|
|
|
jsonObject.put("type", "9"); |
|
|
|
acsToWmsService.lnshApplyTaskToWms(jsonObject); |
|
|
|
} |
|
|
|
|
|
|
|
// 检验取放货条件
|
|
|
|
JSONObject agv_check = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
.uniqueResult(0); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check) && "true".equals(agv_check.getString("extra_value"))) { |
|
|
|
JSONObject agv_check_status = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check_status' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
// 检验取放货条件
|
|
|
|
JSONObject agv_check = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
.uniqueResult(0); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check_status) && "2".equals(agv_check_status.getString("extra_value"))) { |
|
|
|
inst.setExecute_status("1"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
agv_check_status.put("extra_value", "0"); |
|
|
|
device_extra_table.update(agv_check_status); |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV请求取货设备{}未放盖确认,无法反馈"); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
// 取货完成请求离开
|
|
|
|
else if (phase == 0x05) { |
|
|
|
if (ObjectUtil.isEmpty(inst)) { |
|
|
|
logServer.deviceExecuteLog("未找到指令号对应的指令:", "", "", String.valueOf(ikey)); |
|
|
|
break; |
|
|
|
} |
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteDeviceDriver) { |
|
|
|
standardInspectSiteDeviceDriver = (StandardInspectSiteDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardInspectSiteDeviceDriver.writing(3); |
|
|
|
if (standardInspectSiteDeviceDriver.getMode() != 0 |
|
|
|
&& standardInspectSiteDeviceDriver.getMove() == 0) { |
|
|
|
inst.setExecute_status("5"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV取货完成请求离开设备{}有货,无法反馈"); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check) && "true".equals(agv_check.getString("extra_value"))) { |
|
|
|
JSONObject agv_check_status = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check_status' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
.uniqueResult(0); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check_status) && "2".equals(agv_check_status.getString("extra_value"))) { |
|
|
|
inst.setExecute_status("1"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
agv_check_status.put("extra_value", "0"); |
|
|
|
device_extra_table.update(agv_check_status); |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV请求取货设备{}未放盖确认,无法反馈"); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
// if(!inst.getTask_code().startsWith("-")) {
|
|
|
|
// //反馈wms系统动作完成
|
|
|
@ -302,65 +292,69 @@ public class NDCSocketConnectionAutoRun extends AbstractAutoRunnable { |
|
|
|
// acsToWmsService.feedbackActionStatusToWms(feedja);
|
|
|
|
// }
|
|
|
|
|
|
|
|
} |
|
|
|
//请求放货
|
|
|
|
else if (phase == 0x07) { |
|
|
|
if (ObjectUtil.isEmpty(inst)) { |
|
|
|
logServer.deviceExecuteLog("未找到指令号对应的指令:", "", "", String.valueOf(ikey)); |
|
|
|
break; |
|
|
|
} |
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteDeviceDriver) { |
|
|
|
standardInspectSiteDeviceDriver = (StandardInspectSiteDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardInspectSiteDeviceDriver.writing(4); |
|
|
|
if (standardInspectSiteDeviceDriver.getMode() != 0 |
|
|
|
&& standardInspectSiteDeviceDriver.getMove() == 0) { |
|
|
|
inst.setExecute_status("3"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV请求放货设备{}有货,无法反馈"); |
|
|
|
//请求放货
|
|
|
|
else if (phase == 0x07) { |
|
|
|
if (ObjectUtil.isEmpty(inst)) { |
|
|
|
logServer.deviceExecuteLog("未找到指令号对应的指令:", "", "", String.valueOf(ikey)); |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
// 检验取放货条件
|
|
|
|
JSONObject agv_check = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
.uniqueResult(0); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check) && "true".equals(agv_check.getString("extra_value"))) { |
|
|
|
JSONObject agv_check_status = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check_status' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteDeviceDriver) { |
|
|
|
standardInspectSiteDeviceDriver = (StandardInspectSiteDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardInspectSiteDeviceDriver.writing(4); |
|
|
|
if (standardInspectSiteDeviceDriver.getMode() != 0 |
|
|
|
&& standardInspectSiteDeviceDriver.getMove() == 0) { |
|
|
|
inst.setExecute_status("3"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV请求放货设备{}有货,无法反馈"); |
|
|
|
} |
|
|
|
} |
|
|
|
// 检验取放货条件
|
|
|
|
JSONObject agv_check = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
.uniqueResult(0); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check_status) && "1".equals(agv_check_status.getString("extra_value"))) { |
|
|
|
inst.setExecute_status("1"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
agv_check_status.put("extra_value", "0"); |
|
|
|
device_extra_table.update(agv_check_status); |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV请求取货设备{}未取盖确认,无法反馈"); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check) && "true".equals(agv_check.getString("extra_value"))) { |
|
|
|
JSONObject agv_check_status = device_extra_table |
|
|
|
.query("is_delete = '0' AND extra_code = 'agv_check_status' AND device_code = '" + device.getDevice_code() + "'") |
|
|
|
.uniqueResult(0); |
|
|
|
if (ObjectUtil.isNotEmpty(agv_check_status) && "1".equals(agv_check_status.getString("extra_value"))) { |
|
|
|
inst.setExecute_status("1"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
agv_check_status.put("extra_value", "0"); |
|
|
|
device_extra_table.update(agv_check_status); |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV请求取货设备{}未取盖确认,无法反馈"); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
// 放货完成请求离开
|
|
|
|
else if (phase == 0x09) { |
|
|
|
if (ObjectUtil.isEmpty(inst)) { |
|
|
|
logServer.deviceExecuteLog("未找到指令号对应的指令:", "", "", String.valueOf(ikey)); |
|
|
|
break; |
|
|
|
} |
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteDeviceDriver) { |
|
|
|
standardInspectSiteDeviceDriver = (StandardInspectSiteDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardInspectSiteDeviceDriver.writing(5); |
|
|
|
if (standardInspectSiteDeviceDriver.getMode() != 0 |
|
|
|
&& standardInspectSiteDeviceDriver.getMove() != 0) { |
|
|
|
// 放货完成请求离开
|
|
|
|
else if (phase == 0x09) { |
|
|
|
if (ObjectUtil.isEmpty(inst)) { |
|
|
|
logServer.deviceExecuteLog("未找到指令号对应的指令:", "", "", String.valueOf(ikey)); |
|
|
|
break; |
|
|
|
} |
|
|
|
if (device.getDeviceDriver() instanceof StandardInspectSiteDeviceDriver) { |
|
|
|
standardInspectSiteDeviceDriver = (StandardInspectSiteDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardInspectSiteDeviceDriver.writing(5); |
|
|
|
if (standardInspectSiteDeviceDriver.getMode() != 0 |
|
|
|
&& standardInspectSiteDeviceDriver.getMove() != 0) { |
|
|
|
inst.setExecute_status("6"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV放货完成请求离开设备{}无货,无法反馈"); |
|
|
|
} |
|
|
|
} else { |
|
|
|
inst.setExecute_status("6"); |
|
|
|
instructionService.update(inst); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
flag = true; |
|
|
|
} else { |
|
|
|
logServer.deviceExecuteLog(device_code, "", "", "AGV放货完成请求离开设备{}无货,无法反馈"); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
// if(!inst.getTask_code().startsWith("-")){
|
|
|
|
// //反馈wms系统动作完成
|
|
|
@ -376,167 +370,157 @@ public class NDCSocketConnectionAutoRun extends AbstractAutoRunnable { |
|
|
|
// acsToWmsService.feedbackActionStatusToWms(feedja);
|
|
|
|
// }
|
|
|
|
|
|
|
|
} |
|
|
|
//任务完毕
|
|
|
|
//(无车id及状态)
|
|
|
|
else if (phase == 0x0A) { |
|
|
|
if (!ObjectUtil.isEmpty(inst)) { |
|
|
|
inst.setInstruction_status("2"); |
|
|
|
instructionService.finish(inst); |
|
|
|
} |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
//请求删除任务
|
|
|
|
else if (phase == 0x30) { |
|
|
|
flag = true; |
|
|
|
if (!ObjectUtil.isEmpty(inst)) { |
|
|
|
//任务完毕
|
|
|
|
//(无车id及状态)
|
|
|
|
else if (phase == 0x0A) { |
|
|
|
if (!ObjectUtil.isEmpty(inst)) { |
|
|
|
inst.setInstruction_status("2"); |
|
|
|
instructionService.finish(inst); |
|
|
|
} |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
//请求删除任务
|
|
|
|
else if (phase == 0x30) { |
|
|
|
data = AgvService.sendAgvOneModeInst(0x8F, index, 0); |
|
|
|
} else { |
|
|
|
log.info("未找到对应的指令无法删除"); |
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
|
//任务删除确认
|
|
|
|
//(需要WCS反馈)
|
|
|
|
else if (phase == 0xFF) { |
|
|
|
flag = true; |
|
|
|
if (!ObjectUtil.isEmpty(inst)) { |
|
|
|
instructionService.cancel(inst.getInstruction_id()); |
|
|
|
//任务删除确认
|
|
|
|
//(需要WCS反馈)
|
|
|
|
else if (phase == 0xFF) { |
|
|
|
flag = true; |
|
|
|
if (!ObjectUtil.isEmpty(inst)) { |
|
|
|
instructionService.cancel(inst.getInstruction_id()); |
|
|
|
} |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
//进入区域
|
|
|
|
else if (phase == 0x50) { |
|
|
|
//开门
|
|
|
|
if (device.getDeviceDriver() instanceof StandardAutodoorDeviceDriver) { |
|
|
|
standardAutodoorDeviceDriver = (StandardAutodoorDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardAutodoorDeviceDriver.OpenOrClose("1"); |
|
|
|
standardAutodoorDeviceDriver.writeing(1); |
|
|
|
if (standardAutodoorDeviceDriver.getAction() == 1) { |
|
|
|
//进入区域
|
|
|
|
else if (phase == 0x50) { |
|
|
|
//开门
|
|
|
|
if (device.getDeviceDriver() instanceof StandardAutodoorDeviceDriver) { |
|
|
|
standardAutodoorDeviceDriver = (StandardAutodoorDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardAutodoorDeviceDriver.OpenOrClose("1"); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
standardAutodoorDeviceDriver.writeing(1); |
|
|
|
if (standardAutodoorDeviceDriver.getAction() == 1) { |
|
|
|
standardAutodoorDeviceDriver.OpenOrClose("1"); |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
//离开区域
|
|
|
|
else if (phase == 0x51) { |
|
|
|
//关门
|
|
|
|
if (device.getDeviceDriver() instanceof StandardAutodoorDeviceDriver) { |
|
|
|
standardAutodoorDeviceDriver = (StandardAutodoorDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardAutodoorDeviceDriver.OpenOrClose("2"); |
|
|
|
standardAutodoorDeviceDriver.writeing(2); |
|
|
|
if (standardAutodoorDeviceDriver.getAction() == 2) { |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
//离开区域
|
|
|
|
else if (phase == 0x51) { |
|
|
|
//关门
|
|
|
|
if (device.getDeviceDriver() instanceof StandardAutodoorDeviceDriver) { |
|
|
|
standardAutodoorDeviceDriver = (StandardAutodoorDeviceDriver) device.getDeviceDriver(); |
|
|
|
standardAutodoorDeviceDriver.OpenOrClose("2"); |
|
|
|
standardAutodoorDeviceDriver.writeing(2); |
|
|
|
if (standardAutodoorDeviceDriver.getAction() == 2) { |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
} |
|
|
|
} else if (phase == 0x64) { |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
} else if (phase == 0x64) { |
|
|
|
data = AgvService.sendAgvOneModeInst(phase, index, 0); |
|
|
|
} |
|
|
|
//上报异常
|
|
|
|
else if (phase == 0x67) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
//上报异常
|
|
|
|
else if (phase == 0x67) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
if (arr[18] * 256 + arr[19] == 0) { |
|
|
|
dto.setState("IDLE"); |
|
|
|
acsToWmsService.feedbackAgvStatus(String.valueOf(carno), "0", ""); |
|
|
|
} else { |
|
|
|
StringBuffer errbs = new StringBuffer(); |
|
|
|
for (int i = 0; i < ERROR.length; i++) { |
|
|
|
if (((arr[18] * 256 + arr[19]) & (1 << i)) > 0) |
|
|
|
errbs.append("," + ERROR[i]); |
|
|
|
//反馈故障
|
|
|
|
} |
|
|
|
dto.setState("ERROR"); |
|
|
|
acsToWmsService.feedbackAgvStatus(String.valueOf(carno), "1", "error"); |
|
|
|
} |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
if (arr[18] * 256 + arr[19] == 0) { |
|
|
|
dto.setState("IDLE"); |
|
|
|
acsToWmsService.feedbackAgvStatus(String.valueOf(carno), "0", ""); |
|
|
|
} else { |
|
|
|
StringBuffer errbs = new StringBuffer(); |
|
|
|
for (int i = 0; i < ERROR.length; i++) { |
|
|
|
if (((arr[18] * 256 + arr[19]) & (1 << i)) > 0) |
|
|
|
errbs.append("," + ERROR[i]); |
|
|
|
//反馈故障
|
|
|
|
//X坐标
|
|
|
|
else if (phase == 0x70) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
} |
|
|
|
dto.setState("ERROR"); |
|
|
|
acsToWmsService.feedbackAgvStatus(String.valueOf(carno), "1", "error"); |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setPositionX(String.valueOf(ikey)); |
|
|
|
} |
|
|
|
} |
|
|
|
//X坐标
|
|
|
|
else if (phase == 0x70) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
//Y坐标
|
|
|
|
else if (phase == 0x71) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setPositionY(String.valueOf(ikey)); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setPositionX(String.valueOf(ikey)); |
|
|
|
} |
|
|
|
//Y坐标
|
|
|
|
else if (phase == 0x71) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
//角度
|
|
|
|
else if (phase == 0x72) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setPositionAngle(String.valueOf(ikey)); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setPositionY(String.valueOf(ikey)); |
|
|
|
} |
|
|
|
//角度
|
|
|
|
else if (phase == 0x72) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
//电量
|
|
|
|
else if (phase == 0x73) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setEnergyLevel(String.valueOf(ikey)); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setPositionAngle(String.valueOf(ikey)); |
|
|
|
} |
|
|
|
//电量
|
|
|
|
else if (phase == 0x73) { |
|
|
|
AgvDto dto = null; |
|
|
|
Map<String, AgvDto> map = AgvService.findAllAgvFromCache(); |
|
|
|
carno = arr[18] * 256 + arr[19]; |
|
|
|
if (map.containsKey(String.valueOf(carno))) { |
|
|
|
dto = map.get(String.valueOf(carno)); |
|
|
|
} else { |
|
|
|
dto = new AgvDto(); |
|
|
|
if (!ObjectUtil.isEmpty(data)) { |
|
|
|
write(data); |
|
|
|
} |
|
|
|
dto.setName(String.valueOf(carno)); |
|
|
|
dto.setEnergyLevel(String.valueOf(ikey)); |
|
|
|
} catch (Exception e) { |
|
|
|
System.out.println(e); |
|
|
|
log.info(e.toString()); |
|
|
|
log.info(e.getMessage()); |
|
|
|
e.printStackTrace(); |
|
|
|
} |
|
|
|
if (!ObjectUtil.isEmpty(data)) { |
|
|
|
write(data); |
|
|
|
} |
|
|
|
} catch(Exception e){ |
|
|
|
System.out.println(e); |
|
|
|
log.info(e.toString()); |
|
|
|
log.info(e.getMessage()); |
|
|
|
e.printStackTrace(); |
|
|
|
} else { |
|
|
|
System.out.println("agv上报不是0073类型动作,不处理"); |
|
|
|
} |
|
|
|
} else{ |
|
|
|
System.out.println("agv上报不是0073类型动作,不处理"); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} catch( |
|
|
|
Exception e) |
|
|
|
} catch ( |
|
|
|
Exception e) { |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
} finally { |
|
|
|
|
|
|
|
} finally |
|
|
|
|
|
|
|
{ |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
@Override |
|
|
|
public void stop() { |
|
|
|