AgvClient.cs 7.6 KB

using Asa;
using Asa.RFID;
using OnlineStore.Common;
using OnlineStore.LoadCSVLibrary;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;

namespace OnlineStore.DeviceLibrary
{
    public class AgvClient
    {
        private static string ServerIp = ConfigAppSettings.GetValue(Setting_Init.AgvServerIp);
        private static Asa.Client2 agvClient;
        public static Dictionary<string, Asa.ClientAction> actionMap = new Dictionary<string, Asa.ClientAction>();
        public static List<string> NodeList = new List<string>();
        private static bool isInit = false;
        public static void Init()
        {
            try
            {
                if (!isInit)
                {
                    isInit = true;
                    agvClient = new Asa.Client2(ServerIp);
                    agvClient.Log += AgvClient_Log;
                    agvClient.Arrive += AgvClient_Arrive;
                    // agvClient.CanEnter += AgvClient_CanEnter;
                    agvClient.Ready += AgvClient_Ready;
                    //agvClient.GetRFID += AgvClient_GetRFID;
                }
                actionMap = new Dictionary<string, Asa.ClientAction>();
                foreach (string key in NodeList)
                {
                    actionMap.Add(key, Asa.ClientAction.None);
                }

                agvClient.Connect();
                foreach (string str in NodeList)
                {
                    SetStatus(str);
                }

            }
            catch (Exception ex)
            {
                LogUtil.error("初始化agvClient " + ServerIp + " 出错:", ex);
            }
        }

        //private static void AgvClient_GetRFID(string name, byte[] content)
        //{ 
        //    RFIDData data = new RFIDData(content);
        //    LogUtil.info("收到 AgvClient_GetRFID [" + name + "] [" + data.ToData() + "]   ");
        //}

        public static void SetStatus(string id, string shelfId = "", ClientAction action = ClientAction.None, ClientLevel level = ClientLevel.Low)
        {
            ClientAction currA = GetAction(id);
            //相同状态就设置一次
            if (currA.Equals(action))
            {
                return;
            }
            agvClient.SetStatus(id, "",shelfId, action, level);
            UpdateAction(id, action);
        }
        private static void AgvClient_Ready(string id, byte[] content)
        {

            RFIDData data = new RFIDData(content);
            LogUtil.info("收到 AgvClient_Ready [" + id + "] [" + data.ToData() + "]   ");

            UpdateAction(id, Asa.ClientAction.Ready);
            if (id.Equals(LineManager.Config.OutL_AgvName))
            {
                //    MayEnter("C2");
                if (IOManager.IOValue(IO_Type.OutL_InCheck).Equals(IO_VALUE.LOW))
                {
                    SetStatus(id, "", ClientAction.MayEnter);
                    LogUtil.info("收到 AgvClient_Ready [" + id + "] [" + data.ToData() + "]  调用 MayEnter ");

                    Task.Factory.StartNew(delegate
                    {
                        //两秒后改为离开状态
                        Thread.Sleep(5000);
                        SetStatus(id, "", ClientAction.FinishEnter);

                        Thread.Sleep(2000);

                        SetStatus(id, "", ClientAction.None);
                    });
                }
            }

            else if (id.Equals(LineManager.Config.InL_AgvName))
            {
                if (IOManager.IOValue(IO_Type.InL_OutStopCheck).Equals(IO_VALUE.HIGH))
                {
                    LineManager.VMILine.StopIOMove(IO_Type.InL_OutStopDown);
                    //agvClient.MayLeave(id);
                    SetStatus(id, "", ClientAction.MayLeave);
                    LogUtil.info("收到 AgvClient_Ready [" + id + "] [" + data.ToData() + "]  ,下降 InL_OutStopDown 600ms,调用 MayLeave ");
                     
                    Task.Factory.StartNew(delegate
                    {
                        //两秒后改为离开状态
                        Thread.Sleep(5000);
                        SetStatus(id, "", ClientAction.FinishEnter);

                        Thread.Sleep(2000);

                        SetStatus(id, "", ClientAction.None);
                    });
                }
            }
        } 
        private static void AgvClient_Arrive(string id, byte[] content)
        { 
            UpdateAction(id, Asa.ClientAction.Arrive);
            RFIDData data = new RFIDData(content); 
            LogUtil.info("收到 AgvClient_Arrive [" + id + "] [" + data.ToData() + "]   "); 
        }
        public static bool ConnotEnter(string id,string shelfId)
        {
            ClientAction currA = GetAction(id);
            if (currA.Equals(ClientAction.None) || currA.Equals(ClientAction.FinishLeave) || currA.Equals(ClientAction.FinishEnter))
            {
                SetStatus(id, shelfId, ClientAction.None);
                return true;
            }
            return false;
        }
        public static bool NeedEnter(string id, string shelfId)
        {
            ClientAction currA = GetAction(id);
            if (currA.Equals(ClientAction.None) || currA.Equals(ClientAction.FinishLeave) || currA.Equals(ClientAction.FinishEnter))
            {
                SetStatus(id, shelfId, ClientAction.NeedEnter);
                return true;
            }
            return false;
        }
        public static bool NeedLeave(string id, string shelfId)
        {

            ClientAction currA = GetAction(id);
            if (currA.Equals(ClientAction.None) || currA.Equals(ClientAction.FinishLeave) || currA.Equals(ClientAction.FinishEnter))
            {
                SetStatus(id, shelfId, ClientAction.NeedLeave);
                return true;
            }
            return false;
        }
        public static bool ISConnected()
        {
            if (agvClient == null)
            {
                return false;
            }
            return agvClient.IsConn;
        }
        //public static void SendRFID(string NodeName, string rfid)
        //{
        //    agvClient.SendRFID(NodeName, rfid);

        //} 
        private static void AgvClient_Log(string s)
        {
            try
            {
                bool isLog = ConfigAppSettings.GetIntValue(Setting_Init.Agv_Log_Open).Equals(1);
                if (isLog)
                {
                    LogUtil.info(" AGV " + ServerIp + " Log : " + s);
                }
            }
            catch (Exception ex)
            {
                LogUtil.error("AgvClient_Log 出错:" + ex.ToString());
            }
        }

        public static Asa.ClientAction GetAction(string NodeName)
        {
            if (actionMap.ContainsKey(NodeName))
            {
                return actionMap[NodeName];
            }
            return Asa.ClientAction.None;
        }
        public static void UpdateAction(string name,   Asa.ClientAction action)
        {
            if (actionMap.ContainsKey(name))
            {
                actionMap[name] = action;
            }
            else
            {
                actionMap.Add(name, action);
            }
        }
        public static void Dispose()
        {
            try
            { 
                if (agvClient != null)
                {
                    agvClient.Close();
                }
            }
            catch (Exception ex)
            {
                LogUtil.error("agvClient.Close " + ServerIp + " 出错:", ex);
            }
        }
    } 
}