二楼入库工位处理系统.cs 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. using ServiceCenter.SqlSugars;
  2. using System.ComponentModel;
  3. using WCS.Core;
  4. using WCS.Entity;
  5. using WCS.Entity.Protocol.BCR;
  6. using WCS.Entity.Protocol.Station;
  7. using WCS.WorkEngineering.Extensions;
  8. using WCS.WorkEngineering.WebApi.Controllers;
  9. using WCS.WorkEngineering.Worlds;
  10. using WCS.WorkEngineering.Worlds.Logs;
  11. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  12. namespace WCS.WorkEngineering.Systems
  13. {
  14. /// <summary>
  15. /// 二楼入库工位处理系统
  16. /// </summary>
  17. [BelongTo(typeof(MainWorld))]
  18. [Description("二楼入库工位处理系统")]
  19. public class 二楼入库工位处理系统 : DeviceSystem<Station>
  20. {
  21. protected override bool ParallelDo => true;
  22. protected override bool SaveLogsToFile => true;
  23. private List<BCR> BCRS = new List<BCR>();
  24. public 二楼入库工位处理系统()
  25. {
  26. BCRS = Device.All.Where(v => v.HasProtocol<IBCR81>()).Select(v => new BCR(v, World)).ToList();
  27. }
  28. public override void Do(Station obj)
  29. {
  30. obj.StorageStationIsForbid();
  31. //判断凭证号是否一致
  32. if (obj.Data.VoucherNo != obj.Data2.VoucherNo) throw new KnownException($"凭证号不一致,DB520:{obj.Data.VoucherNo}-DB521{obj.Data2.VoucherNo}", LogLevelEnum.High);
  33. //设备是否停止运行
  34. if (obj.Data3.Status.HasFlag(StatusEunm.Run)) throw new KnownException("设备运行中", LogLevelEnum.Low);
  35. if (!obj.Data3.Status.HasFlag(StatusEunm.PH_Status)) throw new KnownException("没有光电", LogLevelEnum.Low);
  36. if (obj.Data2.TaskNumber != 0) throw new KnownException("有任务", LogLevelEnum.Low);
  37. if (obj.Data2.Request != 1) throw new KnownException("没有请求", LogLevelEnum.Low);
  38. WCS_TaskInfo task = null;
  39. var result = SqlSugarHelper.Do(db =>
  40. {
  41. if (obj.Entity.Code == "1025")
  42. {
  43. var taskInfo = db.Default.Queryable<WCS_TaskInfo>().First(v => v.SrmStation == "1025" && v.Device == "SRM3" && v.Type == TaskType.EmptyInit && v.Status == Entity.TaskStatus.WaitingToExecute);
  44. if (taskInfo != null)
  45. {
  46. task = taskInfo;
  47. if (task.Type != TaskType.EmptyInit && task.Status != Entity.TaskStatus.WaitingToExecute) throw new KnownException($"任务:{task.ID}状态不是AGV执行中,请检查异常原因", LogLevelEnum.High);
  48. }
  49. }
  50. if (task == null)
  51. {
  52. //跟据RFID获取对应的任务
  53. task = db.Default.Queryable<WCS_TaskInfo>().First(v => v.BarCode == obj.Entity.Code) ?? throw new KnownException($"未找到任务号:{obj.Entity.Code}对应WCS任务", LogLevelEnum.High);
  54. if (task.Status != Entity.TaskStatus.AGVExecution) throw new KnownException($"任务:{task.ID}状态不是AGV执行中,请检查异常原因", LogLevelEnum.High);
  55. }
  56. if (obj.Entity.Code == "1025")
  57. {
  58. //获取称重
  59. var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
  60. task.Weight = dev91.Data.Weight;
  61. WmsApi.WcsUploadInfo(task.ID, (decimal)task.Weight, task.BarCode);
  62. }
  63. task.Status = Entity.TaskStatus.ConveyorExecution;
  64. db.Default.Updateable(task).AddQueue();
  65. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货");
  66. db.Default.SaveQueues();
  67. });
  68. if (task == null || !result) throw new KnownException("数据更新错误", LogLevelEnum.High);
  69. obj.Data.TaskNumber = task.ID;
  70. }
  71. public override bool Select(Device dev)
  72. {
  73. //return dev.Code == "1025";
  74. return dev.HasFlag(DeviceFlags.一楼入库口);
  75. }
  76. }
  77. }