add:一期扫码器

This commit is contained in:
2025-11-05 13:25:35 +08:00
parent 28db4ead2c
commit df28722b1a
9 changed files with 839 additions and 2 deletions

View File

@@ -67,7 +67,9 @@ public enum DriverTypeEnum {
PLUGGING_UNPLUGGING_MACHINE(25,"plugging_unplugging_machine","插拔轴机","station"),
RGV(28,"rgv","rgv","conveyor");
RGV(28,"rgv","rgv","conveyor"),
MODBUS_SCANNER(28,"modbus_scanner","modbus扫码器","scanner");
//驱动索引

View File

@@ -0,0 +1,89 @@
package org.nl.acs.device_driver.basedriver.modbus_scanner;
import cn.hutool.core.util.StrUtil;
import lombok.Data;
import lombok.extern.slf4j.Slf4j;
import org.nl.acs.device.device_driver.standard_inspect.ItemDto;
import java.util.ArrayList;
import java.util.List;
@Slf4j
@Data
public class
ItemProtocol {
//触发就绪
public static String item_trigger_ready = "trigger_ready";
//触发完成
public static String item_trigger_finish = "trigger_finish";
//条码
public static String item_barcode = "barcode";
//下发触发使能
public static String item_to_trigger_enable = "to_trigger_enable";
//下发触发
public static String item_to_trigger = "to_trigger";
private ModbusScannerDeviceDriver driver;
public ItemProtocol(ModbusScannerDeviceDriver driver) {
this.driver = driver;
}
public int getTrigger_Ready() {
return this.getOpcIntegerValue(item_trigger_ready);
}
public int getTrigger_Finish() {
return this.getOpcIntegerValue(item_trigger_finish);
}
public String getBarcode() {
return this.getOpcStringValue(item_barcode);
}
public int getTo_trigger_Enable() {
return this.getOpcIntegerValue(item_to_trigger_enable);
}
public int getTo_trigger() {
return this.getOpcIntegerValue(item_to_trigger);
}
Boolean isonline;
public int getOpcIntegerValue(String protocol) {
Integer value = this.driver.getIntegeregerValue(protocol);
if (value == null) {
setIsonline(false);
} else {
setIsonline(true);
return value;
}
return 0;
}
public String getOpcStringValue(String protocol) {
String value = this.driver.getStringValue(protocol);
if (!StrUtil.isBlank(value)) {
return value;
}
return null;
}
public static List<ItemDto> getReadableItemDtos() {
ArrayList<ItemDto> list = new ArrayList<>();
list.add(new ItemDto(item_trigger_ready, "触发就绪", "10001"));
list.add(new ItemDto(item_trigger_finish, "触发完成", "10002"));
list.add(new ItemDto(item_barcode, "条码", "32006.30L"));
return list;
}
public static List<ItemDto> getWriteableItemDtos() {
ArrayList<ItemDto> list = new ArrayList<>();
list.add(new ItemDto(item_to_trigger_enable, "下发触发使能", "00001"));
list.add(new ItemDto(item_to_trigger, "下发触发", "00002"));
return list;
}
}

View File

@@ -0,0 +1,56 @@
package org.nl.acs.device_driver.basedriver.modbus_scanner;
import org.nl.acs.device.device_driver.standard_inspect.ItemDto;
import org.nl.acs.device_driver.DeviceDriver;
import org.nl.acs.device_driver.defination.OpcDeviceDriverDefination;
import org.nl.acs.opc.Device;
import org.nl.acs.opc.DeviceType;
import org.springframework.stereotype.Service;
import java.util.LinkedList;
import java.util.List;
@Service
public class ModbusScannerDefination implements OpcDeviceDriverDefination {
@Override
public String getDriverCode() {
return "modbus_scanner";
}
@Override
public String getDriverName() {
return "modbus扫码器";
}
@Override
public String getDriverDescription() {
return "modbus扫码器";
}
@Override
public DeviceDriver getDriverInstance(Device device) {
return (new ModbusScannerDeviceDriver()).setDevice(device).setDriverDefination(this);
}
@Override
public Class<? extends DeviceDriver> getDeviceDriverType() {
return ModbusScannerDeviceDriver.class;
}
@Override
public List<DeviceType> getFitDeviceTypes() {
List<DeviceType> types = new LinkedList();
types.add(DeviceType.scanner);
return types;
}
@Override
public List<ItemDto> getReadableItemDtos() {
return ItemProtocol.getReadableItemDtos();
}
@Override
public List<ItemDto> getWriteableItemDtos() {
return ItemProtocol.getWriteableItemDtos();
}
}

View File

@@ -0,0 +1,134 @@
package org.nl.acs.device_driver.basedriver.modbus_scanner;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson.JSONObject;
import lombok.Data;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.nl.acs.device_driver.DeviceDriver;
import org.nl.acs.device_driver.FeedLmsRealFailed;
import org.nl.acs.device_driver.RouteableDeviceDriver;
import org.nl.acs.device_driver.driver.AbstractOpcDeviceDriver;
import org.nl.acs.device_driver.driver.ExecutableDeviceDriver;
import org.nl.acs.log.service.DeviceExecuteLogService;
import org.nl.acs.monitor.DeviceStageMonitor;
import org.nl.acs.opc.Device;
import org.nl.modules.wql.util.SpringContextHolder;
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.Map;
/**
* 扫码器
*/
@Slf4j
@Data
@RequiredArgsConstructor
public class ModbusScannerDeviceDriver extends AbstractOpcDeviceDriver implements DeviceDriver, ExecutableDeviceDriver, RouteableDeviceDriver, DeviceStageMonitor {
protected ItemProtocol itemProtocol = new ItemProtocol(this);
private final DeviceExecuteLogService logServer = SpringContextHolder.getBean("deviceExecuteLogServiceImpl");
//触发就绪
private int trigger_ready = 0;
private int last_trigger_ready = 0;
//触发完成
private int trigger_finish = 0;
private int last_trigger_finish = 0;
//条码
private String barcode = null;
private String last_barcode = null;
//下发触发使能
private int to_trigger_enable = 0;
private int last_to_trigger_enable = 0;
//下发触发
private int to_trigger = 0;
private int last_to_trigger = 0;
String device_code;
@Override
public Device getDevice() {
return this.device;
}
@Override
public void execute() {
this.device_code = this.getDevice().getDevice_code();
this.trigger_ready = this.itemProtocol.getTrigger_Ready();
this.trigger_finish = this.itemProtocol.getTrigger_Finish();
this.barcode = this.itemProtocol.getBarcode();
this.to_trigger_enable = this.itemProtocol.getTo_trigger_Enable();
this.to_trigger = this.itemProtocol.getTo_trigger();
if (this.trigger_ready != this.last_trigger_ready) {
if (this.trigger_ready == 0) {
this.writing("to_trigger_enable", "1");
}
logServer.deviceExecuteLog(this.device_code, "", "", "信号trigger_ready" + last_trigger_ready + "->" + trigger_ready);
}
if (this.trigger_finish != this.last_trigger_finish) {
if (this.trigger_finish == 1) {
this.writing("to_trigger", "0");
}
logServer.deviceExecuteLog(this.device_code, "", "", "信号trigger_finish" + last_trigger_finish + "->" + trigger_finish);
}
if (!StrUtil.equals(this.barcode, this.last_barcode)) {
logServer.deviceExecuteLog(this.device_code, "", "", "信号barcode" + last_barcode + "->" + barcode);
}
if (this.to_trigger_enable != this.last_to_trigger_enable) {
logServer.deviceExecuteLog(this.device_code, "", "", "信号to_trigger_enable" + last_to_trigger_enable + "->" + to_trigger_enable);
}
if (this.to_trigger != this.last_to_trigger) {
logServer.deviceExecuteLog(this.device_code, "", "", "信号to_trigger" + last_to_trigger + "->" + to_trigger);
}
this.last_trigger_ready = this.trigger_ready;
this.last_trigger_finish = this.trigger_finish;
this.last_barcode = this.barcode;
this.last_to_trigger_enable = this.to_trigger_enable;
this.last_to_trigger = this.to_trigger;
}
public void writing(Map<String, Object> map) {
DeviceExecuteLogService logServer = SpringContextHolder.getBean("deviceExecuteLogServiceImpl");
Map<String, Object> itemMap = new LinkedHashMap<>();
map.forEach((key, value) -> {
if (ObjectUtil.isNotEmpty(value)) {
itemMap.put(getToParam() + key, value);
}
});
if (ObjectUtil.isNotEmpty(itemMap)) {
this.control(itemMap);
logServer.deviceExecuteLog(this.getDevice().getDevice_code(), "", "", "下发多个电气信号:" + itemMap);
}
}
public String getToParam() {
return this.getDevice().getOpc_server_code() + "." + this.getDevice().getOpc_plc_code() + "." + this.getDevice().getDevice_code() + ".";
}
@Override
public JSONObject getDeviceStatusName() {
Map<String, Object> map = new LinkedHashMap<>();
JSONObject jo = new JSONObject(map);
return jo;
}
@Override
public void setDeviceStatus(JSONObject data) {
}
public void writing(String param, String value) {
String to_param = this.getDevice().getOpc_server_code() + "." + this.getDevice().getOpc_plc_code() + "." + this.getDevice().getDevice_code()
+ "." + param;
Map<String, Object> itemMap = new HashMap<String, Object>();
itemMap.put(to_param, Integer.parseInt(value));
this.control(itemMap);
logServer.deviceExecuteLog(device_code, "", "", "下发电气信号设备号:" + device_code + ",下发电气:" + to_param + ",下发电气值:" + value);
}
}

View File

@@ -167,4 +167,10 @@ public class WmsToAcsController {
JSONObject jsonObject = jsonArray.getJSONObject(0);
return new ResponseEntity<>(wmstoacsService.finishTask(jsonObject),HttpStatus.OK);
}
@PostMapping("/getBarcode")
@SaIgnore
public ResponseEntity<Object> getBarcode(@RequestBody JSONObject param){
return new ResponseEntity<>(wmstoacsService.getBarcode(param), HttpStatus.OK);
}
}

View File

@@ -125,4 +125,6 @@ public interface WmsToAcsService {
* @return
*/
Map<String, Object> finishTask(JSONObject jsonObject) throws Exception;
Map<String,Object> getBarcode(JSONObject param);
}

View File

@@ -28,6 +28,7 @@ import org.nl.acs.device_driver.basedriver.hongxiang_conveyor.HongXiangStationDe
import org.nl.acs.device_driver.basedriver.hongxiang_device.HongXiangConveyorDeviceDriver;
import org.nl.acs.device_driver.basedriver.indoor_manipulator.IndoorManipulatorDeviceDriver;
import org.nl.acs.device_driver.basedriver.lamp_three_color.LampThreecolorDeviceDriver;
import org.nl.acs.device_driver.basedriver.modbus_scanner.ModbusScannerDeviceDriver;
import org.nl.acs.device_driver.basedriver.oven_manipulator.OvenGantryManipulatorDeviceDriver;
import org.nl.acs.device_driver.basedriver.paper_tube_device.PaperTubeConveyorDeviceDriver;
import org.nl.acs.device_driver.basedriver.paper_tube_device2.Paper;
@@ -70,6 +71,7 @@ import org.nl.modules.system.service.DictDetailService;
import org.nl.modules.system.service.DictService;
import org.nl.modules.system.service.ParamService;
import org.nl.modules.system.service.dto.DictDetailDto;
import org.nl.modules.system.service.dto.ParamDto;
import org.nl.modules.wql.core.bean.WQLObject;
import org.nl.modules.wql.exception.WDKException;
import org.nl.modules.wql.util.SpringContextHolder;
@@ -100,6 +102,7 @@ public class WmsToAcsServiceImpl implements WmsToAcsService {
private final AcsToLiKuService acsToLiKuService;
private final DictDetailService dictDetailService;
private final DictService dictService;
private final ParamService paramService;
private String log_file_type = "log_file_type";
@@ -1539,4 +1542,41 @@ public class WmsToAcsServiceImpl implements WmsToAcsService {
return resp;
}
@Override
public Map<String, Object> getBarcode(JSONObject param) {
log.info("getBarcode--------------:输入参数" + param.toString());
Map<String, Object> resp = new HashMap<>();
String device_code = param.getString("device_code");
ParamDto paramDto = paramService.findByCode(device_code);
if (paramDto == null) {
throw new BadRequestException("系统参数未配置IN点对应点扫码器!");
}
String smDeviceCode = paramDto.getValue();
if (StrUtil.isEmpty(smDeviceCode)) {
throw new BadRequestException("系统参数配置IN点扫码器为空!");
}
Device device = deviceAppService.findDeviceByCode(smDeviceCode);
if (device != null && device.getDeviceDriver() instanceof ModbusScannerDeviceDriver) {
ModbusScannerDeviceDriver modbusScannerDeviceDriver = (ModbusScannerDeviceDriver) device.getDeviceDriver();
modbusScannerDeviceDriver.writing("to_trigger", "1");
try {
Thread.sleep(1500);
} catch (InterruptedException e) {
e.printStackTrace();
}
device = deviceAppService.findDeviceByCode(smDeviceCode);
modbusScannerDeviceDriver = (ModbusScannerDeviceDriver) device.getDeviceDriver();
resp.put("status",200);
resp.put("message", "成功");
resp.put("vehicle_code", modbusScannerDeviceDriver.getBarcode() == null ? "" : modbusScannerDeviceDriver.getBarcode());
log.info("getBarcode--------------:输出参数" + resp.toString());
return resp;
}
resp.put("status",200);
resp.put("message", "成功");
resp.put("vehicle_code", "");
log.info("getBarcode--------------:输出参数" + resp.toString());
return resp;
}
}