AgvSystems.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. using PlcSiemens.Core.Extension;
  2. using ServiceCenter.Logs;
  3. using ServiceCenter.SqlSugars;
  4. using System.ComponentModel;
  5. using WCS.Core;
  6. using WCS.Entity;
  7. using WCS.Entity.Protocol.Station;
  8. using WCS.WorkEngineering.Extensions;
  9. using WCS.WorkEngineering.WebApi.Controllers;
  10. using WCS.WorkEngineering.Worlds;
  11. using TaskStatus = WCS.Entity.TaskStatus;
  12. namespace WCS.WorkEngineering.Systems
  13. {
  14. /// <summary>
  15. /// Agv交互系统
  16. /// </summary>
  17. [BelongTo(typeof(MainWorld))]
  18. [Description("Agv交互系统")]
  19. public class AgvSystems : DeviceSystem<Device<IStation520>>
  20. {
  21. protected override bool ParallelDo => true;
  22. protected override bool SaveLogsToFile => true;
  23. public AgvSystems()
  24. {
  25. }
  26. public override void Do(Device<IStation520> obj)
  27. {
  28. if (obj.Entity.Code == "2534")
  29. {
  30. var agvTaskInfos = new List<WCS_AgvTaskInfo>();
  31. //获取所有未结束的叫料及背负式补空AGV任务
  32. SqlSugarHelper.Do(db =>
  33. {
  34. agvTaskInfos = db.Default.Queryable<WCS_AgvTaskInfo>().Where(v => v.TaskType == AGVTaskType.CallMaterial)
  35. .Where(v => v.Status < AGVTaskStatus.MissionCompleted)
  36. .SplitTable(tabs => tabs.Take(2)).OrderBy(v => v.AddTime).ToList();
  37. });
  38. //有需要处理的AGV任务
  39. if (agvTaskInfos.Any())
  40. {
  41. this.ExRecord(obj.Entity.Code, "可用出库AGV任务列表", agvTaskInfos.Select(v => v.ID).ToList());
  42. var taskInfos = new List<WCS_TaskInfo>();
  43. foreach (var agv in agvTaskInfos)
  44. {
  45. try
  46. {
  47. SqlSugarHelper.Do(db =>
  48. {
  49. switch (agv.AgvStatus)
  50. {
  51. //取货点安全交互
  52. case AGVTaskStatus.RequestOrPermission2 when agv.Status != AGVTaskStatus.RequestOrPermission2:
  53. {
  54. var taskInfo = db.Default.Queryable<WCS_TaskInfo>().First(v => v.ID == agv.TaskId);
  55. agv.Status = AGVTaskStatus.RequestOrPermission2;
  56. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  57. taskInfo.AddWCS_TASK_DTL(db.Default, "agv", $"允许AGV任务{agv.ID}在站台{agv.Station}取货");
  58. AgvApi.ContinueTask(agv.AgvID, agv.Station);
  59. break;
  60. }
  61. case AGVTaskStatus.PutRequestOrPermission when agv.Status != AGVTaskStatus.PutRequestOrPermission:
  62. {
  63. agv.Status = AGVTaskStatus.PutRequestOrPermission;
  64. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  65. AgvApi.ContinueTask(agv.AgvID, agv.Station);
  66. break;
  67. }
  68. case AGVTaskStatus.LeaveGet when agv.Status != AGVTaskStatus.LeaveGet:
  69. var devinfo = new Device<IStation520>(Device.All.First(x => x.Code == agv.Station), World);
  70. devinfo.Data.CmdType = StationCmd.Res3;
  71. agv.Status = AGVTaskStatus.LeaveGet;
  72. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  73. break;
  74. //完成任务
  75. case AGVTaskStatus.MissionCompleted when agv.Status != AGVTaskStatus.MissionCompleted:
  76. {
  77. if (agv.TaskType is AGVTaskType.CallForMaterial or AGVTaskType.ForkliftFilling or AGVTaskType.CallMaterial)
  78. {
  79. var taskInfo = db.Default.Queryable<WCS_TaskInfo>().First(v => v.AgvTaskID == agv.ID);
  80. if (taskInfo == null) throw new Exception($"未找到AGV任务{agv.ID}对应WCS任务");
  81. //更新AGV任务状态
  82. agv.Status = AGVTaskStatus.MissionCompleted;
  83. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  84. //更新WCS任务状态
  85. taskInfo.Status = Entity.TaskStatus.Finish;
  86. taskInfo.EedTime = DateTime.Now;
  87. db.Default.Updateable(taskInfo).ExecuteCommand();
  88. taskInfo.AddWCS_TASK_DTL(db.Default, "agv", "任务完成");
  89. taskInfos.Add(taskInfo);
  90. }
  91. else
  92. {
  93. agv.Status = AGVTaskStatus.MissionCompleted;
  94. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  95. }
  96. break;
  97. }
  98. }
  99. });
  100. }
  101. catch (Exception ex)
  102. {
  103. World.Log(ex.Message, LogLevelEnum.Mid);
  104. this.ExRecord(obj.Entity.Code, ex.Message);
  105. }
  106. }
  107. foreach (var taskInfo in taskInfos.Where(taskInfo => taskInfo.Status == TaskStatus.Finish))
  108. {
  109. WmsApi.CompleteTask(taskInfo.ID);
  110. }
  111. }
  112. }
  113. else if (obj.Entity.Code == "2533")
  114. {
  115. List<WCS_AgvTaskInfo> agvTaskInfos = new List<WCS_AgvTaskInfo>();
  116. //获取所有未结束的入库AGV任务
  117. SqlSugarHelper.Do(db =>
  118. {
  119. agvTaskInfos = db.Default.Queryable<WCS_AgvTaskInfo>()
  120. .Where(v => v.Status < AGVTaskStatus.MissionCompleted && v.TaskType == AGVTaskType.EnterDepot)
  121. .SplitTable(tabs => tabs.Take(2)).OrderBy(v => v.EditTime).ToList();
  122. });
  123. if (agvTaskInfos.Any())
  124. {
  125. this.ExRecord(obj.Entity.Code, "可用入库AGV任务列表", agvTaskInfos.Select(v => v.ID).ToList());
  126. foreach (var agv in agvTaskInfos)
  127. {
  128. try
  129. {
  130. SqlSugarHelper.Do(db =>
  131. {
  132. #region 开始跟据AGV状态做出处理
  133. switch (agv.AgvStatus)
  134. {
  135. case AGVTaskStatus.NewBuild when agv.Status == AGVTaskStatus.NewBuild:
  136. AgvApi.托盘回库(agv.Position, agv.ID.ToString());
  137. agv.AgvID = agv.ID.ToString();
  138. agv.Status = AGVTaskStatus.Confirm;
  139. agv.AgvStatus = AGVTaskStatus.Confirm;
  140. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  141. break;
  142. //巷道分配
  143. case AGVTaskStatus.RequestOrPermission1 when agv.Status != AGVTaskStatus.Complete1:
  144. {
  145. agv.Status = AGVTaskStatus.Complete1;
  146. agv.Position = "2501";
  147. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  148. //task.Status = TaskStatus.Finish;
  149. //db.Default.Updateable(task).ExecuteCommand();
  150. //task.AddWCS_TASK_DTL(db.Default, "AGV搬运任务分配放货点", agv.Position, $"任务分配至:{agv.Position}");
  151. //调继续执行任务接口
  152. AgvApi.ContinueTask(agv.AgvID, agv.Position);
  153. //}
  154. break;
  155. }
  156. //取货站点安全交互
  157. case AGVTaskStatus.RequestOrPermission2 when agv.Status != AGVTaskStatus.RequestOrPermission2:
  158. {
  159. if (agv.Position.IsNullOrEmpty()) throw new Exception($"无有效放货地址");
  160. var dev = Device.All.First(x => x.Code == agv.Position);
  161. //调继续执行任务接口
  162. AgvApi.ContinueTask(agv.AgvID, dev.Code);
  163. break;
  164. }
  165. case AGVTaskStatus.LeavePut when agv.Status != AGVTaskStatus.LeavePut:
  166. var devinfo = new Device<IStation520, IStation521>(Device.All.First(x => x.Code == agv.Position), World);
  167. devinfo.Data.CmdType = StationCmd.Res2;
  168. break;
  169. //完成任务
  170. case AGVTaskStatus.MissionCompleted when agv.Status != AGVTaskStatus.MissionCompleted:
  171. if (agv.TaskType == AGVTaskType.EnterDepot)
  172. {
  173. agv.Status = AGVTaskStatus.MissionCompleted;
  174. db.Default.Updateable(agv).SplitTable(x=>x.Take(2)).ExecuteCommand();
  175. }
  176. break;
  177. }
  178. #endregion 开始跟据AGV状态做出处理
  179. });
  180. }
  181. catch (Exception ex)
  182. {
  183. World.Log(ex.Message, LogLevelEnum.Mid);
  184. this.ExRecord(obj.Entity.Code, ex.Message);
  185. }
  186. }
  187. }
  188. }
  189. }
  190. public override bool Select(Device dev)
  191. {
  192. return dev.Code is "2534" or "2533";
  193. }
  194. }
  195. }