| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028 |
- using com.hnshituo.core.webapp.vo;
- using Newtonsoft.Json;
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Data;
- using System.Diagnostics;
- using System.Drawing;
- using System.Drawing.Drawing2D;
- using System.IO;
- using System.Linq;
- using System.Net.NetworkInformation;
- using System.Runtime.InteropServices;
- using System.Text;
- using System.Threading;
- using System.Threading.Tasks;
- using System.Windows.Forms;
- namespace CarLocalMeter
- {
- public partial class frmMain : Form
- {
- public frmMain()
- {
- InitializeComponent();
- }
- Log lg = Log.GetInstance();
- private LED_Control led_controler;
- //List<CamerEs> lc = new List<CamerEs>();
- /// <summary>
- /// 硬盘录像机图片抓拍通道
- /// </summary>
- List<int> lc = new List<int>();
- /// <summary>
- /// 服务端委托获取
- /// </summary>
- private PreTrackScaleService PreTrackScaleService = new PreTrackScaleService();
- RESTfulResult<List<PreTrackScale>> rmScaleListCarTimer = new RESTfulResult<List<PreTrackScale>>();
- private MeterWorkCarActualFirstService workCarActualFirstService = new MeterWorkCarActualFirstService(); //一次计量数据
- RESTfulResult<List<MeterWorkCarActualFirst>> RESTfulResultOutTimer = new RESTfulResult<List<MeterWorkCarActualFirst>>();
-
- PlcCls plc = new PlcCls();
- /// <summary>
- /// redis操作类
- /// </summary>
- RedisOption redis = new RedisOption();
- /// <summary>
- /// 图片操作类
- /// </summary>
- ImageOption imgControl = new ImageOption();
- /// <summary>
- /// 重量采集类
- /// </summary>
- MoxaCls mx = new MoxaCls();
- /// <summary>
- /// 语音播放
- /// </summary>
- VoicePlay vicPlayClass = new VoicePlay();
- /// <summary>
- /// 摄像头车号识别枪机
- /// </summary>
- CarNoCls carCls = new CarNoCls();
- /// <summary>
- /// 摄像头识别球机
- /// </summary>
- CarNoCls carCls2 = new CarNoCls();
- /// <summary>
- /// rfid车号识别
- /// </summary>
- RfIdCarNo rfid = new RfIdCarNo();
- /// <summary>
- /// Ping服务器服务是否通
- /// </summary>
- PingNetwork ping = new PingNetwork();
- /// <summary>
- /// 本地离线计量的数据上传
- /// </summary>
- DbUpload upload = new DbUpload();
- /// <summary>
- /// 以下是硬盘录像机的控制
- /// </summary>
- bool bVoice = false;
- CamerEs ce = new CamerEs(AppConfigCache.voicePlayIp, $"{AppConfigCache.voicePlayPort}", AppConfigCache.voicePlayUid, AppConfigCache.voicePlayPwd);
- List<int> voPlay = new List<int>();
- int iPic = 0;
- private void frmMain_Load(object sender, EventArgs e)
- {
- CacleCls.updateRfidInfoTime = DateTime.Now;
- btnSave.Enabled = false;
- if (!string.IsNullOrEmpty(AppConfigCache.ledIp))
- {
- led_controler = new LED_Control(AppConfigCache.ledIp);
- }
- #region 读取音频文件名称
- List<string> ls = new List<string>();
- DirectoryInfo folder = new DirectoryInfo(AppConfigCache.path + "\\Sound");
- foreach (FileInfo file in folder.GetFiles("*.wav"))
- {
- ls.Add(file.Name.Replace(".wav", ""));
- }
- CacleCls.voiceInfo = ls;
- #endregion
- string[] strTd1 = AppConfigCache.channelOther.Split(',');
- string[] strTd2 = AppConfigCache.channelVis.Split(',');
- string[] strAll = new string[strTd1.Length + strTd2.Length];
- strTd1.CopyTo(strAll, 0);
- strTd2.CopyTo(strAll, strTd1.Length);
- List<string> lcs = strAll.Distinct().OrderBy(s => s).ToList(); //
- lc.Add(AppConfigCache.channelCarNo);
- foreach (string str in lcs)
- {
- if ($"{AppConfigCache.channel}" != str && $"{AppConfigCache.channelCarNo}" != str)
- {
- lc.Add(Convert.ToInt32(str)); //抓拍通道与数组中不相同的时候写入,因为我们仪表抓拍的通道需单独进行处理
- }
- }
- plImgShow.Visible = false;
- lbPointName.Text = AppConfigCache.pointName;
- foreach (string str in AppConfigCache.channelVis.Split(','))
- {
- voPlay.Add(Convert.ToInt32(str));
- }
- ce.Connection();
- foreach(int i in voPlay)
- {
- PictureBox pb = new PictureBox();
- pb.Dock = DockStyle.Top;
- pb.DoubleClick += new EventHandler(PictureBoxDoubleClick);
- pb.Height = AppConfigCache.channelVisHeight;
- pb.Name = $"pb{i}";
- panel1.Controls.Add(pb);
- ce.RealPlay(pb, i);
- }
- if (AppConfigCache.plcStart == "1") plc.Start();
- //*
- ping.start();
- upload.start();
- mx.start();
- rfid.Start();
- imgControl.Start();
- carCls.Login(AppConfigCache.voiceCarNoIp, AppConfigCache.voiceCarNoPort, AppConfigCache.voiceCarNoUid, AppConfigCache.voiceCarNoPwd);
- //*/
- //carCls2.Login(AppConfigCache.voiceCarNoIp2, AppConfigCache.voiceCarNoPort2, AppConfigCache.voiceCarNoUid2, AppConfigCache.voiceCarNoPwd2, false);
- blThreadFlag = true;
- DataCollectThread = new Thread(new ThreadStart(DataCollect));
- start();
- }
- #region 本地主逻辑判断线程
- bool blThreadFlag;//数据采集线程开关
- Thread DataCollectThread = null;//采集进程
- bool getPreInfo = false, getFirst = false, flagCaption = false, isVoiceDownCar = false;
- string strOldCarNo = "";
- bool isMeasureSuccess = false;
- int voiceNum = 0;
- int iImgCnt = 0;
- private void start() => DataCollectThread.Start();
- private void stop() => blThreadFlag = false;
- private void DataCollect()
- {
- if (!blThreadFlag) return;
- int iError = 0;
- while (blThreadFlag)
- {
- try
- {
- this.panel3.Invoke(new Action(() => {
- if (!CacleCls.isLock)
- {
- ucWeightT1.setWgt(Math.Round((double)CacleCls.weight / 1000, 2)); //2021年5月10日界面显示单位,调整为T
- ucWeightT1.setStable(CacleCls.isWd != 1 ? true : false);
- ucWeightT1.setExceed(CacleCls.weight > AppConfigCache.maxRange * 1000 ? false : true);
- if (cbCarNo.Text.Trim() != "" && txtCarNo.Text.Trim() != "")
- {
- CacleCls.lockCarNo = cbCarNo.Text.Trim() + txtCarNo.Text.Trim();
- }
- else if (!string.IsNullOrEmpty(CacleCls.rfidCarNo))
- {
- CacleCls.lockCarNo = CacleCls.rfidCarNo;
- }
- else if (!string.IsNullOrEmpty(CacleCls.voicCarNo))
- {
- CacleCls.lockCarNo = CacleCls.voicCarNo;
- }
- else if (!string.IsNullOrEmpty(CacleCls.voicCarNo2))
- {
- CacleCls.lockCarNo = CacleCls.voicCarNo2;
- }
- if (!string.IsNullOrEmpty(CacleCls.lockCarNo) && cbCarNo.Text.Trim() == "" && txtCarNo.Text.Trim() == "")
- {
- cbCarNo.Text = CacleCls.lockCarNo.Substring(0, 1);
- if (CacleCls.lockCarNo.Length > 1)
- {
- txtCarNo.Text = CacleCls.lockCarNo.Substring(1);
- }
- }
- if (strOldCarNo != CacleCls.lockCarNo)
- {
- strOldCarNo = CacleCls.lockCarNo;
- getPreInfo = false;
- getFirst = false;
- }
- }
- iError = 1;
- //是否能连上远程服务器,这里只是服务器,不是服务器上的服务端
- pbLineOn.Load(CacleCls.serverFlag ? (AppConfigCache.path + "\\image\\icon\\green.gif") : (AppConfigCache.path + "\\image\\icon\\red.gif"));
- iError = 2;
- if (CacleCls.weight > 500)
- {
- iError = 21;
- iImgCnt = 0;
- CacleCls.isClear = false;
- #region 一些必要验证及提醒
- if (!CacleCls.isLock)
- {
- //重量最后一位不为0也是超量程
- if ((AppConfigCache.maxRange * 1000 < CacleCls.weight) || CacleCls.weight.ToString().Substring(CacleCls.weight.ToString().Length - 1, 1) != "0")
- {
- //超量程
- vicPlayClass.GetVoicePlay(VoiceEnum.车辆超重, CacleCls.lockCarNo);
- txtMsgInfo.Text = "当前重量已超量程,秤体量程为【" + AppConfigCache.maxRange + "】T,不允许进行自助计量操作!";
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "当前重量已超量程,秤体量程为【" + AppConfigCache.maxRange + "】T,不允许进行自助计量操作!");
- CacleCls.isLock = false;
- return;
- }
- iError = 22;
- if (CacleCls.isWd == 0 && !string.IsNullOrEmpty(CacleCls.lockCarNo))
- {
- if ((CacleCls.topJg == "1" || CacleCls.bottomJg == "1"))
- {
- //重量稳定,且对射验证不合格
- vicPlayClass.GetVoicePlay(VoiceEnum.车辆未停到位, CacleCls.lockCarNo);
- txtMsgInfo.Text = "车辆超出秤台,请调整车位2";
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车辆超出秤台,请调整车位2");
- CacleCls.isLock = false;
- return;
- }
- else if (CacleCls.rightGs == "1")
- {
- //重量稳定,且右光栅不合格
- vicPlayClass.GetVoicePlay(VoiceEnum.车辆未停到位, CacleCls.lockCarNo);
- txtMsgInfo.Text = "车辆超出秤台,请调整车位3";
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车辆超出秤台,请调整车位3");
- CacleCls.isLock = false;
- return;
- }
- else if (CacleCls.leftGs == "1")
- {
- //重量稳定,且左光栅不合格
- vicPlayClass.GetVoicePlay(VoiceEnum.车辆未停到位, CacleCls.lockCarNo);
- txtMsgInfo.Text = "车辆超出秤台,请调整车位4";
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车辆超出秤台,请调整车位4");
- CacleCls.isLock = false;
- return;
- }
- }
- iError = 23;
- /*
- if (PbCache.isOvertimeAlarm)
- {
- //停留超时提醒,不作为计量卡控的条件
- if (!isPlayOvertimeVoice && !PbCache.isLockFrm)
- {
- vicPlayClass.GetVoicePlay("停留超时", PbCache.collect.carno);
- led_controler.setStaticLineMsg(PbCache.sportInfo.ledIp, "停留超时");
- txtMsgInfo.Text = "停留超时";
- PbCache.ResultMessage = "停留超时";
- isPlayOvertimeVoice = true;
- return;
- }
- }
- //*/
- #region 一次计量数据跟预报获取一次,有可能稳定特别快导致一次计量数据跟预报还未获取到,所以我这改为去保存按钮处获取
- /*
- if (!string.IsNullOrEmpty(CacleCls.lockCarNo) && CacleCls.serverFlag)
- {
- //查询一次计量数据
- if (!getFirst)
- {
- RESTfulResultOutTimer = workCarActualFirstService.doQueryWf(new MeterWorkCarActualFirst { valueFlag = "1", carNo = CacleCls.lockCarNo });
- if (RESTfulResultOutTimer.Succeed)
- {
- if (RESTfulResultOutTimer.Data != null && RESTfulResultOutTimer.Data.Count > 0)
- {
- CacleCls.firstDb = RESTfulResultOutTimer.Data[0];
- if (CacleCls.firstDb.predictionNo != null && !CacleCls.firstDb.predictionNo.Contains("_"))
- {
- txtMATTER_NAME.Text = CacleCls.firstDb.matterName;
- txtFORWARDING_UNIT_NAME.Text = CacleCls.firstDb.forwardingUnitName;
- txtRECEIVING_UINT_NAME.Text = CacleCls.firstDb.receivingUintName;
- txtMETER_TYPE.Text = CacleCls.firstDb.meterTypeName;
- }
- }
- }
- getFirst = true;
- }
- iError = 24;
- //根据网络状态及车号以及是否存在一次计量数据,查询一次预报信息,然后将getPreInfo改为true
- if (!getPreInfo)
- {
- if (CacleCls.firstDb == null || string.IsNullOrEmpty(CacleCls.firstDb?.predictionNo))
- {
- //如果没有一次信息或者一次信息里面没带预报信息,则查询一次预报信息
- rmScaleListCarTimer = PreTrackScaleService.doQueryByFlag(new PreTrackScale { lineDesc = "1", carNo = CacleCls.lockCarNo });
- if (rmScaleListCarTimer.Succeed)
- {
- if (rmScaleListCarTimer.Data != null && rmScaleListCarTimer.Data.Count == 1)
- {
- CacleCls.preTrackScale = rmScaleListCarTimer.Data[0];
- txtMATTER_NAME.Text = CacleCls.preTrackScale.matterName;
- txtFORWARDING_UNIT_NAME.Text = CacleCls.preTrackScale.forwardingUnitName;
- txtRECEIVING_UINT_NAME.Text = CacleCls.preTrackScale.receivingUintName;
- txtMETER_TYPE.Text = CacleCls.preTrackScale.meterTypeName;
- }
- }
- }
- getPreInfo = true;
- }
- iError = 25;
- }
- //*/
- #endregion
- //进行计量称重条件的判断 车号不为空、重量稳定、车辆已停到位
- if (CacleCls.isWd == 0 && CacleCls.leftGs != "1" && CacleCls.rightGs != "1" && CacleCls.topJg != "1" && CacleCls.bottomJg != "1")
- {
- iError = 11;
- if (!string.IsNullOrEmpty(CacleCls.lockCarNo))
- {
- if (!isVoiceDownCar)
- {
- txtMsgInfo.Text = "";
- isVoiceDownCar = true;
- vicPlayClass.GetVoicePlay(VoiceEnum.开始计量, CacleCls.lockCarNo);//只播放一次
- }
- //if(!btnSave.Enabled) btnSave.Enabled = true;
- if (!CacleCls.isJg)
- {
- lg.WriteLog(LogType.SystemLog, CacleCls.lockCarNo + "开始保存:" + DateTime.Now.ToLongTimeString());
- btnSave_Click(null, null);
- }
- }
- else
- {
- txtMsgInfo.Text = "车号未识别";
- vicPlayClass.GetVoicePlay(VoiceEnum.车号未识别, "");
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "车号未识别");
- }
- iError = 12;
- }
- }
- #endregion
- //计量完成后进行语音播报,提示离开秤台,播报5次
- if (isMeasureSuccess)
- {
- if (voiceNum < AppConfigCache.voiceNum)
- {
- if (CacleCls.voiceOver)
- {
- vicPlayClass.GetVoicePlay(VoiceEnum.计量完成, CacleCls.lockCarNo);
- voiceNum++;
- }
- }
- return;
- }
- iError = 13;
- }
- else
- {
- iError = 31;
- voiceNum = 0;
- isMeasureSuccess = false;
- lockWgtImg = CacleCls.weight;
- getFirst = false;
- getPreInfo = false;
- flagCaption = false;
- isVoiceDownCar = false;
- strGuid = "";
- if (!CacleCls.isClear)
- {
- iError = 32;
- CacleCls.Clear(); //清理一次数据
- btnSave.Enabled = false;
- cbCarNo.Text = "";
- cbCarNo.SelectedIndex = -1;
- txtCarNo.Text = "";
- txtMATTER_NAME.Text = "";
- txtFORWARDING_UNIT_NAME.Text = "";
- txtRECEIVING_UINT_NAME.Text = "";
- txtMETER_TYPE.Text = "";
- cbCarNo.Enabled = true;
- txtCarNo.Enabled = true;
- txtMsgInfo.Text = "";
- txtGroess.Text = "";
- txtTare.Text = "";
- txtNet.Text = "";
- iError = 33;
- //释放一次内存
- FlushMemory();
- iError = 34;
- //
- imgControl.ZipFiles();
- iError = 35;
- }
- }
- }));
- }
- catch (Exception ex)
- {
- //在关闭程序后,由于线程还会跑一下,所以会有一个错误“调用方法时发生错误。 目标线程不再存在” 这个不影响
- lg.WriteLog(LogType.SystemLog, $"主逻辑判断线程,其i值为:{iError},异常信息为:{ex.Message}");
- }
- Thread.Sleep(AppConfigCache.sleepTime);
- }
- }
- #endregion
- int lockWgtImg = 0;
- string strGuid = "";
- private void btnSave_Click(object sender, EventArgs e)
- {
- try
- {
- #region 下面是业务逻辑代码
- string msgInfo = "";
- if (txtCarNo.Focused) return; //如果正在修改车号,就必须等光标离开后再保存,否则容易导致车号输入了一半保存了
- if (CacleCls.isWd != 0) return;
- ucWeightT1.setStable(true); // 重量稳定
- ucWeightT1.setWgt(Math.Round((double)CacleCls.weight / 1000, 2)); // 最新重量
- CacleCls.lockWgt = CacleCls.weight;
- if (!CacleCls.lockWgt.ToString().EndsWith("0")) //个位不是0则说明超量程了
- {
- //txtMsgInfo.Text = "仪表重量[" + CacleCls.lockWgt + "]不是以0结尾,禁止计量操作!";
- vicPlayClass.GetVoicePlay(VoiceEnum.车辆超重, CacleCls.lockCarNo);
- txtMsgInfo.Text = "当前重量已超量程,秤体量程为【" + AppConfigCache.maxRange + "】T,不允许进行自助计量操作!";
- return;
- }
- //接管状态点的保存
- if (CacleCls.isJg)
- {
- if (string.IsNullOrEmpty(CacleCls.lockCarNo))
- {
- txtMsgInfo.Text = "没有车号,无法保存";
- return;
- }
- else if (CacleCls.lockWgt < 500)
- {
- txtMsgInfo.Text = "重量过小,无法保存";
- return;
- }
- else if (CacleCls.isWd != 0)
- {
- txtMsgInfo.Text = "重量不稳定,无法保存";
- return;
- }
- else if (CacleCls.leftGs == "1" || CacleCls.rightGs == "1" || CacleCls.topJg == "1" || CacleCls.bottomJg == "1")
- {
- txtMsgInfo.Text = "激光被遮挡,车辆未停到位,无法保存";
- return;
- }
- else
- {
- lg.WriteLog(LogType.SystemLog, CacleCls.lockCarNo + "接管状态下进行的保存:" + DateTime.Now.ToLongTimeString());
- }
- }
- //存在零点,且不为接管状态则禁止计量
- if (CacleCls.isZeroState && !CacleCls.isJg)
- {
- vicPlayClass.GetVoicePlay(VoiceEnum.仪表未归零, CacleCls.lockCarNo);
- txtMsgInfo.Text = "仪表未归零,无法计量,请联系大厅"; //btnSave_Click
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "仪表未归零,无法计量");
- return;
- }
- if (!CacleCls.isJg && CacleCls.firstDb != null)
- {
- if (Math.Abs(CacleCls.firstDb.meterWeight.Value - CacleCls.lockWgt) < AppConfigCache.differenceWgt)
- {
- vicPlayClass.GetVoicePlay(VoiceEnum.洁净重量过小, CacleCls.lockCarNo);
- txtMsgInfo.Text = "计量失败,洁净重量过小";
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,洁净重量过小");
- return;
- }
- }
- #region 获取一次数据跟车号
- if (!string.IsNullOrEmpty(CacleCls.lockCarNo) && CacleCls.serverFlag)
- {
- //查询一次计量数据
- if (!getFirst)
- {
- RESTfulResultOutTimer = workCarActualFirstService.doQueryWf(new MeterWorkCarActualFirst { valueFlag = "1", carNo = CacleCls.lockCarNo });
- if (RESTfulResultOutTimer.Succeed)
- {
- if (RESTfulResultOutTimer.Data != null && RESTfulResultOutTimer.Data.Count > 0)
- {
- if (RESTfulResultOutTimer.Data.Count == 1)
- {
- CacleCls.firstDb = RESTfulResultOutTimer.Data[0];
- if (CacleCls.firstDb.predictionNo != null && !CacleCls.firstDb.predictionNo.Contains("_"))
- {
- txtMATTER_NAME.Text = CacleCls.firstDb.matterName;
- txtFORWARDING_UNIT_NAME.Text = CacleCls.firstDb.forwardingUnitName;
- txtRECEIVING_UINT_NAME.Text = CacleCls.firstDb.receivingUintName;
- txtMETER_TYPE.Text = CacleCls.firstDb.meterTypeName;
- }
- }
- else
- {
- vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
- txtMsgInfo.Text = $"存在{RESTfulResultOutTimer.Data.Count}条未结净的一次计量数据";
- lg.WriteLog(LogType.serverLog, $"存在{RESTfulResultOutTimer.Data.Count}条未结净的一次计量数据");
- CacleCls.isLock = false;
- return;
- }
- }
- }
- else
- {
- vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
- txtMsgInfo.Text = "获取一次计量数据失败:" + RESTfulResultOutTimer.Message;
- lg.WriteLog(LogType.serverLog, "获取一次计量数据失败:" + RESTfulResultOutTimer.Message);
- CacleCls.isLock = false;
- return;
- }
- getFirst = true;
- }
- //根据网络状态及车号以及是否存在一次计量数据,查询一次预报信息,然后将getPreInfo改为true
- if (!getPreInfo)
- {
- if (CacleCls.firstDb != null)
- {
- //做结净的时候,才查询一次预报信息
- rmScaleListCarTimer = PreTrackScaleService.doQueryByFlag(new PreTrackScale { lineDesc = "1", carNo = CacleCls.lockCarNo });
- if (rmScaleListCarTimer.Succeed)
- {
- if (rmScaleListCarTimer.Data != null && rmScaleListCarTimer.Data.Count > 0)
- {
- CacleCls.preTrackScale = rmScaleListCarTimer.Data[0];
- txtMATTER_NAME.Text = CacleCls.preTrackScale.matterName;
- txtFORWARDING_UNIT_NAME.Text = CacleCls.preTrackScale.forwardingUnitName;
- txtRECEIVING_UINT_NAME.Text = CacleCls.preTrackScale.receivingUintName;
- txtMETER_TYPE.Text = CacleCls.preTrackScale.meterTypeName;
- }
- }
- }
- getPreInfo = true;
- }
- }
- #endregion
- lg.WriteLog(LogType.SystemLog, $"锁定车号:{CacleCls.lockCarNo},锁定重量:{CacleCls.lockWgt},rfid编号:{CacleCls.rfidEpc},rfid车号:{CacleCls.rfidCarNo},枪机:{CacleCls.voicCarNo},球机:{CacleCls.voicCarNo2}");
- txtMsgInfo.Text = "称重保存中......";
- CacleCls.isLock = true;
- cbCarNo.Enabled = false;
- txtCarNo.Enabled = false;
- strGuid = strGuid == "" ? Guid.NewGuid().ToString() : strGuid;
- #region 截图
- if (!flagCaption)
- {
- for (int i = 0; i < lc.Count(); i++)
- {
- if (i == 0)
- {
- carCls.CapturePictrue2($"{AppConfigCache.path}/imgShort/formalImg/{AppConfigCache.pointNo}_C{strGuid}_tempImg_{i + 2}.jpg");
- continue;
- }
- //从_2开始,因为_1是仪表图片 2是车号快照抓拍
- ce.CapPic((uint)lc[i], $"{AppConfigCache.path}/imgShort/formalImg/{AppConfigCache.pointNo}_C{strGuid}_tempImg_{i + 2}.jpg");
- }
- flagCaption = true;
- }
- if (lockWgtImg != CacleCls.lockWgt)
- {
- lockWgtImg = CacleCls.lockWgt;
- foreach (Control cn in panel1.Controls)
- {
- if (cn.Name.Substring(cn.Name.Length - 1) == $"{AppConfigCache.channel}")
- {
- if (cn is PictureBox)
- {
- Bitmap bit = new Bitmap(cn.Width, cn.Height);//实例化一个和窗体一样大的bitmap
- Graphics g = Graphics.FromImage(bit);
- g.CompositingQuality = CompositingQuality.HighQuality;//质量设为最高 HighQuality
- g.CopyFromScreen(panel1.Left, panel1.Top + 25, 0, 0, new Size(cn.Width, cn.Height));//保存整个窗体为图片
- bit.Save($"{AppConfigCache.path}/imgShort/formalImg/{AppConfigCache.pointNo}_C{strGuid}_tempImg_1.jpg");//默认保存格式为PNG,保存成jpg格式质量不是很好
- bit.Dispose();
- break;
- }
- }
- }
- #region
- /* //下面的代码可实现抓放大的图,不过我这为了时间更准,抓的左侧显示的图
- if (iPic != 0)
- {
- ce.StopRealPlay(iPic);
- }
- ce.RealPlay(pictureShow, AppConfigCache.channel);
- plImgShow.Visible = true;
- Thread.Sleep(200);
- Bitmap bit = new Bitmap(plImgShow.Width, plImgShow.Height);//实例化一个和窗体一样大的bitmap
- Graphics g = Graphics.FromImage(bit);
- g.CompositingQuality = CompositingQuality.HighQuality;//质量设为最高 HighQuality
- g.CopyFromScreen(plImgShow.Left, plImgShow.Top + 25, 0, 0, new Size(plImgShow.Width, plImgShow.Height));//保存整个窗体为图片
- bit.Save($"{AppConfigCache.path}/imgShort/formalImg/{AppConfigCache.pointNo}_C{strGuid}_tempImg_1.jpg");//默认保存格式为PNG,保存成jpg格式质量不是很好
- bit.Dispose();
- plImgShow.Visible = false;
- ce.StopRealPlay(AppConfigCache.channel);
- //*/
- #endregion
- }
- #endregion
- if (CacleCls.serverFlag) //网络正常
- {
- //没有接管的情况下
- if (!CacleCls.isJg && CacleCls.firstDb != null && Math.Abs(CacleCls.firstDb.meterWeight.Value - AppConfigCache.differenceWgt) < AppConfigCache.differenceWgt)
- {
- string str = "第一次计量重量【" + CacleCls.firstDb.meterWeight.Value / 1000 + "T】和第二次计量重量【" + CacleCls.lockWgt / 1000 + "T】接近,小于结净最小值【" + AppConfigCache.differenceWgt / 1000 + " T】";
- vicPlayClass.GetVoicePlay(VoiceEnum.两次计量重量接近, CacleCls.lockCarNo);
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, $"上次重量与当,前重量接近,需操作工确认");
- txtMsgInfo.Text = str;
- lg.WriteLog(LogType.serverLog, str);
- CacleCls.isLock = false;
- return;
- }
- //一次计量
- if (CacleCls.firstDb == null)
- {
- //进行计量,不管有没有一次计量数据,都调用这个,如果服务端判断有一次计量数据则进行结净,没有则做一次计量操作
- RESTfulResult<string> rmRst = workCarActualFirstService.doAddFirstDjDb(CacleCls.preTrackScale, new MeterWorkCarActualFirst
- {
- baseSpotNo = AppConfigCache.pointNo,
- baseSpotName = AppConfigCache.pointName,
- carNo = CacleCls.lockCarNo,
- createTime = DateTime.Now,
- meterWeight = CacleCls.lockWgt,
- createManNo = "system",
- createManName = "system",
- valueFlag = "1",
- meterMode = "2",
- isPreScale = "0",
- dataSource = "1",
- checkFlag = "1"
- });
- if (rmRst.Succeed)
- {
- isMeasureSuccess = true;
- CacleCls.actualNo = rmRst.Data;
- CacleCls.tempNo = strGuid;
- }
- else
- {
- //计量失败,播报失败,然后写led屏幕及日志
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
- vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
- txtMsgInfo.Text = "计量失败,请求服务异常:" + rmRst.ResultMessage;
- lg.WriteLog(LogType.serverLog, "计量失败,请求服务异常:" + rmRst.ResultMessage);
- CacleCls.isLock = false;
- return;
- }
- }
- else //结净操作
- {
- RESTfulResult<string> rmRst = workCarActualFirstService.doAddNet(CacleCls.preTrackScale, CacleCls.firstDb, new MeterWorkCarActualFirst
- {
- baseSpotNo = AppConfigCache.pointNo,
- baseSpotName = AppConfigCache.pointName,
- carNo = CacleCls.lockCarNo,
- createTime = DateTime.Now,
- meterWeight = CacleCls.lockWgt,
- createManNo = "system",
- createManName = "system",
- valueFlag = "1",
- meterMode = "2",
- isPreScale = "0",
- dataSource = "1",
- checkFlag = "1"
- });
- if (rmRst.Succeed)
- {
- isMeasureSuccess = true;
- CacleCls.actualNo = rmRst.Data;
- CacleCls.tempNo = strGuid;
- }
- else
- {
- //计量失败,播报失败,然后写led屏幕及日志
- vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
- txtMsgInfo.Text = "计量失败,请求服务异常:" + rmRst.ResultMessage;
- lg.WriteLog(LogType.serverLog, "计量失败,请求服务异常:" + rmRst.ResultMessage);
- CacleCls.isLock = false;
- return;
- }
- }
- }
- else
- {
- //写本地文件
- 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);
- if (flag)
- {
- isMeasureSuccess = true;
- }
- else
- {
- vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, "计量失败,请联系管理员");
- txtMsgInfo.Text = "计量失败写入,本地文件异常:" + msgInfo;
- lg.WriteLog(LogType.serverLog, "计量失败,写入本地文件异常:" + msgInfo);
- CacleCls.isLock = false;
- return;
- }
- }
- //计量成功
- if (isMeasureSuccess)
- {
- txtMsgInfo.Text = "计量完成";
- #region 毛皮净赋值
- if (CacleCls.firstDb != null && CacleCls.firstDb.meterWeight > 0 && CacleCls.lockWgt > 0)
- {
- if (CacleCls.firstDb.meterWeight > CacleCls.lockWgt)
- {
- txtGroess.Text = $"{CacleCls.firstDb.meterWeight / 1000}";
- txtTare.Text = $"{CacleCls.lockWgt / 1000}";
- txtNet.Text = $"{(CacleCls.firstDb.meterWeight - CacleCls.lockWgt) / 1000}";
- }
- else
- {
- txtGroess.Text = $"{CacleCls.lockWgt / 1000}";
- txtTare.Text = $"{CacleCls.firstDb.meterWeight / 1000}";
- txtNet.Text = $"{(CacleCls.lockWgt - CacleCls.firstDb.meterWeight) / 1000}";
- }
- }
- if (!string.IsNullOrEmpty(CacleCls.LEDResultMessage))
- {
- led_controler.setStaticLineMsg(AppConfigCache.ledIp, CacleCls.LEDResultMessage);
- }
- #endregion
- //屏幕截图操作
- _ = BeginInvoke(new Action(() => { shotImageScreen(strGuid); }));
- BindTable();
- //只需要控制plc即可,其他的不管
- if (AppConfigCache.plcStart == "1")
- {
- plc.DataCollectWrite(AppConfigCache.dz, AppConfigCache.dzValue);
- }
- }
- #endregion
- }
- catch (Exception ex)
- {
- vicPlayClass.GetVoicePlay(VoiceEnum.程序处理异常, CacleCls.lockCarNo);
- lg.WriteLog(LogType.SystemLog, "计量失败1:" + ex.Message);
- CacleCls.isLock = false;
- }
- }
- private void BindTable()
- {
- bool bReadFlag = false;
- string strRtMsgInfo = "";
- List<ActualFirstModel> lm = FileOption.ReadDb<ActualFirstModel>(ref bReadFlag, ref strRtMsgInfo);
- DataTable dtV = dataTableFirst.Clone();
- if (lm != null && lm.Count > 0)
- {
- dtV = lm.ListToDataTable<ActualFirstModel>();
- }
- ClsControlPack.CopyDataToDatatable(ref dtV, ref this.dataTableFirst, true);
- ClsControlPack.RefreshAndAutoSize(ultraGridFirst);
- }
- private void btnOpenVoice_Click(object sender, EventArgs e)
- {
- //*
- if (btnOpenVoice.Text == "打开对讲")
- {
- VoiceOpen();
- }
- else
- {
- VoiceClose();
- }
- //*/
- }
- private void frmMain_FormClosing(object sender, FormClosingEventArgs e)
- {
- stop();
- try { mx?.ClosingCollect(); } catch { }
- try { rfid?.ClosingCollect(); } catch { }
- try { if (bVoice) ce?.StopTalk(); } catch { }
-
- foreach (int i in voPlay)
- {
- try { ce?.StopRealPlay(i); } catch { }
- }
- try { plc?.Stop(); } catch { }
-
- try { ping?.stop(); } catch { }
- try { upload?.stop(); } catch { }
- try { carCls?.LoginOut(); } catch { }
- //try { carCls2?.LoginOut(); } catch { }
- try { imgControl?.Stop(); } catch { }
- }
- /// <summary>
- /// 必须先打开视频,然后再打开语音
- /// </summary>
- private void VoiceOpen()
- {
- try
- {
- if (ce.StartTalk())
- {
- btnOpenVoice.Text = "关闭对讲";
- bVoice = true;
- }
- }
- catch (Exception ex)
- {
- txtMsgInfo.Text = "打开对讲失败:" + ex.Message;
- }
- }
- /// <summary>
- /// 关闭语音对讲
- /// </summary>
- private void VoiceClose()
- {
- try
- {
- if (ce.StopTalk())
- {
- btnOpenVoice.Text = "打开对讲";
- bVoice = false;
- }
- }
- catch (Exception ex)
- {
- txtMsgInfo.Text = "关闭对讲失败:" + ex.Message;
- }
- }
- private void btnExport_Click(object sender, EventArgs e)
- {
- ClsControlPack.ExportDataWithSaveDialog2(ref ultraGridFirst, DateTime.Now.ToString("yyyyMMddHHmmss"));
- }
- private void cbCarNo_SelectedIndexChanged(object sender, EventArgs e)
- {
- CacleCls.isLock = false;
- }
- private void cbJg_CheckedChanged(object sender, EventArgs e)
- {
- CacleCls.isJg = cbJg.Checked;
- btnSave.Enabled = cbJg.Checked;
- }
- private void txtCarNo_TextChanged(object sender, EventArgs e)
- {
- CacleCls.isLock = false;
- }
- private void PictureBoxDoubleClick(object sender, EventArgs e)
- {
- if (iPic != 0)
- {
- ce.StopRealPlay(iPic);
- }
- PictureBox picture = (PictureBox)sender;
- iPic = Convert.ToInt32(picture.Name.Substring(picture.Name.Length - 1, 1));
- plImgShow.Visible = true;
- ce.RealPlay(pictureShow, iPic);
- }
- private void pictureShow_DoubleClick(object sender, EventArgs e)
- {
- plImgShow.Visible = false;
- ce.StopRealPlay(iPic);
- iPic = 0;
- }
- private void txtCarNo_KeyDown(object sender, KeyEventArgs e)
- {
- if (e.KeyCode == Keys.Enter) label3.Focus();
- }
- private void btnOpenDz_Click(object sender, EventArgs e)
- {
- if (AppConfigCache.plcStart == "1")
- {
- plc.DataCollectWrite(AppConfigCache.dz, AppConfigCache.dzValue);
- }
- else
- {
- MessageBox.Show("当前PLC处于未连接状态,请先配置连接再操作");
- }
- }
- /// <summary>
- /// 终端截图(临时截图,使用临时ID存储)
- /// </summary>
- public void shotImageScreen(string strActualFirstNo)
- {
- try
- {
- #region 截取图片信息
- //截取屏幕信息
- Point screenPoint = plCaptionMain.PointToScreen(new Point());
- Rectangle rect = new Rectangle(screenPoint, plCaptionMain.Size);
- Image img = new Bitmap(plCaptionMain.Width, plCaptionMain.Height);
- Graphics g = Graphics.FromImage(img);
- g.CopyFromScreen(rect.X - 1, rect.Y - 1, 0, 0, rect.Size);//"D://file/1.jpg"
- img.Save(string.Format("{0}imgShort\\formalImg\\{1}_{2}_tempImg_{3}.jpg",
- AppDomain.CurrentDomain.SetupInformation.ApplicationBase,
- AppConfigCache.pointNo, "C" + strActualFirstNo, 7), System.Drawing.Imaging.ImageFormat.Jpeg);
- //lg.WriteLog(35, "完成截图 成功标识:" + PbCache.shotSuccess.ToString() + "车号:" + PbCache.lockCarNo + ";重量:" + PbCache.lockWgt + ";时间:" + DateTime.Now.ToLongTimeString());
- #endregion 截取图片信息
- }
- catch (Exception ex)
- {
- lg.WriteLog(LogType.SystemLog, "计量完成,但图片截取失败,编号:" + strActualFirstNo);
- }
- }
- #region 释放内存
- [DllImport("kernel32.dll")]
- private static extern bool SetProcessWorkingSetSize(IntPtr process, int minSize, int maxSize);
- //刷新存储器
- private static void FlushMemory()
- {
- GC.Collect();
- GC.WaitForPendingFinalizers();
- if (Environment.OSVersion.Platform == PlatformID.Win32NT)
- {
- SetProcessWorkingSetSize(Process.GetCurrentProcess().Handle, -1, -1);
- }
- }
- #endregion
- }
- }
|