From 138497ecffb6dbf468c458ed9f7e72bc88d2e7a0 Mon Sep 17 00:00:00 2001
From: schangxiang@126.com <schangxiang@126.com>
Date: 周五, 13 12月 2024 10:56:13 +0800
Subject: [PATCH] 11

---
 CC/iWareCC_ASRS/FormCC.cs |  249 ++++++++++++++++++++++++++-----------------------
 1 files changed, 134 insertions(+), 115 deletions(-)

diff --git a/CC/iWareCC_ASRS/FormCC.cs b/CC/iWareCC_ASRS/FormCC.cs
index d99eb49..0960ab9 100644
--- a/CC/iWareCC_ASRS/FormCC.cs
+++ b/CC/iWareCC_ASRS/FormCC.cs
@@ -37,6 +37,11 @@
     {
 
         /// <summary>
+        /// 鍏ㄥ眬-閰嶇疆鎶ヨ淇℃伅鍒楄〃
+        /// </summary>
+        public static DeviceWarningOutput configDeviceWarningList = DeviceWarningHandler.GetConfigWarningList();
+
+        /// <summary>
         /// 鍏ㄥ眬鈥旀槸鍚﹀彲浠ヨ繍琛屾墽琛屽嚭搴撴ā寮�
         /// </summary>
         public static bool IsAllowRunOutMode = false;
@@ -163,7 +168,7 @@
             this.rBNormal.Checked = SystemValue.rBNormal_Checked = true;
             this.rbHand.Checked = SystemValue.rbHand_Checked = false;
             this.rBDebug.Checked = SystemValue.rBDebug_Checked = false;
-           
+
 
 
             SetModelCheckBoxToSystemValue();
@@ -172,31 +177,12 @@
             startModelTipsThread.Start();
 
             #region 鑾峰彇璁惧鏁版嵁
-            ParameterizedThreadStart parStart1 = new ParameterizedThreadStart(GetSrmInfo);
-            Thread thread1 = new Thread(parStart1);
-            object o1 = (int)EDevice.涓�鍙峰爢鍨涙満;
-            thread1.Start(o1);
-
-            ParameterizedThreadStart parStart2 = new ParameterizedThreadStart(GetSrmInfo);
-            Thread thread2 = new Thread(parStart2);
-            object o2 = (int)EDevice.浜屽彿鍫嗗灈鏈�;
-            thread2.Start(o2);
-
-            ParameterizedThreadStart parStart3 = new ParameterizedThreadStart(GetSrmInfo);
-            Thread thread3 = new Thread(parStart3);
-            object o3 = (int)EDevice.涓夊彿鍫嗗灈鏈�;
-            thread3.Start(o3);
-
-            ParameterizedThreadStart parStart4 = new ParameterizedThreadStart(GetSrmInfo);
-            Thread thread4 = new Thread(parStart4);
-            object o4 = (int)EDevice.鍥涘彿鍫嗗灈鏈�;
-            thread4.Start(o4);
-
-
-
 
             var tskGetStationInfo = new Thread(GetStationInfo);
             tskGetStationInfo.Start();
+
+            var _GetStationWarningInfo = new Thread(GetStationWarningInfo);
+            _GetStationWarningInfo.Start();
 
 
             tskSetSrmLable = new Thread(SrmRead_Label);
@@ -339,9 +325,9 @@
                     this.lbl_Alert_DataProcess_BZ39_IssueInboundTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ39_IssueInboundTask;
                     this.lbl_Alert_DataProcess_RobotBuffer_ForceOutbound.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_ForceOutbound;
                     this.lbl_Alert_DataProcess_BZ12.Text = showNowTime + SystemWarningMsg._lbl_alert_DataProcess_BZ12;
-                    
+
                     //璁剧疆鍫嗗灈鏈轰换鍔′笅鍙戝拰浠诲姟瀹屾垚纭绾跨▼娑堟伅
-                   
+
                     this.lbl_Alert_DataProcess_BZ12_FinishTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ12_FinishTask;
                     this.lbl_Alert_DataProcess_BZ21_FinishTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ21_FinishTask;
 
@@ -351,6 +337,8 @@
                     this.lbl_Alert_PushPackageCodeToMes.Text = showNowTime + SystemWarningMsg._lbl_Alert_PushPackageCodeToMes;
 
                     this.lbl_Alert_DataProcess_BZ12_IssueTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ12_IssueTask;
+
+                    this.lbl_DataProcess_ValidateQiTao.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_ValidateQiTao;
 
                     this.lbl_Alert_DataProcess_RobotBuffer_FinishTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_FinishTask;
 
@@ -389,84 +377,6 @@
 
 
 
-        /// <summary>
-        /// 鑾峰彇鍫嗗灈鏈虹殑瀹炴椂淇℃伅
-        /// </summary>
-        private void GetSrmInfo(object int_device)
-        {
-            while (true)
-            {
-                EDevice device = (EDevice)Enum.Parse(typeof(EDevice), int_device.ToString());
-                Thread.Sleep(cycleDelay_Device);
-                try
-                {
-                    using (var opcClinet = new SrmService.SrmServiceClient())
-                    {
-                        srmViewDict[(int)device] = opcClinet.GetSrmInfo((int)device);
-                        CastToDevice_SrmRealTime(srmViewDict[(int)device]);
-                        List<String> warningAddressList = new List<string>();
-                        if (srmViewDict[(int)device].R_WarningDBList != null && srmViewDict[(int)device].R_WarningDBList.Length > 0)
-                        {
-                            var waringList = srmViewDict[(int)device].R_WarningDBList.ToList();
-                            if (waringList != null && waringList.Count > 0)
-                            {
-                                for (int i = 0; i < waringList.Count; i++)
-                                {
-                                    DeviceWarningHandler.SaveWarning(device, iWareCommon.Utils.LogType.DataProcess_BZ39_IssueInboundTask,
-                                        waringList[i].Code, waringList[i].Address, waringList[i].Context);//鏂板鎶ヨ
-                                    warningAddressList.Add(waringList[i].Address);
-                                }
-                            }
-                        }
-                        DeviceWarningHandler.AutoCloseWarning(device, iWareCommon.Utils.LogType.DataProcess_BZ39_IssueInboundTask, warningAddressList);//鑷姩鍏抽棴鎶ヨ
-                    }
-                }
-                catch (Exception ex)
-                {
-                    Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.DataProcess_BZ39_IssueInboundTask, "鑾峰彇" + device.ToString() + "鐨勫疄鏃朵俊鎭紓甯�:" + ex.Message, ex);
-                    continue;
-                }
-            };
-        }
-
-        /// <summary>
-        /// 杞崲涓篠RM鐨勫疄鏃剁姸鎬�
-        /// </summary>
-        /// <param name="view"></param>
-        private void CastToDevice_SrmRealTime(SrmView view)
-        {
-            List<Device_SrmRealTime> realTimeList = new List<Device_SrmRealTime>();
-            Device_SrmRealTime obj = new Device_SrmRealTime();
-            EDevice device = (EDevice)Enum.Parse(typeof(EDevice), view.R_SrmNo.ToString());
-            obj = new Device_SrmRealTime()
-            {
-                SrmCode = view.R_SrmNo.ToString(),
-                SrmName = device.ToString(),
-                Mode = view.R_Mode.ToString(),
-                ModeName = view.ModeName,
-                State = view.R_State.ToString(),
-                StateName = view.StateName,
-
-                TaskID = view.R_TaskNo.ToString(),
-                LiftFull = view.R_LiftFull == 1,
-                PosX = view.R_PosX,
-                PosY = view.R_PosY,
-                PosZ = view.R_PosZ,
-                PosZName = EnumberHelper.GetEnumName<ESrmForkPosition>(view.R_PosZ).ToString(),
-                // XCoordinate=view.r_xc
-
-                SrmToPlace = view.SrmToPlace,
-                SrmSourcePlace = view.SrmSourcePlace,
-                ZCoordinate = view.R_PosZmm.ToString(),
-                XCoordinate = view.R_PosXmm.ToString(),
-                YCoordinate = view.R_PosYmm.ToString()
-
-            };
-            realTimeList.Add(obj);
-
-            DeviceSrmRealTimeHandler.Update(realTimeList, iWareCommon.Utils.LogType.DataProcess_BZ39_IssueInboundTask);
-
-        }
 
 
 
@@ -523,9 +433,9 @@
             }
         }
 
-     
 
-     
+
+
 
 
         #endregion
@@ -598,6 +508,23 @@
                     }
                     stationView = stationServiceClient.GetStationInfo((int)EDevice.Station);
 
+
+                    this.lbl_Mode_FJ.Text = "璁惧妯″紡:" + PlcHelper.GetModeName(stationView.R_Mode_FJ);
+                    this.lbl_XinTiao_FJ.Text = "蹇冭烦:" + stationView.R_HandShake_FJ;
+                    this.lbl_Warning_FJ.Text = "鎶ヨ绫诲瀷:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_FJ);
+
+                    this.lbl_Mode_MB.Text = "璁惧妯″紡:" + PlcHelper.GetModeName(stationView.R_Mode_MB);
+                    this.lbl_XinTiao_MB.Text = "蹇冭烦:" + stationView.R_HandShake_MB;
+                    this.lbl_Warning_MB.Text = "鎶ヨ绫诲瀷:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_MB);
+
+                    this.lbl_Mode_HB.Text = "璁惧妯″紡:" + PlcHelper.GetModeName(stationView.R_Mode_HB);
+                    this.lbl_XinTiao_HB.Text = "蹇冭烦:" + stationView.R_HandShake_HB;
+                    this.lbl_Warning_HB.Text = "鎶ヨ绫诲瀷:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_HB);
+
+                    this.lbl_Mode_FX.Text = "璁惧妯″紡:" + PlcHelper.GetModeName(stationView.R_Mode_FX);
+                    this.lbl_XinTiao_FX.Text = "蹇冭烦:" + stationView.R_HandShake_FX;
+                    this.lbl_Warning_FX.Text = "鎶ヨ绫诲瀷:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_FX);
+
                     ////鏄剧ずRGV浠诲姟瀹屾垚鍜屽畬鎴愮‘璁や俊鍙�
                     //this.lbl_R_RGV_Finish.Text = "RGV浠诲姟瀹屾垚:" + rgvView.R_RGV_Finish;
                     //this.lbl_W_RGV_FinishACK.Text = "RGV浠诲姟瀹屾垚纭:" + rgvView.W_RGV_FinishACK;
@@ -664,6 +591,55 @@
                         tb_Rgv_Alter.Text = "";
                     }
                     DeviceWarningHandler.AutoCloseWarning(EDevice.RGV, iWareCommon.Utils.LogType.RgvThreadService, warningAddressList);//鑷姩鍏抽棴鎶ヨ
+
+                    //*/
+                }
+                catch (Exception ex)
+                {
+                    rgvView = null;
+                    Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.StationThreadService, "鑾峰彇绔欑偣淇℃伅鍑虹幇寮傚父:" + ex.Message, ex);
+                    continue;
+                }
+            }
+        }
+
+
+        /// <summary>
+        /// 鑾峰彇Station 鎶ヨ淇℃伅
+        /// </summary>
+        /// <param name="obj"></param>
+        private async void GetStationWarningInfo(object obj)
+        {
+            while (true)
+            {
+                Thread.Sleep(2000);//1绉掗挓璇诲彇涓�娆�
+                try
+                {
+                    if (stationServiceClient == null)
+                    {
+                        continue;
+                    }
+                    /*
+                    iWareCC.StationService.DeviceWarningInfo[] waringList = await stationServiceClient.GetWaringInfoListAsync((int)EDevice.Station, configDeviceWarningList.wmsConfigDeviceWarnings.ToArray());
+
+                    //鏄剧ず鎶ヨ淇℃伅
+                    List<String> warningCodeList = new List<string>();
+                    if (waringList != null && waringList.Length > 0)
+                    {
+                        for (int i = 0; i < waringList.Length; i++)
+                        {
+                            var findObj = configDeviceWarningList.wms_config_device_warning_list.Where(x => x.WarningCode == waringList[i].Codek__BackingField).FirstOrDefault();
+                            DeviceWarningHandler.SaveWarning(EDevice.Station, iWareCommon.Utils.LogType.StationThreadService,
+                                findObj.WarningCode, findObj.DeviceAreaCode, findObj.WarningContent, findObj.DeviceWarningType);//鏂板鎶ヨ
+                            warningCodeList.Add(findObj.WarningCode);
+                        }
+
+                    }
+                    else
+                    {
+
+                    }
+                    DeviceWarningHandler.AutoCloseWarning(EDevice.Station, iWareCommon.Utils.LogType.StationThreadService, warningCodeList);//鑷姩鍏抽棴鎶ヨ
 
                     //*/
                 }
@@ -745,11 +721,11 @@
             });
         }
 
-     
+
 
         #endregion
 
-      
+
 
         #region 鍏叡
 
@@ -781,7 +757,7 @@
         }
 
 
-       
+
 
         /// <summary>
         /// 鍫嗗灈鏈轰换鍔$‘璁�
@@ -933,7 +909,7 @@
         {
             //鍫嗗灈鏈�1浠诲姟涓嬪彂
             DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_1, ckB_DataProcess_BZ39_IssueInboundTask);
-            
+
 
             //鍫嗗灈鏈�2浠诲姟涓嬪彂
             DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_2, ckBDataProcess_RobotBuffer_ForceOutbound);
@@ -943,11 +919,11 @@
             DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_3, ckBDataProcess_BZ12);
             DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_3_Finish, ckBDataProcess_BZ21_FinishTask);
 
-          
+
 
 
             //RGV浠诲姟涓嬪彂
-          
+
             DoCommonCheckedChanged(ref SystemValue.isAllowRuning_RgvThreadService_Finish, ckB_PushPaperCutToMes);
             DoCommonCheckedChanged(ref SystemValue.isAllowRuning_RgvThreadService_Finish_BuChang, ck_PushPackageCodeToMes);
 
@@ -986,8 +962,8 @@
 
         private void FormCC_SizeChanged(object sender, EventArgs e)
         {
-           
-          
+
+
         }
 
         /// <summary>
@@ -1273,7 +1249,7 @@
         }
 
 
-       
+
 
         private void btn_TongJi_Click(object sender, EventArgs e)
         {
@@ -1428,7 +1404,7 @@
             }
         }
 
-      
+
         private void button22_Click(object sender, EventArgs e)
         {
             var cargNo = this.tb_wlm.Text.Trim();
@@ -1501,6 +1477,49 @@
                     item.UpiStatus = (int)UpiStatusEnum.鍒濆;
                 }
 
+                //娓呯┖闃熷垪鏁版嵁
+                var list = db.mes_upi_linequeue.ToList();
+                db.mes_upi_linequeue.RemoveRange(list);
+
+                db.SaveChanges();
+            }
+            if (!string.IsNullOrEmpty(alertMsg))
+            {
+                MessageBox.Show("閿欒:" + alertMsg);
+            }
+            else
+            {
+                MessageBox.Show("宸插鐞�");
+            }
+        }
+
+        private void button1_Click(object sender, EventArgs e)
+        {
+
+
+            var alertMsg = "";
+            using (WmsDBModel db = new WmsDBModel())
+            {
+                //鏌ヨ绔嬩綋搴撲腑鐨剈pi鍒楄〃
+                var quanList = db.wms_stock_quan.ToList().Select(x => x.Upi).ToList();
+                var upiList = db.mes_batchOrderUPI_new.Where(x => !quanList.Contains(x.UPI)).ToList();
+                foreach (var item in upiList)
+                {
+                    item.AreaCode = (int)AreaCodeEnum.鏃犲尯鍩�;
+                    item.UpiStatus = (int)UpiStatusEnum.鍒濆;
+                }
+
+                var packageCodeList = upiList.Select(x => x.PackageCode).ToList();
+                var pList = db.mes_package_gather.Where(x => packageCodeList.Contains(x.PackageCode)).ToList();
+                foreach (var item in pList)
+                {
+                    item.AreaCode = (int)AreaCodeEnum.鏃犲尯鍩�;
+                    item.UpiStatus = (int)UpiStatusEnum.鍒濆;
+                }
+                //娓呯┖闃熷垪鏁版嵁
+                var list = db.mes_upi_linequeue.ToList();
+                db.mes_upi_linequeue.RemoveRange(list);
+
                 db.SaveChanges();
             }
             if (!string.IsNullOrEmpty(alertMsg))

--
Gitblit v1.9.3