From 305e2990bb2161177e87ab7711f9dfb205762bcd Mon Sep 17 00:00:00 2001 From: kingno <30263@KINGNO> Date: 星期一, 09 六月 2025 15:52:42 +0800 Subject: [PATCH] 优化数据传递 --- src/Bro.M135.Common/ProductModel.cs | 57 ++++++++++++++++++++++++++++++++++++--------------------- 1 files changed, 36 insertions(+), 21 deletions(-) diff --git a/src/Bro.M135.Common/ProductModel.cs b/src/Bro.M135.Common/ProductModel.cs index 5e1df4b..5bebb83 100644 --- a/src/Bro.M135.Common/ProductModel.cs +++ b/src/Bro.M135.Common/ProductModel.cs @@ -1,7 +1,9 @@ 锘縰sing Bro.Common.Helper; +using Bro.Common.Interface; using Bro.Common.Model; using Bro.M135.DBManager; using Newtonsoft.Json; +using static System.Windows.Forms.VisualStyles.VisualStyleElement.ListView; namespace Bro.M135.Common { @@ -53,11 +55,11 @@ { if (!string.IsNullOrWhiteSpace(d.FAIData)) { - d.SpecList = JsonConvert.DeserializeObject<List<Spec>>(d.FAIData); + d.SpecList = JsonConvert.DeserializeObject<List<ISpec>>(d.FAIData); } else { - d.SpecList = new List<Spec>(); + d.SpecList = new List<ISpec>(); } if (!string.IsNullOrWhiteSpace(d.DefectDesc)) @@ -193,10 +195,12 @@ }); }); - head = $"PID,鏉$爜,姹囨�绘娴嬬粨鏋�,"; + allSpecs.RemoveAll(u => (u.Code.ToLower() == "ngspec" || u.Code == "妫�娴婽BD")); + + head = $"鏃堕棿,PID,鏍忓叿鐮�,鐗╂枡鐮�,鏉$爜,姹囨�绘娴嬬粨鏋�,"; positionList = new List<string>(); - Details = Details.OrderBy(u => u.PositionName).ToList(); + Details = Details.OrderBy(u => u.STATION_CODE).ThenBy(u => u.PositionName).ToList(); foreach (var d in Details) { positionList.Add($"{d.STATION_CODE}_{d.PositionName}"); @@ -233,7 +237,8 @@ }); }); - string data = $"{PID},{SN},{Result},"; + //鏃堕棿,PID,鏍忓叿鐮�,鐗╂枡鐮�,鏉$爜,姹囨�绘娴嬬粨鏋�,"; + string data = $"{DateTime.Now.ToString("yyyyMMddHHmmss")}T,{PID},{BasketCode},{SEQUENCE},{SN},{Result},"; positionList.ForEach(pName => { var detail = Details.FirstOrDefault(u => $"{u.STATION_CODE}_{u.PositionName}" == pName); @@ -301,7 +306,9 @@ }); }); - head = $"鏃堕棿,PID,搴忓彿,鏉$爜,"; + allSpecs.RemoveAll(u => u.Code.ToLower() == "ngspec" || u.Code == "妫�娴婽BD"); + + head = $"鏃堕棿,鏍忓叿鐮�,PID,搴忓彿,鏉$爜,"; foreach (var d in positionDetail) { @@ -338,7 +345,7 @@ }); }); - string data = $"{DateTime.Now.ToString("HH:mm:ss.fff")}T,{PID},{SEQUENCE},{SN},"; + string data = $"{DateTime.Now.ToString("HH:mm:ss.fff")}T,{BasketCode},{PID},{SEQUENCE},{SN},"; positionDetail.ForEach(detail => { if (!detail.IsDone) @@ -378,22 +385,22 @@ } }); - positionDetail.ForEach(detail => - { - if (detail.IsDone) - { + //positionDetail.ForEach(detail => + //{ + // if (detail.IsDone) + // { - var results = detail.ResultList; + // var results = detail.ResultList; - var list = results.Where((DetectResult u) => u.ResultState != EnumHelper.ResultState.OK).SelectMany((DetectResult u) => u.NetResults.Where((NetResult m) => !m.IsAbandoned && m.CurResult != EnumHelper.ResultState.OK).SelectMany((NetResult m) => from n in m.DetectDetails where !n.IsAbandoned && n.FinalResult != EnumHelper.ResultState.OK select n)).ToList(); + // var list = results.Where((DetectResult u) => u.ResultState != EnumHelper.ResultState.OK).SelectMany((DetectResult u) => u.NetResults.Where((NetResult m) => !m.IsAbandoned && m.CurResult != EnumHelper.ResultState.OK).SelectMany((NetResult m) => from n in m.DetectDetails where !n.IsAbandoned && n.FinalResult != EnumHelper.ResultState.OK select n)).ToList(); - list.ForEach(d => - { - data += $"{(d.Rect.Height * d.PixelSize).ToString("f4")},"; - data += $"{(d.Rect.Width * d.PixelSize).ToString("f4")},"; - }); - } - }); + // list.ForEach(d => + // { + // data += $"{(d.Rect.Height * d.PixelSize).ToString("f4")},"; + // data += $"{(d.Rect.Width * d.PixelSize).ToString("f4")},"; + // }); + // } + //}); @@ -415,12 +422,20 @@ #endregion #region PositionCheckTimes - public void InitialPositionCheckList(string positionName, List<int> checkTimes) + public void InitialPositionCheckList(string positionName, List<int> checkTimes,string stationName) { lock (_checkResultLock) { PositionCheckList[positionName] = new List<int>(checkTimes); Details.RemoveAll(u => u.PositionName == positionName); + + + P_PRODUCT_DETAIL detail = new P_PRODUCT_DETAIL(); + detail.STATION_CODE = stationName; + detail.PositionName = positionName; + detail.PID = PID; + detail.IsDone = false; + Details.Add(detail); } } -- Gitblit v1.8.0