frmMain.cs 46 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029
  1. using com.hnshituo.core.webapp.vo;
  2. using Newtonsoft.Json;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.ComponentModel;
  6. using System.Data;
  7. using System.Diagnostics;
  8. using System.Drawing;
  9. using System.Drawing.Drawing2D;
  10. using System.IO;
  11. using System.Linq;
  12. using System.Net.NetworkInformation;
  13. using System.Runtime.InteropServices;
  14. using System.Text;
  15. using System.Threading;
  16. using System.Threading.Tasks;
  17. using System.Windows.Forms;
  18. namespace CarLocalMeter
  19. {
  20. public partial class frmMain : Form
  21. {
  22. public frmMain()
  23. {
  24. InitializeComponent();
  25. }
  26. Log lg = Log.GetInstance();
  27. private LED_Control led_controler;
  28. //List<CamerEs> lc = new List<CamerEs>();
  29. /// <summary>
  30. /// 硬盘录像机图片抓拍通道
  31. /// </summary>
  32. List<int> lc = new List<int>();
  33. /// <summary>
  34. /// 服务端委托获取
  35. /// </summary>
  36. private PreTrackScaleService PreTrackScaleService = new PreTrackScaleService();
  37. RESTfulResult<List<PreTrackScale>> rmScaleListCarTimer = new RESTfulResult<List<PreTrackScale>>();
  38. private MeterWorkCarActualFirstService workCarActualFirstService = new MeterWorkCarActualFirstService(); //一次计量数据
  39. RESTfulResult<List<MeterWorkCarActualFirst>> RESTfulResultOutTimer = new RESTfulResult<List<MeterWorkCarActualFirst>>();
  40. PlcCls plc = new PlcCls();
  41. /// <summary>
  42. /// redis操作类
  43. /// </summary>
  44. RedisOption redis = new RedisOption();
  45. /// <summary>
  46. /// 图片操作类
  47. /// </summary>
  48. ImageOption imgControl = new ImageOption();
  49. /// <summary>
  50. /// 重量采集类
  51. /// </summary>
  52. MoxaCls mx = new MoxaCls();
  53. ComCls cx = new ComCls();
  54. /// <summary>
  55. /// 语音播放
  56. /// </summary>
  57. VoicePlay vicPlayClass = new VoicePlay();
  58. /// <summary>
  59. /// 摄像头车号识别枪机
  60. /// </summary>
  61. CarNoCls carCls = new CarNoCls();
  62. /// <summary>
  63. /// 摄像头识别球机
  64. /// </summary>
  65. CarNoCls carCls2 = new CarNoCls();
  66. /// <summary>
  67. /// rfid车号识别
  68. /// </summary>
  69. RfIdCarNo rfid = new RfIdCarNo();
  70. /// <summary>
  71. /// Ping服务器服务是否通
  72. /// </summary>
  73. PingNetwork ping = new PingNetwork();
  74. /// <summary>
  75. /// 本地离线计量的数据上传
  76. /// </summary>
  77. DbUpload upload = new DbUpload();
  78. /// <summary>
  79. /// 以下是硬盘录像机的控制
  80. /// </summary>
  81. bool bVoice = false;
  82. CamerEs ce = new CamerEs(AppConfigCache.voicePlayIp, $"{AppConfigCache.voicePlayPort}", AppConfigCache.voicePlayUid, AppConfigCache.voicePlayPwd);
  83. List<int> voPlay = new List<int>();
  84. int iPic = 0;
  85. private void frmMain_Load(object sender, EventArgs e)
  86. {
  87. CacleCls.updateRfidInfoTime = DateTime.Now;
  88. btnSave.Enabled = false;
  89. if (!string.IsNullOrEmpty(AppConfigCache.ledIp))
  90. {
  91. led_controler = new LED_Control(AppConfigCache.ledIp);
  92. }
  93. #region 读取音频文件名称
  94. List<string> ls = new List<string>();
  95. DirectoryInfo folder = new DirectoryInfo(AppConfigCache.path + "\\Sound");
  96. foreach (FileInfo file in folder.GetFiles("*.wav"))
  97. {
  98. ls.Add(file.Name.Replace(".wav", ""));
  99. }
  100. CacleCls.voiceInfo = ls;
  101. #endregion
  102. string[] strTd1 = AppConfigCache.channelOther.Split(',');
  103. string[] strTd2 = AppConfigCache.channelVis.Split(',');
  104. string[] strAll = new string[strTd1.Length + strTd2.Length];
  105. strTd1.CopyTo(strAll, 0);
  106. strTd2.CopyTo(strAll, strTd1.Length);
  107. List<string> lcs = strAll.Distinct().OrderBy(s => s).ToList(); //
  108. lc.Add(AppConfigCache.channelCarNo);
  109. foreach (string str in lcs)
  110. {
  111. if ($"{AppConfigCache.channel}" != str && $"{AppConfigCache.channelCarNo}" != str)
  112. {
  113. lc.Add(Convert.ToInt32(str)); //抓拍通道与数组中不相同的时候写入,因为我们仪表抓拍的通道需单独进行处理
  114. }
  115. }
  116. plImgShow.Visible = false;
  117. lbPointName.Text = AppConfigCache.pointName;
  118. foreach (string str in AppConfigCache.channelVis.Split(','))
  119. {
  120. voPlay.Add(Convert.ToInt32(str));
  121. }
  122. ce.Connection();
  123. foreach(int i in voPlay)
  124. {
  125. PictureBox pb = new PictureBox();
  126. pb.Dock = DockStyle.Top;
  127. pb.DoubleClick += new EventHandler(PictureBoxDoubleClick);
  128. pb.Height = AppConfigCache.channelVisHeight;
  129. pb.Name = $"pb{i}";
  130. panel1.Controls.Add(pb);
  131. ce.RealPlay(pb, i);
  132. }
  133. if (AppConfigCache.plcStart == "1") plc.Start();
  134. //*
  135. ping.start();
  136. upload.start();
  137. if(AppConfigCache.getWgtType=="0")
  138. cx.start();
  139. else
  140. mx.start();
  141. rfid.Start();
  142. imgControl.Start();
  143. carCls.Login(AppConfigCache.voiceCarNoIp, AppConfigCache.voiceCarNoPort, AppConfigCache.voiceCarNoUid, AppConfigCache.voiceCarNoPwd);
  144. //*/
  145. if (AppConfigCache.openVoice.Contains("2"))
  146. {
  147. carCls2.Login(AppConfigCache.voiceCarNoIp2, AppConfigCache.voiceCarNoPort2, AppConfigCache.voiceCarNoUid2, AppConfigCache.voiceCarNoPwd2, false);
  148. }
  149. //
  150. blThreadFlag = true;
  151. DataCollectThread = new Thread(new ThreadStart(DataCollect));
  152. start();
  153. txtMsgInfo.Focus();
  154. }
  155. #region 本地主逻辑判断线程
  156. bool blThreadFlag;//数据采集线程开关
  157. Thread DataCollectThread = null;//采集进程
  158. bool getPreInfo = false, getFirst = false, flagCaption = false, isVoiceDownCar = false;
  159. string strOldCarNo = "";
  160. bool isMeasureSuccess = false;
  161. int voiceNum = 0;
  162. private void start() => DataCollectThread.Start();
  163. private void stop() => blThreadFlag = false;
  164. private void DataCollect()
  165. {
  166. if (!blThreadFlag) return;
  167. int iError = 0;
  168. while (blThreadFlag)
  169. {
  170. try
  171. {
  172. this.panel3.Invoke(new Action(() => {
  173. if (!CacleCls.isLock)
  174. {
  175. ucWeightT1.setWgt(Math.Round((double)CacleCls.weight / 1000, 2)); //2021年5月10日界面显示单位,调整为T
  176. ucWeightT1.setStable(CacleCls.isWd != 1 ? true : false);
  177. ucWeightT1.setExceed(CacleCls.weight > AppConfigCache.maxRange * 1000 ? false : true);
  178. if (cbCarNo.Text.Trim() != "" && txtCarNo.Text.Trim() != "" && !txtCarNo.Focused)
  179. {
  180. CacleCls.lockCarNo = cbCarNo.Text.Trim() + txtCarNo.Text.Trim();
  181. }
  182. else if (!string.IsNullOrEmpty(CacleCls.rfidCarNo))
  183. {
  184. CacleCls.lockCarNo = CacleCls.rfidCarNo;
  185. }
  186. else if (!string.IsNullOrEmpty(CacleCls.voicCarNo))
  187. {
  188. CacleCls.lockCarNo = CacleCls.voicCarNo;
  189. }
  190. else if (!string.IsNullOrEmpty(CacleCls.voicCarNo2))
  191. {
  192. CacleCls.lockCarNo = CacleCls.voicCarNo2;
  193. }
  194. if (!string.IsNullOrEmpty(CacleCls.lockCarNo) && cbCarNo.Text.Trim() == "" && txtCarNo.Text.Trim() == "")
  195. {
  196. cbCarNo.Text = CacleCls.lockCarNo.Substring(0, 1);
  197. if (CacleCls.lockCarNo.Length > 1)
  198. {
  199. txtCarNo.Text = CacleCls.lockCarNo.Substring(1);
  200. }
  201. }
  202. if (strOldCarNo != CacleCls.lockCarNo)
  203. {
  204. strOldCarNo = CacleCls.lockCarNo;
  205. getPreInfo = false;
  206. getFirst = false;
  207. }
  208. }
  209. iError = 1;
  210. //是否能连上远程服务器,这里只是服务器,不是服务器上的服务端
  211. pbLineOn.Load(CacleCls.serverFlag ? (AppConfigCache.path + "\\image\\icon\\green.gif") : (AppConfigCache.path + "\\image\\icon\\red.gif"));
  212. iError = 2;
  213. if (CacleCls.weight > 500)
  214. {
  215. iError = 21;
  216. CacleCls.isClear = false;
  217. #region 一些必要验证及提醒
  218. if (!CacleCls.isLock)
  219. {
  220. //重量最后一位不为0也是超量程
  221. if ((AppConfigCache.maxRange * 1000 < CacleCls.weight) || CacleCls.weight.ToString().Substring(CacleCls.weight.ToString().Length - 1, 1) != "0")
  222. {
  223. //超量程
  224. vicPlayClass.GetVoicePlay(VoiceEnum.车辆超重, CacleCls.lockCarNo);
  225. txtMsgInfo.Text = "当前重量已超量程,秤体量程为【" + AppConfigCache.maxRange + "】T,不允许进行自助计量操作!";
  226. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "当前重量已超量程,秤体量程为【" + AppConfigCache.maxRange + "】T,不允许进行自助计量操作!");
  227. CacleCls.isLock = false;
  228. return;
  229. }
  230. iError = 22;
  231. if (CacleCls.isWd == 0 && !string.IsNullOrEmpty(CacleCls.lockCarNo))
  232. {
  233. if ((CacleCls.topJg == "1" || CacleCls.bottomJg == "1"))
  234. {
  235. //重量稳定,且对射验证不合格
  236. vicPlayClass.GetVoicePlay(VoiceEnum.车辆未停到位, CacleCls.lockCarNo);
  237. txtMsgInfo.Text = "车辆超出秤台,请调整车位2";
  238. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车辆超出秤台,请调整车位2");
  239. CacleCls.isLock = false;
  240. return;
  241. }
  242. else if (CacleCls.rightGs == "1")
  243. {
  244. //重量稳定,且右光栅不合格
  245. vicPlayClass.GetVoicePlay(VoiceEnum.车辆未停到位, CacleCls.lockCarNo);
  246. txtMsgInfo.Text = "车辆超出秤台,请调整车位3";
  247. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车辆超出秤台,请调整车位3");
  248. CacleCls.isLock = false;
  249. return;
  250. }
  251. else if (CacleCls.leftGs == "1")
  252. {
  253. //重量稳定,且左光栅不合格
  254. vicPlayClass.GetVoicePlay(VoiceEnum.车辆未停到位, CacleCls.lockCarNo);
  255. txtMsgInfo.Text = "车辆超出秤台,请调整车位4";
  256. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车辆超出秤台,请调整车位4");
  257. CacleCls.isLock = false;
  258. return;
  259. }
  260. }
  261. iError = 23;
  262. /*
  263. if (PbCache.isOvertimeAlarm)
  264. {
  265. //停留超时提醒,不作为计量卡控的条件
  266. if (!isPlayOvertimeVoice && !PbCache.isLockFrm)
  267. {
  268. vicPlayClass.GetVoicePlay("停留超时", PbCache.collect.carno);
  269. led_controler.setStaticLineMsg(PbCache.sportInfo.ledIp, "停留超时");
  270. txtMsgInfo.Text = "停留超时";
  271. PbCache.ResultMessage = "停留超时";
  272. isPlayOvertimeVoice = true;
  273. return;
  274. }
  275. }
  276. //*/
  277. //进行计量称重条件的判断 车号不为空、重量稳定、车辆已停到位
  278. if (CacleCls.isWd == 0 && CacleCls.leftGs != "1" && CacleCls.rightGs != "1" && CacleCls.topJg != "1" && CacleCls.bottomJg != "1")
  279. {
  280. iError = 11;
  281. if (!string.IsNullOrEmpty(CacleCls.lockCarNo))
  282. {
  283. if (!isVoiceDownCar)
  284. {
  285. txtMsgInfo.Text = "";
  286. isVoiceDownCar = true;
  287. vicPlayClass.GetVoicePlay(VoiceEnum.开始计量, CacleCls.lockCarNo);//只播放一次
  288. }
  289. //if(!btnSave.Enabled) btnSave.Enabled = true;
  290. if (!CacleCls.isJg)
  291. {
  292. lg.WriteLog(LogType.SystemLog, CacleCls.lockCarNo + "开始保存:" + DateTime.Now.ToLongTimeString());
  293. btnSave_Click(null, null);
  294. }
  295. }
  296. else
  297. {
  298. txtMsgInfo.Text = "车号未识别";
  299. vicPlayClass.GetVoicePlay(VoiceEnum.车号未识别, "");
  300. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车号未识别");
  301. }
  302. iError = 12;
  303. }
  304. }
  305. #endregion
  306. //计量完成后进行语音播报,提示离开秤台,播报5次
  307. if (isMeasureSuccess)
  308. {
  309. if (voiceNum < AppConfigCache.voiceNum)
  310. {
  311. if (CacleCls.voiceOver)
  312. {
  313. if(flagPre)
  314. vicPlayClass.GetVoicePlay(VoiceEnum.计量完成, CacleCls.lockCarNo);
  315. else
  316. vicPlayClass.GetVoicePlay(VoiceEnum.计量完成多委托, CacleCls.lockCarNo);
  317. voiceNum++;
  318. }
  319. }
  320. return;
  321. }
  322. iError = 13;
  323. }
  324. else
  325. {
  326. iError = 31;
  327. voiceNum = 0;
  328. isMeasureSuccess = false;
  329. lockWgtImg = CacleCls.weight;
  330. getFirst = false;
  331. getPreInfo = false;
  332. flagCaption = false;
  333. isVoiceDownCar = false;
  334. strGuid = "";
  335. flagPre = true;
  336. if (!CacleCls.isClear)
  337. {
  338. iError = 32;
  339. CacleCls.Clear(); //清理一次数据
  340. txtMsgInfo.Focus();
  341. btnSave.Enabled = false;
  342. cbCarNo.Text = "";
  343. cbCarNo.SelectedIndex = -1;
  344. txtCarNo.Text = "";
  345. txtMATTER_NAME.Text = "";
  346. txtFORWARDING_UNIT_NAME.Text = "";
  347. txtRECEIVING_UINT_NAME.Text = "";
  348. txtMETER_TYPE.Text = "";
  349. cbCarNo.Enabled = true;
  350. txtCarNo.Enabled = true;
  351. txtMsgInfo.Text = "";
  352. txtGroess.Text = "";
  353. txtTare.Text = "";
  354. txtNet.Text = "";
  355. led_controler.setStaticLineMsg(AppConfigCache.ledIp, $"欢迎使用,智能计量");
  356. iError = 33;
  357. //释放一次内存
  358. FlushMemory();
  359. iError = 34;
  360. //
  361. imgControl.ZipFiles();
  362. iError = 35;
  363. }
  364. }
  365. }));
  366. }
  367. catch (Exception ex)
  368. {
  369. //在关闭程序后,由于线程还会跑一下,所以会有一个错误“调用方法时发生错误。 目标线程不再存在” 这个不影响
  370. lg.WriteLog(LogType.SystemLog, $"主逻辑判断线程,其i值为:{iError},异常信息为:{ex.Message}");
  371. }
  372. Thread.Sleep(AppConfigCache.sleepTime);
  373. }
  374. }
  375. #endregion
  376. int lockWgtImg = 0;
  377. string strGuid = "";
  378. bool flagPre = true;
  379. private void btnSave_Click(object sender, EventArgs e)
  380. {
  381. try
  382. {
  383. #region 下面是业务逻辑代码
  384. string msgInfo = "";
  385. if (txtCarNo.Focused) return; //如果正在修改车号,就必须等光标离开后再保存,否则容易导致车号输入了一半保存了
  386. if (CacleCls.isWd != 0) return;
  387. ucWeightT1.setStable(true); // 重量稳定
  388. ucWeightT1.setWgt(Math.Round((double)CacleCls.weight / 1000, 2)); // 最新重量
  389. CacleCls.lockWgt = CacleCls.weight;
  390. if (!CacleCls.lockWgt.ToString().EndsWith("0")) //个位不是0则说明超量程了
  391. {
  392. //txtMsgInfo.Text = "仪表重量[" + CacleCls.lockWgt + "]不是以0结尾,禁止计量操作!";
  393. vicPlayClass.GetVoicePlay(VoiceEnum.车辆超重, CacleCls.lockCarNo);
  394. txtMsgInfo.Text = "当前重量已超量程,秤体量程为【" + AppConfigCache.maxRange + "】T,不允许进行自助计量操作!";
  395. return;
  396. }
  397. //接管状态点的保存
  398. if (CacleCls.isJg)
  399. {
  400. if (string.IsNullOrEmpty(CacleCls.lockCarNo))
  401. {
  402. txtMsgInfo.Text = "没有车号,无法保存";
  403. return;
  404. }
  405. else if (CacleCls.lockWgt < 500)
  406. {
  407. txtMsgInfo.Text = "重量过小,无法保存";
  408. return;
  409. }
  410. else if (CacleCls.isWd != 0)
  411. {
  412. txtMsgInfo.Text = "重量不稳定,无法保存";
  413. return;
  414. }
  415. else if (CacleCls.leftGs == "1" || CacleCls.rightGs == "1" || CacleCls.topJg == "1" || CacleCls.bottomJg == "1")
  416. {
  417. txtMsgInfo.Text = "激光被遮挡,车辆未停到位,无法保存";
  418. return;
  419. }
  420. else
  421. {
  422. lg.WriteLog(LogType.SystemLog, CacleCls.lockCarNo + "接管状态下进行的保存:" + DateTime.Now.ToLongTimeString());
  423. }
  424. }
  425. //存在零点,且不为接管状态则禁止计量
  426. if (CacleCls.isZeroState && !CacleCls.isJg)
  427. {
  428. vicPlayClass.GetVoicePlay(VoiceEnum.仪表未归零, CacleCls.lockCarNo);
  429. txtMsgInfo.Text = "仪表未归零,无法计量,请联系大厅"; //btnSave_Click
  430. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "仪表未归零,无法计量");
  431. return;
  432. }
  433. if (!CacleCls.isJg && CacleCls.firstDb != null)
  434. {
  435. //*
  436. if (Math.Abs(CacleCls.firstDb.meterWeight.Value - CacleCls.lockWgt) < AppConfigCache.differenceWgt)
  437. {
  438. vicPlayClass.GetVoicePlay(VoiceEnum.结净重量过小, CacleCls.lockCarNo);
  439. txtMsgInfo.Text = "计量失败,结净重量过小";
  440. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,结净重量过小");
  441. return;
  442. }
  443. //*/
  444. }
  445. #region 获取一次数据跟车号
  446. if (!string.IsNullOrEmpty(CacleCls.lockCarNo) && CacleCls.serverFlag)
  447. {
  448. //查询一次计量数据
  449. if (!getFirst)
  450. {
  451. RESTfulResultOutTimer = workCarActualFirstService.doQueryWf(new MeterWorkCarActualFirst { valueFlag = "1", carNo = CacleCls.lockCarNo });
  452. if (RESTfulResultOutTimer.Succeed)
  453. {
  454. if (RESTfulResultOutTimer.Data != null && RESTfulResultOutTimer.Data.Count > 0)
  455. {
  456. if (RESTfulResultOutTimer.Data.Count == 1)
  457. {
  458. CacleCls.firstDb = RESTfulResultOutTimer.Data[0];
  459. if (CacleCls.firstDb.predictionNo != null && !CacleCls.firstDb.predictionNo.Contains("_"))
  460. {
  461. txtMATTER_NAME.Text = CacleCls.firstDb.matterName;
  462. txtFORWARDING_UNIT_NAME.Text = CacleCls.firstDb.forwardingUnitName;
  463. txtRECEIVING_UINT_NAME.Text = CacleCls.firstDb.receivingUintName;
  464. txtMETER_TYPE.Text = CacleCls.firstDb.meterTypeName;
  465. }
  466. }
  467. else
  468. {
  469. vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
  470. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
  471. txtMsgInfo.Text = $"存在{RESTfulResultOutTimer.Data.Count}条未结净的一次计量数据";
  472. lg.WriteLog(LogType.serverLog, $"存在{RESTfulResultOutTimer.Data.Count}条未结净的一次计量数据");
  473. CacleCls.isLock = false;
  474. return;
  475. }
  476. }
  477. }
  478. else
  479. {
  480. vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
  481. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
  482. txtMsgInfo.Text = "获取一次计量数据失败:" + RESTfulResultOutTimer.Message;
  483. lg.WriteLog(LogType.serverLog, "获取一次计量数据失败:" + RESTfulResultOutTimer.Message);
  484. CacleCls.isLock = false;
  485. return;
  486. }
  487. getFirst = true;
  488. }
  489. //根据网络状态及车号以及是否存在一次计量数据,查询一次预报信息,然后将getPreInfo改为true
  490. if (!getPreInfo)
  491. {
  492. if (CacleCls.firstDb != null)
  493. {
  494. //做结净的时候,才查询一次预报信息
  495. rmScaleListCarTimer = PreTrackScaleService.doQueryByFlag(new PreTrackScale { lineDesc = "0", carNo = CacleCls.lockCarNo });
  496. if (rmScaleListCarTimer.Succeed)
  497. {
  498. if (rmScaleListCarTimer.Data != null && rmScaleListCarTimer.Data.Count > 0)
  499. {
  500. CacleCls.preTrackScale = null;
  501. if (!string.IsNullOrEmpty(CacleCls.firstDb.predictionNo))
  502. {
  503. CacleCls.preTrackScale = rmScaleListCarTimer.Data.Where(s => s.predictionNo == CacleCls.firstDb.predictionNo).FirstOrDefault();
  504. }
  505. else
  506. {
  507. string strMat = "", strFor = "", strRec = "";
  508. foreach (PreTrackScale pr in rmScaleListCarTimer.Data)
  509. {
  510. if (strMat == "")
  511. {
  512. strMat = pr.matterNo;
  513. strFor = pr.forwardingUnitNo;
  514. strRec = pr.receivingUintNo;
  515. }
  516. else if (pr.matterNo != strMat || pr.forwardingUnitNo != strFor || pr.receivingUintNo != strRec)
  517. {
  518. flagPre = false;
  519. break;
  520. }
  521. }
  522. }
  523. if (flagPre && CacleCls.preTrackScale != null)
  524. {
  525. txtMATTER_NAME.Text = CacleCls.preTrackScale.matterName;
  526. txtFORWARDING_UNIT_NAME.Text = CacleCls.preTrackScale.forwardingUnitName;
  527. txtRECEIVING_UINT_NAME.Text = CacleCls.preTrackScale.receivingUintName;
  528. txtMETER_TYPE.Text = CacleCls.preTrackScale.meterTypeName;
  529. }
  530. }
  531. }
  532. }
  533. getPreInfo = true;
  534. }
  535. }
  536. #endregion
  537. lg.WriteLog(LogType.SystemLog, $"锁定车号:{CacleCls.lockCarNo},锁定重量:{CacleCls.lockWgt},rfid编号:{CacleCls.rfidEpc},rfid车号:{CacleCls.rfidCarNo},枪机:{CacleCls.voicCarNo},球机:{CacleCls.voicCarNo2}");
  538. txtMsgInfo.Text = "称重保存中......";
  539. CacleCls.isLock = true;
  540. cbCarNo.Enabled = false;
  541. txtCarNo.Enabled = false;
  542. strGuid = strGuid == "" ? Guid.NewGuid().ToString() : strGuid;
  543. #region 截图
  544. if (!flagCaption)
  545. {
  546. for (int i = 0; i < lc.Count(); i++)
  547. {
  548. if (i == 0)
  549. {
  550. carCls.CapturePictrue2($"{AppConfigCache.path}/imgShort/formalImg/{AppConfigCache.pointNo}_C{strGuid}_tempImg_{i + 2}.jpg");
  551. continue;
  552. }
  553. //从_2开始,因为_1是仪表图片 2是车号快照抓拍
  554. ce.CapPic((uint)lc[i], $"{AppConfigCache.path}/imgShort/formalImg/{AppConfigCache.pointNo}_C{strGuid}_tempImg_{i + 2}.jpg");
  555. }
  556. flagCaption = true;
  557. }
  558. if (lockWgtImg != CacleCls.lockWgt)
  559. {
  560. lockWgtImg = CacleCls.lockWgt;
  561. foreach (Control cn in panel1.Controls)
  562. {
  563. if (cn.Name.Substring(cn.Name.Length - 1) == $"{AppConfigCache.channel}")
  564. {
  565. if (cn is PictureBox)
  566. {
  567. Bitmap bit = new Bitmap(cn.Width, cn.Height);//实例化一个和窗体一样大的bitmap
  568. Graphics g = Graphics.FromImage(bit);
  569. g.CompositingQuality = CompositingQuality.HighQuality;//质量设为最高 HighQuality
  570. g.CopyFromScreen(panel1.Left, panel1.Top + 25, 0, 0, new Size(cn.Width, cn.Height));//保存整个窗体为图片
  571. bit.Save($"{AppConfigCache.path}/imgShort/formalImg/{AppConfigCache.pointNo}_C{strGuid}_tempImg_1.jpg");//默认保存格式为PNG,保存成jpg格式质量不是很好
  572. bit.Dispose();
  573. break;
  574. }
  575. }
  576. }
  577. }
  578. #endregion
  579. if (CacleCls.serverFlag) //网络正常
  580. {
  581. //没有接管的情况下
  582. //* 2023-04-22测试时注释,实际应用时需要
  583. if (!CacleCls.isJg && CacleCls.firstDb != null && Math.Abs(CacleCls.firstDb.meterWeight.Value - CacleCls.lockWgt) < AppConfigCache.differenceWgt)
  584. {
  585. string str = "第一次计量重量【" + Math.Round((decimal)CacleCls.firstDb.meterWeight.Value / 1000, 2) + "T】和第二次计量重量【" + Math.Round((decimal)CacleCls.lockWgt / 1000, 2) + "T】接近,小于结净最小值【" + Math.Round((decimal)AppConfigCache.differenceWgt / 1000, 2) + " T】";
  586. vicPlayClass.GetVoicePlay(VoiceEnum.两次计量重量接近, CacleCls.lockCarNo);
  587. led_controler.setStaticLineMsg(AppConfigCache.ledIp, $"上次重量与当,前重量接近,需操作工确认");
  588. txtMsgInfo.Text = str;
  589. lg.WriteLog(LogType.serverLog, str);
  590. CacleCls.isLock = false;
  591. return;
  592. }
  593. //*/
  594. //一次计量
  595. if (CacleCls.firstDb == null)
  596. {
  597. //进行计量,不管有没有一次计量数据,都调用这个,如果服务端判断有一次计量数据则进行结净,没有则做一次计量操作
  598. RESTfulResult<string> rmRst = workCarActualFirstService.doAddFirstDjDb(CacleCls.preTrackScale, new MeterWorkCarActualFirst
  599. {
  600. baseSpotNo = AppConfigCache.pointNo,
  601. baseSpotName = AppConfigCache.pointName,
  602. carNo = CacleCls.lockCarNo,
  603. createTime = DateTime.Now,
  604. meterWeight = CacleCls.lockWgt,
  605. createManNo = "system",
  606. createManName = "system",
  607. valueFlag = "1",
  608. meterMode = "2",
  609. isPreScale = "0",
  610. dataSource = "1",
  611. checkFlag = "1"
  612. });
  613. if (rmRst.Succeed)
  614. {
  615. isMeasureSuccess = true;
  616. CacleCls.actualNo = rmRst.Data;
  617. CacleCls.tempNo = strGuid;
  618. }
  619. else
  620. {
  621. //计量失败,播报失败,然后写led屏幕及日志
  622. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
  623. vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
  624. txtMsgInfo.Text = "计量失败,请求服务异常:" + rmRst.ResultMessage;
  625. lg.WriteLog(LogType.serverLog, "计量失败,请求服务异常:" + rmRst.ResultMessage);
  626. CacleCls.isLock = false;
  627. return;
  628. }
  629. }
  630. else //结净操作
  631. {
  632. RESTfulResult<string> rmRst = workCarActualFirstService.doAddNet(CacleCls.preTrackScale, CacleCls.firstDb, new MeterWorkCarActualFirst
  633. {
  634. baseSpotNo = AppConfigCache.pointNo,
  635. baseSpotName = AppConfigCache.pointName,
  636. carNo = CacleCls.lockCarNo,
  637. createTime = DateTime.Now,
  638. meterWeight = CacleCls.lockWgt,
  639. createManNo = "system",
  640. createManName = "system",
  641. valueFlag = "1",
  642. meterMode = "2",
  643. isPreScale = "0",
  644. dataSource = "1",
  645. checkFlag = "1"
  646. });
  647. if (rmRst.Succeed)
  648. {
  649. isMeasureSuccess = true;
  650. CacleCls.actualNo = rmRst.Data;
  651. CacleCls.tempNo = strGuid;
  652. }
  653. else
  654. {
  655. //计量失败,播报失败,然后写led屏幕及日志
  656. vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
  657. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
  658. txtMsgInfo.Text = "计量失败,请求服务异常:" + rmRst.ResultMessage;
  659. lg.WriteLog(LogType.serverLog, "计量失败,请求服务异常:" + rmRst.ResultMessage);
  660. CacleCls.isLock = false;
  661. return;
  662. }
  663. }
  664. }
  665. else
  666. {
  667. //写本地文件
  668. bool flag = FileOption.WriterDb(new ActualFirstModel { actualFirstNo = strGuid, baseSpotNo = AppConfigCache.pointNo, baseSpotName = AppConfigCache.pointName, carNo = CacleCls.lockCarNo, createTime = DateTime.Now, meterWeight = CacleCls.lockWgt }, out msgInfo);
  669. if (flag)
  670. {
  671. isMeasureSuccess = true;
  672. }
  673. else
  674. {
  675. vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
  676. led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
  677. txtMsgInfo.Text = "计量失败写入,本地文件异常:" + msgInfo;
  678. lg.WriteLog(LogType.serverLog, "计量失败,写入本地文件异常:" + msgInfo);
  679. CacleCls.isLock = false;
  680. return;
  681. }
  682. }
  683. //计量成功
  684. if (isMeasureSuccess)
  685. {
  686. btnSave.Enabled = false;
  687. if (!flagPre)
  688. {
  689. txtMsgInfo.Text = "计量完成,存在多个委托";
  690. }else
  691. {
  692. txtMsgInfo.Text = "计量完成";
  693. }
  694. #region 毛皮净赋值
  695. if (CacleCls.firstDb != null && CacleCls.firstDb.meterWeight > 0 && CacleCls.lockWgt > 0)
  696. {
  697. if (CacleCls.firstDb.meterWeight > CacleCls.lockWgt)
  698. {
  699. txtGroess.Text = $"{Math.Round((decimal)CacleCls.firstDb.meterWeight / 1000, 2)}";
  700. txtTare.Text = $"{Math.Round((decimal)CacleCls.lockWgt / 1000, 2)}";
  701. txtNet.Text = $"{Math.Round((decimal)(CacleCls.firstDb.meterWeight.Value - CacleCls.lockWgt) / 1000, 2)}";
  702. }
  703. else
  704. {
  705. txtGroess.Text = $"{Math.Round((decimal)CacleCls.lockWgt / 1000, 2)}";
  706. txtTare.Text = $"{Math.Round((decimal)CacleCls.firstDb.meterWeight / 1000, 2)}";
  707. txtNet.Text = $"{Math.Round((decimal)(CacleCls.lockWgt - CacleCls.firstDb.meterWeight) / 1000, 2)}";
  708. }
  709. }
  710. if (CacleCls.firstDb == null)
  711. {
  712. //计量完成多委托
  713. led_controler.setStaticLineMsg(AppConfigCache.ledIp, $"车号{CacleCls.lockCarNo},重量{Math.Round((decimal)CacleCls.lockWgt / 1000, 2)}吨,计量完成");
  714. }
  715. else
  716. {
  717. led_controler.setStaticLineMsg(AppConfigCache.ledIp, $"车号{CacleCls.lockCarNo},重量{Math.Round((decimal)CacleCls.lockWgt / 1000, 2)}吨,净重{Math.Round((decimal)Math.Abs(CacleCls.firstDb.meterWeight.Value - CacleCls.lockWgt) / 1000, 2)}吨,计量完成");
  718. }
  719. #endregion
  720. //屏幕截图操作
  721. _ = BeginInvoke(new Action(() => { shotImageScreen(strGuid); }));
  722. BindTable();
  723. //只需要控制plc即可,其他的不管
  724. if (AppConfigCache.plcStart == "1")
  725. {
  726. plc.DataCollectWrite(AppConfigCache.dz, AppConfigCache.dzValue);
  727. }
  728. }
  729. #endregion
  730. }
  731. catch (Exception ex)
  732. {
  733. vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
  734. lg.WriteLog(LogType.SystemLog, "计量失败1:" + ex.Message);
  735. CacleCls.isLock = false;
  736. }
  737. }
  738. private void BindTable()
  739. {
  740. bool bReadFlag = false;
  741. string strRtMsgInfo = "";
  742. List<ActualFirstModel> lm = FileOption.ReadDb<ActualFirstModel>(ref bReadFlag, ref strRtMsgInfo);
  743. DataTable dtV = dataTableFirst.Clone();
  744. if (lm != null && lm.Count > 0)
  745. {
  746. dtV = lm.ListToDataTable<ActualFirstModel>();
  747. }
  748. ClsControlPack.CopyDataToDatatable(ref dtV, ref this.dataTableFirst, true);
  749. ClsControlPack.RefreshAndAutoSize(ultraGridFirst);
  750. }
  751. private void btnOpenVoice_Click(object sender, EventArgs e)
  752. {
  753. //*
  754. if (btnOpenVoice.Text == "打开对讲")
  755. {
  756. VoiceOpen();
  757. }
  758. else
  759. {
  760. VoiceClose();
  761. }
  762. //*/
  763. }
  764. private void frmMain_FormClosing(object sender, FormClosingEventArgs e)
  765. {
  766. stop();
  767. try {
  768. if (AppConfigCache.getWgtType == "0")
  769. cx?.ClosingCollect();
  770. else
  771. mx?.ClosingCollect();
  772. } catch { }
  773. try { rfid?.ClosingCollect(); } catch { }
  774. try { if (bVoice) ce?.StopTalk(); } catch { }
  775. foreach (int i in voPlay)
  776. {
  777. try { ce?.StopRealPlay(i); } catch { }
  778. }
  779. try { plc?.Stop(); } catch { }
  780. try { ping?.stop(); } catch { }
  781. try { upload?.stop(); } catch { }
  782. try { carCls?.LoginOut(); } catch { }
  783. if (AppConfigCache.openVoice.Contains("2"))
  784. {
  785. try { carCls2?.LoginOut(); } catch { }
  786. }
  787. try { imgControl?.Stop(); } catch { }
  788. }
  789. /// <summary>
  790. /// 必须先打开视频,然后再打开语音
  791. /// </summary>
  792. private void VoiceOpen()
  793. {
  794. try
  795. {
  796. if (ce.StartTalk())
  797. {
  798. btnOpenVoice.Text = "关闭对讲";
  799. bVoice = true;
  800. }
  801. }
  802. catch (Exception ex)
  803. {
  804. txtMsgInfo.Text = "打开对讲失败:" + ex.Message;
  805. }
  806. }
  807. /// <summary>
  808. /// 关闭语音对讲
  809. /// </summary>
  810. private void VoiceClose()
  811. {
  812. try
  813. {
  814. if (ce.StopTalk())
  815. {
  816. btnOpenVoice.Text = "打开对讲";
  817. bVoice = false;
  818. }
  819. }
  820. catch (Exception ex)
  821. {
  822. txtMsgInfo.Text = "关闭对讲失败:" + ex.Message;
  823. }
  824. }
  825. private void btnExport_Click(object sender, EventArgs e)
  826. {
  827. ClsControlPack.ExportDataWithSaveDialog2(ref ultraGridFirst, DateTime.Now.ToString("yyyyMMddHHmmss"));
  828. }
  829. private void cbCarNo_SelectedIndexChanged(object sender, EventArgs e)
  830. {
  831. CacleCls.isLock = false;
  832. }
  833. private void cbJg_CheckedChanged(object sender, EventArgs e)
  834. {
  835. CacleCls.isJg = cbJg.Checked;
  836. if(!isMeasureSuccess) btnSave.Enabled = cbJg.Checked;
  837. }
  838. private void txtCarNo_TextChanged(object sender, EventArgs e)
  839. {
  840. CacleCls.isLock = false;
  841. }
  842. private void PictureBoxDoubleClick(object sender, EventArgs e)
  843. {
  844. if (iPic != 0)
  845. {
  846. ce.StopRealPlay(iPic);
  847. }
  848. PictureBox picture = (PictureBox)sender;
  849. iPic = Convert.ToInt32(picture.Name.Substring(picture.Name.Length - 1, 1));
  850. plImgShow.Visible = true;
  851. ce.RealPlay(pictureShow, iPic);
  852. }
  853. private void pictureShow_DoubleClick(object sender, EventArgs e)
  854. {
  855. plImgShow.Visible = false;
  856. ce.StopRealPlay(iPic);
  857. iPic = 0;
  858. }
  859. private void txtCarNo_KeyDown(object sender, KeyEventArgs e)
  860. {
  861. if (e.KeyCode == Keys.Enter) txtMsgInfo.Focus();
  862. }
  863. private void btnOpenDz_Click(object sender, EventArgs e)
  864. {
  865. if (AppConfigCache.plcStart == "1")
  866. {
  867. plc.DataCollectWrite(AppConfigCache.dz, AppConfigCache.dzValue);
  868. }
  869. else
  870. {
  871. MessageBox.Show("当前PLC处于未连接状态,请先配置连接再操作");
  872. }
  873. }
  874. /// <summary>
  875. /// 终端截图(临时截图,使用临时ID存储)
  876. /// </summary>
  877. public void shotImageScreen(string strActualFirstNo)
  878. {
  879. try
  880. {
  881. #region 截取图片信息
  882. //截取屏幕信息
  883. Point screenPoint = plCaptionMain.PointToScreen(new Point());
  884. Rectangle rect = new Rectangle(screenPoint, plCaptionMain.Size);
  885. Image img = new Bitmap(plCaptionMain.Width, plCaptionMain.Height);
  886. Graphics g = Graphics.FromImage(img);
  887. g.CopyFromScreen(rect.X - 1, rect.Y - 1, 0, 0, rect.Size);//"D://file/1.jpg"
  888. img.Save(string.Format("{0}imgShort\\formalImg\\{1}_{2}_tempImg_{3}.jpg",
  889. AppDomain.CurrentDomain.SetupInformation.ApplicationBase,
  890. AppConfigCache.pointNo, "C" + strActualFirstNo, 7), System.Drawing.Imaging.ImageFormat.Jpeg);
  891. //lg.WriteLog(35, "完成截图 成功标识:" + PbCache.shotSuccess.ToString() + "车号:" + PbCache.lockCarNo + ";重量:" + PbCache.lockWgt + ";时间:" + DateTime.Now.ToLongTimeString());
  892. #endregion 截取图片信息
  893. }
  894. catch (Exception ex)
  895. {
  896. lg.WriteLog(LogType.SystemLog, "计量完成,但图片截取失败,编号:" + strActualFirstNo);
  897. }
  898. }
  899. #region 释放内存
  900. [DllImport("kernel32.dll")]
  901. private static extern bool SetProcessWorkingSetSize(IntPtr process, int minSize, int maxSize);
  902. //刷新存储器
  903. private static void FlushMemory()
  904. {
  905. GC.Collect();
  906. GC.WaitForPendingFinalizers();
  907. if (Environment.OSVersion.Platform == PlatformID.Win32NT)
  908. {
  909. SetProcessWorkingSetSize(Process.GetCurrentProcess().Handle, -1, -1);
  910. }
  911. }
  912. #endregion
  913. }
  914. }