diff --git a/HBLConsole.Business/MessageServer/Base.cs b/HBLConsole.Business/MessageServer/Base.cs index 5a8a9a0..10c8178 100644 --- a/HBLConsole.Business/MessageServer/Base.cs +++ b/HBLConsole.Business/MessageServer/Base.cs @@ -32,7 +32,7 @@ namespace HBLConsole.Business.MessageServer OrderPush = morkOrderpush }); ActionOperate.GetInstance.Send("AddOrder",morkOrderpush); - ActionOperate.GetInstance.Send("DataParse",morkOrderpush); + ActionOperate.GetInstance.Send("DataParse", morkOrderpush); } } } diff --git a/HBLConsole.Communication/LebaiHelper.cs b/HBLConsole.Communication/LebaiHelper.cs index 8cfc860..e987dc4 100644 --- a/HBLConsole.Communication/LebaiHelper.cs +++ b/HBLConsole.Communication/LebaiHelper.cs @@ -43,16 +43,24 @@ namespace HBLConsole.Communication } StartRobot(); MessageLog.GetInstance.Show("乐百机器人连接成功!"); - //GetSpeed(); - //ActionOperate.GetInstance.Send($"{GVL.GeneralConfig.DeviceType.ToString()}/ConnectOk"); } public void GetSpeed() { - //client.StartSys().GetAwaiter(); var aa = client.GetActualTcpSpeed().GetAwaiter(); - //robotData.RobotMode.Mode + + + } + + /// + /// 获取机器人当前运行的命令 + /// + /// + public CmdStatus GetRobotRunCmd() + { + if (robotData == null) return default(CmdStatus); + return robotData.CurrentCmd; } /// diff --git a/HBLConsole.Debug/Debug_MORKIC.xaml b/HBLConsole.Debug/Debug_MORKIC.xaml index 556dcdd..e71656d 100644 --- a/HBLConsole.Debug/Debug_MORKIC.xaml +++ b/HBLConsole.Debug/Debug_MORKIC.xaml @@ -121,7 +121,7 @@ - + @@ -137,6 +137,7 @@ + @@ -144,6 +145,7 @@ + diff --git a/HBLConsole.Debug/ViewModel/ViewModel_MORKIC.cs b/HBLConsole.Debug/ViewModel/ViewModel_MORKIC.cs index d49e702..c2129ea 100644 --- a/HBLConsole.Debug/ViewModel/ViewModel_MORKIC.cs +++ b/HBLConsole.Debug/ViewModel/ViewModel_MORKIC.cs @@ -70,6 +70,10 @@ namespace HBLConsole.Debug /// 成型比 /// public byte CXB { get; set; } + /// + /// 打料完成状态 + /// + public string DLCompleted { get; set; } public List IceCreamModes { get; set; } = new List(); public string SelecteIceCreamdMode { get; set; } @@ -111,7 +115,7 @@ namespace HBLConsole.Debug CurrentMode = MorkIStatus.GetInstance().CurrentMode; IceCreamFault = MorkIStatus.GetInstance().Fault; CXB = MorkIStatus.GetInstance().CXB; - + DLCompleted = MorkIStatus.GetInstance().DLCompleted?"打料完成":"打料中"; Thread.Sleep(500); }), "MORK IC-状态刷新"); } diff --git a/HBLConsole.MORKIC/Control_MORKIC.cs b/HBLConsole.MORKIC/Control_MORKIC.cs index 9202eb5..883d353 100644 --- a/HBLConsole.MORKIC/Control_MORKIC.cs +++ b/HBLConsole.MORKIC/Control_MORKIC.cs @@ -15,6 +15,7 @@ using HBLDevice.Coffee; using HBLDevice.IceCream; using Robotc; using System.Collections.Concurrent; +using System.Diagnostics; namespace HBLConsole.MORKIC { @@ -254,11 +255,13 @@ namespace HBLConsole.MORKIC } + public void ReadData() { ThreadOperate.GetInstance.StartLong(new Action(() => { lebai = LebaiHelper.GetInstance.GetValueAsync(); + Debug.WriteLine(LebaiHelper.GetInstance.GetClawWdight()); Thread.Sleep(100); }), "乐百机器人数据读取"); } diff --git a/HBLConsole/App.xaml.cs b/HBLConsole/App.xaml.cs index 1b3a562..241b960 100644 --- a/HBLConsole/App.xaml.cs +++ b/HBLConsole/App.xaml.cs @@ -50,7 +50,7 @@ namespace HBLConsole protected override void OnExit(ExitEventArgs e) { - IotReport.GetInstance.Close(); + //IotReport.GetInstance.Close(); base.OnExit(e); SqlHelper.GetInstance.Save(); MainConsole.Main.GetInstance.DataSave(); diff --git a/HBLDevice.IceCream/CommandHandler.cs b/HBLDevice.IceCream/CommandHandler.cs index f0fda17..0d00573 100644 --- a/HBLDevice.IceCream/CommandHandler.cs +++ b/HBLDevice.IceCream/CommandHandler.cs @@ -20,6 +20,8 @@ namespace HBLDevice.IceCream private SerialPortClient commProxy; private IceCreamEndCook iceCreamEndCook = new IceCreamEndCook(); + public Action PauseAsk { get; set; } + /// /// 初始化 /// @@ -42,9 +44,12 @@ namespace HBLDevice.IceCream public void ModeSetEventHandle(IEvent @event, EventCallBackHandle callBack = null) { + PauseAsk?.Invoke(true); + Thread.Sleep(200); var data = IcPack.StructureToByte(ICMSG_MODE_DW.Build(((ModeSetEvent)@event).Mode)); commProxy.SendData(data); - + Thread.Sleep(200); + PauseAsk?.Invoke(false); MessageLog.GetInstance.Show(string.Format("设置模式[{0}]", ((ModeSetEvent)@event).Mode)); } @@ -81,8 +86,12 @@ namespace HBLDevice.IceCream if (modeRight) { + PauseAsk?.Invoke(true); + Thread.Sleep(200); var data = IcPack.StructureToByte(ICMSG_MODE_DW.Build(MORKI_MODE.打料)); commProxy.SendData(data); + Thread.Sleep(200); + PauseAsk?.Invoke(false); iceCreamEndCook.Publish(); MessageLog.GetInstance.Show(string.Format("出料操作->设置模式[{0}]", MORKI_MODE.打料)); } diff --git a/HBLDevice.IceCream/IceCreamMachine.cs b/HBLDevice.IceCream/IceCreamMachine.cs index a22d5b5..169163b 100644 --- a/HBLDevice.IceCream/IceCreamMachine.cs +++ b/HBLDevice.IceCream/IceCreamMachine.cs @@ -19,7 +19,8 @@ namespace HBLDevice.IceCream private DataStorage dataStorage = new DataStorage(); //主线程运行标识 private bool running = false; - + //是否下发指令,主线程等待 + private bool free = true; public Action SendCallback; public Action ReciveCallback; @@ -30,7 +31,10 @@ namespace HBLDevice.IceCream commProxy = new SerialPortClient(portName, baud); commProxy.SetDataStorage(dataStorage); commandHandler.Init(commProxy); - + commandHandler.PauseAsk = delegate (bool pause) + { + free = !pause; + }; } public void Start() @@ -49,8 +53,11 @@ namespace HBLDevice.IceCream { ThreadOperate.GetInstance.StartLong(new Action(() => { - commProxy.SendData(commandHandler.GetHeartDW()); - SendCallback?.Invoke(BitConverter.ToString(commandHandler.GetHeartDW())); + if (free) + { + commProxy.SendData(commandHandler.GetHeartDW()); + SendCallback?.Invoke(BitConverter.ToString(commandHandler.GetHeartDW())); + } Thread.Sleep(500); }), "冰淇淋询问线程"); diff --git a/HBLDevice.IceCream/MorkIStatus.cs b/HBLDevice.IceCream/MorkIStatus.cs index 351f202..252e629 100644 --- a/HBLDevice.IceCream/MorkIStatus.cs +++ b/HBLDevice.IceCream/MorkIStatus.cs @@ -52,6 +52,10 @@ namespace HBLDevice.IceCream /// 成型比(门限) /// public byte CXB_Threshold { get; set; } + /// + /// 打料完成(完成为true,正在打料为false) + /// + public bool DLCompleted { get; set; } public bool CanDo { @@ -76,7 +80,17 @@ namespace HBLDevice.IceCream DL = BitConverter.ToInt16(new byte[] { heartUpMsg.DL_L, heartUpMsg.DL_H }, 0); Fault = (MORKI_FAULT)BitConverter.ToInt16(new byte[] { heartUpMsg.GZ_L, heartUpMsg.GZ_H }, 0); CXB = heartUpMsg.CXB; + DLCompleted = (heartUpMsg.DLTJ >> 4 & 1) == 1; + if (RTrig.GetInstance("打料完成检测").Start(DLCompleted)) + { + MessageLog.GetInstance.Show("打料完成"); + } + + if(RTrig.GetInstance("打料中检测").Start(!DLCompleted)) + { + MessageLog.GetInstance.Show("打料中"); + } //MessageLog.GetInstance.Show(string.Format("当前模式为:{0}", CurrentMode)); }