机器人抓取.cs 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. using NetTaste;
  2. using Newtonsoft.Json;
  3. using NPOI.SS.Formula.PTG;
  4. using Org.BouncyCastle.Bcpg;
  5. using ServiceCenter.SqlSugars;
  6. using SqlSugar;
  7. using System;
  8. using System.Collections.Generic;
  9. using System.ComponentModel;
  10. using System.Linq;
  11. using System.Text;
  12. using System.Threading.Tasks;
  13. using WCS.Core;
  14. using WCS.Entity;
  15. using WCS.Entity.Protocol.Protocol.Robot;
  16. using WCS.Entity.Protocol.Robot;
  17. using WCS.Entity.Protocol.Station;
  18. using WCS.WorkEngineering.Extensions;
  19. using WCS.WorkEngineering.WebApi.Models.WCS.Request;
  20. using WCS.WorkEngineering.Worlds;
  21. using static ICSharpCode.SharpZipLib.Zip.ExtendedUnixData;
  22. namespace WCS.WorkEngineering.Systems
  23. {
  24. [BelongTo(typeof(RobotWorld))]
  25. [Description("机器人抓取")]
  26. public class 机器人抓取 : DeviceSystem<Device<IRobot520, IRobot521, IRobot522>>
  27. {
  28. protected override bool ParallelDo => false;
  29. private Device<IStation521, IRobot531>[] PalletStations;
  30. public 机器人抓取()
  31. {
  32. var arr = Device.All.Where(v => v.HasProtocol<IStation521>() && v.HasFlag("装箱码垛") && v.HasFlag("位置", "码垛")).ToArray();
  33. PalletStations = arr.Select(v => new Device<IStation521, IRobot531>(v, this.World)).ToArray();
  34. }
  35. public override void Do(Device<IRobot520, IRobot521, IRobot522> obj)
  36. {
  37. if (obj.Data.VoucherNo != obj.Data2.VoucherNo)
  38. {
  39. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "凭证号不一样,不允许做新的交互", Time = DateTime.Now }));
  40. return;
  41. }
  42. if (obj.Data2.Mode != RobotMode.自动)
  43. {
  44. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "不是自动模式", Time = DateTime.Now }));
  45. return;
  46. }
  47. if (obj.Data2.Alarm != 0)
  48. {
  49. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "有报警,请先解决报警", Time = DateTime.Now }));
  50. World.Log($"{obj.Data3.Alarm}");
  51. return;
  52. }
  53. World.Log($"码垛任务下发{obj.Entity.Code}交互开始时间:一个周期" + DateTime.Now.ToString("yyyyMMddHHmmss"));
  54. if (obj.Data2.Rqst == RobotRqst.抓取完成)
  55. {
  56. var tasks = new int[] { obj.Data2.Task1, obj.Data2.Task2, obj.Data2.Task3 }.Take(obj.Data2.TaskQty).ToArray();
  57. if (tasks.Any(v => v == 0) || tasks.Length == 0)
  58. {
  59. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "抓取完成时任务号有误", Time = DateTime.Now }));
  60. throw new Exception("抓取完成时任务号有误");
  61. }
  62. var res = WMS.抓取完成(tasks, obj.Data2.AddrTo.ToString());
  63. if (!res.Success)
  64. {
  65. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "码垛绑定失败," + res.ResMsg, Time = DateTime.Now }));
  66. throw new Exception("码垛绑定失败," + res.ResMsg);
  67. }
  68. SqlSugarHelper.Do(db =>
  69. {
  70. var arr = db.Default.Queryable<WCS_TaskInfo>().Where(v => tasks.Contains(v.ID)).ToArray();
  71. foreach (var task in arr)
  72. {
  73. if (task.Status != Entity.TaskStatus.码垛抓取中)
  74. {
  75. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = $"{obj.Entity.Code},任务{task.ID}状态有误", Time = DateTime.Now }));
  76. throw new Exception($"任务{task.ID}状态有误");
  77. }
  78. task.Status = Entity.TaskStatus.码垛抓取完成;
  79. task.EditTime = DateTime.Now;
  80. db.Default.Updateable(task).ExecuteCommand();
  81. task.AddWCS_TASK_DTL(db.Default, obj.Data2.AddrTo.ToString(), "码垛抓取完成");
  82. }
  83. if (obj.Data.VoucherNo == -1)
  84. {
  85. obj.Data.Cmd = RobotCmd.抓取完成确认;
  86. obj.Data.VoucherNo = 1;
  87. }
  88. else
  89. {
  90. obj.Data.Cmd = RobotCmd.抓取完成确认;
  91. obj.Data.VoucherNo++;
  92. }
  93. });
  94. return;
  95. }
  96. if (obj.Data2.Status != RobotRunStatus.空闲)
  97. return;
  98. var temp = PalletStations.Where(v => v.Entity.HasFlag("Robot", obj.Entity.Code))
  99. .Where(v => v.Data.TaskNumber > 0 && v.Data.TaskNumber == v.Data2.PalletID).ToArray();
  100. if (temp.Length == 0)
  101. {
  102. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "码垛位状态未就绪", Time = DateTime.Now }));
  103. World.Log("码垛位状态未就绪");
  104. return;
  105. }
  106. var temp2 = temp.Select(v => new { PalletStation = v, QtyLeft = v.Data2.MaxQty - v.Data2.Qty, PickStation = Device.All.Where(d => d.HasFlag("装箱码垛") && d.HasFlag("位置", "抓取") && d.HasFlag("码垛工位", v.Entity.Code)).First() }).ToArray();
  107. var temp3 = temp2.Select(v => new { v.PalletStation, v.QtyLeft, v.PickStation, Arr = Device.All.Where(d => d.HasFlag("装箱码垛") && d.HasFlag("Parent", v.PickStation.Code)).Select(d => d.Protocol<IStation521>(this.World)).ToArray() }).ToArray();
  108. var stArr = temp3.Select(v => new { v.PalletStation, v.QtyLeft, v.PickStation, Tasks = v.Arr.Select(d => d.TaskNumber).Where(d => d > 10000).ToArray() })
  109. .Where(v => v.Tasks.Length > 0).ToArray();
  110. if (stArr.Length == 0)
  111. {
  112. World.Log("抓取位空");
  113. return;
  114. }
  115. SqlSugarHelper.Do(db =>
  116. {
  117. foreach (var item in stArr.OrderBy(v => v.QtyLeft))
  118. {
  119. var stCode = item.PalletStation.Entity.Code;
  120. if (!item.PickStation.Protocol<IStation523>(this.World).Status.HasFlag(StationStatus.自动))
  121. {
  122. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = $"{item.PickStation.Code}不在自动模式", Time = DateTime.Now }));
  123. World.Log($"{item.PickStation.Code}不在自动模式", ServiceCenter.Logs.LogLevelEnum.High);
  124. continue;
  125. }
  126. try
  127. {
  128. var flag = db.Default.Queryable<WCS_TaskInfo>().Where(v => v.AddrTo == item.PalletStation.Entity.Code && v.Status == Entity.TaskStatus.码垛抓取中).Any();
  129. if (flag)
  130. {
  131. World.Log($"{stCode}有正在抓取中的任务");
  132. continue;
  133. }
  134. var p = db.Default.Queryable<Palletizing>().Where(v => v.TaskNum == item.PalletStation.Data.TaskNumber).Where(v => v.PalletizState == 0).First();
  135. if (p == null)
  136. {
  137. World.Log($"{stCode}托盘无码垛数据", ServiceCenter.Logs.LogLevelEnum.High);
  138. MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = $"{stCode}托盘无码垛数据", Time = DateTime.Now }));
  139. continue;
  140. }
  141. if (item.Tasks.Distinct().Count() < 3)
  142. {
  143. if (p.Count >= p.Finish)
  144. continue;
  145. var qty = db.Default.Queryable<WCS_TaskInfo>().Where(v => v.Type == TaskType.OutDepot && v.BusType == "装箱码垛")
  146. .Where(v => v.Status >= Entity.TaskStatus.码垛缓存放行 && v.Status <= Entity.TaskStatus.码垛缓存扫码).Count();
  147. if (qty > item.Tasks.Length)
  148. {
  149. World.Log($"{stCode}有额外货物已缓存放行");
  150. }
  151. }
  152. var rc = db.Default.Updateable<WCS_TaskInfo>()
  153. .SetColumns(v => new WCS_TaskInfo { Status = Entity.TaskStatus.码垛抓取中, EditTime = SqlFunc.GetDate() })
  154. .Where(v => item.Tasks.Contains(v.ID))
  155. .Where(v => v.Status == Entity.TaskStatus.码垛抓取扫码)
  156. .ExecuteCommand();
  157. if (rc != item.Tasks.Length)
  158. {
  159. if (db.Default.Updateable<WCS_TaskInfo>().SetColumns(v => new WCS_TaskInfo { Status = Entity.TaskStatus.码垛抓取中, EditTime = SqlFunc.GetDate() })
  160. .Where(v => item.Tasks.Contains(v.ID)).ExecuteCommand() > 0)
  161. {
  162. World.Log($"{stCode}触发任务状态重复修改机制", ServiceCenter.Logs.LogLevelEnum.High);
  163. }
  164. else
  165. {
  166. World.Log($"{stCode}修改任务状态失败,", ServiceCenter.Logs.LogLevelEnum.High);
  167. continue;
  168. }
  169. }
  170. obj.Data.GoodsType = (short)p.GoodsType;
  171. obj.Data.AddrFrom = short.Parse(item.PickStation.Code);
  172. obj.Data.AddrTo = short.Parse(item.PalletStation.Entity.Code);
  173. obj.Data.TaskQty = (short)item.Tasks.Length;
  174. obj.Data.Task1 = item.Tasks[0];
  175. if (item.Tasks.Length > 1)
  176. obj.Data.Task2 = item.Tasks[1];
  177. else
  178. obj.Data.Task2 = 0;
  179. if (item.Tasks.Length > 2)
  180. obj.Data.Task3 = item.Tasks[2];
  181. else
  182. obj.Data.Task3 = 0;
  183. if (obj.Data.VoucherNo == -1)
  184. {
  185. obj.Data.Cmd = RobotCmd.抓取;
  186. obj.Data.VoucherNo = 1;
  187. }
  188. else
  189. {
  190. obj.Data.Cmd = RobotCmd.抓取;
  191. obj.Data.VoucherNo++;
  192. }
  193. break;
  194. }
  195. catch (Exception ex)
  196. {
  197. World.Log($"{stCode}异常:{ex.Message}");
  198. }
  199. }
  200. });
  201. World.Log($"码垛任务下发{obj.Entity.Code}交互结束时间:一个周期" + DateTime.Now.ToString("yyyyMMddHHmmss"));
  202. }
  203. public override bool Select(Device dev)
  204. {
  205. return dev.Code is "Robot1" or "Robot2";
  206. }
  207. }
  208. }