From 79cddf75458ebc5d8855f66ea9bf9ef073327b03 Mon Sep 17 00:00:00 2001
From: zhoushihao <zsh19950802@163.com>
Date: 星期三, 26 六月 2024 14:09:59 +0800
Subject: [PATCH] 下片任务,进出片任务逻辑初步调整,待测试优化

---
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/mapper/DownGlassInfoMapper.java                   |    2 
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/impl/DownStorageCageDetailsServiceImpl.java |   12 -
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownGlassInfoMapper.xml                                     |   47 +++--
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownStorageCageDetailsMapper.xml                            |   41 +++++
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/DownGlassInfoService.java                 |    8 
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/job/DownLoadCacheGlassTask.java                                 |  290 +++++++++++++++++++++++++++++------
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/mapper/DownStorageCageDetailsMapper.java            |    8 
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/DownStorageCageDetailsService.java          |    3 
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/impl/DownGlassInfoServiceImpl.java        |    4 
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/entity/DownStorageCageDetails.java                  |    8 +
 hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/application.yml                                                    |    7 
 11 files changed, 338 insertions(+), 92 deletions(-)

diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/mapper/DownGlassInfoMapper.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/mapper/DownGlassInfoMapper.java
index 01af6af..fac40d1 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/mapper/DownGlassInfoMapper.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/mapper/DownGlassInfoMapper.java
@@ -16,5 +16,5 @@
 
     Integer queryMaxSequence(@Param(value = "flowCardId") String flowCardId, @Param(value = "layer") int layer);
 
-    List<DownGlassInfoDTO> queryWorkStationNotIn();
+    List<DownGlassInfoDTO> queryWorkStationIsIn(@Param(value = "isDownload") Boolean isDownload);
 }
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/DownGlassInfoService.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/DownGlassInfoService.java
index cea55e5..8475169 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/DownGlassInfoService.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/DownGlassInfoService.java
@@ -25,5 +25,11 @@
 
     Integer queryMaxSequence(String flowCardId, int layer);
 
-    List<DownGlassInfoDTO> queryWorkStationNotIn();
+    /**
+     * 鑾峰彇鏋跺瓙缁戝畾 娴佺▼鍗$殑鐜荤拑淇℃伅锛堝凡钀芥灦/鏈惤鏋讹級
+     *
+     * @param isDownload true/false
+     * @return
+     */
+    List<DownGlassInfoDTO> queryWorkStationIsIn(Boolean isDownload);
 }
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/impl/DownGlassInfoServiceImpl.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/impl/DownGlassInfoServiceImpl.java
index 89770f5..4cfb8bd 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/impl/DownGlassInfoServiceImpl.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downglassinfo/service/impl/DownGlassInfoServiceImpl.java
@@ -45,7 +45,7 @@
     }
 
     @Override
-    public List<DownGlassInfoDTO> queryWorkStationNotIn() {
-        return baseMapper.queryWorkStationNotIn();
+    public List<DownGlassInfoDTO> queryWorkStationIsIn(Boolean isDownload) {
+        return baseMapper.queryWorkStationIsIn(isDownload);
     }
 }
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/entity/DownStorageCageDetails.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/entity/DownStorageCageDetails.java
index 9298084..02f58ca 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/entity/DownStorageCageDetails.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/entity/DownStorageCageDetails.java
@@ -96,6 +96,14 @@
      * 鐜荤拑闂撮殭
      */
     private Integer gap;
+    /**
+     * 鎬诲眰鏁�
+     */
+    private Integer totalLayer;
+    /**
+     * 灞傛暟
+     */
+    private Integer layer;
 
 
 }
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/mapper/DownStorageCageDetailsMapper.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/mapper/DownStorageCageDetailsMapper.java
index 49a3bd9..327b48e 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/mapper/DownStorageCageDetailsMapper.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/mapper/DownStorageCageDetailsMapper.java
@@ -1,13 +1,8 @@
 package com.mes.downstorage.mapper;
 
-import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import com.github.yulichang.base.MPJBaseMapper;
-import com.mes.downglassinfo.entity.DownGlassTask;
 import com.mes.downstorage.entity.DownStorageCageDetails;
-import com.mes.glassinfo.entity.GlassInfo;
-import org.apache.ibatis.annotations.*;
-
-import java.util.List;
+import org.apache.ibatis.annotations.Mapper;
 
 /**
  * <p>
@@ -20,4 +15,5 @@
 @Mapper
 public interface DownStorageCageDetailsMapper extends MPJBaseMapper<DownStorageCageDetails> {
 
+    DownStorageCageDetails getGlassInfoMaxCount();
 }
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/DownStorageCageDetailsService.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/DownStorageCageDetailsService.java
index fa22c2d..1b1479a 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/DownStorageCageDetailsService.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/DownStorageCageDetailsService.java
@@ -65,8 +65,11 @@
 //     * @return 鐩撮�氭煡璇�
 //     */
 //    List<GlassInfo>  DirectConnection();
+
     /**
      * @return 鐩撮�氭煡璇�
      */
     boolean DirectConnection(GlassInfo glassInfo);
+
+    DownStorageCageDetails getGlassInfoMaxCount();
 }
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/impl/DownStorageCageDetailsServiceImpl.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/impl/DownStorageCageDetailsServiceImpl.java
index 42c4c7a..98b237c 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/impl/DownStorageCageDetailsServiceImpl.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/downstorage/service/impl/DownStorageCageDetailsServiceImpl.java
@@ -3,17 +3,12 @@
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
-import com.github.yulichang.query.MPJQueryWrapper;
-
-
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-
 import com.github.yulichang.toolkit.JoinWrappers;
 import com.mes.common.config.Const;
 import com.mes.downstorage.entity.DownStorageCage;
 import com.mes.downstorage.entity.DownStorageCageDetails;
 import com.mes.downstorage.mapper.DownStorageCageDetailsMapper;
-
 import com.mes.downstorage.mapper.DownStorageCageMapper;
 import com.mes.downstorage.service.DownStorageCageDetailsService;
 import com.mes.downworkstation.entity.DownWorkstation;
@@ -195,9 +190,10 @@
         return count > 0;
     }
 
-
-
-
+    @Override
+    public DownStorageCageDetails getGlassInfoMaxCount() {
+        return baseMapper.getGlassInfoMaxCount();
+    }
 
 
     @Override
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/job/DownLoadCacheGlassTask.java b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/job/DownLoadCacheGlassTask.java
index 01ed3ee..37e0d50 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/job/DownLoadCacheGlassTask.java
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/java/com/mes/job/DownLoadCacheGlassTask.java
@@ -3,6 +3,7 @@
 import cn.hutool.core.lang.Assert;
 import cn.smallbun.screw.core.util.CollectionUtils;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.mes.common.S7object;
 import com.mes.common.config.Const;
 import com.mes.device.PlcParameterObject;
@@ -11,22 +12,26 @@
 import com.mes.downglassinfo.service.DownGlassInfoService;
 import com.mes.downglassinfo.service.DownGlassTaskService;
 import com.mes.downstorage.entity.DownStorageCage;
+import com.mes.downstorage.entity.DownStorageCageDetails;
 import com.mes.downstorage.service.DownStorageCageDetailsService;
 import com.mes.downstorage.service.DownStorageCageService;
 import com.mes.downworkstation.entity.DownWorkstation;
 import com.mes.downworkstation.entity.dto.DownGlassInfoDTO;
 import com.mes.downworkstation.service.DownWorkstationService;
-import com.mes.downworkstation.service.DownWorkstationTaskService;
 import com.mes.glassinfo.entity.GlassInfo;
 import com.mes.glassinfo.service.GlassInfoService;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang.StringUtils;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 
 import java.util.Date;
 import java.util.List;
+import java.util.Map;
+import java.util.stream.Collectors;
 
 /**
  * @Author : zhoush
@@ -49,14 +54,21 @@
     DownWorkstationService downWorkstationService;
     @Autowired
     DownGlassInfoService downGlassInfoService;
-    @Autowired
-    private DownWorkstationTaskService downWorkstationTaskService;
+
+    @Value("${mes.threshold}")
+    private Integer threshold;
+
+    @Value("${mes.maxWidth}")
+    private Integer maxWidth;
+
+    @Value("${mes.maxHeight}")
+    private Integer maxHeight;
 
 
     @Scheduled(fixedDelay = 1000)
     public void plcHomeEdgTask() {
         PlcParameterObject plcParameterObject = S7object.getinstance().PlcMesObject;
-        String taskRequestTypeValue = plcParameterObject.getPlcParameter("RequestWord").getValue();
+        String requestWord = plcParameterObject.getPlcParameter("RequestWord").getValue();
         String glassIdeValue = plcParameterObject.getPlcParameter("G04ID").getValue();
         String confirmationWrodValue = plcParameterObject.getPlcParameter("MES_confirmation_word").getValue();
         //A08  A09琛ㄧず绾胯矾鐩稿悓  鍙仛绛変环  鏃犳暟鎹浆int寮傚父
@@ -66,9 +78,9 @@
         String currentSlot = plcParameterObject.getPlcParameter("Current_slot").getValue();
 
         log.info("1銆佽幏鍙栧埌鐨勮姹傚瓧涓猴細{}锛岃幏鍙栧埌鐨勬壂鎻廔D涓猴細{}锛岃幏鍙栧埌鐨勭‘璁ゅ瓧涓猴細{}锛岃幏鍙栧埌鐨勫嚭鐗囩姸鎬佸垎鍒负锛欰09:{}銆丄10:{},褰撳墠鏍煎瓙鍙蜂负锛歿}",
-                taskRequestTypeValue, glassIdeValue, confirmationWrodValue, out08Glassstate, out10Glassstate, currentSlot);
+                requestWord, glassIdeValue, confirmationWrodValue, out08Glassstate, out10Glassstate, currentSlot);
 
-        if ("0".equals(taskRequestTypeValue)) {
+        if ("0".equals(requestWord)) {
             if ("0".equals(confirmationWrodValue)) {
                 log.info("2銆佽幏鍙栧埌鐨勮姹傚瓧涓�0锛屼笖纭瀛椾负0锛屼笉鎵ц浠诲姟");
                 return;
@@ -81,54 +93,69 @@
             log.info("2銆佽幏鍙栧埌鐨勮姹傚瓧涓嶄负0锛屽皢纭瀛椾笉涓�0锛岀洿鎺ョ粨鏉�");
             return;
         }
-        if ("1".equals(taskRequestTypeValue)) {
+        if ("1".equals(requestWord)) {
             log.info("2銆佽繘鐗囪姹傦紝涓旂‘璁ゅ瓧涓�0锛屾墽琛岃繘鐗囦换鍔�");
             inTo(glassIdeValue, confirmationWrodAddress, currentSlot);
-        } else if ("2".equals(taskRequestTypeValue)) {
+        } else if ("2".equals(requestWord)) {
             //09绌洪棽 锛�1      10绌洪棽 锛�2        閮界┖闂诧細3    鍏朵粬0
             log.info("2銆佸嚭鐗囪姹傦紝涓旂‘璁ゅ瓧涓�0锛屾墽琛岃繘鐗囦换鍔�");
-//            outTo(Integer.parseInt(out08Glassstate),
-//                    Integer.parseInt(out10Glassstate), confirmationWrodAddress, "", 0);
-        } else if ("3".equals(taskRequestTypeValue)) {
+            outTo(Integer.parseInt(out08Glassstate),
+                    Integer.parseInt(out10Glassstate), confirmationWrodAddress, "", 0);
+        } else if ("3".equals(requestWord)) {
             log.info("2銆佽繘鐗囧拰鍑虹墖閮界┖闂诧紝鎵ц鍑虹墖浠诲姟");
             //鍔犵瀛愰噷闈㈡槸鍚︽湁鐜荤拑锛屾湁鍏堝嚭锛屾棤鐜荤拑鍏堣繘
-//            boolean outFlase = outTo(Integer.parseInt(out08Glassstate),
-//                    Integer.parseInt(out10Glassstate), confirmationWrodAddress, glassIdeValue, Integer.parseInt(currentSlot));
-//            log.info("鍑虹墖浠诲姟鏄惁瀹屾垚锛歿},澶辫触涓旂幓鐠僫d:{}涓嶄负绌哄垯鎵ц杩涚墖浠诲姟", outFlase, glassIdeValue);
-//            if (!outFlase && StringUtils.isNotBlank(glassIdeValue)) {
-//                inTo(glassIdeValue, confirmationWrodAddress, currentSlot);
-//            }
+            boolean outFlase = outTo(Integer.parseInt(out08Glassstate),
+                    Integer.parseInt(out10Glassstate), confirmationWrodAddress, glassIdeValue, Integer.parseInt(currentSlot));
+            log.info("鍑虹墖浠诲姟鏄惁瀹屾垚锛歿},澶辫触涓旂幓鐠僫d:{}涓嶄负绌哄垯鎵ц杩涚墖浠诲姟", outFlase, glassIdeValue);
+            if (!outFlase && StringUtils.isNotBlank(glassIdeValue)) {
+                inTo(glassIdeValue, confirmationWrodAddress, currentSlot);
+            }
         }
     }
+
 
     private void inTo(String glassId, String confirmationWrodAddress, String currentSlot) {
         log.info("1銆佹寜鐓х幓鐠僫d:{}鑾峰彇鐜荤拑灏忕墖淇℃伅,褰撳墠鏍煎瓙涓�:{}", glassId, currentSlot);
         //娣诲姞杩涚墖浠诲姟  鏌ユ壘绌烘牸
         DownStorageCage nearestEmpty = downStorageCageService.selectCacheEmpty(Integer.parseInt(currentSlot), Boolean.FALSE);
-        Assert.isTrue(null != nearestEmpty, "鏍煎瓙宸叉弧");
+        Assert.isTrue(null != nearestEmpty, "鏍煎瓙宸叉弧,鏃犳硶鎵ц杩涚墖鎿嶄綔");
         log.info("2銆佹煡璇㈠崸寮忕悊鐗囩閲岄潰鐨勭┖鏍�:{}", nearestEmpty);
         GlassInfo glassInfo = glassInfoService.getOne(new LambdaQueryWrapper<GlassInfo>().eq(GlassInfo::getGlassId, glassId));
         Assert.isFalse(null == glassInfo, "鐜荤拑淇℃伅涓嶅瓨鍦�");
-        //鑾峰彇璇ョ幓鐠冪殑娴佺▼鍗℃槸鍚﹀凡缁戝畾鏋跺瓙
-        DownWorkstation one = downWorkstationService.getOne(new LambdaQueryWrapper<DownWorkstation>()
-                .eq(DownWorkstation::getLayer, glassInfo.getLayer())
-                .eq(DownWorkstation::getFlowCardId, glassInfo.getFlowCardId()));
-        Boolean checkFlag = Boolean.TRUE;
-        GlassInfo tempGlassInfo = null;
-        if (null != one) {
-            log.info("璇ユ祦绋嬪崱宸茬粦瀹氭灦瀛�");
-            checkFlag = multilayerCheck(glassInfo);
+        Boolean checkFlag = Boolean.FALSE;
+        //todo:鐜荤拑灏哄鏄惁璧颁汉宸ヤ笅鐗�
+        if (glassInfo.getWidth() > maxWidth || glassInfo.getHeight() > maxHeight) {
+            log.info("璇ョ幓鐠冨昂瀵歌蛋浜哄伐涓嬬墖,鐩存帴杩涚墖");
         } else {
-            log.info("璇ョ幓鐠冪殑娴佺▼鍗℃湭缁戝畾鏋跺瓙锛岃幏鍙栨槸鍚︽湁绌烘灦瀛�");
-            List<DownWorkstation> list = downWorkstationService.list(new LambdaQueryWrapper<DownWorkstation>().isNull(DownWorkstation::getFlowCardId));
-            if (CollectionUtils.isNotEmpty(list)) {
-                log.info("鏈夌┖鏋跺瓙,灏嗘祦绋嬪崱涓庢灦瀛愬ソ缁戝畾锛屾墽琛岃繘鐗囦换鍔� 缁撴潫");
-                checkFlag = Boolean.TRUE;
-            } else {
+            log.info("璇ョ幓鐠冨昂瀵搁潪浜哄伐涓嬬墖");
+            //鑾峰彇璇ョ幓鐠冪殑娴佺▼鍗℃槸鍚﹀凡缁戝畾鏋跺瓙
+            DownWorkstation one = downWorkstationService.getOne(new LambdaQueryWrapper<DownWorkstation>()
+                    .eq(DownWorkstation::getLayer, glassInfo.getLayer())
+                    .eq(DownWorkstation::getFlowCardId, glassInfo.getFlowCardId()));
+            Boolean isBind = Boolean.FALSE;
+            if (null != one) {
+                log.info("璇ユ祦绋嬪崱宸茬粦瀹氭灦瀛�");
+                isBind = Boolean.TRUE;
+                checkFlag = multilayerCheck(glassInfo);
+            }
+            if (!checkFlag && !isBind) {
+                log.info("璇ョ幓鐠冪殑娴佺▼鍗℃湭缁戝畾鏋跺瓙锛岃幏鍙栨槸鍚︽湁绌烘灦瀛�");
+                List<DownWorkstation> list = downWorkstationService.list(new LambdaQueryWrapper<DownWorkstation>()
+                        .isNull(DownWorkstation::getFlowCardId));
+                if (CollectionUtils.isNotEmpty(list)) {
+                    log.info("鏈夌┖鏋跺瓙,灏嗘祦绋嬪崱涓庢灦瀛愬ソ缁戝畾锛屾墽琛岃繘鐗囦换鍔� 缁撴潫");
+                    //缁戝畾娴佺▼鍗�
+                    downWorkstationService.update(new LambdaUpdateWrapper<DownWorkstation>().set(DownWorkstation::getFlowCardId, glassInfo.getFlowCardId())
+                            .eq(DownWorkstation::getWorkstationId, list.get(0).getWorkstationId()));
+                    checkFlag = Boolean.TRUE;
+                }
+            }
+            if (!checkFlag) {
                 log.info("鏃犵┖鏋跺瓙,鑾峰彇宸茬粦瀹氭灦瀛愮殑娴佺▼鍗′俊鎭�,鏌ョ湅鐜荤拑淇℃伅鏄惁鍙瀵硅皟");
-                List<DownGlassInfoDTO> downGlassInfoDTOList = downGlassInfoService.queryWorkStationNotIn();
+                List<DownGlassInfoDTO> downGlassInfoDTOList = downGlassInfoService.queryWorkStationIsIn(Boolean.FALSE);
                 log.info("鑾峰彇鏋跺瓙涓婂凡缁戝畾娴佺▼鍗¤惤鏋剁殑鏁伴噺鍙婃湭钀芥灦鐨勭幓鐠冩暟鎹細{}", downGlassInfoDTOList);
                 Assert.isTrue(CollectionUtils.isNotEmpty(downGlassInfoDTOList), "宸茬粦瀹氭祦绋嬪崱鍧囨棤鏈惤鏋剁幓鐠冿紝璇峰強鏃跺鐞嗘灦瀛愪笂鐨勭幓鐠冿紝娓呴櫎娴佺▼鍗�");
+                //鏇挎崲鐜荤拑淇℃伅
                 endLoop:
                 for (DownGlassInfoDTO e : downGlassInfoDTOList) {
                     List<GlassInfo> glassInfoList = e.getGlassInfoList();
@@ -144,7 +171,7 @@
                                 String flowCardId = glassInfo.getFlowCardId();
                                 Integer layer = glassInfo.getLayer();
                                 log.info("鏇挎崲娴佺▼鍗′俊鎭�,褰撳墠鐜荤拑淇℃伅:{}鐨勬祦绋嬪崱鍙穥}鍙婂眰鏁皗},鏇挎崲鍚庣幓鐠冧俊鎭�:{}鐨勬祦绋嬪崱鍙穥}鍙婂眰鏁皗}",
-                                        tempGlassInfo, glassInfo, flowCardId, layer, tempFlowCardId, tempLayer);
+                                        item, glassInfo, flowCardId, layer, tempFlowCardId, tempLayer);
                                 glassInfo.setFlowCardId(tempFlowCardId);
                                 glassInfo.setLayer(tempLayer);
                                 glassInfoService.updateById(glassInfo);
@@ -156,29 +183,145 @@
                         }
                     }
                 }
-
-            }
-            if (checkFlag) {
-                //鐢熸垚杩涚墖浠诲姟 鎵ц杩涚墖鎿嶄綔
-                initDownGlassTask(glassInfo, nearestEmpty.getSlot() + "", null, Const.GLASS_CACHE_TYPE_IN);
             }
         }
-
-
-//                log.info("3銆佸皢鐜荤拑淇℃伅鎻掑叆鍗у紡鐞嗙墖绗�,褰撳墠鐜荤拑淇℃伅:{}", glassInfo);
-//        EdgStorageCageDetails details = new EdgStorageCageDetails();
-//        BeanUtils.copyProperties(glassInfo, details);
-//        details.setState(Const.GLASS_STATE_IN);
-//        details.setSlot(nearestEmpty.getSlot());
-//        details.setDeviceId(nearestEmpty.getDeviceId());
-//        edgStorageCageDetailsService.save(details);
-//        log.info("4銆佺幓鐠冧俊鎭凡瀛樺叆鐞嗙墖绗艰鎯呰〃锛岀幓鐠冧俊鎭负{}", details);
-//        //娣诲姞杩涚墖浠诲姟
-//        boolean taskCache = saveTaskCache(details.getGlassId(), 0, nearestEmpty.getSlot(), Const.GLASS_CACHE_TYPE_IN);
-//        log.info("5銆佺敓鎴愯繘鐗囦换鍔′俊鎭瓨鍏ヤ换鍔¤〃鏄惁瀹屾垚锛歿}", taskCache);
-//
+        //灏嗕换鍔℃彃鍏ョ悊鐗囩璇︽儏琛�
+        DownStorageCageDetails downStorageCageDetails = new DownStorageCageDetails();
+        BeanUtils.copyProperties(glassInfo, downStorageCageDetails);
+        downStorageCageDetails.setState(Const.GLASS_STATE_IN);
+        downStorageCageDetailsService.save(downStorageCageDetails);
+//        鐢熸垚杩涚墖浠诲姟
+        initDownGlassTask(glassInfo, nearestEmpty.getSlot() + "", null, Const.GLASS_CACHE_TYPE_IN);
+        //log.info("5銆佺敓鎴愯繘鐗囦换鍔′俊鎭瓨鍏ヤ换鍔¤〃鏄惁瀹屾垚锛歿}", taskCache);
 //        S7object.getinstance().plccontrol.writeWord(confirmationWrodAddress, (short) 1);
 //        log.info("6銆佸彂閫佺‘璁ゅ瓧瀹屾垚");
+    }
+
+    private Boolean outTo(int parseInt, int parseInt1, String confirmationWrodAddress, String s, int i) {
+        //瀹氫箟绗煎唴鏃犳硶鍑虹墖鐜荤拑鏁伴噺
+        int glassCount = 0;
+        String glassId = null;
+        Boolean isBind = Boolean.FALSE;
+
+        List<DownStorageCageDetails> list = downStorageCageDetailsService.list(new LambdaQueryWrapper<DownStorageCageDetails>()
+                .eq(DownStorageCageDetails::getState, Const.GLASS_STATE_IN));
+        log.info("绗煎唴鐜荤拑鐨勬暟鎹湁锛歿}", list);
+        if (CollectionUtils.isEmpty(list)) {
+            log.info("绗煎唴娌℃湁鐜荤拑,鏃犳硶鎵ц鍑虹墖");
+            return Boolean.FALSE;
+        }
+        for (DownStorageCageDetails item : list) {
+            if (item.getWidth() > maxWidth || item.getHeight() > maxHeight) {
+                log.info("鐜荤拑瀹藉害鎴栭珮搴﹁秴鍑洪槇鍊硷紝鎵ц浜哄伐涓嬬墖");
+                glassId = item.getGlassId();
+                break;
+            }
+        }
+        loop:
+        if (glassId == null) {
+            //鑾峰彇姝e湪钀芥灦鐨勭粦瀹氭祦绋嬪崱鐨勪俊鎭�
+            List<DownGlassInfoDTO> downGlassInfoDTOList = downGlassInfoService.queryWorkStationIsIn(Boolean.TRUE);
+            List<String> downGlassFlowList = downGlassInfoDTOList.stream().map(item -> item.getFlowCardId() + ":" + item.getLayer()).collect(Collectors.toList());
+            if (CollectionUtils.isEmpty(downGlassFlowList)) {
+                //鑾峰彇鏋跺瓙鐜荤拑閮戒负绌猴紝鍑虹鍐呭瓙鏁伴噺鏈�澶氬昂瀵告渶澶х殑鐜荤拑
+                DownStorageCageDetails downStorageCageDetails = downStorageCageDetailsService.getGlassInfoMaxCount();
+                //缁戝畾娴佺▼鍗★紝鏇存柊鐜荤拑鐘舵�侊紝鐢熸垚鍑虹墖浠诲姟锛�
+                glassId = downStorageCageDetails.getGlassId();
+                isBind = Boolean.TRUE;
+                break loop;
+            }
+            //灏嗙瀛愬唴鐨勭幓鐠冭繘琛岃繃婊わ紝浠呰幏鍙栨棤娉曡惤鏋剁殑娴佺▼鍗$幓鐠�
+            List<DownStorageCageDetails> noDownLoadList = list.stream().filter(item -> !downGlassFlowList.contains(item.getFlowCardId() + ":" + item.getLayer())).collect(Collectors.toList());
+            if (CollectionUtils.isNotEmpty(noDownLoadList)) {
+                //鏄惁鏈夌┖鏋跺瓙
+                List<DownWorkstation> emptyShelfList = downWorkstationService.list(new LambdaQueryWrapper<DownWorkstation>()
+                        .isNull(DownWorkstation::getFlowCardId));
+                if (CollectionUtils.isNotEmpty(emptyShelfList)) {
+                    DownStorageCageDetails downStorageCageDetails = downStorageCageDetailsService.getGlassInfoMaxCount();
+                    //缁戝畾娴佺▼鍗★紝鏇存柊鐜荤拑鐘舵�侊紝鐢熸垚鍑虹墖浠诲姟
+                    glassId = downStorageCageDetails.getGlassId();
+                    isBind = Boolean.TRUE;
+                    break loop;
+                }
+                glassCount = noDownLoadList.size();
+                if (glassCount > threshold) {
+                    //鏇存柊鐜荤拑鐘舵�侊紝鐢熸垚鍑虹墖浜哄伐涓嬬墖浠诲姟
+                    glassId = noDownLoadList.get(0).getGlassId();
+                    isBind = Boolean.FALSE;
+                    break loop;
+                }
+            }
+            //灏嗙瀛愬唴鐨勭幓鐠冭繘琛岃繃婊わ紝浠呰幏鍙栧彲钀芥灦鐨勬祦绋嬪崱鐜荤拑
+            List<DownStorageCageDetails> downLoadList = list.stream().filter(item -> downGlassFlowList.contains(item.getFlowCardId() + ":" + item.getLayer())).collect(Collectors.toList());
+            if (CollectionUtils.isEmpty(downLoadList)) {
+                //涓嶆墽琛屽嚭鐗囦换鍔★紝绗煎唴娌℃湁鍚堥�傜殑鍑虹墖鐜荤拑
+                return Boolean.FALSE;
+            }
+            //灏嗙鍐呯幓鐠冪殑娴佺▼鍗�+灞傚彿 鍜岃惤鏋剁殑娴佺▼鍗� 鍘婚噸锛屽緱鍑哄睍绀烘棤娉曡惤鏋剁殑鐜荤拑锛屽垽鏂幓鐠冩暟鏄惁瓒呰繃闃堝��
+            //绗煎唴鐜荤拑鏄惁鍙惤鏋�:绗煎唴鏄惁鏈夐渶瑕佷腑绌虹殑
+            List<DownStorageCageDetails> multiLayerList = list.stream().filter(item -> item.getTotalLayer() >= 2).collect(Collectors.toList());
+            if (CollectionUtils.isNotEmpty(multiLayerList)) {
+                for (DownStorageCageDetails item : multiLayerList) {
+                    DownGlassInfoDTO downGlassInfoDTO = downGlassInfoService.queryDownGlassMaxLayer(item.getFlowCardId());
+                    if (null == downGlassInfoDTO) {
+//                    钀芥灦鐜荤拑鏌ュ埌鐩稿叧娴佺▼鍗$幓鐠冧俊鎭紝琛ㄦ槑褰撳墠娴佺▼鍗$幓鐠冩湭钀芥灦
+                        log.info("");
+                        return Boolean.FALSE;
+                    }
+                    if (downGlassInfoDTO.getLayer().equals(downGlassInfoDTO.getLayer())) {
+                        log.info("褰撳墠鐜荤拑鐨勬祦绋嬪湪鏋跺瓙涓婅惤鏋舵渶澶�,鐩存帴鍑虹墖");
+                        //鏇存柊鐜荤拑鐘舵�侊紝鐢熸垚鍑虹墖浠诲姟
+                        glassId = noDownLoadList.get(0).getGlassId();
+                        isBind = Boolean.FALSE;
+                        break loop;
+                    }
+                    Integer sequence = downGlassInfoService.queryMaxSequence(item.getFlowCardId(), item.getLayer());
+                    log.info("鑾峰彇褰撳墠鐜荤拑闇�瑕佹斁鐨勬搴忥細绗煎唴鍚屾祦绋� 鍚屽眰鏁扮殑閫氳揪娆″簭+1:{}", sequence);
+                    DownGlassInfo downGlassInfo = downGlassInfoService.getOne(new LambdaQueryWrapper<DownGlassInfo>()
+                            .eq(DownGlassInfo::getFlowCardId, downGlassInfoDTO.getFlowCardId())
+                            .eq(DownGlassInfo::getLayer, downGlassInfoDTO.getLayer()).eq(DownGlassInfo::getSequence, sequence));
+                    if (null != downGlassInfoDTO && downGlassInfo.getWidth().equals(item.getWidth()) && downGlassInfo.getHeight().equals(item.getHeight())) {
+                        log.info("鐩稿悓娆″簭鐜荤拑瀵瑰簲涓婏紝鍙墽琛岃繘鐗囦换鍔�");
+                        //鏇存柊鐜荤拑鐘舵�侊紝鐢熸垚鍑虹墖浠诲姟
+                        glassId = noDownLoadList.get(0).getGlassId();
+                        isBind = Boolean.FALSE;
+                        break loop;
+                    } else {
+                        log.info("鍚屾搴忕幓鐠冨搴斾笉涓婏紝闇�鎵ц鏇挎崲鐜荤拑鐨勬搷浣�");
+                        glassCount += 1;
+                        if (glassCount > threshold) {
+                            glassId = noDownLoadList.get(0).getGlassId();
+                            isBind = Boolean.FALSE;
+                            break loop;
+                        }
+                        continue;
+                    }
+                }
+            }
+
+            Map<String, List<DownStorageCageDetails>> singleLayerMap = list.stream().filter(item -> item.getTotalLayer() == 1)
+                    .collect(Collectors.groupingBy(item -> item.getFlowCardId() + item.getLayer(), Collectors.toList()));
+            if (glassId == null) {
+                if (CollectionUtils.isNotEmpty(singleLayerMap)) {
+                    //鑾峰彇宸茶惤鏋舵祦绋嬪崱淇℃伅锛屾寜钀芥灦鏁伴噺鎺掑簭
+                    for (DownGlassInfoDTO e : downGlassInfoDTOList) {
+                        List<DownStorageCageDetails> downStorageCageDetails = singleLayerMap.get(e.getFlowCardId() + e.getLayer());
+                        if (CollectionUtils.isNotEmpty(downStorageCageDetails)) {
+                            glassId = downStorageCageDetails.get(0).getGlassId();
+                            isBind = Boolean.FALSE;
+                            break;
+                        }
+                    }
+                }
+            }
+        }
+        if (glassId == null) {
+            log.info("娌℃湁鎵惧埌鍙互涓嬬墖鐨勭殑鐜荤拑锛岀粨鏉熶换鍔�");
+            return Boolean.FALSE;
+        } else {
+            //todo:鎸夌収鍑虹墖鐨勭幓鐠僫d鏇存柊绗煎唴鐨勭幓鐠冪姸鎬佷负宸插嚭鐗�
+            return generateDownGlassOutTask(glassId, Const.GLASS_CACHE_TYPE_OUT, isBind);
+        }
     }
 
     private Boolean multilayerCheck(GlassInfo glassInfo) {
@@ -213,7 +356,46 @@
         }
     }
 
+    private Boolean generateDownGlassOutTask(String glassId, Integer taskType, Boolean isBind) {
+        //鎸夌幓鐠僫d鑾峰彇鐜荤拑淇℃伅
+        DownStorageCageDetails downStorageCageDetails = downStorageCageDetailsService.getOne(new LambdaQueryWrapper<DownStorageCageDetails>()
+                .eq(DownStorageCageDetails::getGlassId, glassId));
+        String endCell = null;
+        if (isBind) {
+            //鑾峰彇绌烘灦瀛愪俊鎭紝灏嗙┖鏋跺瓙淇℃伅缁戝畾娴佺▼鍗�
+            DownWorkstation emptyDownWorkstation = downWorkstationService.getOne(new LambdaQueryWrapper<DownWorkstation>()
+                    .isNull(DownWorkstation::getFlowCardId).orderByDesc(DownWorkstation::getWorkstationId).last("limit 1"));
+            if (null != emptyDownWorkstation) {
+                log.info("鑾峰彇鍒扮┖鏋跺瓙淇℃伅锛岀粦瀹氭祦绋嬪崱");
+                emptyDownWorkstation.setFlowCardId(downStorageCageDetails.getFlowCardId());
+                emptyDownWorkstation.setLayer(downStorageCageDetails.getLayer());
+                downWorkstationService.updateById(emptyDownWorkstation);
+                endCell = emptyDownWorkstation.getWorkstationId() + "";
+            } else {
+                log.info("娌℃湁绌烘灦瀛愪俊鎭紝鏃犳硶缁戝畾娴佺▼鍗�");
+                return Boolean.FALSE;
+            }
+        } else {
+            DownWorkstation workstation = downWorkstationService.getOne(new LambdaUpdateWrapper<DownWorkstation>()
+                    .eq(DownWorkstation::getFlowCardId, downStorageCageDetails.getFlowCardId()).eq(DownWorkstation::getLayer, downStorageCageDetails.getLayer()));
+            endCell = workstation.getWorkstationId() + "";
+        }
+        //鏇存柊璇︽儏琛ㄥ唴鐨勭姸鎬�
+        if (downStorageCageDetailsService.update(new LambdaUpdateWrapper<DownStorageCageDetails>()
+                .set(DownStorageCageDetails::getState, Const.GLASS_STATE_OUT).eq(DownStorageCageDetails::getGlassId, glassId))) {
+            log.info("鏇存柊璇︽儏琛ㄥ唴鐨勭姸鎬佹垚鍔�");
+        } else {
+            log.info("鏇存柊璇︽儏琛ㄥ唴鐨勭姸鎬佸け璐�");
+            return Boolean.FALSE;
+        }
+        //鐢熸垚浠诲姟淇℃伅
+        GlassInfo glassInfo = new GlassInfo();
+        BeanUtils.copyProperties(downStorageCageDetails, glassInfo);
+        return initDownGlassTask(glassInfo, downStorageCageDetails.getSlot() + "", endCell, taskType);
+    }
+
     private Boolean initDownGlassTask(GlassInfo glassInfo, String startCell, String endCell, Integer taskType) {
+        log.info("鐜荤拑{}鐢熸垚杩涚墖浠诲姟", glassInfo.getGlassId());
         DownGlassTask downGlassTask = new DownGlassTask();
         BeanUtils.copyProperties(glassInfo, downGlassTask);
         downGlassTask.setStartCell(startCell);
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/application.yml b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/application.yml
index 46db88a..0f84cf8 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/application.yml
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/application.yml
@@ -3,7 +3,7 @@
 
 spring:
   profiles:
-    active: cz
+    active: dev
   application:
     name: unLoadGlass
 
@@ -12,3 +12,8 @@
   mapper-locations: classpath*:mapper/*.xml
   configuration:
     log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
+
+mes:
+  maxWidth: 1000    #涓嬬墖鐨勬渶澶у搴�
+  maxHeight: 1000   #涓嬬墖鐨勬渶澶ч珮搴�
+  threshold: 5      #涓嬬墖鐨勬渶澶ч槇鍊�
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownGlassInfoMapper.xml b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownGlassInfoMapper.xml
index 967696b..df344d2 100644
--- a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownGlassInfoMapper.xml
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownGlassInfoMapper.xml
@@ -44,26 +44,35 @@
           AND layer = #{layer}
     </select>
 
-    <select id="queryWorkStationNotIn" resultMap="downGlassInfo">
-        SELECT T.*,
-               T1.*
+    <select id="queryWorkStationIsIn" resultMap="downGlassInfo">
+        SELECT T.*
+        <if test="isDownload == null and isDownload == true ">
+            ,T1.*
+        </if>
         FROM (
-                 SELECT T.FLOW_CARD_ID,
-                        T.LAYER,
-                        COUNT(T.LAYER) AS COUNT
-                 FROM
-                     DOWN_GLASS_INFO T
-                     INNER JOIN DOWN_WORKSTATION T1
-                 ON T.FLOW_CARD_ID = T1.FLOW_CARD_ID
-                     AND T.LAYER = T1.LAYER
-                 GROUP BY
-                     T.FLOW_CARD_ID,
-                     T.LAYER
-             ) T
-                 INNER JOIN GLASS_INFO T1 ON T.FLOW_CARD_ID = T1.FLOW_CARD_ID
-            AND T.LAYER = T1.LAYER
-                 LEFT JOIN DOWN_GLASS_INFO T2 ON T1.GLASS_ID = T2.GLASS_ID
-        WHERE T2.GLASS_ID IS NULL
+        SELECT T.FLOW_CARD_ID,
+        T.LAYER,
+        COUNT(T.LAYER) AS COUNT
+        FROM
+        DOWN_GLASS_INFO T
+        INNER JOIN DOWN_WORKSTATION T1
+        ON T.FLOW_CARD_ID = T1.FLOW_CARD_ID
+        AND T.LAYER = T1.LAYER
+        GROUP BY
+        T.FLOW_CARD_ID,
+        T.LAYER
+        ) T
+        INNER JOIN GLASS_INFO T1 ON T.FLOW_CARD_ID = T1.FLOW_CARD_ID
+        AND T.LAYER = T1.LAYER
+        LEFT JOIN DOWN_GLASS_INFO T2 ON T1.GLASS_ID = T2.GLASS_ID
+        <where>
+            <if test="isDownload == null or isDownload == false">
+                AND T2.GLASS_ID IS NULL
+            </if>
+            <if test="isDownload == true">
+                AND T2.GLASS_ID IS not NULL
+            </if>
+        </where>
         order by t.count desc
     </select>
 </mapper>
\ No newline at end of file
diff --git a/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownStorageCageDetailsMapper.xml b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownStorageCageDetailsMapper.xml
new file mode 100644
index 0000000..c506462
--- /dev/null
+++ b/hangzhoumesParent/moduleService/UnLoadGlassModule/src/main/resources/mapper/DownStorageCageDetailsMapper.xml
@@ -0,0 +1,41 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="com.mes.downstorage.mapper.DownStorageCageDetailsMapper">
+
+    <resultMap id="downStorageCageDetails" type="com.mes.downstorage.entity.DownStorageCageDetails">
+        <id column="id" property="id"/>
+        <result column="slot" property="slot"/>
+        <result column="glass_id" property="glassId"/>
+        <result column="sequence" property="sequence"/>
+        <result column="filmsid" property="filmsid"/>
+        <result column="flow_card_id" property="flowCardId"/>
+        <result column="glass_type" property="glassType"/>
+        <result column="width" property="width"/>
+        <result column="height" property="height"/>
+        <result column="thickness" property="thickness"/>
+        <result column="tempering_layout_id" property="temperingLayoutId"/>
+        <result column="tempering_feed_sequence" property="temperingFeedSequence"/>
+        <result column="state" property="state"/>
+        <result column="gap" property="gap"/>
+        <result column="total_layer" property="totalLayer"/>
+        <result column="layer" property="layer"/>
+    </resultMap>
+
+    <select id="getGlassInfoMaxCount" resultMap="downStorageCageDetails">
+        SELECT *
+        FROM DOWN_STORAGE_CAGE_DETAILS
+        WHERE (FLOW_CARD_ID, LAYER) = (SELECT FLOW_CARD_ID, LAYER
+                                       FROM DOWN_STORAGE_CAGE_DETAILS
+                                       WHERE STATE = 100
+                                       GROUP BY FLOW_CARD_ID, LAYER
+                                       ORDER BY COUNT(FLOW_CARD_ID) DESC
+            LIMIT 1 )
+          AND STATE = 100
+        ORDER BY
+            WIDTH DESC,
+            HEIGHT DESC
+            LIMIT 1
+    </select>
+
+
+</mapper>
\ No newline at end of file

--
Gitblit v1.8.0