NoInteractionSystems.cs 38 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607
  1. using Newtonsoft.Json;
  2. using PlcSiemens.Core.Extension;
  3. using ServiceCenter.Extensions;
  4. using ServiceCenter.Logs;
  5. using ServiceCenter.SqlSugars;
  6. using SqlSugar;
  7. using System.ComponentModel;
  8. using WCS.Core;
  9. using WCS.Entity;
  10. using WCS.Entity.Protocol.Station;
  11. using WCS.WorkEngineering.Extensions;
  12. using WCS.WorkEngineering.WebApi.Controllers;
  13. using WCS.WorkEngineering.WebApi.Models.WMS.Request;
  14. using WCS.WorkEngineering.Worlds;
  15. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  16. using TaskStatus = WCS.Entity.TaskStatus;
  17. namespace WCS.WorkEngineering.Systems
  18. {
  19. /// <summary>
  20. /// 无交互系统
  21. /// </summary>
  22. [BelongTo(typeof(NoInteractionWorld))]
  23. [Description("无交互系统")]
  24. public class NoInteractionSystems : DeviceSystem<Device<IStation520>>
  25. {
  26. protected override bool ParallelDo => true;
  27. public override void Do(Device<IStation520> obj)
  28. {
  29. var taskInfos = new List<int>();
  30. var sqlSugar = new SqlSugarHelper();
  31. SqlSugarHelper.Do(db =>
  32. {
  33. //获取所有的新建任务,组盘任务不需要
  34. taskInfos = db.Default.Queryable<WCS_TaskInfo>().NoLock().Where(x => x.Status == 0).ToList()
  35. .Where(x => x.Type != TaskType.SetPlate || (x.Type == TaskType.SetPlate && x.AddrFrom != "Robot") && x.BusType!="芯股用空托盘入库" && !x.BarCode.Contains("Error")).Select(x => x.ID).ToList();
  36. var time = DateTime.Now.AddMinutes(-20);
  37. var time1 = DateTime.Now.AddMinutes(-40);
  38. var timeOut = db.Default.Queryable<WCS_TaskInfo>().NoLock().Count(x => x.BusType == "车间叫料" && x.Status < TaskStatus.StackerExecution && x.AddTime < time);
  39. if (timeOut > 0) World.Log($"共有{timeOut}个车间叫料任务超过二十分钟未执行,请检查相关相关任务对应的堆垛机是否正常、堆垛机放货点是否卡任务等", LogLevelEnum.High);
  40. var timeOut1 = db.Default.Queryable<WCS_TaskInfo>().NoLock().Count(x => x.BusType == "车间叫料" && x.Status < TaskStatus.StackerExecution && x.AddTime < time1);
  41. if (timeOut1 > 0) World.Log($"共有{timeOut1}个车间叫料任务超过四十分钟未执行,请检查相关相关任务对应的堆垛机是否正常、堆垛机放货点是否卡任务等", LogLevelEnum.High);
  42. var timeOut2 = db.Default.Queryable<WCS_TaskInfo>().NoLock().Count(x => x.BusType == "皮盘入库" && x.Status < TaskStatus.StackerExecution && x.AddTime < time);
  43. if (timeOut2 > 0) World.Log($"共有{timeOut2}个皮盘入库任务超过二十分钟未执行,请检查相关相关任务及对应agv设备", LogLevelEnum.High);
  44. var timeOut3 = db.Default.Queryable<WCS_TaskInfo>().NoLock().Count(x => x.BusType == "皮盘入库" && x.Status < TaskStatus.StackerExecution && x.AddTime < time1);
  45. if (timeOut3 > 0) World.Log($"共有{timeOut3}个皮盘入库任务超过四十分钟未执行,请检查相关相关任务及对应agv设备", LogLevelEnum.High);
  46. var time3 = DateTime.Now.AddHours(-24);
  47. var timeOut4 = db.Default.Queryable<BillInvnow>().NoLock().Count(x => x.AddTime < time3 && x.ContGrpBarCode.Contains("TPB"));
  48. if (timeOut4 > 0) World.Log($"共有{timeOut4}个库存信息超过24小时未执行,请检查相关库存信息并处理", LogLevelEnum.High);
  49. var time4 = DateTime.Now.AddHours(-12);
  50. var timeOut5 = db.Default.Queryable<WCS_Palletizing>().NoLock().Where(x => x.AddTime < time4 && !x.Finish).ToList();
  51. if (timeOut5.Count > 0) World.Log($"共有{timeOut5.Count}个桁架码垛信息超过12小时未结束,请检查相关码垛信息并处理,具体在{JsonConvert.SerializeObject(timeOut5.Select(x=>x.PalletizingStation).ToList())}", LogLevelEnum.High);
  52. });
  53. if (!taskInfos.Any())
  54. {
  55. return;
  56. }
  57. var isEnd = false; //每个周期只处理一个任务
  58. foreach (var item in taskInfos)
  59. {
  60. if (isEnd) return;
  61. try
  62. {
  63. SqlSugarHelper.Do(db =>
  64. {
  65. var task = db.Default.Queryable<WCS_TaskInfo>().RowLock().Where(t => t.ID == item && t.Status== TaskStatus.NewBuild).First();
  66. switch (task.Type)
  67. {
  68. case TaskType.SetPlate:
  69. if (task.AddrFrom != "Robot")
  70. {
  71. //更新任务状态
  72. task.Status = TaskStatus.WaitingToExecute;
  73. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status }).ExecuteCommand();
  74. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化入库任务信息");
  75. isEnd = true;
  76. }
  77. break;
  78. case TaskType.EnterDepot:
  79. if (task.LastInteractionPoint == "2")
  80. {
  81. var sta = GetAgvStation(task, db);
  82. var agv = new WCS_AgvTaskInfo()
  83. {
  84. ID = db.GetAgvTaskId(),
  85. TaskType = AGVTaskType.EnterDepot,
  86. Status = AGVTaskStatus.NewBuild,
  87. TaskId = task.ID,
  88. Position = task.WorkBench,
  89. Station = sta,
  90. AddWho = "WCS",
  91. AddTime = DateTime.Now
  92. };
  93. db.Default.InsertableRowLock(agv).SplitTable().ExecuteCommand();
  94. task.AgvTaskID = agv.ID;
  95. task.Status = Entity.TaskStatus.WaitingToExecute;
  96. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status, x.AgvTaskID }).ExecuteCommand();
  97. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化单独返皮盘任务");
  98. }
  99. else if (task.BusType == TaskBusType.芯股用空托盘入库.GetDescription()) return;
  100. else if (task.BusType == TaskBusType.人工满托入库.GetDescription())
  101. {
  102. var agv = new WCS_AgvTaskInfo()
  103. {
  104. ID = db.GetAgvTaskId(),
  105. TaskType = AGVTaskType.EnterDepot,
  106. Status = AGVTaskStatus.NewBuild,
  107. TaskId = task.ID,
  108. Position = task.WorkBench,
  109. Station = task.WarehouseCode switch
  110. {
  111. "1N" => "2535",
  112. "1S" => "2735",
  113. "2N" => "2935",
  114. "2S" => "3135",
  115. _ => "2535"
  116. },
  117. AddWho = "WCS",
  118. AddTime = DateTime.Now
  119. };
  120. db.Default.InsertableRowLock(agv).SplitTable().ExecuteCommand();
  121. task.AgvTaskID = agv.ID;
  122. task.Device = task.WarehouseCode switch
  123. {
  124. "1N" => "TY1",
  125. "1S" => "TY2",
  126. "2N" => "TY3",
  127. "2S" => "TY4",
  128. _ => "TY1"
  129. };
  130. task.Height = 1;
  131. task.Status = Entity.TaskStatus.WaitingToExecute;
  132. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status, x.AgvTaskID, x.Device, x.Height }).ExecuteCommand();
  133. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化人工满托入库任务");
  134. }
  135. else if (task.BusType == TaskBusType.UT人工满托入库.GetDescription())
  136. {
  137. var agv = new WCS_AgvTaskInfo()
  138. {
  139. ID = db.GetAgvTaskId(),
  140. TaskType = AGVTaskType.EnterDepot,
  141. Status = AGVTaskStatus.NewBuild,
  142. TaskId = task.ID,
  143. Position = task.WorkBench,
  144. Station = task.WarehouseCode switch
  145. {
  146. "1N" => "2533",
  147. "1S" => "2733",
  148. "2N" => "2933",
  149. "2S" => "3133",
  150. _ => "2533"
  151. },
  152. AddWho = "WCS",
  153. AddTime = DateTime.Now
  154. };
  155. db.Default.InsertableRowLock(agv).SplitTable().ExecuteCommand();
  156. task.AgvTaskID = agv.ID;
  157. task.Device = task.WarehouseCode switch
  158. {
  159. "1N" => "TY1",
  160. "1S" => "TY2",
  161. "2N" => "TY3",
  162. "2S" => "TY4",
  163. _ => "TY1"
  164. };
  165. task.Height = 1;
  166. task.Status = Entity.TaskStatus.WaitingToExecute;
  167. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status, x.AgvTaskID, x.Device, x.Height }).ExecuteCommand();
  168. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化UT人工满托入库任务");
  169. }
  170. else if (task.BusType == TaskBusType.重绕满托入库.GetDescription())
  171. {
  172. task.Status = Entity.TaskStatus.WaitingToExecute;
  173. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status }).ExecuteCommand();
  174. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化入库任务信息");
  175. }
  176. else if (task.BusType == TaskBusType.帘线退料重绕.GetDescription())
  177. {
  178. var agv = new WCS_AgvTaskInfo()
  179. {
  180. ID = db.GetAgvTaskId(),
  181. TaskType = AGVTaskType.EnterDepot,
  182. Status = AGVTaskStatus.NewBuild,
  183. TaskId = task.ID,
  184. Position = task.WorkBench,
  185. WorkShop = 222,
  186. Station = "9001",
  187. AddWho = "WCS",
  188. AddTime = DateTime.Now
  189. };
  190. db.Default.InsertableRowLock(agv).SplitTable().ExecuteCommand();
  191. task.Status = Entity.TaskStatus.WaitingToExecute;
  192. task.AgvTaskID = agv.ID;
  193. task.AddrTo = agv.Station;
  194. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status,x.AgvTaskID,x.AddrTo }).ExecuteCommand();
  195. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化入库任务信息");
  196. }
  197. else
  198. {
  199. //更新任务状态
  200. task.Status = Entity.TaskStatus.WaitingToExecute;
  201. task.Device = task.WarehouseCode switch
  202. {
  203. "1N" => "SRM1",
  204. "1S" => "SRM2",
  205. "2N" => "SRM3",
  206. "2S" => "SRM4",
  207. "3N" => "SRM5",
  208. "3S" => "SRM6",
  209. _ => task.Device
  210. };
  211. task.Device = task.AddrFrom switch
  212. {
  213. "1666" or "1661" => "SRM1",
  214. "1681" or "1676" => "SRM2",
  215. "1696" or "1691" => "SRM3",
  216. "1711" or "1706" => "SRM4",
  217. "1726" or "1721" => "SRM5",
  218. "1741" or "1736" => "SRM6",
  219. _ => task.Device
  220. };
  221. //计算下一个地址
  222. var path1 = DevicePath.GetPath(task.AddrFrom, task.Device);
  223. task.AddrNext = path1.Points[1].Code;
  224. task.SrmStation = task.BarCode.Contains("TPA") || task.BarCode.Contains("TPB") ? task.AddrFrom : path1.Points[2].Code;
  225. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status, x.Device, x.AddrNext, x.SrmStation }).ExecuteCommand();
  226. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化入库任务信息");
  227. }
  228. isEnd = true;
  229. break;
  230. case TaskType.OutDepot:
  231. {
  232. if (task.Device.Contains("Robot")) //机器人任务
  233. {
  234. var lastTask = db.Default.Queryable<WCS_TaskInfo>().NoLock().First(x => x.Type == TaskType.OutDepot && x.AddrTo == task.AddrTo && x.Status > TaskStatus.WaitingToExecute && x.Status < TaskStatus.Finish);
  235. if (lastTask != null)
  236. {
  237. World.Log($"等待任务结束:{task.AddrTo}上一组码垛任务未结束,等待{lastTask.ID}任务完成后开始初始化当前任务{task.ID}");
  238. return;
  239. }
  240. var pos = task.AddrFrom.Split("-");
  241. task.Status = Entity.TaskStatus.WaitingToExecute;
  242. task.Line = pos[0].ToShort();
  243. task.Col = pos[1].ToShort();
  244. task.Layer = pos[2].ToShort();
  245. task.Depth = pos[3].ToShort();
  246. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.Status, x.Line, x.Col, x.Layer, x.Depth }).ExecuteCommand();
  247. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化出库任务信息,放货站台:{task.SrmStation}");
  248. isEnd = true;
  249. }
  250. else if (task.Device == "FJXG") //芯股仓库的任务
  251. {
  252. if (task.LastInteractionPoint != "3") //车间叫料任务,此值为3时是单独取满任务
  253. {
  254. var sta = GetAgvStation(task, db); //芯股任务,取货站台就是芯股站台
  255. var agv = new WCS_AgvTaskInfo()
  256. {
  257. ID = db.GetAgvTaskId(),
  258. TaskType = AGVTaskType.EnterDepot,
  259. Status = AGVTaskStatus.NewBuild,
  260. TaskId = task.ID,
  261. Position = task.WorkBench,
  262. Station = sta,
  263. AddWho = "WCS",
  264. AddTime = DateTime.Now
  265. };
  266. db.Default.InsertableRowLock(agv).SplitTable().ExecuteCommand();
  267. }
  268. var agvId = DateTime.Now.GetFormat(GetFormatterEnum.only) + task.ID;
  269. var agvTask = new WCS_AgvTaskInfo()
  270. {
  271. ID = db.GetAgvTaskId(),
  272. TaskType = AGVTaskType.CallMaterial,
  273. Status = AGVTaskStatus.NewBuild,
  274. TaskId = task.ID,
  275. Position = task.WorkBench,
  276. Station = task.AddrFrom,
  277. AddWho = "WCS",
  278. AddTime = DateTime.Now,
  279. AgvID = agvId
  280. };
  281. //开始处理车间叫料AGV任务任务
  282. db.Default.InsertableRowLock(agvTask).SplitTable().ExecuteCommand();
  283. agvTask = db.Default.Queryable<WCS_AgvTaskInfo>().RowLock().SplitTable(x => x.Take(2)).Single(x => x.TaskId == task.ID && x.TaskType == AGVTaskType.CallMaterial);
  284. if (agvTask.Status != AGVTaskStatus.NewBuild)
  285. {
  286. World.Log($"AGV任务{agvTask.ID}状态不是新建", LogLevelEnum.High);
  287. return;
  288. }
  289. agvId = agvTask.AgvID;
  290. agvTask.Status = AGVTaskStatus.Confirm;
  291. agvTask.AgvStatus = AGVTaskStatus.Confirm;
  292. db.Default.UpdateableRowLock(agvTask).UpdateColumns(x => new { x.AgvID, x.Status, x.AgvStatus }).SplitTable(x => x.Take(2)).ExecuteCommand();
  293. task.Status = TaskStatus.AGVExecution;
  294. task.AgvTaskID = agvTask.ID;
  295. task.EditTime = DateTime.Now;
  296. task.EditWho = "WCS";
  297. db.Default.Updateable(task).UpdateColumns(x => new { x.Status, x.AgvTaskID, x.EditTime, x.EditWho }).ExecuteCommand();
  298. task.AddWCS_TASK_DTL(db.Default, task.AddrFrom, "AGV", $"任务下发至AGV{agvId}");
  299. var res = AgvApi.机台叫料(task.AddrFrom, task.WorkBench, agvId);
  300. isEnd = true;
  301. }
  302. else if (task.BusType == TaskBusType.芯股站台送空托.GetDescription())
  303. {
  304. if (task.SrmStation == "1")
  305. {
  306. var srmStation = new string[2];
  307. switch (task.Device)
  308. {
  309. case "SRM1":
  310. srmStation[0] = "2534";
  311. srmStation[1] = "2533";
  312. break;
  313. case "SRM2":
  314. srmStation[0] = "2734";
  315. srmStation[1] = "2733";
  316. break;
  317. case "SRM3":
  318. srmStation[0] = "2934";
  319. srmStation[1] = "2933";
  320. break;
  321. case "SRM4":
  322. srmStation[0] = "3134";
  323. srmStation[1] = "3133";
  324. break;
  325. case "SRM5":
  326. srmStation[0] = "3334";
  327. srmStation[1] = "3333";
  328. break;
  329. case "SRM6":
  330. srmStation[0] = "3534";
  331. srmStation[1] = "3533";
  332. break;
  333. }
  334. //开始计算当前这个任务要从哪个站台出
  335. //计算两个站台小于取货完成数量的AGV任务
  336. var agv1 = db.Default.Queryable<WCS_TaskInfo>().NoLock().Where(x => x.Status <= TaskStatus.StackerExecution && x.AddrTo == srmStation[0]).Count();
  337. var agv2 = db.Default.Queryable<WCS_TaskInfo>().NoLock().Where(x => x.Status <= TaskStatus.StackerExecution && x.AddrTo == srmStation[1]).Count();
  338. task.SrmStation = "";
  339. //if (srmStation[0] == "2534"/* || srmStation[0] == "2934"*/)
  340. //{
  341. // task.AddrTo = srmStation[0];
  342. //}
  343. //else
  344. {
  345. task.AddrTo = agv1 > agv2 ? srmStation[1] : srmStation[0];
  346. }
  347. }
  348. if (task.SrmStation.IsNullOrEmpty()) //如果没有指定放货站台
  349. {
  350. if (task.Device.IsNullOrEmpty())
  351. {
  352. task.Device = "SRM" + task.Tunnel.GetLastDigit();
  353. }
  354. //获取堆垛机到目标地址的路径信息
  355. var path = DevicePath.GetPath(task.Device, task.AddrTo);
  356. task.SrmStation = path.Points[1].Code;
  357. }
  358. //更新任务状态
  359. task.Status = Entity.TaskStatus.WaitingToExecute;
  360. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.SrmStation, x.AddrTo, x.Status }).ExecuteCommand();
  361. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化出库任务信息,放货站台:{task.SrmStation}");
  362. isEnd = true;
  363. }
  364. else if (task.Device == "CR")
  365. {
  366. if (task.LastInteractionPoint != "3") //车间叫料任务,此值为3时是单独取满任务
  367. {
  368. //var sta = GetAgvStation(task, db);
  369. var agv = new WCS_AgvTaskInfo()
  370. {
  371. ID = db.GetAgvTaskId(),
  372. TaskType = AGVTaskType.EnterDepot,
  373. Status = AGVTaskStatus.NewBuild,
  374. TaskId = task.ID,
  375. Position = task.WorkBench,
  376. Station = "2501",//默认去分拣一
  377. AddWho = "WCS",
  378. AddTime = DateTime.Now
  379. };
  380. db.Default.InsertableRowLock(agv).SplitTable().ExecuteCommand();
  381. }
  382. //更新任务状态
  383. task.Status = Entity.TaskStatus.WaitingToExecute;
  384. task.AddrTo = task.WorkBench;
  385. db.Default.UpdateableRowLock(task).UpdateColumns(x => new {x.Status , x.AddrTo }).ExecuteCommand();
  386. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化出库任务信息,重绕组盘区{task.AddrFrom}");
  387. isEnd = true;
  388. break;
  389. }
  390. else //立库出库任务
  391. {
  392. if (task.SrmStation == "1")
  393. {
  394. var srmStation = new string[2];
  395. switch (task.Device)
  396. {
  397. case "SRM1":
  398. srmStation[0] = "2534";
  399. srmStation[1] = "2533";
  400. break;
  401. case "SRM2":
  402. srmStation[0] = "2734";
  403. srmStation[1] = "2733";
  404. break;
  405. case "SRM3":
  406. srmStation[0] = "2934";
  407. srmStation[1] = "2933";
  408. break;
  409. case "SRM4":
  410. srmStation[0] = "3134";
  411. srmStation[1] = "3133";
  412. break;
  413. case "SRM5":
  414. srmStation[0] = "3334";
  415. srmStation[1] = "3333";
  416. break;
  417. case "SRM6":
  418. srmStation[0] = "3534";
  419. srmStation[1] = "3533";
  420. break;
  421. }
  422. //开始计算当前这个任务要从哪个站台出
  423. //计算两个站台小于取货完成数量的AGV任务
  424. var agv1 = db.Default.Queryable<WCS_TaskInfo>().NoLock().Where(x => x.Status <= TaskStatus.StackerExecution && x.AddrTo == srmStation[0]).Count();
  425. var agv2 = db.Default.Queryable<WCS_TaskInfo>().NoLock().Where(x => x.Status <= TaskStatus.StackerExecution && x.AddrTo == srmStation[1]).Count();
  426. task.SrmStation = "";
  427. //if (srmStation[0] == "2534"/* || srmStation[0] == "2934"*/)
  428. //{
  429. // task.AddrTo = srmStation[0];
  430. //}
  431. //else
  432. {
  433. task.AddrTo = agv1 > agv2 ? srmStation[1] : srmStation[0];
  434. }
  435. }
  436. if (task.SrmStation.IsNullOrEmpty()) //如果没有指定放货站台
  437. {
  438. if (task.Device.IsNullOrEmpty())
  439. {
  440. task.Device = "SRM" + task.Tunnel.GetLastDigit();
  441. }
  442. //获取堆垛机到目标地址的路径信息
  443. var path = DevicePath.GetPath(task.Device, task.AddrTo);
  444. task.SrmStation = path.Points[1].Code;
  445. }
  446. var devs = Device.All.Where(x => x.HasFlag(DeviceFlags.AGV取货站台口)).Select(x => x.Code);
  447. if (devs.Contains(task.SrmStation) && task.LastInteractionPoint != "3") //车间叫料任务,此值为3时是单独取满任务
  448. {
  449. var sta = GetAgvStation(task, db);
  450. var agv = new WCS_AgvTaskInfo()
  451. {
  452. ID = db.GetAgvTaskId(),
  453. TaskType = AGVTaskType.EnterDepot,
  454. Status = AGVTaskStatus.NewBuild,
  455. TaskId = task.ID,
  456. Position = task.WorkBench,
  457. Station = sta,
  458. AddWho = "WCS",
  459. AddTime = DateTime.Now
  460. };
  461. db.Default.InsertableRowLock(agv).SplitTable().ExecuteCommand();
  462. }
  463. //更新任务状态
  464. task.Status = Entity.TaskStatus.WaitingToExecute;
  465. db.Default.UpdateableRowLock(task).UpdateColumns(x => new { x.SrmStation, x.AddrTo, x.Status }).ExecuteCommand();
  466. task.AddWCS_TASK_DTL(db.Default, task.Device, $"初始化出库任务信息,放货站台:{task.SrmStation}");
  467. isEnd = true;
  468. }
  469. break;
  470. }
  471. case TaskType.Delivery:
  472. break;
  473. case TaskType.EmptyInit:
  474. break;
  475. }
  476. });
  477. }
  478. catch (Exception ex)
  479. {
  480. if (ex.Message.Contains("Index")) World.Log($"{ex.Message}:{ex.StackTrace}");
  481. if (ex.Message.Contains("SqlTransaction")) World.Log($"{ex.Message}:{ex.StackTrace}");
  482. World.Log(ex.Message, LogLevelEnum.Mid);
  483. }
  484. }
  485. }
  486. public override bool Select(Device dev)
  487. {
  488. return dev.Code == nameof(NoInteractionSystems);
  489. }
  490. /// <summary>
  491. /// 获取AGV的目标站台
  492. /// </summary>
  493. /// <param name="task"></param>
  494. /// <param name="db"></param>
  495. /// <returns></returns>
  496. public string GetAgvStation(WCS_TaskInfo task, SqlSugarHelper db)
  497. {
  498. string sta = "";
  499. var n = 0;
  500. var s = 0;
  501. var warehouseCode = task.WarehouseCode;
  502. if (task.BusType == TaskBusType.皮盘入库.GetDescription() || task.BusType == TaskBusType.车间叫料.GetDescription())
  503. {
  504. warehouseCode = task.MaterialCode switch
  505. {
  506. "分拣库1北" => "1N",
  507. "分拣库1南" => "1S",
  508. "分拣库2北" => "2N",
  509. "分拣库2南" => "2S",
  510. "分拣库3北" => "3N",
  511. "分拣库3南" => "3S",
  512. _ => task.WarehouseCode
  513. };
  514. }
  515. //同侧之间均分
  516. if (warehouseCode.Contains("1"))
  517. {
  518. n = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v => v.Status >= AGVTaskStatus.Confirm && v.Status < AGVTaskStatus.Complete1 && v.TaskType == AGVTaskType.EnterDepot && v.Station.StartsWith("25"))
  519. .SplitTable(v => v.Take(2)).Count();
  520. s = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v => v.Status >= AGVTaskStatus.Confirm && v.Status < AGVTaskStatus.Complete1 && v.TaskType == AGVTaskType.EnterDepot && v.Station.StartsWith("27"))
  521. .SplitTable(v => v.Take(2)).Count();
  522. sta = n > s ? "2701" : "2501";
  523. }
  524. else if (warehouseCode.Contains("2"))
  525. {
  526. n = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v => v.Status >= AGVTaskStatus.Confirm && v.Status < AGVTaskStatus.Complete1 && v.TaskType == AGVTaskType.EnterDepot && v.Station.StartsWith("29"))
  527. .SplitTable(v => v.Take(2)).Count();
  528. s = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v => v.Status >= AGVTaskStatus.Confirm && v.Status < AGVTaskStatus.Complete1 && v.TaskType == AGVTaskType.EnterDepot && v.Station.StartsWith("31"))
  529. .SplitTable(v => v.Take(2)).Count();
  530. sta = n > s ? "3101" : "2901";
  531. }
  532. else if (warehouseCode.Contains("3"))
  533. {
  534. n = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v => v.Status >= AGVTaskStatus.Confirm && v.Status < AGVTaskStatus.Complete1 && v.TaskType == AGVTaskType.EnterDepot && v.Station.StartsWith("33"))
  535. .SplitTable(v => v.Take(2)).Count();
  536. s = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v => v.Status >= AGVTaskStatus.Confirm && v.Status < AGVTaskStatus.Complete1 && v.TaskType == AGVTaskType.EnterDepot && v.Station.StartsWith("35"))
  537. .SplitTable(v => v.Take(2)).Count();
  538. sta = n > s ? "3501" : "3301";
  539. }
  540. else
  541. {
  542. return default;
  543. }
  544. n = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v =>
  545. v.Status >= AGVTaskStatus.Confirm &&
  546. v.Status < AGVTaskStatus.Complete1 &&
  547. v.TaskType == AGVTaskType.EnterDepot && v.Station == sta)
  548. .SplitTable(v => v.Take(2)).Count();
  549. //任务数量配置
  550. int num = 5;
  551. var config = db.Default.Queryable<fjSysConfig>().NoLock().First(x => x.Code == "SameSideTaskNum");
  552. if (config != null)
  553. {
  554. num = config.SContent.ToInt();
  555. }
  556. if (n > num)
  557. {
  558. sta = db.Default.Queryable<WCS_AgvTaskInfo>().NoLock().Where(v => v.Status >= AGVTaskStatus.Confirm && v.Status < AGVTaskStatus.Complete1 && v.TaskType == AGVTaskType.EnterDepot
  559. && (v.Station != "2535" && v.Station != "2735" && v.Station != "2935" && v.Station != "3135" && !v.Station.StartsWith("9")))//过滤掉人工满托入库和重绕区任务
  560. .SplitTable(v => v.Take(2)).ToList().GroupBy(x => x.Station).Select(x => new { x.Key, Count = x.Count() }).MinBy(x => x.Count).Key;
  561. }
  562. return sta;
  563. }
  564. }
  565. }