From af42a9904d1d3939da7fa0a00c3a7a2ced78258e Mon Sep 17 00:00:00 2001
From: lss <Lss@HanInfo>
Date: 星期三, 21 五月 2025 17:26:18 +0800
Subject: [PATCH] 佳通问题优化

---
 HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs |  124 ++++++++++++++++++++++++++++------------
 1 files changed, 86 insertions(+), 38 deletions(-)

diff --git a/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs b/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs
index a4abc4b..2655f71 100644
--- a/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs
+++ b/HH.WCS.Mobox3/HH.WCS.Mobox3.JiaTong/process/TaskProcess.cs
@@ -13,6 +13,7 @@
 using System.IdentityModel.Protocols.WSTrust;
 using System.Linq;
 using System.Security.Cryptography;
+using System.Threading;
 using static HH.WCS.JiaTong.api.ApiModel;
 using static HH.WCS.JiaTong.LISTA.process.HttpModel;
 
@@ -32,15 +33,33 @@
             var trayCarryCount = mst.N_CNTR_COUNT > 0 ? mst.N_CNTR_COUNT : 1;
             if (load)
             {
-                Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}");
-                LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}");
-                LocationHelper.UnBindingLoc(mst.S_START_LOC, mst.S_CNTR_CODE.Split(',').ToList());
+                //Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}");
+
+                if (!string.IsNullOrEmpty(mst.S_CNTR_CODE))
+                {
+                    LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_START_LOC}鍙栬揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}");
+                    LocationHelper.UnBindingLoc(mst.S_START_LOC, mst.S_CNTR_CODE.Split(',').ToList());
+                }
+                else
+                {
+                    LogHelper.Info($"浠诲姟{mst.S_CODE} 鎵樼洏涓虹┖ ,鍙В閿佽揣浣�);
+                    LocationHelper.UnlockLoc(mst.S_START_LOC);
+                }
             }
             else
             {
-                Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岀粓鐐圭粦瀹氬鍣▄mst.S_CNTR_CODE}");
-                LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}");
-                LocationHelper.BindingLoc(mst.S_END_LOC, mst.S_CNTR_CODE.Split(',').ToList());
+                // Console.WriteLine($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岀粓鐐圭粦瀹氬鍣▄mst.S_CNTR_CODE}");
+
+                if (!string.IsNullOrEmpty(mst.S_CNTR_CODE))
+                {
+                    LogHelper.Info($"浠诲姟{mst.S_CODE} 璐т綅{mst.S_END_LOC}鍗歌揣瀹屾垚锛岃捣鐐硅В缁戝鍣▄mst.S_CNTR_CODE}");
+                    LocationHelper.BindingLoc(mst.S_END_LOC, mst.S_CNTR_CODE.Split(',').ToList());
+                }
+                else
+                {
+                    LogHelper.Info($"浠诲姟{mst.S_CODE} 鎵樼洏涓虹┖ ,鍙В閿佽揣浣�);
+                    LocationHelper.UnlockLoc(mst.S_END_LOC);
+                }
             }
 
         }
@@ -73,9 +92,9 @@
         /// <summary>
         /// 瀹夊叏璇锋眰
         /// </summary>
-        /// <param name="model"></param>
-        /// <param name="url"></param>
-        /// <param name="wcs"></param>
+        /// <param name="model">璇锋眰鍙傛暟</param>
+        /// <param name="url">鍦板潃</param>
+        /// <param name="TN_Task">浠诲姟</param>
         internal static void OperateReq(AgvTaskState model, string url, WCSTask TN_Task)
         {
             try
@@ -103,16 +122,25 @@
                         else
                         {
                             //浜曟澗鍙犵洏鏈哄畨鍏ㄤ氦浜�-                            if (TN_Task.Z_TYPE == 2 && TN_Task.S_NOTE == "绌烘墭鍥炲簱")
+                            if (TN_Task.S_NOTE == "绌烘墭鍥炲簱")
                             {
                                 if (S7Helper.WriteDpj(1002, 1))
                                 {
-                                    if (S7Helper.ReadDpj(2004, S7.Net.VarType.Byte) == 1)
+                                    int value = S7Helper.ReadDpj(2004, S7.Net.VarType.Byte);
+                                    if (value == 1)
                                     {
                                         NDCApi.ChangeOrderParam(TN_Task.S_CODE.Trim(), 6, "1");
                                     }
+                                    else
+                                    {
+                                        LogHelper.Info("鍙犵洏鏈哄畨鍏ㄤ氦浜掑け璐ワ紝璇诲彇VB2004鐨勫�涓簕2004}");
+                                    }
                                 }
-                              
+                                else
+                                {
+                                    LogHelper.Info("鍙犵洏鏈哄畨鍏ㄤ氦浜掑け璐ワ紝鍐欏叆VB1002鍊�澶辫触");
+                                }
+
                             }
                             else
                             {
@@ -138,10 +166,17 @@
                                 //NDCHelper.ChangeParam(TN_Task.S_CODE.Trim(), 1101, 18);
                             }
                         }
-                        if (TN_Task.Z_TYPE == 2 && TN_Task.S_NOTE == "绌烘墭鍥炲簱")
+                        if (TN_Task.S_NOTE == "绌烘墭鍥炲簱")
                         {
-                            S7Helper.WriteDpj(1001, 1);
-                            S7Helper.WriteDpj(1002, 0);
+                            //鍐欏叆澶辫触閲嶆柊鍐欏叆
+                            while (!S7Helper.WriteDpj(1001, 1))
+                            {
+                                Thread.Sleep(1000);
+                            }
+                            while (!S7Helper.WriteDpj(1002, 0))
+                            {
+                                Thread.Sleep(1000);
+                            }
                         }
                     }
                     if (model.state == 1103)
@@ -223,6 +258,7 @@
                 else
                 {
                     LogHelper.Info($"瀹夊叏璇锋眰澶辫触=>msg:{result.msg}");
+                    ApiHelper.AddErrorInfo("瀹夊叏浜や簰澶辫触", result.msg, "", tasknum);
                 }
                 return permit;
             }
@@ -272,6 +308,7 @@
                 else
                 {
                     LogHelper.Info($"瀹夊叏璇锋眰澶辫触=>msg:{result.err_msg}");
+                    ApiHelper.AddErrorInfo("瀹夊叏浜や簰澶辫触", result.err_msg, "", no);
                 }
                 return permit;
             }
@@ -806,9 +843,8 @@
         /// <summary>
         /// mes鐗╂枡鍒颁綅鍚屾
         /// </summary>
-        /// <param name="taskNum"></param>
-        /// <param name="orderNum"></param>
-        /// <param name="taskStatus"></param>
+        /// <param name="mst">浠诲姟</param>
+        /// <param name="url">鍦板潃</param>
         public static void MESIteminfoback(WCSTask mst, string url)
         {
             LogHelper.Info($"------------寮�鐗╂枡淇℃伅鍥炴姤-----------");
@@ -816,37 +852,47 @@
             {
                 var cntritem = ContainerHelper.GetCntrItemRel(mst.S_CNTR_CODE).FirstOrDefault();
                 //鍥炴姤鏁版嵁
-                Request<iteminfoArrive> statusarrive = new Request<iteminfoArrive>();
-                List<LotListh> lotLists = new List<LotListh>();
-                string TaskNumber = mst.S_EQ_NO;
-                if (!string.IsNullOrEmpty(mst.S_WMS_NO))
-                {
-                    TaskNumber = mst.S_WMS_NO;
-                }
+                Request<MesItemBackModel> request = new Request<MesItemBackModel>();
+                List<MesItemBackInfoModel> list = new List<MesItemBackInfoModel>();
+              
                 //鑾峰彇鏃堕棿鎴�                 var time = DateTimeOffset.UtcNow.ToUnixTimeMilliseconds();
                 //鐗╂枡鍒颁綅鎺ュ彛鍜岀姸鎬佸弽棣堝悓鏃惰皟IIOT锛屼负浜嗗尯鍒唅d锛岀墿鏂欏埌浣嶉暱搴﹀姞涓�尯鍒�-                statusarrive.RequestId = "鏉弶AGV" + time + "1";
-                statusarrive.UseToken = "iFQ5fExGrLYLXliHYWzs";
+                request.RequestId = "鏉弶AGV" + time + "1";
+                request.UseToken = "iFQ5fExGrLYLXliHYWzs";
 
-                iteminfoArrive iteminfoArrive = new iteminfoArrive();
-                iteminfoArrive.TaskNumber = TaskNumber;
-                iteminfoArrive.LocationNum = mst.S_END_LOC;
-                iteminfoArrive.Rfid = mst.S_CNTR_CODE;
-                iteminfoArrive.ArricalTime = DateTime.Now.ToString("yyyy-MM-dd");
+                MesItemBackModel mesItemBackModel = new MesItemBackModel();
+                mesItemBackModel.TaskNumber = mst.S_EQ_NO;
+                mesItemBackModel.WmsTaskNumber = mst.S_WMS_NO;
+                mesItemBackModel.Rfid = mst.S_CNTR_CODE;
+                mesItemBackModel.LocationNum = mst.S_END_LOC;
+                mesItemBackModel.Result = "1";
+                mesItemBackModel.ArricalTime = DateTime.Now.ToString("yyyy-MM-dd");
                 if (cntritem != null)
                 {
-                    lotLists.Add(new LotListh() { LotNumber = cntritem.S_BATCH_NO, Weight = double.Parse(cntritem.F_WEIGHT) });
-                    iteminfoArrive.PartDesc = cntritem.S_ITEM_NAME;
-                    iteminfoArrive.PartNumber = cntritem.S_ITEM_CODE;
+                    list.Add(new MesItemBackInfoModel()
+                    {
+                        LotNumber = cntritem.S_BATCH_NO,
+                        PartNumber = cntritem.S_ITEM_NAME,
+                        Subpool = cntritem.Subpool,
+                        ReceiveLot = cntritem.ReceiveLot,
+                        Supplier = cntritem.S_SUPPLIER_NO,
+                        TyreType = cntritem.TyreType,
+                        ProduceTime = cntritem.D_PRD_DATE,
+                        Rfid = cntritem.S_CNTR_CODE,
+                        Qty = cntritem.F_WEIGHT,
+                        Level = cntritem.LEV
+                    });
+
 
                 }
-                iteminfoArrive.LotList = lotLists;
-                statusarrive.data = iteminfoArrive;
+                mesItemBackModel.List = list;
+                request.data = mesItemBackModel;
+
                 //浠诲姟涓婃姤
                 HttpHelper httpHelper = new HttpHelper();
                 MesResult result = new MesResult();
-                string date = JsonConvert.SerializeObject(statusarrive);
+                string date = JsonConvert.SerializeObject(request);
 
                 LogHelper.Info($"鐗╂枡鍒颁綅鍥炴姤锛氬湴鍧�{url}锛屽唴瀹癸細{date}");
                 var r = httpHelper.MesWebPost(url, date);
@@ -868,6 +914,8 @@
             }
 
         }
+
+
         /// <summary>
         /// 鍒涘缓鎼繍浠诲姟
         /// </summary>

--
Gitblit v1.9.1