You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

313 lines
12 KiB

  1. using System;
  2. using System.Collections.Generic;
  3. using System.Configuration;
  4. using System.Linq;
  5. using System.Threading;
  6. using BPA.Message;
  7. using BPA.Utility;
  8. using HBLConsole.Communication;
  9. using HBLConsole.Factory;
  10. using HBLConsole.GVL;
  11. using HBLConsole.Interface;
  12. using HBLConsole.Model;
  13. using HBLConsole.Service;
  14. using HBLDevice.Coffee;
  15. using HBLDevice.IceCream;
  16. using Robotc;
  17. using System.Collections.Concurrent;
  18. using System.Diagnostics;
  19. using BPA.Message.IOT;
  20. using HBLDevice.ICChip;
  21. namespace HBLConsole.MORKIC
  22. {
  23. /*
  24. * 冰淇淋咖啡机组合套装
  25. * 物料位置:
  26. * 1:冰淇料
  27. * 2:冰淇淋杯
  28. * 5:咖啡
  29. * 6:咖啡杯
  30. */
  31. public class Control_MORKIC : IControl
  32. {
  33. GVL_MORIC mORKD = new GVL_MORIC();
  34. //咖啡机主控程序
  35. private CoffeeMachine coffeeMachine;
  36. private ICChipMachine icchipMachine;
  37. //冰淇淋主控程序
  38. private IceCreamMachine iceCreamMachine;
  39. //物料存放位置
  40. private Dictionary<string, PolymerBatching> batchings = new Dictionary<string, PolymerBatching>();
  41. //容器位置
  42. private string holderLoc;
  43. //主料位置
  44. private string mainMaterialLoc;
  45. //子订单ID
  46. private string subOrderId;
  47. /// <summary>
  48. /// 获取乐百机器人的数据
  49. /// </summary>
  50. SignalResult lebai = new SignalResult();
  51. public void ConnectOk()
  52. {
  53. }
  54. ConcurrentQueue<MorkOrderPush> morkOrderPushes = new ConcurrentQueue<MorkOrderPush>();
  55. public void Init()
  56. {
  57. //构建所有商品物料信息
  58. batchings = PolymerBatching.BuildAll();
  59. EventBus.GetInstance().Subscribe<CoffeEndCook>(CoffeEndCookHandle);
  60. System.Configuration.Configuration config = System.Configuration.ConfigurationManager.OpenExeConfiguration(System.Configuration.ConfigurationUserLevel.None);
  61. //一系列外围基础配置
  62. var com_Coffee = config.AppSettings.Settings["COM_Coffee"].Value;
  63. var baud_Coffee = config.AppSettings.Settings["BAUD_Coffee"].Value;
  64. var com_IceCream = config.AppSettings.Settings["COM_IceCream"].Value;
  65. var baud_IceCream = config.AppSettings.Settings["BAUD_IceCream"].Value;
  66. var iceCreamCXBThreshold = int.Parse(config.AppSettings.Settings["IceCream_CXB_Threshold"].Value);
  67. var com_ICChip = config.AppSettings.Settings["COM_ICChip"].Value;
  68. var baud_ICChip = config.AppSettings.Settings["BAUD_IChip"].Value;
  69. if (iceCreamCXBThreshold > 0)
  70. {
  71. //设置冰淇淋成型比
  72. MorkIStatus.GetInstance().CXB_Threshold = (byte)iceCreamCXBThreshold;
  73. }
  74. //咖啡机创建
  75. coffeeMachine = new CoffeeMachine(com_Coffee, (BaudRates)Enum.Parse(typeof(BaudRates), baud_Coffee));
  76. //冰淇淋机创建
  77. iceCreamMachine = new IceCreamMachine(com_IceCream, (BaudRates)Enum.Parse(typeof(BaudRates), baud_IceCream));
  78. icchipMachine = new ICChipMachine(com_ICChip, (BaudRates)Enum.Parse(typeof(BaudRates), baud_ICChip));
  79. Main();
  80. ReadData();
  81. ThreadOperate.GetInstance.StartLong(new Action(() =>
  82. {
  83. while (morkOrderPushes.Count > 0)
  84. {
  85. if (morkOrderPushes.TryDequeue(out MorkOrderPush order))
  86. {
  87. //Thread.Sleep(5000);
  88. //SimpleFactory.GetInstance.OrderChanged(subOrderId, BPA.Message.Enum.ORDER_STATUS.COMPLETED_COOK);
  89. //商品类型
  90. GOODS_TYPE currentGoodsType = GOODS_TYPE.NEITHER;
  91. //子订单ID
  92. subOrderId = order.SuborderId;
  93. //遍历物料
  94. foreach (var item in order.GoodBatchings)
  95. {
  96. var res = Json<BatchingInfoPar>.Data.orderMaterialDelivery.BatchingInfo.FirstOrDefault(p => p.BatchingId == item.BatchingId);
  97. if (res != null)
  98. {
  99. //验证商品是咖啡还是冰淇淋
  100. if (ValidateGoodsByBatching(res.BatchingLoc) != GOODS_TYPE.NEITHER)
  101. {
  102. //获取当前物料所属商品类型
  103. currentGoodsType = ValidateGoodsByBatching(res.BatchingLoc);
  104. }
  105. //获取主料和容器位置
  106. switch (batchings[res.BatchingLoc].BatchingClass)
  107. {
  108. case BATCHING_CLASS.HOLDER:
  109. holderLoc = res.BatchingLoc;
  110. break;
  111. case BATCHING_CLASS.MAIN_MATERIAL:
  112. mainMaterialLoc = res.BatchingLoc;
  113. break;
  114. }
  115. }
  116. }
  117. //根据商品类型执行具体制作流程
  118. switch (currentGoodsType)
  119. {
  120. case GOODS_TYPE.COFFEE:
  121. DoCoffee();
  122. break;
  123. case GOODS_TYPE.ICECREAM:
  124. DoIceCream();
  125. break;
  126. }
  127. }
  128. }
  129. Thread.Sleep(1000);
  130. }), "订单制作");
  131. }
  132. public void DataParse<T>(T order)
  133. {
  134. if (order is MorkOrderPush morkOrderPush)
  135. {
  136. morkOrderPushes.Enqueue(morkOrderPush);
  137. }
  138. }
  139. /// <summary>
  140. /// 验证当前是做咖啡还是做冰淇淋
  141. /// </summary>
  142. /// <param name="batchingLoc">物料位置</param>
  143. private GOODS_TYPE ValidateGoodsByBatching(string batchingLoc)
  144. {
  145. if (batchings.ContainsKey(batchingLoc))
  146. return batchings[batchingLoc].GoodsType;
  147. return GOODS_TYPE.NEITHER;
  148. }
  149. private AutoResetEvent are = new AutoResetEvent(false);
  150. /// <summary>
  151. /// 做咖啡
  152. /// </summary>
  153. private void DoCoffee()
  154. {
  155. //订单状态改变:开始制作
  156. SimpleFactory.GetInstance.OrderChanged(subOrderId, BPA.Message.Enum.ORDER_STATUS.COOKING);
  157. //todo:先调用机器人
  158. ThreadOperate.GetInstance.Start(new Action(() => { LebaiHelper.GetInstance.Scene(10002); }), "调用乐百机器人做咖啡场景");
  159. while (!(lebai.Ok && lebai.Value == 1))
  160. {
  161. Thread.Sleep(5);
  162. }
  163. //todo:咖啡杯下杯
  164. MessageLog.GetInstance.Show("咖啡杯取杯完成");
  165. LebaiHelper.GetInstance.SetValue(100);
  166. while (!(lebai.Ok && lebai.Value == 2))
  167. {
  168. Thread.Sleep(5);
  169. }
  170. MessageLog.GetInstance.Show("机器人到达接咖啡口位置");
  171. new MakeCoffeeEvent() { DrinkCode = (DrCoffeeDrinksCode)int.Parse(mainMaterialLoc) }.Publish();
  172. are.WaitOne(1000 * 180);
  173. MessageLog.GetInstance.Show("咖啡机制作咖啡完成");
  174. LebaiHelper.GetInstance.SetValue(101);
  175. while (!(lebai.Ok && lebai.Value == 3))
  176. {
  177. Thread.Sleep(5);
  178. }
  179. MessageLog.GetInstance.Show("机器人到达接咖啡口位置");
  180. //订单状态改变:完成
  181. SimpleFactory.GetInstance.OrderChanged(subOrderId, BPA.Message.Enum.ORDER_STATUS.COMPLETED_COOK);
  182. }
  183. /// <summary>
  184. /// 做冰淇淋
  185. /// </summary>
  186. private void DoIceCream()
  187. {
  188. //订单状态改变:开始制作
  189. SimpleFactory.GetInstance.OrderChanged(subOrderId, BPA.Message.Enum.ORDER_STATUS.COOKING);
  190. //todo:先调用机器人
  191. ThreadOperate.GetInstance.Start(new Action(() => { LebaiHelper.GetInstance.Scene(10001); }), "调用乐百机器人做冰淇淋场景");
  192. while (!(lebai.Ok && lebai.Value == 1))
  193. {
  194. Thread.Sleep(5);
  195. }
  196. new TakeCupEvent() { Cup = IC_CUP.CUP_ICECREAM }.Publish();
  197. while (!ChipStatus.GetInstance().CompletedTake_CPU_CUP_ICECREAM) { Thread.Sleep(5); }
  198. new MakeIceCreamEvent() { SteeringEngine = IC_SE.SE_1 }.Publish();
  199. LebaiHelper.GetInstance.SetValue(100);
  200. //are.WaitOne(100 * 90);
  201. //订单状态改变:完成
  202. SimpleFactory.GetInstance.OrderChanged(subOrderId, BPA.Message.Enum.ORDER_STATUS.COMPLETED_COOK);
  203. }
  204. private void CoffeEndCookHandle(IEvent @event, EventBus.EventCallBackHandle callBack)
  205. {
  206. are.Set();
  207. }
  208. public void Main()
  209. {
  210. //咖啡机开启主线程
  211. coffeeMachine.Start();
  212. //冰淇淋机开启主线程
  213. iceCreamMachine.Start();
  214. new ModeSetEvent() { Mode = MORKI_MODE.制冷模式 }.Publish();
  215. //开始心跳刷新,根据咖啡机及冰淇淋机来判断
  216. ThreadOperate.GetInstance.StartLong(new Action(() =>
  217. {
  218. //GeneralConfig.Healthy = true;
  219. //GeneralConfig.Healthy =
  220. // LebaiHelper.GetInstance.IsConnected &&
  221. // MorkIStatus.GetInstance().CanDo &&
  222. // MorkCStatus.GetInstance().CanDo;
  223. GeneralConfig.Healthy =
  224. LebaiHelper.GetInstance.IsConnected &&
  225. MorkCStatus.GetInstance().CanDo;
  226. Thread.Sleep(100);
  227. }), "MORK-IC心跳刷新");
  228. }
  229. public void ReadData()
  230. {
  231. ThreadOperate.GetInstance.StartLong(new Action(() =>
  232. {
  233. lebai = LebaiHelper.GetInstance.GetValueAsync();
  234. LebaiHelper.GetInstance.GetRobotModeStatus();
  235. Thread.Sleep(100);
  236. }), "乐百机器人数据读取");
  237. }
  238. public void SimOrder<T>(T simOrder)
  239. {
  240. //ThreadOperate.GetInstance.Start(new Action(() =>
  241. //{
  242. // DoIceCream();
  243. // //DoCoffee();
  244. //}), "aaa");
  245. }
  246. /// <summary>
  247. /// IOT 广播消息命令
  248. /// </summary>
  249. public void IotBroadcast<T>(T broadcast)
  250. {
  251. if (broadcast != null && broadcast is IOTCommandModel iOTCommand)
  252. {
  253. switch (iOTCommand.CommandName)
  254. {
  255. case 0://控制类
  256. if (iOTCommand.CommandValue != null)
  257. {
  258. if (iOTCommand.CommandValue.ContainsKey("SimOrder"))
  259. {
  260. SimOrder(new SimOrderData { NoodleLoc = 1, BowlLoc = 10 });
  261. }
  262. }
  263. break;
  264. case 1://设置属性
  265. break;
  266. case 2://通知消息
  267. break;
  268. default:
  269. break;
  270. }
  271. }
  272. }
  273. }
  274. }