From 8f0f149d607a7246fa25e81340602ce5e47398fe Mon Sep 17 00:00:00 2001 From: pulg <plg@Haninfo> Date: 星期四, 10 七月 2025 18:14:38 +0800 Subject: [PATCH] 1 --- HH.WCS.QingXiNongfu/process/DeviceProcess.cs | 516 +++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 459 insertions(+), 57 deletions(-) diff --git a/HH.WCS.QingXiNongfu/process/DeviceProcess.cs b/HH.WCS.QingXiNongfu/process/DeviceProcess.cs index af4df1d..402373f 100644 --- a/HH.WCS.QingXiNongfu/process/DeviceProcess.cs +++ b/HH.WCS.QingXiNongfu/process/DeviceProcess.cs @@ -1,28 +1,14 @@ -锘縰sing HH.WCS.QingXigongchang.core; -using HH.WCS.QingXigongchang.device; +锘縰sing HH.WCS.QingXigongchang.device; using HH.WCS.QingXigongchang.dispatch; using HH.WCS.QingXigongchang.util; using HH.WCS.QingXigongchang.wms; -using Microsoft.SqlServer.Server; using Newtonsoft.Json; -using NLog.Time; using SqlSugar; using System; -using System.Collections; using System.Collections.Generic; using System.Data; -using System.Diagnostics.Eventing.Reader; using System.Linq; -using System.Reflection; -using System.Runtime.InteropServices; -using System.Security.Cryptography; using System.Threading; -using System.Threading.Tasks; -using System.Timers; -using System.Web.Http.Results; -using System.Web.Security; -using System.Web.UI.WebControls; -using static HH.WCS.QingXigongchang.dispatch.NDC; using static HH.WCS.QingXigongchang.util.Settings; namespace HH.WCS.QingXigongchang.process @@ -158,7 +144,6 @@ } } - private static void Analysis13(string data, deviceInfo plc) { //鐢ㄤ簬 鍑哄簱鏃�鏄惁鍙互鐩磋揪 鎻愬崌鏈恒� 00 鍚庨潰杩橀渶澧炲姞閫�枡宸ュ崟澶勭悊銆� @@ -327,7 +312,7 @@ si = "0"; } - else if (data.Contains("11"))// && (ods.Find(x => x.SQL_PLineNo.Contains("绾哥")) != null || plc.deviceName.Contains("T1")) + if (data.Contains("11"))// && (ods.Find(x => x.SQL_PLineNo.Contains("绾哥")) != null || plc.deviceName.Contains("T1")) { //if (!ods.Any()) // return; @@ -335,16 +320,28 @@ if (_cl.N_CURRENT_NUM > 0 || _clrel.Any()) { LogHelper.Info($" time锛歿_clrel0?.T_CREATE} = s_type锛歿_clrel0.S_TYPE}"); + //if (DateTime.Now.Subtract(_clrel0.T_CREATE).TotalSeconds < 10 || !string.IsNullOrEmpty(_clrel0.S_TYPE)) + // goto ballll; + //plg 2025骞�鏈�3鏃� 鍘婚櫎10绉掓椂闂撮檺鍒� if (_clrel.Any()) - if (DateTime.Now.Subtract(_clrel0.T_CREATE).TotalSeconds < 10 || !string.IsNullOrEmpty(_clrel0.S_TYPE)) - goto ballll; - - LocationHelper.DoAction(db => { - db.Deleteable(_clrel).ExecuteCommand(); - _cl.N_CURRENT_NUM = 0; - return db.Updateable(_cl).UpdateColumns(x => new { x.N_CURRENT_NUM }).ExecuteCommand() > 0; - }); + if (od?.SQL_PLineNo == "T1鎻愬崌鏈�) + { + if (!string.IsNullOrEmpty(_clrel0.S_TYPE)) + goto ballll; + } + else + { + if (DateTime.Now.Subtract(_clrel0.T_CREATE).TotalSeconds < 3 || !string.IsNullOrEmpty(_clrel0.S_TYPE)) + goto ballll; + } + } + LocationHelper.DoAction(db => + { + db.Deleteable(_clrel).ExecuteCommand(); + _cl.N_CURRENT_NUM = 0; + return db.Updateable(_cl).UpdateColumns(x => new { x.N_CURRENT_NUM }).ExecuteCommand() > 0; + }); } if (!plc.deviceName.Contains("T1")) goto ballll; @@ -379,8 +376,10 @@ if (sBit != null) { var sign = Settings.GetTimeStamp(); - var res = TaskProcess.CreateTransport(sign, sBit.S_LOC_CODE, _cl.S_LOC_CODE, "鍘熺墿鏂欐惉杩�绾哥", new List<string> { _clrel.FirstOrDefault().S_CNTR_CODE }, sBit.N_CURRENT_NUM, 1, 1, 50);///, EdnRarea == "YWLYLTKQ" ? _clrel0.S_TYPE : ""); + var res = TaskProcess.CreateTransport(sign, sBit.S_LOC_CODE, _cl.S_LOC_CODE, "鍘熺墿鏂欐惉杩�绾哥", new List<string> { _clrel.FirstOrDefault().S_CNTR_CODE }, sBit.N_CURRENT_NUM, 1, 1, 60);///, EdnRarea == "YWLYLTKQ" ? _clrel0.S_TYPE : ""); LogHelper.Info($"鍘熺墿鏂欐惉杩�涓婃彁鍗囨満銆�{sign} 浠诲姟 锛屽垱寤簕res} "); + //var res = TaskProcess.CreateTransport(sign, sBit.S_LOC_CODE, _cl.S_LOC_CODE, "鍘熺墿鏂欐惉杩�绾哥", new List<string> { _clrel.FirstOrDefault().S_CNTR_CODE }, sBit.N_CURRENT_NUM, 1, 1, 50);///, EdnRarea == "YWLYLTKQ" ? _clrel0.S_TYPE : ""); + //LogHelper.Info($"鍘熺墿鏂欐惉杩�涓婃彁鍗囨満銆�{sign} 浠诲姟 锛屽垱寤簕res} "); } } } @@ -1734,18 +1733,51 @@ 鐘舵�2 閫佺┖瀹屾垚涔嬪悗涓虹姸鎬� 鐘舵�3 婊℃墭鍙栬蛋锛岄�绌轰箣鍓嶄负鐘舵�3锛屽紑鏈洪粯璁ょ姸鎬佷篃涓虹姸鎬� */ + //3F 00 12 22 0D 0A--鏃犱换鍔′俊鍙�+ //3F 00 11 22 0D 0A--A鍙e伐浣滀俊鍙�+ //3F 00 12 21 0D 0A--B鍙d俊鍙�+ //3F 00 11 21 0D 0A--A銆丅鍙e伐浣滀俊鍙�+ + //A鍙e浣嶄俊鍙�- 3F 00 10 0D 0A + //B鍙e浣嶄俊鍙�- 3F 00 20 0D 0A if (data.Length == 4) { - if (data.Substring(1, 1) == "1") + if (data == "1122")//A鍙e伐浣滀俊鍙� { - if (BottlePEMInfoFull(plc, plc.location[0])) + if (BottlePEMInfoFullTwo(plc, plc.location[0])) { - //璁惧娌℃湁鎵樼洏锛屾垨鑰呭凡缁忔湁浠诲姟锛屼笉澶勭悊婊℃墭淇″彿锛岃繑鍥炲凡缁忓彇璐у畬鎴�- //3F 00 11 0d 0a - //PlcHelper.SendHex(plc.address, "3F00110d0a"); + } } + else if (data == "1221")//B鍙e伐浣滀俊鍙�+ { + if (BottlePEMInfoFullTwo(plc, plc.location[1])) + { + + } + } + else if (data == "1121")//AB鍙e伐浣滀俊鍙�+ { + if (BottlePEMInfoFullTwo(plc, plc.location[0])) + { + + } + if (BottlePEMInfoFullTwo(plc, plc.location[1])) + { + + } + } + + //if (data.Substring(1, 1) == "1") + //{ + // if (BottlePEMInfoFull(plc, plc.location[0])) + // { + // //璁惧娌℃湁鎵樼洏锛屾垨鑰呭凡缁忔湁浠诲姟锛屼笉澶勭悊婊℃墭淇″彿锛岃繑鍥炲凡缁忓彇璐у畬鎴�+ // //3F 00 11 0d 0a + // //PlcHelper.SendHex(plc.address, "3F00110d0a"); + // } + //} //else if (data.Substring(1, 1) == "3") //{ // if (BottleCapInfoEmpty(plc, plc.location[0])) @@ -1754,13 +1786,13 @@ // } //} - if (data.Substring(3, 1) == "1") - { - if (BottlePEMInfoFull(plc, plc.location[1])) - { - //PlcHelper.SendHex(plc.address, "3F00210d0a"); - } - } + //if (data.Substring(3, 1) == "1") + //{ + // if (BottlePEMInfoFull(plc, plc.location[1])) + // { + // //PlcHelper.SendHex(plc.address, "3F00210d0a"); + // } + //} //else if (data.Substring(3, 1) == "3") //{ // if (BottleCapInfoEmpty(plc, plc.location[1])) @@ -1963,6 +1995,376 @@ } } } + } + } + private static object locko = new object(); + private static object lockoIn = new object(); + private static object lockoOut = new object(); + + static bool BottlePEMInfoFullTwo(Settings.deviceInfo plc, string location) + { + try + { + lock (locko) + { + var chi = new SqlHelper<object>().GetInstance(); + var newDb = chi.CopyNew(); + Location endBit = null; + Location staBit = null; + bool SentTask = false; + if (location == "") + { + throw new Exception("璐т綅涓虹┖"); + } + var workOrder = WCSHelper.GetWorkOrder(plc.deviceName); + if (workOrder == null) + { + throw new Exception("娌℃湁銆愭墽琛屼腑銆戠殑宸ュ崟"); + } + //鍏堟煡璇㈣揣浣嶆湁娌℃湁璐� 婊$殑涓嬫弧 绌虹殑鍒欎笂绌�+ // = newDb.Queryable<Location>().FindAll(x => x.S_LOCK_STATE == "鏃� && x.N_CURRENT_NUM == 0); + var hojs = newDb.Queryable<Location>().Where(e => e.S_LOC_CODE == location).First(); + if (hojs != null && hojs.S_LOCK_STATE != "鏃�) + { + return false; + } + var bcpList = WCSHelper.BcpQyOrderList(plc.deviceName); + if (bcpList.Count() == 0) + { + throw new Exception("鏈垝鍒嗗搴旂殑鍖哄煙 鏌ョ湅杩欎釜浜х嚎鏄惁鍦ㄥ崐鎴愬搧鍖哄煙琛ㄨ繘琛岄厤缃�骞跺惎鐢�); + } + if (hojs.N_CURRENT_NUM == 0)//涓婃墭鐩�鍚﹀垯涓嬫墭鐩�+ { + //涓婃墭鐩�绌烘 + var jcjykk = bcpList.FindAll(e => e.S_CNTR_TYPE == "绌烘墭").OrderByDescending(g => g.N_PRI).ToList(); + var AreaList = jcjykk.Select(e => e.S_AREA_CODE).Distinct().ToList(); + foreach (var Area in AreaList) + { + var Row = jcjykk.FindAll(f => f.S_AREA_CODE == Area).Select(e => e.N_ROW).Distinct().ToList(); + //杩囩畻娉�璁$畻璧风偣 + var staList = GetOutWork(Area, Row); + if (staList.Any()) + { + foreach (var item in jcjykk) + { + Location sta = null; + var staLisL = staList.FindAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW).ToList(); + if (staLisL.Any()) + { + sta = staLisL.OrderByDescending(e => e.N_COL).First(); + } + if (sta != null) + { + staBit = sta; + break; + } + } + } + } + if (staBit != null) + { + var _ctrl = LocationHelper.GetLocCntrRel(staBit.S_LOC_CODE); + int StaLayer = staBit.N_CURRENT_NUM; + var carryCntrs = new List<string> { _ctrl.FirstOrDefault().S_CNTR_CODE };//DateTime.Now.ToString("yyMMddHHmmss") }; + var bb = TaskProcess.CreateTransport(workOrder.SQL_WorkNo, staBit.S_LOC_CODE, location, "娉ㄥ绌烘嫋-鍑哄簱", carryCntrs, StaLayer, 1, carryCntrs.Count, plc.taskPri); + if (bb) + { + SentTask = true; + } + } + if (SentTask) + { + return SentTask; + } + } + else + { + var time = LocationHelper.GetT_FULL_TIME(location); + LogHelper.Info(location + "锛氭墭鐩樻斁缃椂闂�(" + time + ") 璐т綅鎵樼洏鏁伴噺(" + hojs.N_CURRENT_NUM + ")"); + if (DateTime.Now.Subtract(time ?? DateTime.Now).TotalMinutes < 1) + { + for (var i = 0; i < plc.location.Length; i++) + { + if (location == plc.location[i]) + { + PlcHelper.SendHex(plc.address, "3F00" + (i + 1) + "0" + "0d0a"); + break; + } + } + return false; + } + + LocCntrRel _clrel = LocationHelper.GetLocCntrRel(hojs.S_LOC_CODE).FirstOrDefault(); + //涓婃墭鐩�婊℃ + var jcjykk = bcpList.FindAll(e => e.S_CNTR_TYPE == "婊℃墭").OrderByDescending(g => g.N_PRI).ToList(); + var AreaList = jcjykk.Select(e => e.S_AREA_CODE).Distinct().ToList(); + + //杩囩畻娉�璁$畻璧风偣 + foreach (var Area in AreaList) + { + var Row = jcjykk.Select(e => e.N_ROW).Distinct().ToList(); + + + + var EndList = GetInWork(Area, Row, true, workOrder.SQL_ItemCode); + if (EndList.Any()) + { + foreach (var item in jcjykk) + { + Location End = null; + var EndListT = EndList.FindAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW).ToList(); + if (EndListT.Count() > 0) + { + End = EndListT.OrderBy(e => e.N_COL).First(); + } + if (End != null) + { + endBit = End; + break; + } + } + } + } + if (endBit != null) + { + var _ctrl = LocationHelper.GetLocCntrRel(location); + List<CntrItemRel> RItem = new List<CntrItemRel>(); + foreach (var item in _ctrl) + { + + var r = new CntrItemRel + { + S_CNTR_CODE = item.S_CNTR_CODE, + S_ITEM_CODE = workOrder.SQL_ItemCode, + S_ITEM_NAME = workOrder.SQL_ItemName, + F_QTY = workOrder.SQL_UsingNowTotal, + S_ORDER_NO = workOrder.SQL_WorkNo, + S_BATCH_NO = workOrder.SQL_BatchNo + }; + RItem.Add(r); + var cntrrel = ContainerHelper.GetCntrItemRel(item.S_CNTR_CODE).FirstOrDefault(); + if (cntrrel != null) + { + newDb.Deleteable<CntrItemRel>().Where(it => it.S_ID.Trim() == cntrrel.S_ID.Trim()).ExecuteCommand(); + } + } + var ggf = newDb.Insertable(RItem).ExecuteCommand(); + if (ggf > 0) + { + int endLayer = endBit.N_CURRENT_NUM + 1; + var carryCntrs = new List<string> { _ctrl.FirstOrDefault().S_CNTR_CODE };//DateTime.Now.ToString("yyMMddHHmmss") }; + var bb = TaskProcess.CreateTransport(workOrder.SQL_WorkNo, location, endBit.S_LOC_CODE, "娉ㄥ婊℃墭-鍏ュ簱", carryCntrs, 1, endLayer, carryCntrs.Count, plc.taskPri); + if (bb) + { + SentTask = true; + //瑙﹀彂鑷姩瑙g粦 + //var zdjb = jcjykk.FindAll(e => e.SQL_UsingNow == "Y").OrderByDescending(g => g.N_PRI).ToList(); + //foreach (var item in zdjb) + //{ + + //} + //var Jb = newDb.Queryable<Location>().Where(e => e.S_AREA_CODE == Area && Row.Contains(e.N_ROW)).ToList(); + ////鏌ヨ绗竴鎺掓槸鍚︽弧 骞朵笖绗簩鎺掑叆婊′笁涓悗瑙g粦绗竴鎺�+ ////1.鏌ヨ绗竴鎺掓槸鍚︽湁绌鸿揣浣�鏈�鍒欒烦杩�+ } + } + } + if (SentTask) + { + return SentTask; + } + + } + return true; + } + } + catch (Exception ex) + { + LogHelper.Info(plc.deviceName + $" 鎶ラ敊: {ex.Message}"); + return false; + } + } + + /// <summary> + /// 鐡跺澂绠楁硶--鍑哄簱 + /// </summary> + /// <param name="AreaCode"></param> + /// <param name="Row"></param> + /// <param name="ItemCode"></param> + /// <returns></returns> + public static List<Location> GetOutWork(string AreaCode, List<int> Row, bool InOutLock = true, string ItemCode = "") + { + var lstCanOutL = new List<Location>(); + try + { + var chi = new SqlHelper<object>().GetInstance(); + var newDb = chi.CopyNew(); + var ca = Expressionable.Create<Location, LocCntrRel, CntrItemRel>(); + if (string.IsNullOrEmpty(ItemCode))//绠楃┖鎵� + { + ca.And((o, p, t) => o.N_CURRENT_NUM > 0 && o.S_LOCK_STATE == "鏃� && string.IsNullOrEmpty(t.S_ITEM_CODE) && o.S_AREA_CODE == AreaCode); + ca.AndIF(Row.Count() > 0, (o, p, t) => Row.Contains(o.N_ROW)); + lstCanOutL = newDb.Queryable<Location>().InnerJoin<LocCntrRel>((o, p) => o.S_LOC_CODE == p.S_LOC_CODE).LeftJoin<CntrItemRel>((o, p, t) => p.S_CNTR_CODE == t.S_CNTR_CODE).Where(ca.ToExpression()).ToList(); + } + else//绠楁弧鎵�+ { + ca.And((o, p, t) => o.N_CURRENT_NUM > 0 && o.S_LOCK_STATE == "鏃� && t.S_ITEM_CODE == ItemCode && o.S_AREA_CODE == AreaCode); + ca.AndIF(Row.Count() > 0, (o, p, t) => Row.Contains(o.N_ROW)); + lstCanOutL = newDb.Queryable<Location>().InnerJoin<LocCntrRel>((o, p) => o.S_LOC_CODE == p.S_LOC_CODE).InnerJoin<CntrItemRel>((o, p, t) => p.S_CNTR_CODE == t.S_CNTR_CODE).Where(ca.ToExpression()).ToList(); + } + //鍦板爢涓撻棬绠楁硶杩囨护 + if (lstCanOutL.Count() > 0) + { + var Inloca = Expressionable.Create<Location>(); + Inloca.And(it => it.S_AREA_CODE == AreaCode); + Inloca.AndIF(Row.Count() > 0, o => Row.Contains(o.N_ROW)); + var locationInLock = newDb.Queryable<Location>().Where(Inloca.ToExpression()).ToList(); + //绌洪棿閿�鎺掗櫎涓�暣鎺�+ var KjLick = locationInLock.FindAll(e => e.S_LOCK_STATE == "绌洪棿閿�).ToList(); + if (KjLick.Count() > 0) + { + foreach (var item in KjLick) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW); + } + } + if (InOutLock) + { + var CkLick = locationInLock.FindAll(e => e.S_LOCK_STATE == "鍑哄簱閿�).ToList(); + if (CkLick.Count() > 0) + { + foreach (var item in CkLick) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW); + } + } + var OutLick = locationInLock.FindAll(e => e.S_LOCK_STATE == "鍏ュ簱閿�).ToList(); + if (OutLick.Count() > 0) + { + foreach (var item in OutLick) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW); + } + } + } + + + } + return lstCanOutL; + } + catch (Exception ex) + { + LogHelper.Info("鐡跺澂绠楁硶" + $" 鎶ラ敊: {ex.Message}"); + return lstCanOutL; + } + } + + /// <summary> + /// 鐡跺澂绠楁硶--鍏ュ簱 + /// </summary> + /// <param name="AreaCode"></param> + /// <param name="Row"></param> + /// <param name="ItemCode"></param> + /// <returns></returns> + public static List<Location> GetInWork(string AreaCode, List<int> Row, bool InOutLock = true, string ItemCode = "") + { + var lstCanOutL = new List<Location>(); + try + { + lock (lockoIn) + { + var chi = new SqlHelper<object>().GetInstance(); + var newDb = chi.CopyNew(); + var ca = Expressionable.Create<Location, LocCntrRel, CntrItemRel>(); + ca.And((o, p, t) => o.N_CURRENT_NUM == 0 && o.S_LOCK_STATE == "鏃� && string.IsNullOrEmpty(p.S_CNTR_CODE) && string.IsNullOrEmpty(t.S_ITEM_CODE) && o.S_AREA_CODE == AreaCode); + ca.AndIF(Row.Count() > 0, (o, p, t) => Row.Contains(o.N_ROW)); + lstCanOutL = newDb.Queryable<Location>().LeftJoin<LocCntrRel>((o, p) => o.S_LOC_CODE == p.S_LOC_CODE).LeftJoin<CntrItemRel>((o, p, t) => p.S_CNTR_CODE == t.S_CNTR_CODE).Where(ca.ToExpression()).ToList(); + + var Inloca = Expressionable.Create<Location>(); + Inloca.And(it => it.S_AREA_CODE == AreaCode); + Inloca.AndIF(Row.Count() > 0, o => Row.Contains(o.N_ROW)); + var locationInLock = newDb.Queryable<Location>().Where(Inloca.ToExpression()).ToList(); + + //鍦板爢涓撻棬绠楁硶杩囨护 + if (lstCanOutL.Count() > 0) + { + //绌洪棿閿�鎺掗櫎涓�暣鎺�+ var KjLick = locationInLock.FindAll(e => e.S_LOCK_STATE == "绌洪棿閿�).ToList(); + if (KjLick.Count() > 0) + { + foreach (var item in KjLick) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW); + } + } + + //鑾峰彇鎸囧畾搴撳尯 鎸囧畾鎺�婊$殑璐т綅 鐒跺悗鎺掗櫎 姣旀渶澶у垪杩樺皬鐨勭┖璐т綅 + var Mhw = locationInLock.FindAll(e => e.N_CURRENT_NUM > 0).ToList(); + if (Mhw.Count() > 0) + { + var RowLis = Mhw.GroupBy(e => e.N_ROW).Select(f => f.First()).ToList(); + foreach (var item in RowLis) + { + var MaxCol = Mhw.FindAll(e => e.N_ROW == item.N_ROW).OrderByDescending(c => c.N_COL).FirstOrDefault(); + if (MaxCol != null) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW && e.N_COL < MaxCol.N_COL); + } + } + + //鎺掗櫎鍒殑鐗╂枡鎵�湪鐨勬帓 + if (!string.IsNullOrEmpty(ItemCode)) + { + var fzRow = Mhw.Select(e => e.N_ROW).Distinct().ToList(); + foreach (var item in fzRow) + { + var mtlo = Mhw.FindAll(e => e.N_ROW == item).FirstOrDefault(); + if (mtlo != null) + { + var _clrel = LocationHelper.GetLocCntrRel(mtlo.S_LOC_CODE).FirstOrDefault(); + if (_clrel != null) + { + var cntritems = ContainerHelper.GetCntrItemRel(_clrel.S_CNTR_CODE).FirstOrDefault(); + if (cntritems != null) + { + if (cntritems.S_ITEM_CODE != ItemCode) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == mtlo.S_AREA_CODE && e.N_ROW == mtlo.N_ROW); + } + } + } + + } + } + } + } + if (InOutLock) + { + var CkLick = locationInLock.FindAll(e => e.S_LOCK_STATE == "鍑哄簱閿�).ToList(); + if (KjLick.Count() > 0) + { + foreach (var item in KjLick) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW); + } + } + var OutLick = locationInLock.FindAll(e => e.S_LOCK_STATE == "鍏ュ簱閿�).ToList(); + if (KjLick.Count() > 0) + { + foreach (var item in KjLick) + { + lstCanOutL.RemoveAll(e => e.S_AREA_CODE == item.S_AREA_CODE && e.N_ROW == item.N_ROW); + } + } + } + } + return lstCanOutL; + } + } + catch (Exception ex) + { + LogHelper.Info("鐡跺澂绠楁硶" + $" 鎶ラ敊: {ex.Message}"); + return lstCanOutL; } } @@ -2721,7 +3123,6 @@ //灏辨煡鐪嬫湁娌℃湁绌虹殑鎺掍簡銆� //if (endBit != null) /// 瀵绘壘鏈弧鎺掞紝 鐩存帴杩斿洖缁撴灉銆� return endBit; - //LogHelper.Info(" _tempList over锛�); //杩欓噷寮� 瀵绘壘绌烘帓 Empty: @@ -3492,26 +3893,27 @@ } if (endBit == null && _tempList.Any()) { - LogHelper.Info(" ar_RplaceRow over锛�); - var ar_RplaceRows = LocationHelper.GetLocList(x => x.S_AREA_CODE != area1 && x.S_AREA_CODE.Contains(are) && x.S_LOCK_STATE != "鎶ュ簾");//.Select(x => x.N_ROW).Distinct(); - //var ar_RplaceRow1 = ar_RplaceRows.FindAll(x => x.S_LOCK_STATE != "鏃�).Select(x => x.N_ROW).Distinct(); - IEnumerable<int> ar_RplaceRow1 = ar_RplaceRows.FindAll(x => "鍏ュ簱閿�鍑哄簱閿�.Contains(x.S_LOCK_STATE?.Trim())).Select(x => x.N_ROW).Distinct(); - LogHelper.Info(" 鏈夐攣鎺�- " + JsonConvert.SerializeObject(ar_RplaceRow1)); //LogHelper.Info(" 鏈夐攣鎺�- " + JsonConvert.SerializeObject(ar_RplaceRow1)); - var ar_RplaceRow2 = ar_RplaceRows.FindAll(x => x.N_CURRENT_NUM > 0).Select(x => x.N_ROW).Distinct(); - LogHelper.Info(" 鏈夎揣鎺掞細 - " + JsonConvert.SerializeObject(ar_RplaceRow2)); - var ar_RplaceRow_rowlock = LocationHelper.GetRowLock(x => x.S_AREA_CODE.Contains(are))?.Select(x => x.N_ROW); + LogHelper.Info(" ar_RplaceRow over锛� + JsonConvert.SerializeObject(_tempList.Select(x => x.N_ROW).Distinct())); + //var ar_RplaceRows = LocationHelper.GetLocList(x => x.S_AREA_CODE != area1 && x.S_AREA_CODE.Contains(are) && x.S_LOCK_STATE != "鎶ュ簾");//.Select(x => x.N_ROW).Distinct(); + // //var ar_RplaceRow1 = ar_RplaceRows.FindAll(x => x.S_LOCK_STATE != "鏃�).Select(x => x.N_ROW).Distinct(); + //IEnumerable<int> ar_RplaceRow1 = ar_RplaceRows.FindAll(x => "鍏ュ簱閿�鍑哄簱閿�.Contains(x.S_LOCK_STATE?.Trim())).Select(x => x.N_ROW).Distinct(); + //LogHelper.Info(" 鏈夐攣鎺�- " + JsonConvert.SerializeObject(ar_RplaceRow1)); //LogHelper.Info(" 鏈夐攣鎺�- " + JsonConvert.SerializeObject(ar_RplaceRow1)); + //var ar_RplaceRow2 = ar_RplaceRows.FindAll(x => x.N_CURRENT_NUM > 0).Select(x => x.N_ROW).Distinct(); + //LogHelper.Info(" 鏈夎揣鎺掞細 - " + JsonConvert.SerializeObject(ar_RplaceRow2)); + //var ar_RplaceRow_rowlock = LocationHelper.GetRowLock(x => x.S_AREA_CODE.Contains(are))?.Select(x => x.N_ROW); - var ar_RplaceRow = ar_RplaceRow1.Concat(ar_RplaceRow2).Concat(ar_RplaceRow_rowlock).Distinct(); + //var ar_RplaceRow = ar_RplaceRow1.Concat(ar_RplaceRow2).Concat(ar_RplaceRow_rowlock).Distinct(); - if (ar_RplaceRow.Any()) - { - LogHelper.Info("鎺掗櫎闈炵┖鎺�- " + JsonConvert.SerializeObject(ar_RplaceRow)); - _tempList.RemoveAll(x => ar_RplaceRow.Contains(x.N_ROW)); - } - if (_tempList.Any())//涓変釜搴撳尯鐨勪氦闆嗙┖鎺�- { - endBit = _tempList.OrderBy(x => x.N_ROW).ThenBy(x => x.N_COL).FirstOrDefault(); - } + //if (ar_RplaceRow.Any()) + //{ + // LogHelper.Info("鎺掗櫎闈炵┖鎺�- " + JsonConvert.SerializeObject(ar_RplaceRow)); + // _tempList.RemoveAll(x => ar_RplaceRow.Contains(x.N_ROW)); + //} + //if (_tempList.Any())//涓変釜搴撳尯鐨勪氦闆嗙┖鎺�+ //{ + // endBit = _tempList.OrderBy(x => x.N_ROW).ThenBy(x => x.N_COL).FirstOrDefault(); + //} + endBit = _tempList.OrderBy(x => x.N_ROW).ThenBy(x => x.N_COL).FirstOrDefault(); } #endregion -- Gitblit v1.9.1