海波 张
2025-06-16 8361a150d223eb6d4935b5e2e97811055b35d9c2
core/TaskCore.cs
@@ -11,6 +11,7 @@
using System.Reflection;
using System.Threading.Tasks;
using System.Web.Services.Description;
using Top.Api;
using static HH.WCS.ZhongCeJinTan.api.ApiModel;
using static HH.WCS.ZhongCeJinTan.util.Settings;
@@ -19,7 +20,6 @@
    internal class TaskCore
    {
        public static void OperateTaskStatus(AgvTaskState model) {
            var wmsTask = TaskHelper.GetTask(model.task_no);
            var db = new SqlHelper<object>().GetInstance();
@@ -33,7 +33,7 @@
                        switch (model.state)
                        {
                            case 1:
                                TaskHelper.Begin(wmsTask);
                                TaskHelper.Begin(wmsTask,model.forklift_no);
                                //胎面交互
                                TaskHelper.TmSafety(wmsTask);
                                break;
@@ -62,9 +62,26 @@
                                }                        
                            break;
                            case 2:
                                TaskHelper.End(wmsTask);
                            //空托出或者满托出任务完成判断是否要提高入库优先级
                            LogHelper.Info($"任务{wmsTask.S_CODE}完成,判断入库优先级", "入库优先级");
                            TaskProcess.inPri(wmsTask);
                            TaskHelper.End(wmsTask);
                            break;
                            case 7:
                                var wcsTask1 = TaskHelper.GetTaskByWorkNo(wmsTask.S_OP_CODE, "wcs");
                                if (wcsTask1!=null)
                                {
                                    //agv执行通知 wcs取消
                                    WcsTask.WcsCallback(wmsTask, model.state, model.forklift_no);
                                    if (!TaskHelper.CheckActionRecordExist(wcsTask1.S_CODE, "6"))
                                    {
                                        TaskHelper.Fail(wcsTask1);
                                        TaskProcess.OperateStatus(wcsTask1, 7);
                                    }
                                }
                                TaskHelper.Fail(wmsTask);
                                TaskProcess.OperateStatus(wmsTask, 7);
                                //入库或者回库任务取消删除托盘物料
@@ -73,20 +90,19 @@
                                    ContainerHelper.delCntr(wmsTask.S_CNTR_CODE);
                                    ContainerHelper.delCntrItem(wmsTask.S_CNTR_CODE);
                                }
                                    //出库取消判断接驳位是否有货,有货需要解绑
                                    if (!WcsTask.WcsCvstate(wmsTask))
                                    {
                                        LogHelper.Info($"Wcs立库接驳位无货,解绑货位:{wmsTask.S_START_LOC}", "立库");
                                        TaskProcess.OperateStatus(wmsTask, 4);
                                        ContainerHelper.delCntr(wmsTask.S_CNTR_CODE);
                                        ContainerHelper.delCntrItem(wmsTask.S_CNTR_CODE);
                                    }
                                break;
                                //出库取消判断接驳位是否有货,有货需要解绑
                                if (!WcsTask.WcsCvstate(wmsTask))
                                {
                                    LogHelper.Info($"Wcs立库接驳位无货,解绑货位:{wmsTask.S_START_LOC}", "立库");
                                    TaskProcess.OperateStatus(wmsTask, 4);
                                    ContainerHelper.delCntr(wmsTask.S_CNTR_CODE);
                                    ContainerHelper.delCntrItem(wmsTask.S_CNTR_CODE);
                                }
                            break;
                        }
                         TaskHelper.AddActionRecord(wmsTask.S_CODE, model.state, model.forklift_no, model.ext_data);
                        //agv执行通知
                        //WcsTask.WcsCallback(wmsTask, model.state, model.forklift_no);
                         TaskHelper.AddActionRecord(wmsTask.S_CODE, model.state, model.forklift_no, model.ext_data);
                }
                else
                {
@@ -94,7 +110,6 @@
                    TaskProcess.OperateReq(model.task_no, model.state, model.forklift_no, model.ext_data);
                }
            }
        }
      
@@ -111,7 +126,11 @@
            var list = TaskHelper.GetTaskListByState("未执行", "agv");
            if (list.Count > 0) {
                list.ForEach(task => {
                    //任务拦截
                    if (TaskHelper.Intercept())
                    {
                        TaskProcess.SendTask(task);
                    }
                });     
            }
        }
@@ -127,7 +146,7 @@
            if (list.Count > 0)
            {
                list.ForEach(task => {
                    WcsTask.WcsTaskEntity(task);
                        WcsTask.WcsTaskEntity(task);
                });
            }
        }