| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 | using Aitex.Core.RT.Log;using Aitex.Core.RT.Routine;using Aitex.Core.RT.SCCore;using Aitex.Sorter.Common;using CyberX8_Core;using CyberX8_RT.Devices.EFEM;using MECF.Framework.Common.Equipment;using MECF.Framework.Common.Routine;using MECF.Framework.Common.SubstrateTrackings;using System;using System.Collections.Generic;using System.Linq;using System.Runtime.InteropServices;using System.Text;using System.Threading;using System.Threading.Tasks;namespace CyberX8_RT.Modules.EFEM{    public class EfemRobotMapRoutine : RoutineBase, IRoutine    {        enum RoutineStep        {            GotoMapWaitIdle,            GotoMap,            WaitEFEMIdle,            Map,            RequestMapWaitIdle,            RequestMap,            BackWaitIdle,            Back,            End,        }        /// <summary>        /// 构造函数        /// </summary>        /// <param name="efem"></param>        public EfemRobotMapRoutine(EfemBase efem):base(ModuleName.EfemRobot.ToString())        {            _efem = efem;        }        #region 内部变量        private int _timeout = 0;        private ModuleName _module = ModuleName.EfemRobot;        private EfemBase _efem;        #endregion        /// <summary>        /// 启动        /// </summary>        /// <param name="objs"></param>        /// <returns></returns>        public RState Start(params object[] objs)        {            Reset();            _module=(ModuleName)objs[0];            _timeout = SC.GetValue<int>("EFEM.LoadPort.MotionTimeout");            return Runner.Start(Module, $"Start Map {_module}");        }        public RState Monitor()        {            Runner.Wait(RoutineStep.GotoMapWaitIdle, WaitModuleReady)            .Run(RoutineStep.GotoMap, GotoMap, CheckStepDone, _timeout * 1000)            .Wait(RoutineStep.WaitEFEMIdle, WaitModuleReady)            .Run(RoutineStep.Map, Map, CheckStepDone, _timeout * 1000)            .Wait(RoutineStep.RequestMapWaitIdle, WaitModuleReady)            .Run(RoutineStep.RequestMap, RequestMap, CheckStepDone, _timeout * 1000)            .Wait(RoutineStep.BackWaitIdle, WaitModuleReady)            .Run(RoutineStep.Back, Back, CheckStepDone, _timeout * 1000)            .End(RoutineStep.End, NullFun, _delay_1s);            return Runner.Status;        }        private bool GotoMap()        {            return _efem.GotoMap(_module, Hand.Blade1);        }        private bool Map()        {            return _efem.Map(_module);        }        private bool Back()        {            return _efem.GotoMap(_module, Hand.Blade1, "RE");        }        private bool RequestMap()        {            return _efem.RequestMapResult(_module);        }        private bool WaitModuleReady()        {            return _efem.Status == RState.End;        }        private bool CheckStepDone()        {            if (_efem.Status == RState.End)            {                return true;            }            else if (_efem.Status == RState.Failed)            {                NotifyError(eEvent.ERR_EFEM_ROBOT, $"Efem robot picking failed: {_efem.Status}", -1);                return true;            }            return false;        }        public void Abort()        {            Runner.Stop("Manual Abort");        }    }}
 |