SendFullShelfToLineJob.cs 14.8 KB
using Common;
namespace DeviceLibrary
{
    /// <summary>
    /// 从A6向产线运行任务(出满料)
    /// </summary>
    public class SendFullShelfToLineJob : Job
    {
        /// <summary>
        /// 从A6向产线运行任务(出满料)
        /// </summary>
        /// <param name="palce">产线名</param>
        /// <param name="rfid">料架RFID</param>
        /// <param name="isIgNoreBigShelf">是否忽略大料架</param>
        public SendFullShelfToLineJob(HttpManager.BoxDestInfo boxDestInfo, bool isIgNoreBigShelf = false)
        {
            FullShelfPlace = boxDestInfo.location;
            RFID = boxDestInfo.id;
            BoxDestInfo = boxDestInfo;
            IsIgnoreBigShelf = isIgNoreBigShelf;
        }

        /// <summary>
        /// 满料架目标位置点
        /// </summary>
        public string FullShelfPlace { get; set; }

        public string RFID { get; set; }

        public HttpManager.BoxDestInfo BoxDestInfo { get; private set; }
        /// <summary>
        /// 是否忽略大料架移库解绑
        /// </summary>
        public bool IsIgnoreBigShelf { get; private set; }


        private string runInfo = "";
        /// <summary>
        /// 运行信息
        /// </summary>
        public override string RunInfo
        {
            get { return string.Format("送满料任务[RFID={0}][{1}]:{2}",RFID, CurTaskID, runInfo); }
        }


        private JobStep<SEND_FULL_SHELF_STEP> jobStep = new JobStep<SEND_FULL_SHELF_STEP>(SEND_FULL_SHELF_STEP.NONE);

        public override Job Execute(Agv_Info agv)
        {
            string msg = string.Format("{0} 送满料任务[RFID={1}]: ", agv.Name,RFID);
            //bool rtn = false;
            agv.RFID = RFID;
            if (jobStep.IsStep(SEND_FULL_SHELF_STEP.NONE))
            {
                HttpManager.AgvRemoveRfid(RFID);
                if (FullShelfPlace.StartsWith(SettingString.RoomC_Name_Prefix))
                {
                    jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_DOOR);
                    runInfo = string.Format("前往{0}门,从双层线A6送往{1}",SettingString.RoomD_Name, FullShelfPlace);
                    msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    jobStep.Msg = msg;
                    MissionSys.AssignMission(agv, SettingString.DoorDToC);
                     UpdateJobTaskInfo(agv);
                }
                else
                {
                    jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_LINE);
                    runInfo = "从双层线A6送往[" + FullShelfPlace + "]";
                    msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    jobStep.Msg = msg;
                    MissionSys.AssignMission(agv, FullShelfPlace);
                     UpdateJobTaskInfo(agv);
                }

            }
            else if (jobStep.IsStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_DOOR))
            {
                CurTaskState = MissionSys.GetTakJobState(agv);
                if (MissionSys.CheckTaskFinished(agv, SettingString.DoorDToC, CurTaskState))
                {
                    if (AGVManager.CheckRoomCTarget(agv, FullShelfPlace))//被占用
                    {
                        jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_REACH_TEMP_PLACE);
                        runInfo = "目的地" + FullShelfPlace + "有小车占用,先到临时待机位";
                        msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                        jobStep.Msg = msg;
                        AGVManager.MoveToRoomCStandy(agv);
                         UpdateJobTaskInfo(agv);
                    }
                    else
                    {
                        if(AGVManager.CheckIsInAirDoor(FullShelfPlace))
                        {
                            jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_AIR_DOOR);
                            runInfo = "到达"+SettingString.RoomC_Name+"门,过风淋门[" + FullShelfPlace + "]";
                            msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                            jobStep.Msg = msg;
                            MissionSys.AssignMission(agv, SettingString.DoorAirIn);
                             UpdateJobTaskInfo(agv);
                        }
                        else
                        {
                            jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_LINE);
                            runInfo = "从双层线A6送往[" + FullShelfPlace + "]";
                            msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                            jobStep.Msg = msg;
                            MissionSys.AssignMission(agv, FullShelfPlace);
                             UpdateJobTaskInfo(agv);
                        }
                    }

                }
            }
            else if (jobStep.IsStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_AIR_DOOR))
            {
                CurTaskState = MissionSys.GetTakJobState(agv);
                if (MissionSys.CheckTaskFinished(agv, SettingString.DoorAirIn, CurTaskState))
                {
                        jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_LINE);
                        runInfo = "送往[" + FullShelfPlace + "]";
                        msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                        jobStep.Msg = msg;
                        MissionSys.AssignMission(agv, FullShelfPlace);
                         UpdateJobTaskInfo(agv);                  
                }
            }
            else if (jobStep.IsStep(SEND_FULL_SHELF_STEP.WAIT_REACH_TEMP_PLACE))
            {
                CurTaskState = MissionSys.GetTakJobState(agv);
                if (MissionSys.CheckTaskFinished(agv, SettingString.C4_STANDBY1, CurTaskState) || MissionSys.CheckTaskFinished(agv, SettingString.C4_STANDBY2, CurTaskState))
                {
                    if (!AGVManager.CheckRoomCTarget(agv, FullShelfPlace))//未占用
                    {
                        if (AGVManager.CheckIsInAirDoor(FullShelfPlace))
                        {
                            jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_AIR_DOOR);
                            runInfo = "到临时待机位,去产线先过风淋门[" + FullShelfPlace + "]";
                            msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                            jobStep.Msg = msg;
                            MissionSys.AssignMission(agv, SettingString.DoorAirIn);
                             UpdateJobTaskInfo(agv);
                        }
                        else
                        {
                            jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_LINE);
                            runInfo = "从临时待机位送往[" + FullShelfPlace + "]";
                            msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                            jobStep.Msg = msg;
                            MissionSys.AssignMission(agv, FullShelfPlace);
                             UpdateJobTaskInfo(agv);
                        }
                    }
                }
            }
            else if (jobStep.IsStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_LINE))
            {
                CurTaskState = MissionSys.GetTakJobState(agv);
                if (MissionSys.CheckTaskFinished(agv, FullShelfPlace, CurTaskState))
                {
                    //if (FullShelfPlace.Equals(SettingString.C4FeederIn))
                    //{
                    //    runInfo = "AGV到达 " + FullShelfPlace + "完成";
                    //    msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    //    SendFullShelfStep.Msg = msg;
                    //    return new EnterLeaveShelfJob(FullShelfPlace, eEnterLeaveType.Leave);
                    //}
                    if (IsIgnoreBigShelf)
                    {
                        jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_LINE_RESPONSE);
                        runInfo = "AGV到达 " + FullShelfPlace + ",并发送入料架请求[ReadyEnter]";
                        msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                        jobStep.Msg = msg;
                        AGVManager.server.ReadyEnter(FullShelfPlace);
                    }
                    else
                    {
                        if (RFID.StartsWith(SettingString.BigShelf_Prefix) && !FullShelfPlace.Equals(SettingString.RoomDFeederIn) && !FullShelfPlace.Equals(SettingString.RoomCFeederIn))
                        {
                            jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_BIG_SHELF_UNLOCK);
                            runInfo = "AGV到达 " + FullShelfPlace + ",并等待大料架解绑";
                            msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                            jobStep.Msg = msg;
                        }
                        else
                        {
                            jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_LINE_RESPONSE);
                            runInfo = "AGV到达 " + FullShelfPlace + ",并发送入料架请求[ReadyEnter]";
                            msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                            jobStep.Msg = msg;
                            AGVManager.server.ReadyEnter(FullShelfPlace);
                        }
                    }

                }
            }
            else if (jobStep.IsStep(SEND_FULL_SHELF_STEP.WAIT_BIG_SHELF_UNLOCK))
            {
                MiR_API.Get_IO_Status(agv, out bool[] input, out bool[] output);
                System.Threading.Thread.Sleep(50);
                if (HttpManager.GetRackBy(RFID, out string lineName) || (input != null && input[0]))
                {
                    runInfo = "大料架在" + FullShelfPlace + "解绑完成[" + agv.BoxDestInfo + "]";
                    agv.BoxDestInfo = "";
                    msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    jobStep.Msg = msg;
                    return new EmptyShelfBackJob(FullShelfPlace, eShelfType.BigShelf);
                }
            }
            else if (jobStep.IsStep(SEND_FULL_SHELF_STEP.WAIT_LINE_RESPONSE))
            {
                int id = AGVManager.FindNode(FullShelfPlace);
                ClientNode node = AGVManager.nodeInfo[id];
                MiR_API.Get_IO_Status(agv, out bool[] input, out bool[] output);
                System.Threading.Thread.Sleep(50);
                if (node.StateEquals(eNodeStatus.MayEnter))
                {
                    if (!agv.CurTarName.Equals(SettingString.Leave))
                    {
                        jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT__SHELF_IN_LINE);
                        runInfo = "收到产线入料架请求[ReadyEnter]的响应 " + FullShelfPlace + "入料架,小车链条运行";
                        msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                        jobStep.Msg = msg;
                        MissionSys.AssignMission(agv,SettingString.Leave);
                         UpdateJobTaskInfo(agv);
                    }

                }
                else if (input != null && !input[3] && input[0])
                {
                    runInfo = "手动操作:满料架进入" + FullShelfPlace + "完成[" + agv.BoxDestInfo + "]";
                    msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    jobStep.Msg = msg;
                    agv.RFID = "";
                    agv.BoxDestInfo = "";
                    HttpManager.UpdateStatus(RFID, FullShelfPlace);
                    return new EmptyAGVBackJob(FullShelfPlace);
                }
                else if (jobStep.IsTimeOut(15000, out double timeOutValue))
                {
                    jobStep.ToNextStep(SEND_FULL_SHELF_STEP.WAIT_AGV_REACH_LINE);
                    runInfo = "AGV到达 " + FullShelfPlace + ",15秒后重新向产线发送入料架请求[ReadyEnter]";
                    msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    jobStep.Msg = msg;
                }
            }
            else if (jobStep.IsStep(SEND_FULL_SHELF_STEP.WAIT__SHELF_IN_LINE))
            {
                CurTaskState = MissionSys.GetTakJobState(agv);
                if (MissionSys.CheckTaskFinished(agv,SettingString.Leave, CurTaskState))
                {
                    runInfo = "满料进入" + FullShelfPlace + "完成[" + agv.BoxDestInfo + "]";
                    msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    jobStep.Msg = msg;
                    agv.RFID = "";
                    agv.BoxDestInfo = "";
                    HttpManager.UpdateStatus(RFID, FullShelfPlace);
                    return new EmptyAGVBackJob(FullShelfPlace);
                }
                else if (jobStep.IsTimeOut(60000, out double timeOutValue))
                {
                    //链条停止
                    runInfo = "满料在[" + FullShelfPlace + "]离开小车超时[" + timeOutValue.ToString("f1") + "秒],请检查料架离开小车的情况";
                    //msg += string.Format("[{0}] {1}", jobStep.CurStep(),runInfo);
                    //SendFullShelfStep.Msg = msg;
                }

            }
            //else if (SendFullShelfStep.IsStep(SEND_FULL_SHELF_STEP.END))
            //{

            //}

            return this;
        }

    }
    /// <summary>
    /// AGV送满料架到产线
    /// </summary>
    public enum SEND_FULL_SHELF_STEP
    {
        /// <summary>
        /// 料架已进入小车,去目的地
        /// </summary>
        NONE,
        /// <summary>
        /// 等待AGV到达门
        /// </summary>
        WAIT_AGV_REACH_DOOR,
        /// <summary>
        /// 等待agv到达4C临时待机位
        /// </summary>
        WAIT_REACH_TEMP_PLACE,
        /// <summary>
        /// 等待到达4C风淋门
        /// </summary>
        WAIT_AGV_REACH_AIR_DOOR,
        /// <summary>
        /// 等待小车到达目的地
        /// </summary>
        WAIT_AGV_REACH_LINE,
        /// <summary>
        /// 等待大料架解绑
        /// </summary>
        WAIT_BIG_SHELF_UNLOCK,
        /// <summary>
        /// 等待AGV载大料架返回双层线
        /// </summary>
        WAIT_BIG_SHELF_BACK_DOUBLE_LINE,
        /// <summary>
        /// 等待AGV到达停车位
        /// </summary>
        WAIT_BIG_SHELF_BACK_STANDYBY,
        /// <summary>
        /// 等待产线回应
        /// </summary>
        WAIT_LINE_RESPONSE,
        /// <summary>
        /// 等待料架进入产线
        /// </summary>
        WAIT__SHELF_IN_LINE,

        /// <summary>
        /// 进入产线完成
        /// </summary>
        END
    }
}