gkj 2 年 前
コミット
0a4b96bfd0

+ 31 - 7
WCS.WorkEngineering/Systems/AgvSystems.cs

@@ -102,7 +102,11 @@ namespace WCS.WorkEngineering.Systems
                                 else //二楼
                                 {
                                 }
-                                if (srm == null) throw new KnownException("无可用堆垛机", LogLevelEnum.Mid);
+                                if (srm == null)
+                                {
+                                    World.Log("无可用堆垛机", LogLevelEnum.Mid);
+                                    continue;
+                                };
 
                                 task.Device = srm.Entity.Code;
                                 task.Tunnel = task.Device.GetLastDigit().ToString();
@@ -123,14 +127,34 @@ namespace WCS.WorkEngineering.Systems
 
                             case AGVTaskStatus.RequestOrPermission2: //安全交互
                                 var dev = devs.Find(v => v.Entity.Code == agv.Position);
-                                if (dev.Data.VoucherNo == dev.Data2.VoucherNo && dev.Data3.Status.HasFlag(StatusEunm.Auto)
-                                && !dev.Data3.Status.HasFlag(StatusEunm.PH_Status) && !dev.Data3.Status.HasFlag(StatusEunm.OT_Status) && !dev.Data3.Status.HasFlag(StatusEunm.Run))
+                                if (dev.Data.VoucherNo != dev.Data2.VoucherNo)
                                 {
-                                    //调继续执行任务接口
-                                    AgvApi.ContinueTask(agv.AgvID, dev.Entity.Code);
-                                    agv.Status = AGVTaskStatus.Complete2;
+                                    World.Log($"AGV请求放货,但{obj.Entity.Code}凭证号不一致", LogLevelEnum.Mid);
+                                    continue;
                                 }
-
+                                if (!dev.Data3.Status.HasFlag(StatusEunm.Auto))
+                                {
+                                    World.Log($"AGV请求放货,但{obj.Entity.Code}不在自动状态", LogLevelEnum.Mid);
+                                    continue;
+                                }
+                                if (dev.Data3.Status.HasFlag(StatusEunm.PH_Status))
+                                {
+                                    World.Log($"AGV请求放货,但{obj.Entity.Code}光电有货", LogLevelEnum.Mid);
+                                    continue;
+                                }
+                                if (dev.Data3.Status.HasFlag(StatusEunm.OT_Status))
+                                {
+                                    World.Log($"AGV请求放货,但{obj.Entity.Code}任务有货", LogLevelEnum.Mid);
+                                    continue;
+                                }
+                                if (dev.Data3.Status.HasFlag(StatusEunm.Run))
+                                {
+                                    World.Log($"AGV请求放货,但{obj.Entity.Code}在运行状态", LogLevelEnum.Mid);
+                                    continue;
+                                }
+                                //调继续执行任务接口
+                                AgvApi.ContinueTask(agv.AgvID, dev.Entity.Code);
+                                agv.Status = AGVTaskStatus.Complete2;
                                 break;
 
                             case AGVTaskStatus.MissionCompleted:

+ 25 - 17
WCS.WorkEngineering/Systems/一楼入库工位处理系统.cs

@@ -34,7 +34,7 @@ namespace WCS.WorkEngineering.Systems
         {
             obj.StorageStationIsForbid();
             //判断凭证号是否一致
-            if (obj.Data.VoucherNo != obj.Data2.VoucherNo) throw new KnownException($"凭证号不一致,DB520:{obj.Data.VoucherNo}-DB521{obj.Data2.VoucherNo}", LogLevelEnum.High);
+            if (obj.Data.VoucherNo != obj.Data2.VoucherNo) throw new KnownException($"凭证号不一致,DB520-{obj.Data.VoucherNo}-DB521{obj.Data2.VoucherNo}", LogLevelEnum.High);
             //设备是否停止运行
             if (obj.Data3.Status.HasFlag(StatusEunm.Run)) throw new KnownException("设备运行中", LogLevelEnum.Low);
             if (!obj.Data3.Status.HasFlag(StatusEunm.PH_Status)) throw new KnownException("没有光电", LogLevelEnum.Low);
@@ -42,31 +42,39 @@ namespace WCS.WorkEngineering.Systems
             if (obj.Data2.Request != 1) throw new KnownException("没有请求", LogLevelEnum.Low);
 
             WCS_TaskInfo task = null;
-             SqlSugarHelper.Do(db =>
-            {
-                //获取RFID
-                var barcode = BCRS.GetBCRCode(obj.Entity.Code);
-                //跟据RFID获取对应的任务
-                task = db.Default.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID:{barcode}对应WCS任务", LogLevelEnum.High);
+            SqlSugarHelper.Do(db =>
+           {
+               //获取RFID
+               var barcode = BCRS.GetBCRCode(obj.Entity.Code);
+               //跟据RFID获取对应的任务
+               task = db.Default.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID-{barcode}对应WCS任务", LogLevelEnum.High);
+               if (task.Status != Entity.TaskStatus.AGVExecution) throw new KnownException($"任务-{task.ID}状态不是AGV执行中,请检查异常原因", LogLevelEnum.High);
 
-                if (task.Status != Entity.TaskStatus.AGVExecution) throw new KnownException($"任务:{task.ID}状态不是AGV执行中,请检查异常原因", LogLevelEnum.High);
+               if (!obj.Data3.Status.HasFlag(StatusEunm.ManualStorage)) //不是手动入库
+               {
+                   //判断AGV任务目标地址是否是当前地址
+                   var agv = db.Default.Queryable<WCS_AgvTaskInfo>().SplitTable(v => v.Take(2)).First(v => v.ID == task.AgvTaskID) ?? throw new KnownException($"任务{task.ID}未找到对应AGV任务", LogLevelEnum.Mid);
+                   if (agv.Position != obj.Entity.Code) throw new KnownException($"任务{task.ID}对应AGV任务目标地址不是当前站台", LogLevelEnum.Mid);
+               }
 
-                //获取称重
-                var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
-                task.Weight = dev91.Data.Weight;
-                WmsApi.WcsUploadInfo(task.ID, (decimal)task.Weight, task.BarCode);
 
-                task.Status = Entity.TaskStatus.ConveyorExecution;
-                db.Default.Updateable(task).AddQueue();
-                task.AddWCS_TASK_DTL(db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货");
-                db.Default.SaveQueues();
-            });
+               //获取称重
+               var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
+               task.Weight = dev91.Data.Weight;
+               WmsApi.WcsUploadInfo(task.ID, (decimal)task.Weight, task.BarCode);
+
+               task.Status = Entity.TaskStatus.ConveyorExecution;
+               db.Default.Updateable(task).AddQueue();
+               task.AddWCS_TASK_DTL(db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货");
+               db.Default.SaveQueues();
+           });
             if (task == null) throw new KnownException("数据更新错误", LogLevelEnum.High);
             obj.Data.TaskNumber = task.ID;
         }
 
         public override bool Select(Device dev)
         {
+            //return dev.Code == "1013";
             return dev.HasFlag(DeviceFlags.一楼入库口);
         }
     }