月台扫码.cs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. using DBHelper;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. using WCS.Core;
  8. using WCS.Entity;
  9. using WCS.Entity.Protocol;
  10. using WCS.Service.Extensions;
  11. namespace WCS.Service.Works.Stations
  12. {
  13. [WorkTitle(typeof(ProductHandler), "月台扫码")]
  14. class 月台扫码:DeviceWork<Device<IStation521, IStation520>>
  15. {
  16. protected override bool SelectDevice(WCS.Entity.WCS_DEVICE dev)
  17. {
  18. return dev.Is(DF.扫码) && dev.CODE == "2265";
  19. }
  20. protected override void Do(Device<IStation521, IStation520> dev)
  21. {
  22. if (Ltc.Do(dev, v => v.Data2.CONFIRM == true))
  23. {
  24. return;
  25. }
  26. if (Ltc.Do(dev, v => !v.Data.REQUEST))
  27. return;
  28. var bcrDev = Device.Find("BCR" + dev.Entity.CODE);
  29. var bcr = bcrDev.PROTOCOLS.First().Data<IBCR80>();
  30. var barcode = bcr.CONTENT.Trim('\r');
  31. if (Ltc.Do(barcode, barcode => string.IsNullOrEmpty(barcode)))
  32. {//扫码失败,退回
  33. dev.Data2.TASKNUM = dev.Data.TASKNUM;
  34. dev.Data2.GOODSEND = -1;
  35. dev.Data2.CONFIRM = true;
  36. return;
  37. }
  38. var rgv = dev.Entity.ROUTES.Select(v => v.NEXT).Where(v => v.IsRGV()).FirstOrDefault();
  39. var arr = rgv.ROUTES.Select(v => v.NEXT).Where(v => v.ROUTES.Any(d => d.NEXT.IsTunnel())).ToArray();
  40. var endStations = arr.Select(v => v.Device<IStation521, IStation520>()).ToArray();
  41. endStations = Ltc.Do(endStations, arr => arr.Where(v => v.Data.TASKNUM == 0 && v.Data.PH_STATUS == false).ToArray());
  42. endStations = endStations.Where(v => v.Data.TASKNUM == 0 && !v.Data.PH_STATUS).ToArray();
  43. if (endStations.Length == 0)
  44. {
  45. return;
  46. }
  47. //if (Ltc.Do(dev, v => !v.Entity.WakeupOn(10000, "月台扫码")))
  48. // return;
  49. var resp = WMS.InBound(barcode, dev.Entity.CODE, true);
  50. var target = resp.TunnelNum.Split(',').Select(v => endStations.FirstOrDefault(d => d.Entity.TunnelNum().ToString() == v))
  51. .Where(v => v != null)
  52. .Select(v => new { Conv = v, SC = v.Entity.ROUTES.First().NEXT.ROUTES.Where(v => v.NEXT.IsSC()).First().NEXT.Device<ISC521>() })
  53. .OrderBy(v => v.Conv.Entity.TunnelNum() == 2 ? 0 : 1)
  54. .ThenBy(v=> {
  55. try
  56. {
  57. return v.SC.Data.Tunnel == v.Conv.Entity.TunnelNum() ? 0 : 1;
  58. }
  59. catch
  60. {
  61. return 99;
  62. }
  63. })
  64. .Select(v => v.Conv)
  65. .FirstOrDefault();
  66. if (target == null)
  67. {
  68. throw new Exception("路径计算失败");
  69. }
  70. DB.Do(db =>
  71. {
  72. var task = new WCS_TASK
  73. {
  74. TYPE = TaskType.入库,
  75. STATUS = WCS.Entity.TaskStatus.执行中,
  76. BARCODE = barcode,
  77. TUNNEL = target.Entity.Tunnel(),
  78. ADDRFROM = dev.Entity.CODE,
  79. WMSTASK = int.Parse(resp.WMSTaskNum),
  80. UPDATETIME = DateTime.Now,
  81. UPDATEUSER = "WCS",
  82. ADDRTO = target.Entity.CODE,
  83. FLOOR = 1,
  84. //ADDRCURRENT = dev.Entity.CODE
  85. };
  86. db.Default.Set<WCS_TASK>().Add(task);
  87. db.Default.SaveChanges();
  88. dev.Data2.GOODSEND = target.Entity.Code();
  89. dev.Data2.TASKNUM = task.ID;
  90. dev.Data2.CONFIRM = true;
  91. task.CreateStatusLog(db, $"任务下发输送机[{dev.Entity.CODE}]执行,起始地址[{dev.Entity.CODE}],目标地址[{target.Entity.CODE}]");
  92. });
  93. }
  94. }
  95. }