ConvPlc03.cs 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  1. using System;
  2. using System.Linq;
  3. using WCS.Data;
  4. using WCS.Data.Models;
  5. using WCS.Data.Utils;
  6. using WCS.PLC;
  7. using WCS.PLC.Model.Equipment;
  8. namespace WCS.Workflow
  9. {
  10. public class ConvPlc03 : Base_Conv
  11. {
  12. #region 只读变量
  13. private readonly string Conv_1390 = "1390";
  14. private readonly string Conv_1418 = "1418";
  15. private readonly string Conv_1401 = "1401";
  16. private readonly string Conv_1416 = "1416";
  17. #endregion 只读变量
  18. public override void Run()
  19. {
  20. Conv_ScanBarCodeExeTask();
  21. ConvTaskFinish();
  22. }
  23. private void ConvTaskFinish()
  24. {
  25. ConveyorTaskFinish(PlcName, Conv_1401, false, true);
  26. ConveyorTaskFinish(PlcName, Conv_1416, false, true);
  27. ConveyorTaskFinish();
  28. }
  29. public void ConveyorTaskFinish()
  30. {
  31. try
  32. {
  33. //调用函数完成任务
  34. string result = TryCachHelper.TryExecute((db) =>
  35. {
  36. var task = db.Queryable<WCS_TASK>().First(v => v.TASK_POSIDTO == Conv_1418 && v.TASK_WKSTATUS < 99);
  37. if (task == null) return;
  38. //修改任务的状态
  39. db.Updateable<WCS_TASK>(it => new WCS_TASK() { TASK_WKSTATUS = 99, TASK_EDITUSERNO = "WCS", TASK_EDITDATETIME = DateTime.Now })
  40. .Where(it => it.TASK_NO == task.TASK_NO)
  41. .ExecuteCommand();
  42. });
  43. if (!string.IsNullOrWhiteSpace(result))
  44. {
  45. throw new Exception(result);
  46. }
  47. }
  48. catch (Exception ex)
  49. {
  50. LogMessageHelper.RecordLogMessage(ex);
  51. }
  52. }
  53. /// <summary>
  54. /// 输送线任务完成
  55. /// </summary>
  56. /// <param name="plcName">Plc</param>
  57. /// <param name="convNo">输送线出口</param>
  58. /// <param name="isCheckEndPos">是否检测当前地址和任务目标地址一致</param>
  59. /// <param name="isTaskDelete">是否删除输送线任务</param>
  60. public override void ConveyorTaskFinish(string plcName, string convNo, bool isCheckEndPos = true, bool isTaskDelete = false)
  61. {
  62. try
  63. {
  64. var plc = Current.PlcSet.FirstOrDefault(v => v.PLC_NAME == plcName);
  65. var conveyorTo = plc.WCS_EquipmentInfoSet.FirstOrDefault(v => v.Equ_No == convNo);
  66. var cs = conveyorTo.EquSignal_Conv;
  67. if (cs.DB521_Tasknum > 0 && cs.DB521_Request)
  68. {
  69. if (convNo == "1401" || convNo == "1416")
  70. {
  71. Log4netHelper.Logger_Info.InfoFormat(string.Format("工位[{0}]获取删除任务请求信号成功!", convNo));
  72. }
  73. //调用函数完成任务
  74. string result = TryCachHelper.TryExecute((db) =>
  75. {
  76. WCS_TASK taskcur = db.Queryable<WCS_TASK>().First(v => v.TASK_NO == cs.DB521_Tasknum && v.TASK_WKSTATUS < 99);
  77. if (taskcur == null) return;
  78. if (isCheckEndPos)
  79. {
  80. if (taskcur.TASK_COMTYPE != 6 && taskcur.TASK_POSIDTO != convNo) return;
  81. }
  82. //任务类型不是出库/搬运/移动类型
  83. if (taskcur.TASK_COMTYPE != 2 && taskcur.TASK_COMTYPE != 4 && taskcur.TASK_COMTYPE != 5) return;
  84. //var task = db.Queryable<WCS_TASK>().First(v => v.TASK_WKSTATUS == 99 && v.TASK_POSIDFROM == "1390" && v.TASK_POSIDTO == taskcur.TASK_POSIDTO);
  85. //if (task == null)
  86. //{
  87. //修改任务的状态
  88. db.Updateable<WCS_TASK>(it => new WCS_TASK() { TASK_WKSTATUS = 99, TASK_EDITUSERNO = "WCS", TASK_EDITDATETIME = DateTime.Now })
  89. .Where(it => it.TASK_NO == taskcur.TASK_NO)
  90. .ExecuteCommand();
  91. //}
  92. //else
  93. //{
  94. // BaseWorkflow.AddLedErrorMsg(convNo, string.Format("目标工位[{0}]上一个箱子[{1}]存在未完成任务[{2}]",task.TASK_POSIDTO, task.TASK_BOXBARCODE,task.TASK_NO), 0);
  95. // // LogMessageHelper.RecordLogMessage(string.Format("上一个箱子[{0}]存在未完成任务", task.TASK_BOXBARCODE, task.TASK_NO), true, LogLevelEnum.INFO.ToString());
  96. // throw new Exception(string.Format("目标工位[{0}]上一个箱子[{1}]存在未完成任务[{2}]", task.TASK_POSIDTO, task.TASK_BOXBARCODE, task.TASK_NO));
  97. //}
  98. });
  99. if (!string.IsNullOrWhiteSpace(result))
  100. {
  101. throw new Exception(result);
  102. }
  103. else
  104. {
  105. if (convNo == "1401" || convNo == "1416")
  106. {
  107. Log4netHelper.Logger_Info.InfoFormat(string.Format("工位[{0}]任务[{1}]标识完成成功!", convNo, cs.DB521_Tasknum));
  108. }
  109. }
  110. if (isTaskDelete)
  111. {
  112. if (cs.DB521_Tasknum > 0 && cs.DB523_Fault == false && cs.CvDB51_PH_Status == false
  113. //&& cs.DB521_Goodsend == Convert.ToInt32(convNo)
  114. && cs.DB521_Request)
  115. {
  116. var converywrite = new WCSWriteToConveyorSignal()
  117. {
  118. Plc = plc.Plc,
  119. DBName = plc.WriteDBName,
  120. ConveyorNo = convNo,
  121. WriteStartAddress = cs.EquDbInfo_ReadWrite.DBReadIndox,
  122. TaskDelete = true
  123. };
  124. WriteInfoToConv(cs, converywrite, true);
  125. }
  126. }
  127. }
  128. }
  129. catch (Exception ex)
  130. {
  131. LogMessageHelper.RecordLogMessage(ex);
  132. }
  133. }
  134. private void Conv_ScanBarCodeExeTask()
  135. {
  136. Conv_ScanningRequest(Conv_1390, Current.Pvchouseputong, Conv_1418);
  137. }
  138. public string TranslationBarCode(string barCode)
  139. {
  140. var arr = barCode.Split('}');
  141. return arr[1];
  142. }
  143. protected virtual void Conv_ScanningRequest(string convPosFrom, string warehouseid, string exitNo = "")
  144. {
  145. try
  146. {
  147. var plc = Current.PlcSet.FirstOrDefault(v => v.PLC_NAME == PlcName);
  148. var conveyor = plc.WCS_EquipmentInfoSet.FirstOrDefault(v => v.Equ_No == convPosFrom);
  149. var cs = conveyor.EquSignal_Conv;
  150. if (!cs.DB521_Request) return;
  151. if (cs.DB520_Confirm) return;
  152. WCS_TASK task = QueryTaskByCode(cs, convPosFrom, exitNo);
  153. if (task == null)
  154. {
  155. if (WcsScanConvIsUsed(convPosFrom))
  156. {
  157. string code = TranslationBarCode(cs.BarCodeStr);
  158. var param = new GetInTaskParam()
  159. {
  160. ContainerBarCode = code,
  161. ContainerType = 1,
  162. MatBarCode = string.Empty,
  163. WareHouseId = warehouseid,
  164. EquipmentNo = convPosFrom,
  165. EndPostion = string.Empty,
  166. Memo2 = exitNo
  167. };
  168. task = BaseWorkflow.GetWcsInTask(param);
  169. }
  170. }
  171. if (task == null) return;
  172. //判断任务是否已经执行
  173. if (task.TASK_WKSTATUS >= 2)
  174. {
  175. if (task.TASK_POSIDFROM != task.TASK_POSIDCUR)
  176. {
  177. task = SugarBase.DB.Queryable<WCS_TASK>().First(v => v.TASK_POSIDFROM == convPosFrom && v.TASK_POSIDCUR == convPosFrom && v.TASK_COMTYPE == 6);
  178. if (task == null)
  179. {
  180. #region 重码异常口排出
  181. string message = string.Format("条码[{0}]是重码。", cs.BarCodeStr);
  182. LogMessageHelper.RecordLogMessage(message);
  183. var wcstask = new WCS_TASK()
  184. {
  185. TASK_WMSNO = "wcs_" + DateTime.Now.ToString("yyyyMMddhhmmss"),
  186. TASK_COMTYPE = (int)ComTypeEnum.托盘异常退回,
  187. TASK_SYSTYPE = "WCS",
  188. TASK_POSIDFROM = convPosFrom,//起点地址
  189. TASK_POSIDCUR = convPosFrom,
  190. TASK_POSIDNEXT = convPosFrom,
  191. TASK_POSIDMOVE = "",
  192. TASK_PRIORITY = 1,
  193. TASK_WKSTATUS = 1,
  194. TASK_WHID = Current.Pvchouseputong,
  195. TASK_ADDUSERNO = "WCS",
  196. TASK_ADDDATETIME = DateTime.Now,
  197. TASK_EDITUSERNO = "WCS",
  198. TASK_EDITDATETIME = DateTime.Now,
  199. TASK_NOTES = "",
  200. TASK_RGVNO = "",
  201. TASK_BOXBARCODE = "MultipleCoding_" + DateTime.Now.ToString("yyyyMMddhhmmss"),
  202. TASK_POSIDTO = Conv_1418
  203. };
  204. string result = TryCachHelper.TryTranExecute((db) =>
  205. {
  206. int id = db.Insertable(wcstask).ExecuteReturnIdentity();
  207. if (id <= 0)
  208. {
  209. throw new Exception(string.Format("重码[{0}]添加异常排出任务失败。", cs.BarCodeStr));
  210. }
  211. else
  212. {
  213. wcstask.TASK_NO = id;
  214. }
  215. var task_dtl = new WCS_TASK_DTL()
  216. {
  217. ID = Guid.NewGuid().ToString(),
  218. PARENTID = wcstask.TASK_NO,
  219. TASKNO = wcstask.TASK_NO,
  220. POSIDCUR = convPosFrom,
  221. POSIDNEXT = convPosFrom,
  222. DESCRIPTION = message,
  223. EXECUTEDATE = DateTime.Now
  224. };
  225. db.Insertable(task_dtl).ExecuteReturnIdentity();
  226. BaseWorkflow.AddLedErrorMsg(db, convPosFrom, message, wcstask.TASK_NO, 100);
  227. });
  228. if (!string.IsNullOrWhiteSpace(result))
  229. {
  230. throw new Exception(result);
  231. }
  232. #endregion 重码异常口排出
  233. }
  234. }
  235. }
  236. if (task.TASK_WKSTATUS >= 2) return;
  237. //WCS_PalletizingCode palletizingCode = null;
  238. if (task.TASK_COMTYPE != 6)
  239. {
  240. //var PalletizingCodeSet = SugarBase.DB.Queryable<WCS_PalletizingCode>().ToList();
  241. //palletizingCode = Current.IsAvailableRange_BoxSize(PalletizingCodeSet, task.PalletizingBoxSize, task.TASK_NO);
  242. //palletizingCode = PalletizingCodeSet.FirstOrDefault(v => v.IsAvailableRange_BoxSize(task.PalletizingBoxSize, task.TASK_NO));
  243. if (task == null)
  244. {
  245. throw new Exception(string.Format("输送线[{0}]任务[{1}]未获取到码垛清单,请维护码垛信息.", convPosFrom, task.TASK_NO));
  246. }
  247. }
  248. bool notask = false;
  249. int goodsend = 0;
  250. if (task.TASK_COMTYPE == (int)ComTypeEnum.托盘异常退回)
  251. {
  252. notask = true;
  253. goodsend = Convert.ToInt32(exitNo);
  254. }
  255. else
  256. {
  257. var routeSet = EquRouteHelper.QueryRoute(convPosFrom, task.TASK_POSIDTO);
  258. var routes = routeSet.Where(v => v.ROUTE_STARTPOS == convPosFrom).ToList();
  259. if (routes.Count() == 0)
  260. {
  261. throw new Exception(string.Format("输送线扫描位置[{0}]任务[{1}]查询路由失败。", convPosFrom, task.TASK_NO));
  262. }
  263. else
  264. {
  265. goodsend = Convert.ToInt32(routes.First().ROUTE_SONPOS);
  266. }
  267. }
  268. if (goodsend == 0) return;
  269. var converywrite = new WCSWriteToConveyorSignal()
  270. {
  271. Plc = plc.Plc,
  272. DBName = plc.WriteDBName,
  273. ConveyorNo = convPosFrom,
  274. WriteStartAddress = cs.EquDbInfo_ReadWrite.DBReadIndox,
  275. Tasknum = task.TASK_NO,
  276. Goodstype = Convert.ToInt32(task.TASK_POSIDTO),
  277. Goodssize = task.TASK_COMTYPE != 6 ? Convert.ToInt32(task.PalletizingBoxSize) : 0,
  278. Goodsstart = Convert.ToInt32(convPosFrom),
  279. //UpMatRequest = task.TASK_ORDERTYPE >= 1 ? true : false,
  280. TASK_WEIGHT = task.TASK_COMTYPE != 6 ? Convert.ToInt32(task.TASK_WEIGHT) : 0,
  281. Notask = notask,
  282. Goodsend = goodsend
  283. };
  284. WriteInfoToConv(cs, converywrite);
  285. }
  286. catch (Exception ex)
  287. {
  288. BaseWorkflow.AddLedErrorMsg(convPosFrom, ex.Message, 0);
  289. LogMessageHelper.RecordLogMessage(ex);
  290. }
  291. }
  292. protected WCS_TASK QueryTaskByCode(ConvSignal cs, string convPosFrom, string exitNo)
  293. {
  294. WCS_TASK task = null;
  295. if (cs.DB521_BCR_Noread)
  296. {
  297. task = Current.TaskSet.SingleOrDefault(v => v.TASK_POSIDFROM == convPosFrom && v.TASK_POSIDCUR == convPosFrom);
  298. if (task == null)
  299. {
  300. string errormsg = string.Format("箱式输送线[{0}]条码未读出。", convPosFrom);
  301. LogMessageHelper.RecordLogMessage(errormsg);
  302. BaseWorkflow.AddLedErrorMsg(convPosFrom, errormsg, 0);
  303. string wmsno = "wcs_" + DateTime.Now.ToString("yyyyMMddhhmmss");
  304. //wms任务异常需要生成退回托盘任务
  305. task = new WCS_TASK()
  306. {
  307. TASK_WMSNO = wmsno,
  308. TASK_COMTYPE = (int)ComTypeEnum.托盘异常退回,
  309. TASK_SYSTYPE = "WCS",
  310. TASK_POSIDFROM = convPosFrom,//起点地址
  311. TASK_POSIDCUR = convPosFrom,
  312. TASK_POSIDNEXT = convPosFrom,
  313. TASK_POSIDMOVE = "",
  314. TASK_PRIORITY = 1,
  315. TASK_WKSTATUS = 1,
  316. TASK_WHID = "PVC普通立库",
  317. TASK_ADDUSERNO = "WCS",
  318. TASK_ADDDATETIME = DateTime.Now,
  319. TASK_EDITUSERNO = "WCS",
  320. TASK_EDITDATETIME = DateTime.Now,
  321. TASK_NOTES = "",
  322. TASK_RGVNO = "",
  323. TASK_BOXBARCODE = wmsno,
  324. TASK_POSIDTO = exitNo
  325. };
  326. int id = SugarBase.DB.Insertable(task).ExecuteReturnIdentity();
  327. if (id <= 0)
  328. {
  329. throw new Exception(string.Format("添加WCS读码异常任务失败"));
  330. }
  331. else
  332. {
  333. task.TASK_NO = id;
  334. }
  335. var task_dtl = new WCS_TASK_DTL()
  336. {
  337. ID = Guid.NewGuid().ToString(),
  338. PARENTID = task.TASK_NO,
  339. TASKNO = task.TASK_NO,
  340. POSIDCUR = convPosFrom,
  341. POSIDNEXT = convPosFrom,
  342. DESCRIPTION = errormsg,
  343. EXECUTEDATE = DateTime.Now
  344. };
  345. SugarBase.DB.Insertable(task_dtl).ExecuteReturnIdentity();
  346. }
  347. }
  348. else
  349. {
  350. if (string.IsNullOrWhiteSpace(cs.BarCodeStr)) throw new Exception(string.Format("输送线[{0}]存在请求信号,但没读取到条码信息。", convPosFrom));
  351. if (cs.BarCodeStr.ToUpper().Contains("ERROR") ||
  352. cs.BarCodeStr.ToUpper().Contains("N") ||
  353. cs.BarCodeStr.Contains("?"))
  354. {
  355. throw new Exception(string.Format("输送线[{0}]存在请求信号,但条码是:[{1}]存在报错,PLC应该报条码错误信号", convPosFrom, cs.BarCodeStr));
  356. }
  357. }
  358. if (task == null)
  359. {
  360. string code = TranslationBarCode(cs.BarCodeStr);
  361. task = Current.TaskSet.FirstOrDefault(v => v.TASK_BOXBARCODE == code);
  362. }
  363. if (task == null)
  364. {
  365. task = Current.TaskSet.FirstOrDefault(v => v.TASK_POSIDFROM == convPosFrom && v.TASK_POSIDCUR == convPosFrom && v.TASK_POSIDNEXT == convPosFrom && v.TASK_COMTYPE == (int)ComTypeEnum.托盘异常退回);
  366. }
  367. //if (task != null && task.TASK_COMTYPE == (int)ComTypeEnum.托盘异常退回 && task.TASK_WKSTATUS == 2)
  368. //{
  369. // int updateResult = SugarBase.DB.Updateable<WCS_TASK>(it => new WCS_TASK() { TASK_WKSTATUS = 99, TASK_EDITUSERNO = "wcs", TASK_EDITDATETIME = DateTime.Now })
  370. // .Where(it => it.TASK_NO == task.TASK_NO)
  371. // .ExecuteCommand();
  372. // if (updateResult <= 0)
  373. // {
  374. // throw new Exception(string.Format("异常任务[{0}]结束失败。", task.TASK_NO));
  375. // }
  376. // task = null;
  377. //}
  378. return task;
  379. }
  380. }
  381. }