From d62951d7c0947303fc6eed23a664c162f2ea0010 Mon Sep 17 00:00:00 2001
From: 1 <1>
Date: 星期五, 05 十二月 2025 09:07:32 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/controller/OpenController.java           |   31 +++++
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java        |  182 ++++++++++++++++++++++++++---
 src/main/java/com/zy/asrs/entity/param/AgvBindCtnrAndBinParam.java |   14 ++
 src/main/java/com/zy/asrs/entity/param/PdaWriteBarcodeParam.java   |    9 +
 src/main/java/com/zy/asrs/entity/BasAgvMast.java                   |    9 +
 src/main/java/com/zy/core/thread/SiemensDevpThread.java            |   85 ++++++++-----
 src/main/resources/application.yml                                 |    4 
 src/main/webapp/static/js/basAgvMast/basAgvMast.js                 |    2 
 8 files changed, 277 insertions(+), 59 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OpenController.java b/src/main/java/com/zy/asrs/controller/OpenController.java
index a07109a..344b920 100644
--- a/src/main/java/com/zy/asrs/controller/OpenController.java
+++ b/src/main/java/com/zy/asrs/controller/OpenController.java
@@ -8,8 +8,15 @@
 import com.core.exception.CoolException;
 import com.zy.asrs.entity.WrkMast;
 import com.zy.asrs.entity.param.ArmPrecomputeParam;
+import com.zy.asrs.entity.param.PdaWriteBarcodeParam;
 import com.zy.asrs.service.OpenService;
 import com.zy.common.web.BaseController;
+import com.zy.core.cache.MessageQueue;
+import com.zy.core.cache.SlaveConnection;
+import com.zy.core.enums.SlaveType;
+import com.zy.core.model.Task;
+import com.zy.core.model.protocol.StaProtocol;
+import com.zy.core.thread.SiemensDevpThread;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.transaction.annotation.Transactional;
@@ -65,6 +72,30 @@
         return R.ok().add(param);
     }
 
+    /**
+     * 娣诲姞鍑哄簱鍗�
+     */
+    @PostMapping("/task/cs/barcode/default/v1")
+    @AppAuth(memo = "PDA涓嬪彂鏉$爜")
+    public synchronized R wcsBarcode(@RequestHeader(required = false) String appkey,
+                                              @RequestBody PdaWriteBarcodeParam param,
+                                              HttpServletRequest request) {
+        try{
+            auth(appkey, param, request);
+        } catch (Exception e){
+            return new R(403,e.getMessage());
+        }
+        if (Cools.isEmpty(param)) {
+            return R.parse(BaseRes.PARAM);
+        }
+        SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, 2);
+        StaProtocol staProtocol = devpThread.getStation().get(param.getSiteId());
+        staProtocol.setBarcode(param.getBarcode());
+        MessageQueue.offer(SlaveType.Devp, 2, new Task(2, staProtocol));
+
+        return R.ok("涓嬪彂鎴愬姛璇风◢绛�");
+    }
+
 
     private void auth(String appkey, Object obj, HttpServletRequest request) {
 //        log.info("{}鎺ュ彛琚闂紱appkey:{}锛涜姹傛暟鎹細{}", "open/sensorType/list/auth/v1", appkey, JSON.toJSONString(obj));
diff --git a/src/main/java/com/zy/asrs/entity/BasAgvMast.java b/src/main/java/com/zy/asrs/entity/BasAgvMast.java
index 429a0c5..79f38cd 100644
--- a/src/main/java/com/zy/asrs/entity/BasAgvMast.java
+++ b/src/main/java/com/zy/asrs/entity/BasAgvMast.java
@@ -7,6 +7,8 @@
 import java.util.Date;
 
 import com.core.common.SnowflakeIdWorker;
+import com.fasterxml.jackson.databind.annotation.JsonSerialize;
+import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
 import org.springframework.format.annotation.DateTimeFormat;
 import java.text.SimpleDateFormat;
 import java.util.Date;
@@ -45,7 +47,14 @@
      * RGV浠诲姟鍙�
      */
     @ApiModelProperty(value= "RGV浠诲姟鍙�")
+    @JsonSerialize(using = ToStringSerializer.class)
     private Long timestamp;
+    @TableField(exist = false)
+    private String timestampStr;
+
+    public String getTimestampStr() {
+        return timestamp == null ? "" : timestamp.toString();
+    }
 
     /**
      * 婧愮珯鐐�
diff --git a/src/main/java/com/zy/asrs/entity/param/AgvBindCtnrAndBinParam.java b/src/main/java/com/zy/asrs/entity/param/AgvBindCtnrAndBinParam.java
index 624875c..47952b8 100644
--- a/src/main/java/com/zy/asrs/entity/param/AgvBindCtnrAndBinParam.java
+++ b/src/main/java/com/zy/asrs/entity/param/AgvBindCtnrAndBinParam.java
@@ -34,6 +34,10 @@
                 getAgvTaskAssignmentParam0(basAgvMast);
                 indBind = "1";
                 return;
+            case 2:
+                getAgvTaskAssignmentParam1(basAgvMast);
+                indBind = "1";
+                return;
             default:
                 return;
         }
@@ -50,5 +54,15 @@
         this.stgBinCode = basAgvLocNoSou != null ? basAgvLocNoSou.getAgvLocNo() : "";
     }
 
+    public void getAgvTaskAssignmentParam1(BasAgvMast basAgvMast) {
+        BasAgvLocNoService basAgvLocNoService = SpringUtils.getBean(BasAgvLocNoService.class);
+        this.reqCode = basAgvMast.getTaskNo() + "-" + System.currentTimeMillis();
+        BasAgvLocNo basAgvLocNoSou = basAgvLocNoService.selectOne(
+                new EntityWrapper<BasAgvLocNo>().eq("sta_no", basAgvMast.getSourceStaNo())
+        );
+
+        this.stgBinCode = basAgvLocNoSou != null ? basAgvLocNoSou.getAgvLocNo() : "";
+    }
+
 
 }
diff --git a/src/main/java/com/zy/asrs/entity/param/PdaWriteBarcodeParam.java b/src/main/java/com/zy/asrs/entity/param/PdaWriteBarcodeParam.java
new file mode 100644
index 0000000..2b8ddd4
--- /dev/null
+++ b/src/main/java/com/zy/asrs/entity/param/PdaWriteBarcodeParam.java
@@ -0,0 +1,9 @@
+package com.zy.asrs.entity.param;
+
+import lombok.Data;
+
+@Data
+public class PdaWriteBarcodeParam {
+    private Integer siteId;
+    private String barcode;
+}
diff --git a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
index 29fd386..6cdc58d 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -450,23 +450,74 @@
                     continue;
                 }
                 String barcode = barcodeThread.getBarcode();
-                if(!Cools.isEmpty(barcode)) {
-//                    News.info(""+mark+" - 1"+" - {}鍙锋潯鐮佹壂鎻忓櫒妫�娴嬫潯鐮佷俊鎭細{}", pickSta.getBarcode(), barcode);
-                    if("NG".endsWith(barcode) || "NoRead".equals(barcode)) {
-                        continue;
-                    }
-                } else {
-                    continue;
-                }
-
-                // 鑾峰彇鎷f枡鍏ュ簱绔欎俊鎭�
                 SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId());
                 StaProtocol staProtocol = devpThread.getStation().get(pickSta.getStaNo());
+                LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, pickSta.getLed());
                 if (staProtocol == null) {
                     continue;
                 } else {
                     staProtocol = staProtocol.clone();
                 }
+                // 灏哄妫�娴嬪紓甯�
+                boolean back = false;
+                String errMsg = "";
+                if (staProtocol.isFrontErr()) {
+                    errMsg = "鍓嶈秴闄�";
+                    back = true;
+                }
+                if (!back && staProtocol.isBackErr()) {
+                    errMsg = "鍚庤秴闄�";
+                    back = true;
+                }
+                if (!back && staProtocol.isHighErr()) {
+                    errMsg = "楂樿秴闄�";
+                    back = true;
+                }
+                if (!back && staProtocol.isLeftErr()) {
+                    errMsg = "宸﹁秴闄�";
+                    back = true;
+                }
+                if (!back && staProtocol.isRightErr()) {
+                    errMsg = "鍙宠秴闄�";
+                    back = true;
+                }
+                if (!back && staProtocol.isWeightErr()) {
+                    errMsg = "瓒呴噸";
+                    back = true;
+                }
+                if (!back && staProtocol.isBarcodeErr()) {
+                    errMsg = "鎵爜澶辫触";
+                    log.error("鐗╂枡鐮佹壂鐮佸け璐�");
+                    back = true;
+                }
+                // 閫�鍥�
+                if (back) {
+                    News.warn("鎵爜鍏ュ簱澶辫触锛寋}鍏ュ簱绔欏洜{}寮傚父锛屾墭鐩樺凡琚��鍥�", pickSta.getStaNo(), errMsg);
+                    MessageQueue.offer(SlaveType.Led, pickSta.getLed(), new Task(3, errMsg));
+
+                    if (!staProtocol.isLoading()){
+                        continue;
+                    }
+                    if (!staProtocol.isPakMk()) {
+                        continue;
+                    }
+                    // led 寮傚父鏄剧ず
+                    if (ledThread != null) {
+                        MessageQueue.offer(SlaveType.Led, pickSta.getLed(), new Task(3, errMsg));
+                    }
+                    staProtocol.setWorkNo(wrkNo);
+                    staProtocol.setErrCode(errMsg);
+                    News.info("寮傚父鍒ゆ柇{}鍏ュ簱鍥為��锛歿}锛屼换鍔″彿锛歿}", pickSta.getStaNo(), errMsg,wrkNo);
+                    wrkNo++;
+                    staProtocol.setStaNo(pickSta.getBackSta().shortValue());
+                    devpThread.setPakMk(staProtocol.getSiteId(), false);
+                    staProtocol.setBarcode(barcode);
+                    staProtocol.setPakMk(false);
+                    MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+                    System.out.println(staProtocol);
+                    log.error("杈撻�佺嚎涓嬪彂1锛�"+wrkNo+","+pickSta.getBackSta());
+                }
+
 
 //                // 鍏ュ嚭搴撴ā寮忓垽鏂�
 //                if (devpThread.ioMode != IoModeType.PAKIN_MODE) { continue; }
@@ -506,7 +557,7 @@
                         devpThread.setPakMk(staProtocol.getSiteId(), false);
                         MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
                         //LED
-                        LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, pickSta.getLed());
+//                        LedThread ledThread = (LedThread) SlaveConnection.get(SlaveType.Led, pickSta.getLed());
                         // led 寮傚父鏄剧ず
                         if (ledThread != null) {
                             String errorMsg = "姝や负鎷f枡銆佸苟鏉裤�佺洏鐐瑰啀鍏ュ簱.璇锋斁鍦�"+pickSta.getBackSta().shortValue()+"绔欑偣";
@@ -2299,6 +2350,9 @@
                     case 57:
                         ledCommand.setTitle("鐩樼偣鍐嶅叆搴�");
                         break;
+                    case 53:
+                        ledCommand.setTitle("鎷f枡鍐嶅叆搴�");
+                        break;
                     case 101:
                         ledCommand.setTitle("鍏ㄦ澘鍑哄簱");
                         break;
@@ -2879,7 +2933,7 @@
             StaProtocol staProtocol = null;
             if(emptyCount >= 2 && site == 1108){
                 continue;
-            }else if(emptyCount == 1 && site == 2031){
+            }else if(emptyCount > 1 && site == 2031){
                 continue;
             }
             //濡傛灉绔欑偣鍙嚭绂佺敤锛屽垯涓嶇敓鎴愮┖鐩樺嚭搴撲换鍔�
@@ -4989,6 +5043,55 @@
                     continue;
                 }
                 if (staProtocol.isAutoing() ) {
+                    if(staProtocol.getWorkNo()>10000){
+                        BasAgvMast basAgvMast = new BasAgvMast();
+                        List<BasAgvMast> basAgvMastList = basAgvMastService.selectList(new EntityWrapper<BasAgvMast>().eq("task_no", staProtocol.getWorkNo()));
+                        if(!basAgvMastList.isEmpty()){
+                            continue;
+                        }
+
+                        try {
+                            LocTypeDto locTypeDto = new LocTypeDto(staProtocol);
+
+                            SearchLocParam param = new SearchLocParam();
+                            param.setBarcode(staProtocol.getWorkNo().toString());
+                            param.setIoType(1);
+                            param.setSourceStaNo(outStaAgv.getStaNo());
+                            param.setLocType1(locTypeDto.getLocType1());
+                            String response = new HttpHandler.Builder()
+                                    .setUri(wmsUrl)
+                                    .setPath("/rpc/pakin/agv/loc/v1")
+                                    .setJson(JSON.toJSONString(param))
+                                    .build()
+                                    .doPost();
+                            JSONObject jsonObject = JSON.parseObject(response);
+                            if (jsonObject.getInteger("code").equals(200)) {
+                                StartupDto dto = jsonObject.getObject("data", StartupDto.class);
+                                basAgvMast.setFloorNo(1);
+                                basAgvMast.setTaskNo(staProtocol.getWorkNo());
+                                basAgvMast.setSourceStaNo(outStaAgv.getStaNo());
+                                basAgvMast.setLocNo(dto.getLocNo());
+                                basAgvMast.setBarcode("1");
+                                basAgvMast.setSourceLocNo("1041");
+                                basAgvMast.setDevpId(devp.getId());
+                                basAgvMast.setIoType(2);
+                                basAgvMastService.insert(basAgvMast);
+                                LocMast locMast = locMastService.selectOne(new EntityWrapper<LocMast>().eq("loc_no",dto.getLocNo()));
+                                locMast.setLocSts("S");
+                                locMastService.updateById(locMast);
+
+                                AgvBindCtnrAndBinParam agvBindCtnrAndBinParam = new AgvBindCtnrAndBinParam(basAgvMast);
+                                agvBindCtnrAndBinParam.setCtnrCode(basAgvMast.getTimestamp().toString());
+                                agvBindCtnrAndBinParam.setCtnrTyp("1");
+                                ReturnT<String> resultBind = new PostMesDataUtils().postMesDataAgv("AGV鍑哄簱瀹瑰櫒缁戝畾瑙g粦", AgvConstant.AGV_URL, AgvConstant.AGV_CTNRANDBING, agvBindCtnrAndBinParam);
+
+                            }
+                        }catch (Exception e){
+                            News.error(JSON.toJSONString(e.getMessage()));
+
+                        }
+
+                    }
                     WrkMast wrkMast = wrkMastService.selectByWrkNo(staProtocol.getWorkNo());
                     if (Cools.isEmpty(wrkMast) || Cools.isEmpty(wrkMast.getTakeNone()) || !wrkMast.getTakeNone().equals("1")){
                         continue;
@@ -5040,8 +5143,10 @@
                             basAgvMast.setIoType(2);
 
                             basAgvMastService.insert(basAgvMast);
-
-
+                            AgvBindCtnrAndBinParam agvBindCtnrAndBinParam = new AgvBindCtnrAndBinParam(basAgvMast);
+                            agvBindCtnrAndBinParam.setCtnrCode(basAgvMast.getBarcode());
+                            agvBindCtnrAndBinParam.setCtnrTyp("1");
+                            ReturnT<String> resultBind = new PostMesDataUtils().postMesDataAgv("AGV瀹瑰櫒缁戝畾", AgvConstant.AGV_URL, AgvConstant.AGV_CTNRANDBING, agvBindCtnrAndBinParam);
 
                             wrkMast.setTakeNone("2");
                             wrkMastMapper.updateById(wrkMast);
@@ -5067,6 +5172,8 @@
                 // 鑾峰彇鍏ュ簱绔欎俊鎭�
                 SiemensDevpThread devpThread = (SiemensDevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId());
                 StaProtocol staProtocol = devpThread.getStation().get(outStaAgv.getStaNo());
+                BarcodeThread barcodeThread = (BarcodeThread) SlaveConnection.get(SlaveType.Barcode, 6);
+
                 if (staProtocol == null) {
                     continue;
                 } else {
@@ -5078,7 +5185,7 @@
                     continue;
                 }
 
-                String barcode = staProtocol.getBarcode();
+                String barcode = barcodeThread.getBarcode();//2033
                 if(!Cools.isEmpty(barcode)) {
                     if("NG".endsWith(barcode) || "NoRead".equals(barcode) || "0".equals(barcode)) {
 //                        News.info("{}鍙风珯鐐规壂鎻忓櫒妫�娴嬫潯鐮佷俊鎭細{}", outStaAgv.getStaNo(), barcode);
@@ -5091,7 +5198,7 @@
                 if (staProtocol.isAutoing()) {
 
                     // 鍒ゆ柇閲嶅宸ヤ綔妗�
-                    List<BasAgvMast> basAgvMastList = basAgvMastService.selectList(new EntityWrapper<BasAgvMast>().eq("source_sta_no", outStaAgv.getStaNo()));
+                    List<BasAgvMast> basAgvMastList = basAgvMastService.selectList(new EntityWrapper<BasAgvMast>().eq("source_sta_no", outStaAgv.getStaNo()).eq("barcode",barcode));
                     if (!basAgvMastList.isEmpty()) {
 //                        News.info("{}鍙风珯鐐瑰瓨鍦ㄤ换鍔℃墽琛屼腑锛岃绛夊緟浠诲姟鎵ц瀹屾瘯锛歿}", outStaAgv.getStaNo(), barcode);
                         continue;
@@ -5099,9 +5206,17 @@
                     if(barcode.equals("0")){
                         continue;
                     }
+                    List<LocMast> locMastListFull = locMastService.selectList(new EntityWrapper<LocMast>()
+                            .eq("loc_sts", "O")
+                            .ge("row1", 28)
+                            .le("row1", 31)
+                    );
+                    if(locMastListFull.isEmpty()){
+                        continue;
+                    }
                     List<LocMast> locMastList = locMastService.selectList(new EntityWrapper<LocMast>().eq("barcode", barcode));
                     if (!locMastList.isEmpty()) {
-                        News.info("{}鍙风珯鐐规潯鐮佷俊鎭噸澶嶏細{}", outStaAgv.getStaNo(), barcode);
+//                        News.info("{}鍙风珯鐐规潯鐮佷俊鎭噸澶嶏細{}", outStaAgv.getStaNo(), barcode);
                         continue;
                     }
                     // 浠诲姟鐢熸垚鍖� --------------------------------------------------------------------------
@@ -5126,7 +5241,29 @@
                         JSONObject jsonObject = JSON.parseObject(response);
                         if (jsonObject.getInteger("code").equals(200)) {
                             StartupDto dto = jsonObject.getObject("data", StartupDto.class);
-                            basAgvMast.setTaskNo(outStaAgv.getStaNo());
+                            List<BasAgvMast> list = basAgvMastService.selectList(
+                                    new EntityWrapper<BasAgvMast>()
+                                            .eq("source_sta_no", outStaAgv.getStaNo())
+                                            .in("task_no", 2033, 2031)
+                            );
+                            boolean has2033 = false;
+                            boolean has2034 = false;
+                            for (BasAgvMast mast : list) {
+                                if (mast.getTaskNo() == 2033) {
+                                    has2033 = true;
+                                }
+                                if (mast.getTaskNo() == 2031) {
+                                    has2034 = true;
+                                }
+                            }
+
+                            if (has2033 && has2034) {
+                                return;
+                            } else if (has2033) {
+                                basAgvMast.setTaskNo(2031);
+                            } else {
+                                basAgvMast.setTaskNo(2033);
+                            }
                             basAgvMast.setSourceStaNo(outStaAgv.getStaNo());
                             basAgvMast.setLocNo(dto.getLocNo());
                             basAgvMast.setDevpId(devp.getId());
@@ -5139,8 +5276,10 @@
                             News.error(JSON.toJSONString(staProtocol));
                         }
                     } catch (Exception e) {
-                        News.error(JSON.toJSONString(e.getMessage()));
+                        News.error("AGV浠诲姟鐢熸垚寮傚父", e);
+                        throw new CoolException("AGV浠诲姟鐢熸垚寮傚父");
                     }
+
                 }
             }
         }
@@ -5367,10 +5506,7 @@
                         staProtocol = staProtocol.clone();
                     }
 
-                    if ((!Cools.isEmpty(staProtocol.getWorkNo()) && staProtocol.getWorkNo().equals(basAgvMast.getTaskNo()))
-                            ||
-                            (basAgvMast.getSourceStaNo().equals(2033))){
-
+                    if ((!Cools.isEmpty(staProtocol.getWorkNo()) && staProtocol.getWorkNo().equals(basAgvMast.getTaskNo())) || basAgvMast.getSourceStaNo().equals(2033)){
                         AgvTaskAssignmentParam agvTaskAssignmentParam = new AgvTaskAssignmentParam(basAgvMast);
                         if(basAgvMast.getFloorNo()==1) {
 //                            WrkMast wrkMast = wrkMastService.selectByWrkNo(staProtocol.getWorkNo());
diff --git a/src/main/java/com/zy/core/thread/SiemensDevpThread.java b/src/main/java/com/zy/core/thread/SiemensDevpThread.java
index 87c8c2e..11c8aa7 100644
--- a/src/main/java/com/zy/core/thread/SiemensDevpThread.java
+++ b/src/main/java/com/zy/core/thread/SiemensDevpThread.java
@@ -90,6 +90,7 @@
 //        add(2045);add(2046);add(2047);add(2048);
         add(2101);add(2102);add(2103);add(2104);add(2105);add(2106);add(2107);add(2108);add(2109);add(2110);
         add(2111);add(2112);add(2113);add(2114);add(2115);add(2116);add(2117);add(2118);add(2119);add(2120);
+        add(2121);add(2122);
         add(4001);add(4003);add(4004);add(4006);
     }};
 
@@ -165,17 +166,27 @@
         put(2031, 120);put(2032, 124);put(2033, 128);put(2034, 132);put(2035, 136);
         put(2037, 144);
 
-        put(4001, 240);put(4002, 244);put(4003, 248);put(4004, 252);put(4005, 256);
-        put(4006, 260);
+        put(2101, 160);put(2102, 164);put(2103, 168);put(2104, 172);put(2105, 176);
+        put(2106, 180);put(2107, 184);put(2108, 188);put(2109, 192);put(2110, 196);
+        put(2111, 200);put(2112, 204);put(2113, 208);put(2114, 212);put(2115, 216);
+        put(2116, 220);put(2117, 224);put(2118, 228);put(2119, 232);put(2120, 236);
+        put(2121, 240);put(2122, 244);
+        put(4001, 248);put(4002, 252);put(4003, 256);put(4004, 260);put(4005, 264);
+        put(4006, 268);
         // 鍏朵粬绔欑偣鍚岀悊缁х画鍔�
     }};
 
     public static final Map<Integer, Integer> siteErrOffsetMap = new HashMap<Integer, Integer>() {{
-        put(1036, 512);put(1103, 476);put(1047, 452);put(2037, 270);put(4001,294);
+        put(1036, 512);put(1103, 476);put(1047, 452);put(2037, 278);put(4001,302);
 
     }};
     public static final Map<Integer, Integer> siteAgvOffsetMap = new HashMap<Integer, Integer>() {{
         put(1037, 0);put(1039, 2);put(1041, 4);put(2033, 0);put(2034,2);put(4003,4);put(4006,6);
+
+    }};
+
+    public static final Map<Integer, Integer> site2lBarcodeOffsetMap = new HashMap<Integer, Integer>() {{//2妤紁da鍐欏叆鏉$爜
+        put(2102, 2280);put(2105, 3048);put(2112, 4840);put(2115, 5608);
 
     }};
 
@@ -486,12 +497,12 @@
             result1 = siemensS7Net.Read("DB200.0", (short) (3000));//2001-2030
             result2 = siemensS7Net.Read("DB201.0", (short) (720));//2031-2037
             result3 = siemensS7Net.Read("DB400.0", (short) (600));//4001-4006
-            result6 = siemensS7Net.Read("DB202.0", (short) (7400));//2101-2122
-            resultErr = siemensS7Net.Read("DB3.0", (short) (354));
+            result6 = siemensS7Net.Read("DB202.0", (short) (2024));//2101-2122
+            resultErr = siemensS7Net.Read("DB3.0", (short) (386));
 //            resultAgv = siemensS7Net.Read("DB901.0", (short) (7)); //agv鍙栨斁璐ц姹�
 //            resultPlc = siemensS7Net.Read("DB902.0", (short) (7)); //杈撻�佺嚎纭
-            resultArm5 = siemensS7Net.Read("DB202.4328", (short) (254));//2110
-            resultArm6 = siemensS7Net.Read("DB202.6888", (short) (254));//2120
+            resultArm5 = siemensS7Net.Read("DB202.4328", (short) (256));//2110
+            resultArm6 = siemensS7Net.Read("DB202.6888", (short) (256));//2120
         }
 
 
@@ -528,7 +539,7 @@
                         if (siteId == 2110) {
                             if (resultArm5.IsSuccess) {
                                 // 杞崲涓哄瓧绗︿覆
-                                String resultString = siemensS7Net.getByteTransform().TransString(resultArm5.Content, 2, 252,"UTF-8");
+                                String resultString = siemensS7Net.getByteTransform().TransString(resultArm5.Content, 2, 254,"UTF-8");
                                 // 鍘婚櫎鍙兘鐨勭┖瀛楃
 //                                resultString = resultString.TrimEnd('\0');
 //                                System.out.println("2110Barcode:"+resultString);
@@ -539,7 +550,7 @@
                         } else if (siteId == 2120){
                             if (resultArm6.IsSuccess) {
                                 // 杞崲涓哄瓧绗︿覆
-                                String resultString = siemensS7Net.getByteTransform().TransString(resultArm6.Content, 2, 252,"UTF-8");
+                                String resultString = siemensS7Net.getByteTransform().TransString(resultArm6.Content, 2, 254,"UTF-8");
                                 // 鍘婚櫎鍙兘鐨勭┖瀛楃
 //                                resultString = resultString.TrimEnd('\0');
 //                                System.out.println("2120Barcode:"+resultString);
@@ -611,7 +622,7 @@
                     staProtocol.setAutoing(!status[0]);  // 鑷姩
                     boolean[] status1 = siemensS7Net.getByteTransform().TransBool(result.Content, offset + offset3 - 4, 3);
                     boolean[] statusErr = siemensS7Net.getByteTransform().TransBool(result.Content, offset + offset3 - 8, 3);
-//                    boolean[] statusSign = siemensS7Net.getByteTransform().TransBool(resultErr.Content, offsetSign, 3);
+                    boolean[] statusSign = siemensS7Net.getByteTransform().TransBool(resultErr.Content, offsetSign, 3);
 
                     boolean loading = false;
                     if(!status1[0])
@@ -665,28 +676,28 @@
                     staProtocol.setDataError(statusErr[18]);
 
                     //淇″彿
-//                    staProtocol.setSensorGArrive(statusSign[0]);
-//                    staProtocol.setSensorGDec(statusSign[1]);
-//                    staProtocol.setSensorGArrive2(statusSign[2]);
-//                    staProtocol.setSensorLimit(statusSign[3]);
-//                    staProtocol.setEmergency(statusSign[4]);
-//                    staProtocol.setSensorGLeave(statusSign[5]);
-//                    staProtocol.setSensorGLeave2(statusSign[6]);
-//                    staProtocol.setSensorCUp(statusSign[7]);
-//                    staProtocol.setSensorCDown(statusSign[8]);
-//                    staProtocol.setLiftMotorFr(statusSign[9]);
-//                    staProtocol.setLineMotorFr(statusSign[10]);
-//                    staProtocol.setTranMotorFr(statusSign[11]);
-//                    staProtocol.setRst1(statusSign[12]);
-//                    staProtocol.setRst2(statusSign[13]);
-//                    staProtocol.setRst3(statusSign[14]);
-//                    staProtocol.setRst4(statusSign[15]);
-//                    staProtocol.setSensorArriveD(statusSign[16]);
-//                    staProtocol.setSensorDecD(statusSign[17]);
-//                    staProtocol.setSensorArriveL(statusSign[18]);
-//                    staProtocol.setSensorDecL(statusSign[19]);
-//                    staProtocol.setSensorArriveR(statusSign[20]);
-//                    staProtocol.setSensorDecR(statusSign[21]);
+                    staProtocol.setSensorGArrive(statusSign[0]);
+                    staProtocol.setSensorGDec(statusSign[1]);
+                    staProtocol.setSensorGArrive2(statusSign[2]);
+                    staProtocol.setSensorLimit(statusSign[3]);
+                    staProtocol.setEmergency(statusSign[4]);
+                    staProtocol.setSensorGLeave(statusSign[5]);
+                    staProtocol.setSensorGLeave2(statusSign[6]);
+                    staProtocol.setSensorCUp(statusSign[7]);
+                    staProtocol.setSensorCDown(statusSign[8]);
+                    staProtocol.setLiftMotorFr(statusSign[9]);
+                    staProtocol.setLineMotorFr(statusSign[10]);
+                    staProtocol.setTranMotorFr(statusSign[11]);
+                    staProtocol.setRst1(statusSign[12]);
+                    staProtocol.setRst2(statusSign[13]);
+                    staProtocol.setRst3(statusSign[14]);
+                    staProtocol.setRst4(statusSign[15]);
+                    staProtocol.setSensorArriveD(statusSign[16]);
+                    staProtocol.setSensorDecD(statusSign[17]);
+                    staProtocol.setSensorArriveL(statusSign[18]);
+                    staProtocol.setSensorDecL(statusSign[19]);
+                    staProtocol.setSensorArriveR(statusSign[20]);
+                    staProtocol.setSensorDecR(statusSign[21]);
 
 //                    Integer offsetAgv = siteAgvOffsetMap.get(siteId);
 //
@@ -843,6 +854,9 @@
                 for (Integer siteId : staNos) {
                     StaProtocol staProtocol = station.get(siteId);
                     basDevps.add(staProtocol.toSqlModel());
+                    if(siteId == 2110){
+                        basDevps.add(staProtocol.toSqlModel());
+                    }
                     if(staProtocol.isWriteMk() && staProtocol.isErrorMk()){
                         try {
                             // 鏃ュ織璁板綍寮傚父鎯呭喌
@@ -937,7 +951,7 @@
                 }else{
                     write1 = siemensS7Net.Write("DB200." + (offset + offset2 + 12), staProtocol.getStaNo().intValue());    // 鐩爣绔�
                 }
-            }else if(siteId < 4000){
+            }else if(siteId < 2121){
                 write = siemensS7Net.Write("DB201." + (offset + offset2), staProtocol.getWorkNo());    // 宸ヤ綔鍙�
                 Thread.sleep(200);
                 if(specialSites2.contains(siteId)){
@@ -945,6 +959,11 @@
                 }else{
                     write1 = siemensS7Net.Write("DB201." + (offset + offset2 + 12), staProtocol.getStaNo().intValue());    // 鐩爣绔�
                 }
+            } else if(siteId < 4000){
+                Integer offsetBarcode = site2lBarcodeOffsetMap.get(siteId);
+                write = siemensS7Net.Write("DB202." + offsetBarcode, staProtocol.getBarcode());    // 鏉$爜
+                write1 = siemensS7Net.Write("DB202." + offsetBarcode, staProtocol.getBarcode());
+                Thread.sleep(200);
             }else{
                 write = siemensS7Net.Write("DB400." + (offset + offset2), staProtocol.getWorkNo());    // 宸ヤ綔鍙�
                 Thread.sleep(200);
diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml
index c3c84ca..49f5811 100644
--- a/src/main/resources/application.yml
+++ b/src/main/resources/application.yml
@@ -462,8 +462,8 @@
     # 鎷f枡鍏ュ簱鍙�1
     pickSta[0]:
       staNo: 1036
-      barcode: ${wcs-slave.barcode[2].id}
-      led: ${wcs-slave.led[5].id}
+      barcode: ${wcs-slave.barcode[0].id}
+      led: ${wcs-slave.led[1].id}
       backSta: 1037
     # 鍏ュ簱鍙�1
     inSta[2]:
diff --git a/src/main/webapp/static/js/basAgvMast/basAgvMast.js b/src/main/webapp/static/js/basAgvMast/basAgvMast.js
index 59f5208..404280c 100644
--- a/src/main/webapp/static/js/basAgvMast/basAgvMast.js
+++ b/src/main/webapp/static/js/basAgvMast/basAgvMast.js
@@ -24,7 +24,7 @@
             {type: 'checkbox'}
             ,{field: 'id', align: 'center',title: 'ID'}
             ,{field: 'taskNo', align: 'center',title: 'WMS浠诲姟鍙�'}
-            ,{field: 'timestamp', align: 'center',title: 'RGV浠诲姟鍙�'}
+            ,{field: 'timestampStr', align: 'center', title: 'RGV浠诲姟鍙�'}
             ,{field: 'sourceStaNo', align: 'center',title: '婧愮珯鐐�'}
             ,{field: 'staNo', align: 'center',title: '鐩殑绔欑偣'}
             ,{field: 'sourceLocNo', align: 'center',title: '婧愬簱浣�'}

--
Gitblit v1.9.1