|
@@ -8,6 +8,7 @@ using WCS.Entity.Protocol;
|
|
|
using WCS.Entity.Protocol.SRM;
|
|
|
using WCS.Service.Extensions;
|
|
|
using WCS.Service.Helpers;
|
|
|
+using WCS.Service.Log;
|
|
|
|
|
|
namespace WCS.Service.Works.Station
|
|
|
{
|
|
@@ -80,76 +81,90 @@ namespace WCS.Service.Works.Station
|
|
|
|
|
|
protected override void Do(StationDeviceGroup obj)
|
|
|
{
|
|
|
- var code = obj.Entity.CODE;
|
|
|
- //当前组有一个运行的设备就停止执行
|
|
|
- if (obj.WhetherToExecute()) return;
|
|
|
-
|
|
|
- //获取需要进行巷道分配的设备
|
|
|
- var devs = obj.TaskedDeviceGetNextAddress() ?? throw new Exception(LogHelper.SpliceLogMessage("无可用任务", obj.Entity.CODE, WCS_EXCEPTIONTYPE.逻辑异常, GetType()));
|
|
|
-
|
|
|
- DB.Do(db =>
|
|
|
+ try
|
|
|
{
|
|
|
- var taskIds = devs.Select(p => p.Data2.Tasknum);
|
|
|
- var tasks = db.Default.Set<WCS_TASK>().Where(p => taskIds.Any(v => v == p.ID)).ToList();
|
|
|
- var res = WMS.GetTunnelList(tasks.Select(v => v.WMSTASK.ToString()).ToList(), code);
|
|
|
- if (string.IsNullOrEmpty(res.TunnelNum)) throw new Exception(LogHelper.SpliceLogMessage($"WMS未返回巷道", obj.Entity.CODE, WCS_EXCEPTIONTYPE.逻辑异常, GetType()));
|
|
|
- var tunnelNo = res.TunnelNum.Split(',').Select(v => "TY" + v).ToList();
|
|
|
-
|
|
|
- var tunnels = Device.Where(v => tunnelNo.Contains(v.CODE)).ToList();
|
|
|
-
|
|
|
- List<TunnelInfo> tunnelInfos = new List<TunnelInfo>();
|
|
|
- foreach (var item in tunnels)
|
|
|
+ var code = obj.Entity.CODE;
|
|
|
+ //当前组有一个运行的设备就停止执行
|
|
|
+ foreach (var item in obj.Items)
|
|
|
{
|
|
|
- //当前巷道的取货点
|
|
|
- var allIn = Device.Where(v => v.Is(DF.一楼SRM取货)) //一楼所有取货点
|
|
|
- .Where(v => v.ROUTES.Any(p => p.NEXT == item)) //下一个点为当前巷道的取货点
|
|
|
- .Select(v => v.CODE)
|
|
|
- .ToList();
|
|
|
- var q = Device.Where(v => v.IsConv() && v.ROUTES.Any(p => allIn.Contains(p.NEXT.CODE))) //下一个目标地址包含取货点的设备
|
|
|
- .Select(v => v.Create<StationDevice>()) //取所有可以到达取货点设备的信息
|
|
|
- .Where(v => !v.Data3.Status.HasFlag(StationStatus.运行状态位) && !v.Data2.Status.HasFlag(IstationStatus.光电状态) && v.Data2.Tasknum < 10000)//筛选出空闲的路径点,此处因输送机都是一个动力,因此可以先找路径点再找设备组
|
|
|
- .Distinct()
|
|
|
- .FirstOrDefault();//去一次重
|
|
|
- if (q == null) continue;
|
|
|
- var dev = Device.Where(p => p.CODE.StartsWith("G") && p.DEVICEGROUP.Any(d => d.MEMBER == q.Entity)).OrderBy(p => p.CODE).FirstOrDefault();
|
|
|
-
|
|
|
- tunnelInfos.Add(new TunnelInfo
|
|
|
- {
|
|
|
- Tunnel = item,
|
|
|
- taskIN = dev, //找到放货点设备所在组
|
|
|
- SRM = Device.Where(p => p.IsSC()).FirstOrDefault(p => item.ROUTES.Any(d => d.NEXT.CODE == p.CODE)).Create<SRMDevice>()
|
|
|
- });
|
|
|
+ var dev = Device.Find(item.Entity.CODE).Create<StationDevice>();
|
|
|
+ if (dev.Data.VoucherNo != dev.Data2.VoucherNo) return;
|
|
|
+ if (dev.Data3.Status.HasFlag(StationStatus.运行状态位)) return;
|
|
|
+ if (!dev.Data2.Status.HasFlag(IstationStatus.光电状态)) return;
|
|
|
+ if (dev.Data2.Tasknum > 10000 && dev.Data2.Request != IstationRequest.请求分配目标地址) return;
|
|
|
}
|
|
|
- //筛选出优先级最高的可用巷道
|
|
|
- var tunnelInfo = tunnelInfos.Where(v => { try { return v.SRM.Data3.SCAlarm == 0 && v.SRM.Data2.SRMMode == SCMode.远程 && v.SRM.Data2.SRMStatus == SCRunStatus.空闲; } catch { return false; } })
|
|
|
- .OrderBy(v => tunnelNo.IndexOf(v.Tunnel.CODE)).FirstOrDefault();
|
|
|
- if (tunnelInfo == null) throw new Exception(LogHelper.SpliceLogMessage("无可用巷道", obj.Entity.CODE, WCS_EXCEPTIONTYPE.逻辑异常, GetType()));
|
|
|
|
|
|
- //开始向设备中写入任务信息
|
|
|
- foreach (var dev in devs)
|
|
|
+ //获取需要进行巷道分配的设备
|
|
|
+ var devs = obj.TaskedDeviceGetNextAddress() ?? throw new Exception(LogHelper.SpliceLogMessage("无可用任务", obj.Entity.CODE, WCS_EXCEPTIONTYPE.逻辑异常, GetType()));
|
|
|
+
|
|
|
+ DB.Do(db =>
|
|
|
{
|
|
|
- var task = tasks.FirstOrDefault(p => p.ID == dev.Data2.Tasknum);
|
|
|
- if ((task.TaskGroupKey.Contains($"{task.WMSTASK}_") || task.TaskGroupKey.Contains($"_{task.WMSTASK}"))) continue;
|
|
|
- if (dev.Data2.Goodsend != task.ADDRNEXT.ToShort()) continue;
|
|
|
- dev.Data.Tasknum = task.ID;
|
|
|
- dev.Data.Goodsstart = Conv_1030.ToShort();
|
|
|
- dev.Data.Goodsend = tunnelInfo.taskIN.CODE.Replace("G", "").ToShort();
|
|
|
- dev.Data.CmdType = IstationCmdType.分配目标地址;
|
|
|
- dev.Data.VoucherNo++;
|
|
|
-
|
|
|
- task.DEVICE = tunnelInfo.SRM.Entity.CODE;
|
|
|
- task.TUNNEL = tunnelInfo.Tunnel.CODE;
|
|
|
- task.ADDRNEXT = dev.Data.Goodsend.ToString();
|
|
|
- task.TaskGroupKey = res.WMSTaskGroupKey;
|
|
|
- task.ADDRTO = task.DEVICE;
|
|
|
- db.Default.SaveChanges();
|
|
|
-
|
|
|
- var msg = $"下达从{Conv_1030}移动至{dev.Data.Goodsend}的PLC指令。同时将任务分配至[{ task.TUNNEL }]-[{task.DEVICE}]";
|
|
|
- msg += $"[{dev.Data.Tasknum}][{Conv_1030}][{dev.Data.Goodsend}][{tunnelInfo.SRM.Entity.CODE}][{dev.Data.VoucherNo}[{dev.Data2.VoucherNo}]";
|
|
|
-
|
|
|
- task.CreateStatusLog(db, msg, this.GetType());
|
|
|
- }
|
|
|
- });
|
|
|
+ var taskIds = devs.Select(p => p.Data2.Tasknum);
|
|
|
+ var tasks = db.Default.Set<WCS_TASK>().Where(p => taskIds.Any(v => v == p.ID)).ToList();
|
|
|
+ var res = WMS.GetTunnelList(tasks.Select(v => v.WMSTASK.ToString()).ToList(), code);
|
|
|
+ if (string.IsNullOrEmpty(res.TunnelNum)) throw new Exception(LogHelper.SpliceLogMessage($"WMS未返回巷道", obj.Entity.CODE, WCS_EXCEPTIONTYPE.逻辑异常, GetType()));
|
|
|
+ var tunnelNo = res.TunnelNum.Split(',').Select(v => "TY" + v).ToList();
|
|
|
+
|
|
|
+ var tunnels = Device.Where(v => tunnelNo.Contains(v.CODE)).ToList();
|
|
|
+
|
|
|
+ List<TunnelInfo> tunnelInfos = new List<TunnelInfo>();
|
|
|
+ foreach (var item in tunnels)
|
|
|
+ {
|
|
|
+ //当前巷道的取货点
|
|
|
+ var allIn = Device.Where(v => v.Is(DF.一楼SRM取货)) //一楼所有取货点
|
|
|
+ .Where(v => v.ROUTES.Any(p => p.NEXT == item)) //下一个点为当前巷道的取货点
|
|
|
+ .Select(v => v.CODE)
|
|
|
+ .ToList();
|
|
|
+ var q = Device.Where(v => v.IsConv() && v.ROUTES.Any(p => allIn.Contains(p.NEXT.CODE))) //下一个目标地址包含取货点的设备
|
|
|
+ .Select(v => v.Create<StationDevice>()) //取所有可以到达取货点设备的信息
|
|
|
+ .Where(v => !v.Data3.Status.HasFlag(StationStatus.运行状态位) && !v.Data2.Status.HasFlag(IstationStatus.光电状态) && v.Data2.Tasknum < 10000)//筛选出空闲的路径点,此处因输送机都是一个动力,因此可以先找路径点再找设备组
|
|
|
+ .Distinct()
|
|
|
+ .FirstOrDefault();//去一次重
|
|
|
+ if (q == null) continue;
|
|
|
+ var dev = Device.Where(p => p.CODE.StartsWith("G") && p.DEVICEGROUP.Any(d => d.MEMBER == q.Entity)).OrderBy(p => p.CODE).FirstOrDefault();
|
|
|
+
|
|
|
+ tunnelInfos.Add(new TunnelInfo
|
|
|
+ {
|
|
|
+ Tunnel = item,
|
|
|
+ taskIN = dev, //找到放货点设备所在组
|
|
|
+ SRM = Device.Where(p => p.IsSC()).FirstOrDefault(p => item.ROUTES.Any(d => d.NEXT.CODE == p.CODE)).Create<SRMDevice>()
|
|
|
+ });
|
|
|
+ }
|
|
|
+ //筛选出优先级最高的可用巷道
|
|
|
+ var tunnelInfo = tunnelInfos.Where(v => { try { return v.SRM.Data3.SCAlarm == 0 && v.SRM.Data2.SRMMode == SCMode.远程 && v.SRM.Data2.SRMStatus == SCRunStatus.空闲; } catch { return false; } })
|
|
|
+ .OrderBy(v => tunnelNo.IndexOf(v.Tunnel.CODE)).FirstOrDefault();
|
|
|
+ if (tunnelInfo == null) throw new Exception(LogHelper.SpliceLogMessage("无可用巷道", obj.Entity.CODE, WCS_EXCEPTIONTYPE.逻辑异常, GetType()));
|
|
|
+
|
|
|
+ //开始向设备中写入任务信息
|
|
|
+ foreach (var item in devs)
|
|
|
+ {
|
|
|
+ var dev = Device.Find(item.Entity.CODE).Create<StationDevice>();
|
|
|
+ var task = tasks.FirstOrDefault(p => p.ID == dev.Data2.Tasknum);
|
|
|
+ //if (dev.Data2.Goodsend == task.ADDRNEXT.ToShort() && (task.TaskGroupKey.Contains($"{task.WMSTASK}_") || task.TaskGroupKey.Contains($"_{task.WMSTASK}"))) continue;
|
|
|
+ dev.Data.Tasknum = task.ID;
|
|
|
+ dev.Data.Goodsstart = Conv_1030.ToShort();
|
|
|
+ dev.Data.Goodsend = tunnelInfo.taskIN.CODE.Replace("G", "").ToShort();
|
|
|
+ dev.Data.CmdType = IstationCmdType.分配目标地址;
|
|
|
+ dev.Data.VoucherNo++;
|
|
|
+
|
|
|
+ task.DEVICE = tunnelInfo.SRM.Entity.CODE;
|
|
|
+ task.TUNNEL = tunnelInfo.Tunnel.CODE;
|
|
|
+ task.ADDRNEXT = dev.Data.Goodsend.ToString();
|
|
|
+ task.TaskGroupKey = res.WMSTaskGroupKey;
|
|
|
+ task.ADDRTO = task.DEVICE;
|
|
|
+ db.Default.SaveChanges();
|
|
|
+
|
|
|
+ var msg = $"下达从{Conv_1030}移动至{dev.Data.Goodsend}的PLC指令。同时将任务分配至[{ task.TUNNEL }]-[{task.DEVICE}]";
|
|
|
+ msg += $"[{dev.Data.Tasknum}][{Conv_1030}][{dev.Data.Goodsend}][{tunnelInfo.SRM.Entity.CODE}][{dev.Data.VoucherNo}[{dev.Data2.VoucherNo}]";
|
|
|
+
|
|
|
+ task.CreateStatusLog(db, msg, this.GetType());
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ catch (Exception ex)
|
|
|
+ {
|
|
|
+ InfoLog.INFO_ERROR(ex.Message);
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|