From dad3cd8ed8afa86b651bb1a053421e7aa2b8c7ac Mon Sep 17 00:00:00 2001 From: Junjie <540245094@qq.com> Date: 星期日, 05 五月 2024 16:31:09 +0800 Subject: [PATCH] # --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java | 73 ++++++++++++++---------------------- 1 files changed, 29 insertions(+), 44 deletions(-) diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java index 0eb07b2..619c409 100644 --- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java +++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/rcs/model/protocol/ShuttleProtocol.java @@ -7,23 +7,19 @@ import com.zy.asrs.wcs.core.service.LocService; import com.zy.asrs.wcs.core.utils.RedisUtil; import com.zy.asrs.wcs.rcs.constant.DeviceRedisConstant; -import com.zy.asrs.wcs.rcs.model.enums.ShuttleDeviceStatusType; import com.zy.asrs.wcs.rcs.model.enums.ShuttleProtocolStatusType; import com.zy.asrs.wcs.rcs.entity.Device; import com.zy.asrs.wcs.rcs.entity.ShuttleDeviceStatus; -import com.zy.asrs.wcs.rcs.model.enums.SlaveType; import com.zy.asrs.wcs.rcs.service.ShuttleDeviceStatusService; import lombok.Data; import lombok.extern.slf4j.Slf4j; - -import java.util.HashMap; /** * 鍥涘悜绌挎杞� */ @Slf4j @Data -public class ShuttleProtocol { +public class ShuttleProtocol implements Cloneable{ //**********************蹇呴』瀛樺湪灞炴��********************** /** @@ -60,6 +56,11 @@ * 灏忚溅璁惧鐘舵�� */ private Integer deviceStatus; + + /** + * 灏忚溅妯″紡锛�0锛氭墜鍔� 1锛氳嚜鍔� + */ + private Integer mode; /** * 褰撳墠浜岀淮鐮� @@ -163,9 +164,24 @@ private Long deviceDataLog = System.currentTimeMillis(); /** + * 鎸囦护涓嬪彂鏃堕棿 + */ + private Long sendTime = 0L; + + /** + * 鏈�杩戜竴娆″湪绾挎椂闂� + */ + private Long lastOnlineTime = System.currentTimeMillis(); + + /** * 璁惧淇℃伅 */ private Device device; + + /** + * 鎵╁睍瀛楁 + */ + private Object extend; /** * 璁剧疆灏忚溅鐘舵�� @@ -202,28 +218,6 @@ return ""; } - /** - * 鑾峰彇灏忚溅绌洪棽鐘舵�� - */ - public Boolean getIdle() { - if (this.deviceStatus == null) { - return false; - } - - ShuttleDeviceStatusService shuttleDeviceStatusService = SpringUtils.getBean(ShuttleDeviceStatusService.class); - ShuttleDeviceStatus status = shuttleDeviceStatusService.getOne(new LambdaQueryWrapper<ShuttleDeviceStatus>() - .eq(ShuttleDeviceStatus::getHostId, this.device.getHostId()) - .eq(ShuttleDeviceStatus::getDevicePlc, this.device.getDevicePlc()) - .eq(ShuttleDeviceStatus::getStatus, 1) - .eq(ShuttleDeviceStatus::getDeviceStatus, this.deviceStatus)); - if (status != null) { - if (status.getFlag() != null && status.getFlag().equals(String.valueOf(ShuttleDeviceStatusType.IDLE))) { - return true;//绌洪棽涓� - } - } - return false;//榛樿涓嶇┖闂� - } - public Integer getTaskNo() { RedisUtil redisUtil = SpringUtils.getBean(RedisUtil.class); if (null != redisUtil) { @@ -235,7 +229,7 @@ return this.taskNo == null ? 0 : this.taskNo; } - public void setTaskNo(Integer taskNo) { + public synchronized void setSyncTaskNo(Integer taskNo) { RedisUtil redisUtil = SpringUtils.getBean(RedisUtil.class); if (null != redisUtil) { redisUtil.set(DeviceRedisConstant.SHUTTLE_FLAG + this.shuttleNo, taskNo); @@ -265,23 +259,14 @@ return currentLoc.getLocNo(); } - // 鏄惁澶勪簬绌洪棽寰呭懡鐘舵�� - public Boolean isIdle() { - if (this.deviceStatus == null - || this.pakMk == null - || this.errorCode == null - || this.protocolStatus == null - ) { - return false; + @Override + public ShuttleProtocol clone() { + try { + return (ShuttleProtocol) super.clone(); + } catch (CloneNotSupportedException e) { + e.printStackTrace(); } - - boolean res = this.deviceStatus.equals(ShuttleDeviceStatusType.IDLE) - && this.pakMk - && !this.errorCode.equals("0") - && this.getTaskNo() == 0 - && this.protocolStatus.intValue() == ShuttleProtocolStatusType.IDLE.id - ; - return res; + return null; } } -- Gitblit v1.9.1