From a745fd53a1c8840a886c826c6a6bf0b8b226cd25 Mon Sep 17 00:00:00 2001 From: zhoushihao <zsh19950802@163.com> Date: 星期四, 20 六月 2024 22:07:05 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java | 444 +++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 282 insertions(+), 162 deletions(-) diff --git a/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java b/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java index 63c5dbb..01aa22e 100644 --- a/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java +++ b/hangzhoumesParent/moduleService/CacheVerticalGlassModule/src/main/java/com/mes/job/PlcStorageCageTask.java @@ -2,32 +2,38 @@ import cn.hutool.core.lang.Assert; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; +import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; +import com.github.yulichang.toolkit.JoinWrappers; +import com.mes.bigstorage.entity.BigStorageCage; import com.mes.bigstorage.entity.BigStorageCageDetails; import com.mes.bigstorage.entity.BigStorageDTO; +import com.mes.bigstorage.entity.dto.SlotSequenceDTO; +import com.mes.bigstorage.entity.dto.TemperingLayoutDTO; import com.mes.bigstorage.service.BigStorageCageDetailsService; import com.mes.bigstorage.service.BigStorageCageService; import com.mes.bigstoragetask.entity.BigStorageCageFeedTask; import com.mes.bigstoragetask.entity.BigStorageCageOutTask; import com.mes.bigstoragetask.service.BigStorageCageFeedTaskService; import com.mes.bigstoragetask.service.BigStorageCageOutTaskService; -import com.mes.common.S7object; import com.mes.common.config.Const; -import com.mes.device.PlcParameterObject; +import com.mes.edgglasstask.entity.EdgGlassTaskInfo; import com.mes.edgglasstask.service.EdgGlassTaskInfoService; import com.mes.glassinfo.entity.GlassInfo; import com.mes.glassinfo.service.GlassInfoService; +import com.mes.temperingglass.entity.TemperingGlassInfo; import com.mes.temperingglass.service.TemperingGlassInfoService; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Value; -import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; -import org.springframework.util.CollectionUtils; import javax.annotation.Resource; +import java.util.ArrayList; +import java.util.Date; import java.util.List; import java.util.Map; -import java.util.concurrent.atomic.AtomicReference; import java.util.stream.Collectors; /** @@ -52,178 +58,280 @@ @Resource private TemperingGlassInfoService temperingGlassInfoService; + private static final String REQUEST_WORD = "1"; + @Value("${mes.sequence.order}") private boolean sequenceOrder; - public static boolean bigStorageCageFullAlarm = false; + @Value("${mes.slotWidth}") + private Integer slotWidth; - private int line1Time = 0; - private int line2Time = 0; + // @Scheduled(fixedDelay = 5000) + public void plcToHomeEdgScan(String d01Id) { +// PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; +// String d01Request = plcParameterObject.getPlcParameter("D01Request").getValue(); +// String d01Id = plcParameterObject.getPlcParameter("D01ID1").getValue(); +// String d02SitState = plcParameterObject.getPlcParameter("D02SitState").getValue(); +// String d04Request = plcParameterObject.getPlcParameter("D04Request").getValue(); +// String d04Id = plcParameterObject.getPlcParameter("D04ID1").getValue(); +// String d05SitState = plcParameterObject.getPlcParameter("D05SitState").getValue(); - /** - * fixedRate : 涓婁竴涓皟鐢ㄥ紑濮嬪悗鍐嶆璋冪敤鐨勫欢鏃讹紙涓嶇敤绛夊緟涓婁竴娆¤皟鐢ㄥ畬鎴愶級 - * fixedDelay : 涓婁竴涓皟鐢ㄧ粨鏉熷悗鍐嶆璋冪敤鐨勫欢鏃� - */ - @Scheduled(fixedDelay = 5000) - public void plcStorageCageTask() throws InterruptedException { - - PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; - try { - - String plcFeedGlassid = ""; - String plcFeedReqLine = "0"; - if ("1".equals(plcParameterObject.getPlcParameter("D01Request").getValue())) { - plcFeedReqLine = "1"; - plcFeedGlassid = plcParameterObject.getPlcParameter("D01ID1").getValue(); - } - if ("1".equals(plcParameterObject.getPlcParameter("D04Request").getValue())) { - plcFeedReqLine = "2"; - plcFeedGlassid = plcParameterObject.getPlcParameter("D04ID1").getValue(); - } - line1Time += 1; - line2Time += 1; - - if (!("0".equals(plcFeedReqLine))) { - log.info("1銆丳lc杩涚墖璇锋眰鏃�"); - BigStorageCageDetails bigStorageCageDetails = new BigStorageCageDetails(); - GlassInfo glassInfo = glassInfoService.getById(plcFeedGlassid); - log.info("2銆佹牴鎹幓鐠僫d鑾峰彇鐜荤拑淇℃伅" + glassInfo); - if (bigStorageCageDetailsService.selectGetBoard(plcFeedReqLine) >= 0) { - BigStorageCageDetails slotInfo = bigStorageCageService.feedGlass(glassInfo, bigStorageCageDetails); - if (slotInfo != null) { - int taskType = edgGlassTaskInfoService.judgeTasktype(plcFeedReqLine); - log.info("3銆佹煡璇换鍔¤〃鍒ゆ柇褰撳墠浠诲姟绫诲瀷涓轰笂杞︾瓑鍒拌繕鏄笂杞﹀惎鍔�" + taskType); - bigStorageCageFeedTaskService.addFeedTask(slotInfo, Integer.parseInt(plcFeedReqLine), taskType); - log.info("4銆佹坊鍔犱换鍔″埌浠诲姟琛�"); - bigStorageCageFullAlarm = false; - } else { - bigStorageCageFullAlarm = true; - } - } else { - log.info("褰撳墠鐜荤拑瀹藉害涓嶅涓婅溅" + glassInfo); - if (!("1".equals(plcFeedReqLine))) { - S7object.getinstance().plccontrol.writetime(plcParameterObject.getPlcParameter("D02Go").getAddress(), 1); - } else { - S7object.getinstance().plccontrol.writetime(plcParameterObject.getPlcParameter("D05Go").getAddress(), 1); - } - } - } else { - List<BigStorageCageFeedTask> bigStorageCageFeedTaskList = bigStorageCageFeedTaskService.querybigStorageCageFeedTask(1); - log.info("5銆佹煡璇换鍔¤〃鏄惁鏈夊凡缁忓畬鎴愮殑杩涚墖浠诲姟" + bigStorageCageFeedTaskList.size()); - for (BigStorageCageFeedTask bigStorageCageFeedTask : bigStorageCageFeedTaskList - ) { - BigStorageCageDetails bigStorageCageDetails = new BigStorageCageDetails(); - bigStorageCageDetails.setId(bigStorageCageFeedTask.getId()); - bigStorageCageDetails.setState(1); - bigStorageCageDetailsService.updateById(bigStorageCageDetails); - log.info("6銆佷慨鏀圭悊鐗囩璇︽儏鐜荤拑鐘舵��"); - bigStorageCageFeedTaskService.removeById(bigStorageCageFeedTask); - log.info("7銆佸垹闄ゅ凡缁忓畬鎴愮殑杩涚墖浠诲姟"); - } - //鍚姩闃堝�� - if (line1Time >= 300) { - if ("0".equals(plcParameterObject.getPlcParameter("D05Go").getValue())) { - S7object.getinstance().plccontrol.writetime(plcParameterObject.getPlcParameter("D02Go").getAddress(), 1); - } - } - if (line2Time >= 300) { - if ("0".equals(plcParameterObject.getPlcParameter("D02Go").getValue())) { - S7object.getinstance().plccontrol.writetime(plcParameterObject.getPlcParameter("D05Go").getAddress(), 1); - } - } - } - - //鏌ヨ鍑虹墖琛ㄦ槸鍚︽湁浠诲姟鏈畬鎴愮殑浠诲姟 - List<BigStorageCageOutTask> bigStorageCageOutTask = bigStorageCageOutTaskService.querybigStorageCageOutTask(0); - if (bigStorageCageOutTask.size() == 0) { - boolean result = bigStorageCageService.outGlass(); - log.info("8銆佹病鏈夋湭瀹屾垚浠诲姟鏃惰皟鐢ㄥ嚭鐗囨帴鍙�"); - if (result == false) { - temperingGlassInfoService.schedulingTask(); - } - } - bigStorageCageOutTaskService.updateOutTask(); - log.info("9銆佹牴鎹换鍔¤〃鐘舵�佷慨鏀归挗鍖栧皬鐗囪〃浠诲姟鐘舵��"); - - //鏉ヤ笉鍙婇�佹椂鐩存帴璧� - String line = Integer.toString(edgGlassTaskInfoService.startTask()); - - if (!(line.equals(plcFeedReqLine))) { - S7object.getinstance().plccontrol.writetime(plcParameterObject.getPlcParameter("D02Go").getAddress(), 1); - } else { - S7object.getinstance().plccontrol.writetime(plcParameterObject.getPlcParameter("D05Go").getAddress(), 1); - } - - - } catch (Exception e) { - e.printStackTrace(); + String d01Request = "1"; + String d02SitState = "0"; +// String d01Id = "P24060403|3|6"; + String d04Request = "0"; + String d05SitState = "0"; +// String d04Id = "P24060403|4|3"; + String d04Id = "P24060403|5|4"; + log.info("1銆佽幏鍙栧埌鐨勮姹傚瓧d01涓猴細{}锛岃幏鍙栧埌鐨勬壂鎻廔D涓猴細{};鑾峰彇鍒扮殑璇锋眰瀛梔04涓猴細{}锛岃幏鍙栧埌鐨勬壂鎻廔D涓猴細{};", + d01Request, d01Id, d04Request, d04Id); + if (!REQUEST_WORD.equals(d01Request) && !REQUEST_WORD.equals(d04Request)) { + log.info("涓ゆ潯绾挎湭鏀跺埌杩涚墖浠诲姟锛岀粨鏉熸湰娆℃壂鎻忚繘鍗ц浆绔嬩换鍔�"); + return; + } + if (REQUEST_WORD.equals(d02SitState) && REQUEST_WORD.equals(d05SitState)) { + log.info("涓ゆ潯绾垮崸杞珛鍧囧湪鎵ц浠诲姟锛岀粨鏉熸湰娆℃壂鎻忚繘鍗ц浆绔嬩换鍔�"); + return; + } + Boolean flag01 = Boolean.FALSE; + Boolean flag04 = Boolean.FALSE; + //鎸夌収绾胯矾鍙婄幓鐠僫d鑾峰彇鐩搁偦涓ゅ潡鐜荤拑 鍗ц浆绔嬩笂鐨勭幓鐠� + if (REQUEST_WORD.equals(d01Request) && !REQUEST_WORD.equals(d02SitState)) { + flag01 = judgeGlassTypeStatus(d01Id, Const.A09_OUT_TARGET_POSITION); + } + if (REQUEST_WORD.equals(d04Request) && !REQUEST_WORD.equals(d05SitState)) { + flag04 = judgeGlassTypeStatus(d04Id, Const.A10_OUT_TARGET_POSITION); + } + if (flag01 && flag04) { + //姣旇緝鏈�鏃╀竴鐗囦换鍔$殑鐗堝浘id鍙婄増搴� 姹傚嚭鍗ц浆绔嬬殑绾胯矾 + Integer startLine = getStartLine(); + //璁$畻鐩爣鏍煎瓙锛屽彂閫佸惎鍔ㄤ换鍔� + computeTargetByLine(startLine); + } else if (flag01 || flag04) { + Integer startLine = flag01.equals(Boolean.TRUE) ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; + //璁$畻鐩爣鏍煎瓙锛屽彂閫佸惎鍔ㄤ换鍔� + computeTargetByLine(startLine); + } else { + log.info("涓ゆ潯绾挎湭鏀跺埌杩涚墖浠诲姟锛岀粨鏉熸湰娆℃壂鎻忚繘鍗ц浆绔嬩换鍔�"); } } - @Scheduled(fixedDelay = 5000) + // @Scheduled(fixedDelay = 5000) public void plcToHomeEdgFreeCarTask() { - PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; - String freeCar = plcParameterObject.getPlcParameter("freeCar").getValue(); - if ("1".equals(freeCar)) { - log.info("澶ц溅闈炵┖闂�"); +// PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject; +// String e01Status = plcParameterObject.getPlcParameter("E01Status").getValue(); + String e01Status = "0"; + if (REQUEST_WORD.equals(e01Status)) { + log.info("杩涚墖澶ц溅闈炵┖闂�"); return; } - String d01Request = plcParameterObject.getPlcParameter("D01Request").getValue(); - String d01ID1 = plcParameterObject.getPlcParameter("D01ID1").getValue(); -// 0锛氫笉骞查 锛� 1锛氭潯浠舵弧瓒虫儏鍐典笅绔嬪嵆鍙戣溅 - String d04Request = plcParameterObject.getPlcParameter("D04Request").getValue(); - String d04ID1 = plcParameterObject.getPlcParameter("D04ID1").getValue(); +// String d01Request = plcParameterObject.getPlcParameter("D01Request").getValue(); +// String d01Id = plcParameterObject.getPlcParameter("D01ID1").getValue(); +// String d04Request = plcParameterObject.getPlcParameter("D04Request").getValue(); +// String d04Id = plcParameterObject.getPlcParameter("D04ID1").getValue(); + String d01Request = ""; + String d01Id = ""; + String d04Request = "1"; + String d04Id = ""; log.info("1銆佽幏鍙栧埌鐨勮姹傚瓧d01涓猴細{}锛岃幏鍙栧埌鐨勬壂鎻廔D涓猴細{};鑾峰彇鍒扮殑璇锋眰瀛梔04涓猴細{}锛岃幏鍙栧埌鐨勬壂鎻廔D涓猴細{};", - d01Request, d01ID1, d04Request, d04ID1); + d01Request, d01Id, d04Request, d04Id); //涓ゆ潯绾块兘鏈夎繘鍗ц浆绔嬩换鍔★紝鐩存帴缁撴潫 if (Const.BIG_STORAGE_REQUEST_IN.equals(d01Request) - && Const.BIG_STORAGE_REQUEST_IN.equals(d04Request) - && StringUtils.isNotBlank(d01ID1) - && StringUtils.isNotBlank(d04ID1)) { + && Const.BIG_STORAGE_REQUEST_IN.equals(d04Request)) { log.info("涓ゆ潯绾块兘瀛樺湪杩涚墖浠诲姟锛岀粨鏉熶换鍔�"); return; } //鑾峰彇涓ゆ潯绾垮崸杞珛鏄惁鏈夌幓鐠冿紝涓斾换鍔$姸鎬侀兘涓�2 - List<String> lineList = bigStorageCageFeedTaskService.querySitToUpGlass(); + List<Integer> lineList = bigStorageCageFeedTaskService.querySitToUpGlass(); if (CollectionUtils.isEmpty(lineList)) { log.info("涓ゆ潯绾垮崸杞珛涓虹┖鎴栬�呮湁杩涚墖浠诲姟鏈畬鎴愶紝缁撴潫浠诲姟"); return; } -// 0锛氫笉骞查 锛� 1锛氭潯浠舵弧瓒虫儏鍐典笅绔嬪嵆鍙戣溅 - String d02GoAdress = plcParameterObject.getPlcParameter("D02Go").getAddress(); - // 0锛氫笉骞查 锛� 1锛氭潯浠舵弧瓒虫儏鍐典笅绔嬪嵆鍙戣溅 - String d05GoAdress = plcParameterObject.getPlcParameter("D05Go").getAddress(); - String line1 = lineList.get(0); - String flagLine = line1.equals(Const.A09_OUT_TARGET_POSITION) ? d01ID1 : d04ID1; + Integer lineFirst = lineList.get(0); + String lineGlassId = lineFirst.equals(Const.A09_OUT_TARGET_POSITION) ? d01Id : d04Id; if (lineList.size() == 1) { - //鍙戦�� - if (StringUtils.isNotBlank(flagLine)) { - return; - } //璁$畻浠诲姟琛ㄨ繘鐗囨牸瀛� 鍙戦�佽繘鐗囦换鍔� - computeTargetByLine(Integer.parseInt(flagLine), d02GoAdress, d05GoAdress); + if (StringUtils.isEmpty(lineGlassId)) { + computeTargetByLine(lineFirst); + } + return; } - if (StringUtils.isBlank(d01ID1) && StringUtils.isBlank(d04ID1)) { + if (StringUtils.isBlank(d01Id) && StringUtils.isBlank(d04Id)) { //姣旇緝鏈�鏃╀竴鐗囦换鍔$殑鐗堝浘id鍙婄増搴� 姹傚嚭鍗ц浆绔嬬殑绾胯矾 Integer line = getStartLine(); //璁$畻浠诲姟琛ㄨ繘鐗囨牸瀛� 鍙戦�佽繘鐗囦换鍔� - computeTargetByLine(line, d02GoAdress, d05GoAdress); + computeTargetByLine(line); return; } - int outLine = StringUtils.isBlank(d01ID1) ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; + int outLine = StringUtils.isBlank(d01Id) ? Const.A09_OUT_TARGET_POSITION : Const.A10_OUT_TARGET_POSITION; //璁$畻浠诲姟琛ㄨ繘鐗囨牸瀛� 鍙戦�佽繘鐗囦换鍔� - computeTargetByLine(outLine, d02GoAdress, d05GoAdress); + computeTargetByLine(outLine); + } + + // @Scheduled(fixedDelay = 5000) + public void plcToHomeEdgOutTask() { + //浠诲姟鏁版嵁 鑾峰彇杞﹀瓙瀛樻斁鐜荤拑鏈�澶ф暟閲� 鐜荤拑闂撮殧 + List<BigStorageCageOutTask> bigStorageCageOutTaskList = new ArrayList<>(); + //鏄惁鏈夋鍦ㄩ挗鍖栫殑鐜荤拑 + List<TemperingGlassInfo> temperingGlassInfoList = temperingGlassInfoService.list(new LambdaQueryWrapper<TemperingGlassInfo>() + .eq(TemperingGlassInfo::getState, Const.TEMPERING_NEW) + .orderBy(Boolean.TRUE, sequenceOrder, TemperingGlassInfo::getTemperingFeedSequence)); + if (CollectionUtils.isNotEmpty(temperingGlassInfoList)) { + log.info("鏈夋鍦ㄥ嚭鐗囩殑閽㈠寲浠诲姟"); + //鎵撹溅鍓╀綑灏哄 + Integer remainWidth = Const.BIG_STORAGE_WIDTH; + for (TemperingGlassInfo e : temperingGlassInfoList) { + if (bigStorageCageOutTaskList.size() > 5 || e.getWidth() > remainWidth) { + break; + } + remainWidth = remainWidth - e.getWidth().intValue() - Const.BIG_STORAGE_GAP; + bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getState(), Const.A09_OUT_TARGET_POSITION, + e.getWidth().intValue(), 0, 0, 1)); + } + bigStorageCageOutTaskService.saveBatch(bigStorageCageOutTaskList); + return; + } + //鏄惁鏈変汉宸ヤ笅鐗囦换鍔� 鏈夌洿鎺ュ嚭 + List<BigStorageCageDetails> artificialList = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() + .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_ARTIFICIAL).orderByDesc(BigStorageCageDetails::getWidth)); + if (CollectionUtils.isNotEmpty(artificialList)) { + Integer remainWidth = Const.BIG_STORAGE_WIDTH; + for (BigStorageCageDetails e : artificialList) { + if (remainWidth < e.getWidth().intValue()) { + break; + } + bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getSlot(), Const.A10_OUT_TARGET_POSITION, + e.getWidth().intValue(), 0, 0, 1)); + remainWidth = remainWidth - e.getWidth().intValue() - Const.BIG_STORAGE_GAP; + } + bigStorageCageOutTaskService.saveBatch(bigStorageCageOutTaskList); + return; + } + //閽㈠寲浼樺厛锛氳幏鍙栫悊鐗囩 鐜荤拑灏忕墖 鐮存崯琛� 鏁伴噺 鍒ゆ柇绗煎唴鐗堝浘鏄惁鍒伴綈 + TemperingLayoutDTO temperingLayoutDTO = bigStorageCageDetailsService.temperingIsAll(); + if (null != temperingLayoutDTO) { + //鐜荤拑鍒伴綈 + //鍒伴綈锛屽皢鐜荤拑灏忕墖鏁版嵁瀛樺叆閽㈠寲灏忕墖琛紝閫昏緫鐢熸垚鍑虹墖浠诲姟 缁撴潫 + List<TemperingGlassInfo> temperingGlassInfos = glassInfoService.selectJoinList(TemperingGlassInfo.class, JoinWrappers.lambda(GlassInfo.class) + .selectAll(GlassInfo.class) + .selectAs(BigStorageCageDetails::getSlot, TemperingGlassInfo::getSlot) + .innerJoin(BigStorageCageDetails.class, BigStorageCageDetails::getGlassId, GlassInfo::getGlassId) + .eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN) + .eq(GlassInfo::getTemperingLayoutId, temperingLayoutDTO.getTemperingLayoutId()) + .eq(GlassInfo::getEngineerId, temperingLayoutDTO.getEngineerId())); + temperingGlassInfoService.saveBatch(temperingGlassInfos); + + //澶ц溅鍓╀綑灏哄 + Integer remainWidth = Const.BIG_STORAGE_WIDTH; + for (TemperingGlassInfo e : temperingGlassInfos) { + if (bigStorageCageOutTaskList.size() > 5 || e.getWidth() > remainWidth) { + break; + } + remainWidth = remainWidth - e.getWidth().intValue() - Const.BIG_STORAGE_GAP; + bigStorageCageOutTaskList.add(new BigStorageCageOutTask(e.getGlassId(), e.getState(), Const.A09_OUT_TARGET_POSITION, + e.getWidth().intValue(), 0, 0, 1)); + } + bigStorageCageOutTaskService.saveBatch(bigStorageCageOutTaskList); + return; + } + //鏈埌榻� 鎵ц鍐呴儴璋冨害浠诲姟 + TemperingLayoutDTO temperingOccupySlot = bigStorageCageDetailsService.queryTemperingOccupySlot(); + if (null != temperingOccupySlot) { + List<SlotSequenceDTO> slotSequenceList = bigStorageCageDetailsService.queryGlassMaxAndMin(temperingOccupySlot.getEngineerId(), temperingOccupySlot.getTemperingLayoutId()); + for (int i = 0; i < slotSequenceList.size() - 1; i++) { + SlotSequenceDTO first = slotSequenceList.get(i); + SlotSequenceDTO second = slotSequenceList.get(i + 1); + int slotWidth = Const.BIG_STORAGE_WIDTH - first.getRemainWidth() - Const.BIG_STORAGE_GAP; + if (first.getMinSequence() == second.getMaxSequence() + 1 + && second.getRemainWidth() > slotWidth) { + List<BigStorageCageDetails> list = bigStorageCageDetailsService.list(new LambdaQueryWrapper<BigStorageCageDetails>() + .eq(BigStorageCageDetails::getSlot, first.getSlot()).eq(BigStorageCageDetails::getState, Const.GLASS_STATE_IN)); + List<BigStorageCageOutTask> outTasks = list.stream().map(e -> new BigStorageCageOutTask(e.getGlassId(), first.getSlot(), second.getSlot(), + slotWidth, 0, 0, 1)).collect(Collectors.toList()); + bigStorageCageOutTaskService.saveBatch(outTasks); + return; + } + } + } + } + + + /** + * 鎸夌収鐜荤拑id鍒ゆ柇鐜荤拑鐘舵�佸強鍗ц浆绔嬫槸鍚﹀彲鐩存帴鍚姩 + */ + public Boolean judgeGlassTypeStatus(String glassId, Integer line) { + //1銆佽幏鍙栦换鍔¤〃涓浉閭荤幓鐠� + List<EdgGlassTaskInfo> edgGlassTaskInfoList = edgGlassTaskInfoService.list(new LambdaQueryWrapper<EdgGlassTaskInfo>() + .eq(EdgGlassTaskInfo::getLine, line) + .apply("time >= (select time from edg_glass_task_info where glass_id = '" + glassId + "')") + .orderByAsc(EdgGlassTaskInfo::getTime)); + Assert.isFalse(CollectionUtils.isEmpty(edgGlassTaskInfoList), "璇嗗埆鐜荤拑淇℃伅鏈嚭鐜板湪灏哄琛ㄤ腑,鑾峰彇鐩搁偦涓ゅ潡鐜荤拑澶辫触"); + //2銆佽幏鍙栧崸杞珛鍓╀綑瀹藉害 + BigStorageDTO sitToUpRemainWidth = bigStorageCageFeedTaskService.querySitToUpRemainWidth(line); + Integer remainWidth; + Integer glassCount; + if (0 == sitToUpRemainWidth.getGlassCount()) { + remainWidth = Const.BIG_STORAGE_WIDTH; + glassCount = 0; + } else { + remainWidth = sitToUpRemainWidth.getWidth(); + glassCount = sitToUpRemainWidth.getGlassCount(); + } + //2銆佽幏鍙栧崸杞珛 + Integer widthFirst = edgGlassTaskInfoList.get(0).getWidth(); + if (edgGlassTaskInfoList.size() == 1) { + if (remainWidth >= widthFirst) { + if (glassCount <= 5) { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_WAIT, widthFirst); + return Boolean.FALSE; + } else { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst); + return Boolean.TRUE; + } + } + } else { + Integer widthSecond = edgGlassTaskInfoList.get(1).getWidth(); + if (remainWidth >= widthFirst) { + if (remainWidth - widthFirst - Const.BIG_STORAGE_GAP >= widthSecond) { + if (glassCount <= 5) { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_WAIT, widthFirst); + return Boolean.FALSE; + } else { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst); + return Boolean.TRUE; + } + } else { + addFeedTask(glassId, line, Const.BIG_STORAGE_IN_RUN, widthFirst); + } + } + } + //璁板綍鏃犳硶鏀句笅鐜荤拑锛屽悗缁垽鏂惎鍔� + return Boolean.TRUE; + } + + /** + * 娣诲姞浠诲姟淇℃伅 + */ + private Boolean addFeedTask(String glassId, Integer line, Integer taskType, Integer width) { + BigStorageCageFeedTask bigStorageCageFeedTask = new BigStorageCageFeedTask(); + bigStorageCageFeedTask.setGlassId(glassId); + bigStorageCageFeedTask.setTaskState(Const.BIG_STORAGE_IN_NEW); + bigStorageCageFeedTask.setLine(line); + bigStorageCageFeedTask.setTaskType(taskType); + bigStorageCageFeedTask.setWidth(width); + bigStorageCageFeedTask.setCreateTime(new Date()); + return bigStorageCageFeedTaskService.save(bigStorageCageFeedTask); } /** * 鑾峰彇闇�瑕佸惎鍔ㄧ殑绾胯矾锛氫袱鏉$嚎閮藉彲鍚姩 鑾峰彇绗竴鐗囩幓鐠冪増鍥緄d鏈�灏� 鐗堝簭鏈�澶х殑绾胯矾 * - * @return + * @return 闇�瑕佸惎鍔ㄧ殑绾胯矾 */ - private Integer getStartLine() { + public Integer getStartLine() { List<BigStorageCageFeedTask> taskList = bigStorageCageFeedTaskService.list(new LambdaQueryWrapper<BigStorageCageFeedTask>() .inSql(BigStorageCageFeedTask::getId, "select min(id) from big_storage_cage_feed_task where task_state = 2 group by line")); - Assert.isTrue(CollectionUtils.isEmpty(taskList), "鍗ц浆绔嬩袱鏉$嚎閮芥病鏈夌幓鐠冭繘鐗囦换鍔�"); + Assert.isFalse(CollectionUtils.isEmpty(taskList), "鍗ц浆绔嬩袱鏉$嚎閮芥病鏈夌幓鐠冭繘鐗囦换鍔�"); Map<String, Integer> taskMap = taskList.stream().collect(Collectors.toMap(BigStorageCageFeedTask::getGlassId, BigStorageCageFeedTask::getLine)); GlassInfo glassInfo = glassInfoService.getOne(new LambdaQueryWrapper<GlassInfo>() @@ -237,39 +345,51 @@ /** * 璁$畻浠诲姟琛ㄨ繘鐗囩嚎璺殑鐩爣鏍煎瓙锛屽苟鍚姩浠诲姟 */ - private boolean computeTargetByLine(Integer line, String d02GoAdress, String d05GoAdress) { + public boolean computeTargetByLine(Integer line) { //1銆佽幏鍙栦换鍔¤〃涓殑鎵�鏈夌幓鐠冿紙鎸囧畾绾胯矾涓斿凡缁忚繘鍗ц浆绔嬪畬鎴愶級 List<BigStorageCageFeedTask> taskList = bigStorageCageFeedTaskService.list(new LambdaQueryWrapper<BigStorageCageFeedTask>() .eq(BigStorageCageFeedTask::getLine, line) - .eq(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP) + .in(BigStorageCageFeedTask::getTaskState, Const.BIG_STORAGE_IN_UP_ALL) .orderByAsc(BigStorageCageFeedTask::getId)); //2銆佸幓绗煎瓙鍐呮煡鎵炬槸鍚﹀彲浠ョ户缁瓨鏀剧殑绗煎瓙 List<String> glassIds = taskList.stream().map(BigStorageCageFeedTask::getGlassId).collect(Collectors.toList()); List<GlassInfo> glassInfos = glassInfoService.list(new LambdaQueryWrapper<GlassInfo>().in(GlassInfo::getGlassId, glassIds)); - AtomicReference<Integer> temperingLayoutIdTemp = new AtomicReference<>(0); - AtomicReference<Integer> temperingFeedSequenceTemp = new AtomicReference<>(0); - AtomicReference<BigStorageDTO> bigStorageDTO = new AtomicReference<>(new BigStorageDTO()); - Map<String, GlassInfo> glassInfoMap = glassInfos.stream().collect(Collectors.toMap(GlassInfo::getGlassId, p -> p)); - taskList.stream().forEach(e -> { - //鎸夌収鐗堝浘淇℃伅鑾峰彇杩涚墖绗煎瓙鏍煎瓙鍙� + return computeIsTemperingTargetByLine(glassInfos, taskList, Boolean.TRUE) && computeIsTemperingTargetByLine(glassInfos, taskList, Boolean.FALSE); + } + + /** + * 鏄惁閽㈠寲鐜荤拑杩涚鐩爣浣嶇疆 + * + * @param glassInfos 褰撴潯绾垮崸杞珛鎵�鏈夌幓鐠� + * @param taskList 褰撴潯绾垮崸杞珛鎵�鏈変换鍔� + * @param isTempering true 閽㈠寲 false 涓嶉挗鍖� + */ + private boolean computeIsTemperingTargetByLine(List<GlassInfo> glassInfos, List<BigStorageCageFeedTask> taskList, Boolean isTempering) { + //1銆佸皢鐜荤拑淇℃伅闆嗗悎杞负glassid涓簁ey鐨刴ap + Map<String, GlassInfo> glassInfoMap = glassInfos.stream() + .collect(Collectors.toMap(GlassInfo::getGlassId, p -> p)); + for (BigStorageCageFeedTask e : taskList) { GlassInfo info = glassInfoMap.get(e.getGlassId()); - if (temperingLayoutIdTemp.equals(info.getTemperingLayoutId()) - && temperingFeedSequenceTemp.equals(info.getTemperingFeedSequence() + 1) - && info.getWidth() <= bigStorageDTO.get().getWidth()) { - bigStorageDTO.get().setWidth(bigStorageDTO.get().getWidth() - info.getWidth().intValue() - Const.BIG_STORAGE_GAP); - } else { - bigStorageDTO.set(bigStorageCageDetailsService.queryTargetSlotByTempering(info)); + if (info == null) { + continue; } - e.setTragetSlot(bigStorageDTO.get().getSlot()); - temperingLayoutIdTemp.set(info.getTemperingLayoutId()); - temperingFeedSequenceTemp.set(info.getTemperingFeedSequence()); - }); - //3銆佹洿鏂拌繘鐗囦换鍔¤〃 - boolean taskFlag = bigStorageCageFeedTaskService.updateBatchById(taskList); - if (taskFlag) { - String lineAddress = line.equals(Const.A09_OUT_TARGET_POSITION) ? d02GoAdress : d05GoAdress; - S7object.getinstance().plccontrol.writeWord(lineAddress, (short) 1); + BigStorageCageDetails cageDetails = new BigStorageCageDetails(); + BeanUtils.copyProperties(info, cageDetails); + //2銆佽幏鍙栫洰鏍囨牸瀛愪俊鎭� + BigStorageDTO bigStorageDTO = bigStorageCageDetailsService.queryTargetSlotByTempering(info); + //3銆佹洿鏂板ぇ鐞嗙墖绗艰〃鍓╀綑瀹藉害 + bigStorageCageService.update(new LambdaUpdateWrapper<BigStorageCage>().set(BigStorageCage::getRemainWidth, bigStorageDTO.getWidth()) + .eq(BigStorageCage::getSlot, bigStorageDTO.getSlot())); + //4銆佹洿鏂拌繘鐗囦换鍔¤〃锛岀洰鏍囨牸瀛愬強鐘舵�侊紙鐘舵�佹敼涓�2 鐢垫皵鎵埌鑷澶勭悊锛� 閬囧埌闂锛氭棤娉曟壒閲忔洿鏂帮紝鎵归噺鏇存柊鏃犳硶璧版寚瀹氫粠搴� + e.setTargetSlot(bigStorageDTO.getSlot()); + e.setTaskType(Const.BIG_STORAGE_IN_RUN); + bigStorageCageFeedTaskService.updateById(e); + + //5銆佸皢杩涚墖淇℃伅瀛樺叆澶х悊鐗囩璇︽儏琛� + cageDetails.setSlot(bigStorageDTO.getSlot()); + cageDetails.setState(Const.GLASS_STATE_IN); + bigStorageCageDetailsService.save(cageDetails); } - return taskFlag; + return Boolean.TRUE; } } \ No newline at end of file -- Gitblit v1.8.0