组盘缓存生成AGV任务.cs 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. using Microsoft.OpenApi.Extensions;
  2. using ServiceCenter.Extensions;
  3. using ServiceCenter.Logs;
  4. using ServiceCenter.SqlSugars;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.ComponentModel;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using WCS.Core;
  12. using WCS.Entity;
  13. using WCS.Entity.Protocol.Station;
  14. using WCS.WorkEngineering.Extensions;
  15. using WCS.WorkEngineering.WebApi.Controllers;
  16. using WCS.WorkEngineering.WebApi.Models.WMS.Response;
  17. using WCS.WorkEngineering.Worlds;
  18. using TaskStatus = WCS.Entity.TaskStatus;
  19. namespace WCS.WorkEngineering.Systems.重绕区
  20. {
  21. /// <summary>
  22. /// 组盘缓存生成AGV任务
  23. /// </summary>
  24. [BelongTo(typeof(RewindWorld))]
  25. [Description("组盘缓存生成AGV任务")]
  26. public class 组盘缓存生成AGV任务 : DeviceSystem<Device<IStation520, IStation521, IStation523>>
  27. {
  28. protected override bool ParallelDo => true;
  29. public override void Do(Device<IStation520, IStation521, IStation523> obj)
  30. {
  31. if (!obj.Data3.Status.HasFlag(StationStatus.Auto))
  32. {
  33. World.Log($"设备处于{obj.Data3.Status.GetDisplayName()}状态");
  34. return;
  35. }
  36. if (!obj.Data3.Status.HasFlag(StationStatus.PH_Status))
  37. {
  38. World.Log($"设备无光电");
  39. return;
  40. }
  41. SqlSugarHelper.Do(_db =>
  42. {
  43. var db = _db.Default;
  44. var task = db.Queryable<WCS_TaskInfo>().ReadPastUpdLock().Single(x => x.Status == TaskStatus.ConveyorExecution && x.ID == obj.Data2.TaskNumber);
  45. if (task == null)
  46. {
  47. World.Log($"未找到对应任务[{obj.Data2.TaskNumber}],请检查该任务状态与更新状态是否均为输送机执行中", LogLevelEnum.High);
  48. return;
  49. }
  50. var agvId = DateTime.Now.GetFormat(GetFormatterEnum.only) + task.ID;
  51. //开始创建AGV任务
  52. var agvTask = db.Queryable<WCS_AgvTaskInfo>().RowLock().SplitTable(x => x.Take(2)).Single(x => x.TaskId == task.ID && x.TaskType == AGVTaskType.EnterDepot);
  53. if (agvTask == null)
  54. {
  55. db.InsertableRowLock(new WCS_AgvTaskInfo()
  56. {
  57. ID = _db.GetAgvTaskId(),
  58. TaskType = AGVTaskType.EnterDepot,
  59. Status = AGVTaskStatus.NewBuild,
  60. TaskId = task.ID,
  61. Position = obj.Entity.Code,
  62. Station = task.SrmStation,
  63. WorkShop = 111,
  64. AddWho = "WCS",
  65. AddTime = DateTime.Now,
  66. AgvID = agvId
  67. }).SplitTable().ExecuteCommand();
  68. World.Log($"{task.ID}未找到对应的AGV任务");
  69. return;
  70. }
  71. if (agvTask.Status != AGVTaskStatus.NewBuild)
  72. {
  73. World.Log($"AGV任务{agvTask.ID}状态不是新建", LogLevelEnum.High);
  74. return;
  75. }
  76. //分配缓存货位 暂时先根据光电判断
  77. List<string> cacheWells = new List<string> { "9201", "9202", "9203", "9204", "9205", "9206", "9207", "9208", "9209","9210","9211","9212",
  78. "9213","9214","9215",/*"9216","9217","9218","9219","9220","9221","9222","9223","9224"*/};
  79. var devs = Device.All.Where(x => cacheWells.Contains(x.Code)).Select(x =>
  80. new Device<IStation520, IStation521, IStation523>(x, World));
  81. if (!devs.Any()) return;
  82. string sta = "";
  83. if (!devs.Any(v => !v.Data3.Status.HasFlag(StationStatus.PH_Status))) return;
  84. foreach (var dev in devs)
  85. {
  86. if (!dev.Data3.Status.HasFlag(StationStatus.PH_Status) && !db.Queryable<WCS_AgvTaskInfo>().RowLock().SplitTable(x => x.Take(2)).Any(x => x.Station == dev.Entity.Code && x.TaskType == AGVTaskType.EnterDepot
  87. && x.Status < AGVTaskStatus.MissionCompleted))
  88. {
  89. var res = WmsApi.GetFlatLocalIn(obj.Data2.TaskNumber,"T1",dev.Entity.Code,1);
  90. if (res.ResCode == ResponseStatusCodeEnum.Sucess && res.ResData.CellNo == dev.Entity.Code)
  91. {
  92. sta = dev.Entity.Code;
  93. }
  94. else if (res.ResCode == ResponseStatusCodeEnum.Sucess)
  95. {
  96. sta = res.ResData.CellNo;
  97. World.Log($"{dev.Entity.Code}分配货位{res.ResData.CellNo}");
  98. }
  99. else
  100. {
  101. continue;
  102. }
  103. break;
  104. //sta = dev.Entity.Code;
  105. //break;
  106. }
  107. }
  108. agvId = agvTask.AgvID;
  109. if (sta == "") return;
  110. agvTask.Status = AGVTaskStatus.Confirm;
  111. agvTask.AgvStatus = AGVTaskStatus.Confirm;
  112. agvTask.Station = sta;
  113. db.UpdateableRowLock(agvTask).UpdateColumns(x => new { x.AgvID, x.Status, x.AgvStatus, x.Station }).SplitTable(x => x.Take(2)).ExecuteCommand();
  114. task.Status = TaskStatus.AGVExecution;
  115. task.AgvTaskID = agvTask.ID;
  116. task.EditTime = DateTime.Now;
  117. task.EditWho = "WCS";
  118. task.AddrFrom = obj.Entity.Code;
  119. task.AddrTo = agvTask.Station;
  120. db.Updateable(task).UpdateColumns(x => new { x.Status, x.AgvTaskID, x.EditTime, x.EditWho,x.AddrFrom, x.AddrTo }).ExecuteCommand();
  121. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "AGV", $"任务下发至AGV{agvId},目标缓存货位{agvTask.Station}");
  122. AgvApi.组盘入库(obj.Entity.Code, agvTask.Station, agvId);
  123. });
  124. }
  125. public override bool Select(Device dev)
  126. {
  127. return dev.Code is "9126";
  128. }
  129. }
  130. }