Example #1
0
        public void Execute(IApplication app, ISPADEventArgs eventArgs)
        {
            ICDUScreen cdu = EfisHelper.GetCDU(app, CDU_NUMBER.Captain);

            if (cdu == null)
            {
                return;
            }

            if (EfisHelper.GetPageName(cdu) != "EFIS CONTROL")
            {
                if (!EfisHelper.SwitchAndWaitForPage(cdu, "MENU", CDU_KEYS.KEY_MENU))
                {
                    return;
                }
            }
            if (!EfisHelper.SwitchAndWaitForPage(cdu, "EFIS CONTROL", CDU_KEYS.KEY_R2))
            {
                return;
            }

            var oldVal = 0;

            for (int i = 0; i < 6; i++)
            {
                var cell = cdu.GetCell(6, i);
                if (!Char.IsDigit(cell.Symbol))
                {
                    break;
                }
                oldVal = oldVal * 10 + (cell.Symbol - '0');
            }
            oldVal += Convert.ToInt32(eventArgs.NewValue);
            logger.Info($"new Value = {oldVal}");
            while (!cdu.GetCell(13, 0).IsEmpty)
            {
                cdu.SendKey(CDU_KEYS.KEY_CLR);
                Thread.Sleep(100);
            }

            var newVal = oldVal.ToString();

            for (int i = 0; i < newVal.Length; i++)
            {
                cdu.SendKey(CDU_KEYS.KEY_0 + (newVal[i] - '0'));
            }
            Thread.Sleep(100);
            cdu.SendKey(CDU_KEYS.KEY_L3);
        }
Example #2
0
        public void CDUAvailable(object sender, ISPADEventArgs e)
        {
            logger.Info($"EfisHelper: CDUAvailable {e}");
            logger.Info($"Sender {sender}");
            ICDUScreen cdu = e.NewValue as ICDUScreen;

            logger.Info($"CDU {cdu}");
            if ((cdu != null) && (cdu.IsValid) && (cdu.IsPowered) && (cdu.CDUNumber == CDU_NUMBER.Captain))
            {
                logger.Info("CDU Available");
                if (!SwitchAndWaitForPage(cdu, "MENU", CDU_KEYS.KEY_MENU))
                {
                    return;
                }
                var efisLine = cdu.GetRow(4, 19);
                if (efisLine != "EFIS>")
                {
                    logger.Info($"'{efisLine}' != 'EFIS>'");
                    cdu.SendKey(CDU_KEYS.KEY_R1); // Enable Efis
                }
            }
        }
Example #3
0
 public static void RaiseEvent(string eventName, ISPADEventArgs e)
 {
     EventSystemHandler.RaiseEvent(eventName, e);
 }
Example #4
0
        public void Execute(IApplication app, ISPADEventArgs eventArgs)
        {
            var lg = app.GetLogger("EXT");

            lg.Warn(eventArgs.ToString());
        }