| | |
| | | using System;
|
| | | using System.Collections;
|
| | | using System.Collections.Generic;
|
| | | using System.ComponentModel;
|
| | | using System.Linq;
|
| | | using System.Reflection;
|
| | | using System.Text;
|
| | | using System.Threading.Tasks;
|
| | | using Autofac.Core;
|
| | | using HslCommunication;
|
| | | using HslCommunication.Core;
|
| | | using Microsoft.VisualBasic.FileIO;
|
| | | using OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime;
|
| | | using OfficeOpenXml.FormulaParsing.Excel.Functions.RefAndLookup;
|
| | | using System.Text;
|
| | | using Quartz;
|
| | | using SixLabors.ImageSharp.PixelFormats;
|
| | | using WIDESEAWCS_BasicInfoService;
|
| | | using WIDESEAWCS_Common.PLCEnum;
|
| | | using WIDESEAWCS_Communicator;
|
| | | using WIDESEAWCS_Core.BaseRepository;
|
| | | using WIDESEAWCS_Core.Helper;
|
| | | using WIDESEAWCS_IBasicInfoService;
|
| | | using WIDESEAWCS_Model.Models;
|
| | | using WIDESEAWCS_QuartzJob;
|
| | | using WIDESEAWCS_QuartzJob.DeviceBase;
|
| | | using WIDESEAWCS_QuartzJob.StackerCrane.Enum;
|
| | |
|
| | | namespace WIDESEAWCS_Tasks
|
| | | {
|
| | |
| | | private readonly IFormulaService _formulaService;
|
| | | private readonly IFormulaDetailService _formulaDetailService;
|
| | | private readonly IProcessInfoService _processInfoService;
|
| | | private readonly IProcessInfoDetailService _processDetailInfoService;
|
| | | private readonly IUnitOfWorkManage _unitOfWorkManage;
|
| | | public PLCJob(IBoxingService boxingService, IBoxingDetailService boxingDetailService, IFormulaService formulaService, IFormulaDetailService formulaDetailService, IProcessInfoService processInfoService, IUnitOfWorkManage unitOfWorkManage)
|
| | | private readonly IScanStationService _scanStationService;
|
| | | //private readonly string PalletCode = "PL107";
|
| | |
|
| | | public PLCJob(IBoxingService boxingService,
|
| | | IBoxingDetailService boxingDetailService,
|
| | | IFormulaService formulaService,
|
| | | IFormulaDetailService formulaDetailService,
|
| | | IProcessInfoService processInfoService,
|
| | | IProcessInfoDetailService processDetailInfoService,
|
| | | IUnitOfWorkManage unitOfWorkManage,
|
| | | IScanStationService scanStationService
|
| | | )
|
| | | {
|
| | | _boxingService = boxingService;
|
| | | _boxingDetailService = boxingDetailService;
|
| | | _formulaService = formulaService;
|
| | | _formulaDetailService = formulaDetailService;
|
| | | _processInfoService = processInfoService;
|
| | | _processDetailInfoService = processDetailInfoService;
|
| | | _unitOfWorkManage = unitOfWorkManage;
|
| | | _scanStationService = scanStationService;
|
| | | }
|
| | | private readonly string set = "0x16,0x4D,0x0D,0x30,0x34,0x30,0x31,0x44,0x30,0x35,0x2E";//主æºåéè®¾ç½®æ«ææ¨¡å¼ä¸ºä¸»æºæ¨¡å¼çå½ä»¤,æ«æå¨è¿åæ¥æ¶å°çå½ä»¤å<ACK>ï¼0x06ï¼åï¼å°æ«ææ¨¡å¼æ´æ¹ä¸ºä¸»æºæ¨¡å¼
|
| | | private readonly string Text = "å¼å¯æ«ç ";//主æºåéè®¾ç½®æ«ææ¨¡å¼ä¸ºä¸»æºæ¨¡å¼çå½ä»¤,æ«æå¨è¿åæ¥æ¶å°çå½ä»¤å<ACK>ï¼0x06ï¼åï¼å°æ«ææ¨¡å¼æ´æ¹ä¸ºä¸»æºæ¨¡å¼
|
| | | private readonly string command = "0x16,0x54,0x0D";//åéå¼å§è§£ç å½ä»¤ï¼"0x16,0x55,0x0D"åéåæ¢è§£ç å½ä»¤
|
| | | public Task Execute(IJobExecutionContext context)
|
| | | {
|
| | |
|
| | |
| | | var AutoExecuting = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolAutoExecuting);
|
| | | var OnlineExecuting = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolOnlineExecuting);
|
| | | var Error = device.GetValue<R_PLCDBName, bool>(R_PLCDBName.rboolError);
|
| | |
|
| | | if (Heart && !EMG && AutoExecuting && OnlineExecuting && !Error)
|
| | | {
|
| | | #region ä¸çº¿æ«ç
|
| | |
| | | var Location1ScanDone = device.GetValue<W_PLCDBName, bool>(W_PLCDBName.wboolLocation1ScanDone);
|
| | | if (Location1ScanStart && !Location1ScanDone)//æ§å¶æ«ç æªæ«ææçç ï¼æ ¹æ®æçç æ¥è¯¢ç»çæ°æ®ï¼å¤ææçç»å®æåæ¯å¦å·²ç»å®æææéé¶ä»¶
|
| | | {
|
| | | #region 串å£è¿æ¥
|
| | | SerialPortCommunicator portCommunicator1 = new SerialPortCommunicator("COM1", 9600, "ä¸çº¿æ«ç æª");
|
| | | bool IsConnected1 = false;
|
| | | SerialPortCommunicator portCommunicator2 = new SerialPortCommunicator("COM2", 9600, "ä¸çº¿æ«ç æª");
|
| | | bool IsConnected2 = false;
|
| | | if (!IsConnected1) IsConnected1 = portCommunicator1.Connect();
|
| | | if (!IsConnected2) IsConnected2 = portCommunicator2.Connect();
|
| | | byte[] dataToSend1 = Encoding.ASCII.GetBytes(command);//转æåèæ°ç»
|
| | | portCommunicator1.Write(dataToSend1);
|
| | | string receiveData = portCommunicator2.ToString(Encoding.UTF8);
|
| | | //if (receiveData == "0x16,0x54,0x0D")
|
| | | //{
|
| | | // Console.WriteLine(receiveData);
|
| | | byte[] dataToSend2 = Encoding.ASCII.GetBytes("PL106");//转æåèæ°ç»
|
| | | portCommunicator2.Write(dataToSend2);
|
| | | //}
|
| | | string PalletCode = portCommunicator1.ToString(Encoding.UTF8);
|
| | | using (var uow = _unitOfWorkManage.CreateUnitOfWork())
|
| | | {
|
| | | var PalletCode = TcpClientExample.Start("192.168.2.120", 2001);
|
| | | try
|
| | | {
|
| | | if (PalletCode.IsNotEmptyOrNull())
|
| | | if (!PalletCode.IsNotEmptyOrNull())
|
| | | {
|
| | | throw new InvalidOperationException("æç为空");
|
| | | }
|
| | | var boxing = _boxingService.Repository.QueryFirst(x => x.PalletCode == PalletCode);
|
| | | if (boxing == null)
|
| | | {
|
| | | WriteError(device.DeviceName, "空æç");
|
| | | return;
|
| | | throw new InvalidOperationException("æªæ·»å ç»çä¿¡æ¯");
|
| | | }
|
| | | List<Dt_BoxingDetail> dt_BoxingDetails = _boxingDetailService.Repository.QueryData(x => x.BoxingId == boxing.Id);
|
| | | Dt_Formula dt_Formula = _formulaService.Repository.QueryFirst(x => x.ProductCode == boxing.ProductCode);
|
| | | if (dt_Formula == null)
|
| | | {
|
| | | WriteError(device.DeviceName, "æ æåé
æ¹");
|
| | | return;
|
| | | throw new InvalidOperationException("æ æåé
æ¹");
|
| | | }
|
| | | List<Dt_FormulaDetail> dt_FormulaDetails = _formulaDetailService.Repository.QueryData(x => x.FormulaId == dt_Formula.Id);
|
| | | List<Dt_FormulaDetail> dt_FormulaDetails = _formulaDetailService.Repository.QueryData(x => x.FormulaId == dt_Formula.Id && x.IsScanned == 1);
|
| | | //æ¯è¾é¶ä»¶æ¯å¦é½å
¨
|
| | | if (!_boxingDetailService.IsComponentCodesEqual(dt_BoxingDetails, dt_FormulaDetails))
|
| | | {
|
| | | WriteError(device.DeviceName, "é¶ä»¶æé®é¢ï¼è¯·å¤ç");
|
| | | return;
|
| | | throw new InvalidOperationException("é¶ä»¶æé®é¢ï¼è¯·å¤ç");
|
| | | }
|
| | | }
|
| | | //æäº¤äºå¡
|
| | | uow.Commit();
|
| | |
|
| | | IsConnected1 = !portCommunicator1.Disconnect();
|
| | | IsConnected2 = !portCommunicator2.Disconnect();
|
| | | #endregion
|
| | | device.SetValue(W_PLCDBName.wboolLocation1ScanDone, true);
|
| | | |
| | |
|
| | | }
|
| | | catch (Exception ex)
|
| | | {
|
| | | WriteError(device.DeviceName, "ä¸çº¿æ«ç æµç¨æ§è¡å¼å¸¸", ex);
|
| | | }
|
| | | }
|
| | | }
|
| | | else if (!Location1ScanStart && Location1ScanDone)
|
| | |
| | | var Location2ScanDone = device.GetValue<W_PLCDBName, bool>(W_PLCDBName.wboolLocation2ScanDone);
|
| | | if (Location2ScanStart && !Location2ScanDone)//æ§å¶æ«ç æªæ«ææçç ï¼æ ¹æ®æçç æ¥è¯¢æçç»å®æåå å·¥æéæ°æ®ï¼åå
¥PLC
|
| | | {
|
| | | #region MyRegion
|
| | | #region 串å£è¿æ¥
|
| | | SerialPortCommunicator portCommunicator17 = new SerialPortCommunicator("COM17", 9600, "åè£
æ«ç æª");
|
| | | bool IsConnected17 = false;
|
| | | SerialPortCommunicator portCommunicator18 = new SerialPortCommunicator("COM18", 9600, "åè£
æ«ç æª");
|
| | | bool IsConnected18 = false;
|
| | | if (!IsConnected17) IsConnected17 = portCommunicator17.Connect();
|
| | | if (!IsConnected18) IsConnected18 = portCommunicator18.Connect();
|
| | | byte[] dataToSend1 = Encoding.ASCII.GetBytes(command);//转æåèæ°ç»
|
| | | portCommunicator17.Write(dataToSend1);
|
| | | string receiveData = portCommunicator18.ToString(Encoding.UTF8);
|
| | | byte[] dataToSend2 = Encoding.ASCII.GetBytes("PL106");//转æåèæ°ç»
|
| | | portCommunicator18.Write(dataToSend2);
|
| | | //}
|
| | | string PalletCode = portCommunicator17.ToString(Encoding.UTF8);
|
| | | using (var uow = _unitOfWorkManage.CreateUnitOfWork())
|
| | | {
|
| | | var PalletCode = TcpClientExample.Start("192.168.2.121", 2001);
|
| | |
|
| | | try
|
| | | {
|
| | | if (PalletCode.IsNotEmptyOrNull())
|
| | | if (!PalletCode.IsNotEmptyOrNull())
|
| | | {
|
| | | throw new InvalidOperationException("æç为空");
|
| | | }
|
| | | Dt_Boxing dt_Boxing = _boxingService.Repository.QueryFirst(x => x.PalletCode == PalletCode);
|
| | | Dt_Formula dt_Formula = _formulaService.Repository.QueryFirst(x => x.ProductCode == dt_Boxing.ProductCode);
|
| | | //åå
¥PLC
|
| | |
| | | device.SetValue(W_PLCDBName.wrealScrewDownsetDistance, dt_Formula.ScrewDownsetDistance);
|
| | | device.SetValue(W_PLCDBName.wrealScrewTorqueOutput, dt_Formula.ScrewTorqueOutput);
|
| | | device.SetValue(W_PLCDBName.wDintAutoScrewOn, dt_Formula.DintAutoScrewOn);
|
| | |
|
| | | //åè£
æ«ç 宿
|
| | | device.SetValue(W_PLCDBName.wboolLocation2ScanDone, true);
|
| | |
|
| | | //æ¥æ¶æ°æ®
|
| | | float PressHeight = device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectPressHeight);
|
| | | float ScrewTorque = device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectScrewTorque);
|
| | | float ScrewAngle = device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectScrewAngle);
|
| | |
|
| | | decimal PressHeight = (decimal)device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectPressHeight);
|
| | | decimal ScrewTorque = (decimal)device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectScrewTorque);
|
| | | decimal ScrewAngle = (decimal)device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectScrewAngle);
|
| | | //æ·»å å°æ°æ®åº
|
| | | Dt_ProcessInfo dt_ProcessInfo = new Dt_ProcessInfo()
|
| | | {
|
| | |
| | | PressHeight = PressHeight,
|
| | | ScrewTorque = ScrewTorque,
|
| | | ScrewAngle = ScrewAngle
|
| | |
|
| | | };
|
| | | _processInfoService.Repository.AddData(dt_ProcessInfo);
|
| | | }
|
| | | //æäº¤äºå¡
|
| | | uow.Commit();
|
| | |
|
| | | IsConnected17 = !portCommunicator17.Disconnect();
|
| | | IsConnected18 = !portCommunicator18.Disconnect();
|
| | | #endregion
|
| | | #endregion
|
| | |
|
| | | }
|
| | | catch (Exception ex)
|
| | | {
|
| | | WriteError(device.DeviceName, "åè£
æ«ç æµç¨æ§è¡å¼å¸¸", ex);
|
| | | }
|
| | | }
|
| | | }
|
| | | else if (!Location2ScanStart && Location2ScanDone)
|
| | |
| | | var Location3ScanDone = device.GetValue<W_PLCDBName, bool>(W_PLCDBName.wboolLocation3ScanDone);
|
| | | if (Location3ScanStart && !Location3ScanDone)
|
| | | {
|
| | | #region MyRegion
|
| | | #region 串å£è¿æ¥
|
| | | SerialPortCommunicator portCommunicator19 = new SerialPortCommunicator("COM19", 9600, "æ£æµæ«ç æª");
|
| | | bool IsConnected19 = false;
|
| | | SerialPortCommunicator portCommunicator20 = new SerialPortCommunicator("COM20", 9600, "æ£æµæ«ç æª");
|
| | | bool IsConnected20 = false;
|
| | | if (!IsConnected19) IsConnected19 = portCommunicator19.Connect();
|
| | | if (!IsConnected20) IsConnected20 = portCommunicator20.Connect();
|
| | | byte[] dataToSend1 = Encoding.ASCII.GetBytes(command);//转æåèæ°ç»
|
| | | portCommunicator19.Write(dataToSend1);
|
| | | string receiveData = portCommunicator20.ToString(Encoding.UTF8);
|
| | | byte[] dataToSend2 = Encoding.ASCII.GetBytes("PL106");//转æåèæ°ç»
|
| | | portCommunicator20.Write(dataToSend2);
|
| | | //}
|
| | | string PalletCode = portCommunicator19.ToString(Encoding.UTF8);
|
| | |
|
| | | using (var uow = _unitOfWorkManage.CreateUnitOfWork())
|
| | | {
|
| | | var PalletCode = TcpClientExample.Start("192.168.2.122", 2001);
|
| | | try
|
| | | {
|
| | | if (PalletCode.IsNotEmptyOrNull())
|
| | | if (!PalletCode.IsNotEmptyOrNull())
|
| | | {
|
| | | throw new InvalidOperationException("æç为空");
|
| | | }
|
| | | Dt_Boxing dt_Boxing = _boxingService.Repository.QueryFirst(x => x.PalletCode == PalletCode);
|
| | | Dt_Formula dt_Formula = _formulaService.Repository.QueryFirst(x => x.ProductCode == dt_Boxing.ProductCode);
|
| | | //åå
¥PLC
|
| | |
| | | device.SetValue(W_PLCDBName.wboolLocation3ScanDone, true);
|
| | |
|
| | | //æ¥æ¶æ°æ®
|
| | | float Height1 = device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectHeight1);
|
| | | float Height2 = device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectHeight2);
|
| | | float Height3 = device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectHeight3);
|
| | | decimal Height1 = (decimal)device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectHeight1);
|
| | | decimal Height2 = (decimal)device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectHeight2);
|
| | | decimal Height3 = (decimal)device.GetValue<R_PLCDBName, float>(R_PLCDBName.rrealDetectHeight3);
|
| | |
|
| | | Dt_ProcessInfo dt_ProcessInfo = _processInfoService.Repository.QueryFirst(x => x.PalletCode == PalletCode);
|
| | | if (dt_ProcessInfo == null)
|
| | | {
|
| | | WriteInfo(device.DeviceName, "æåæªåè£
");
|
| | | device.SetValue(W_PLCDBName.wboolLocation1ScanDone, true);
|
| | | return;
|
| | | throw new InvalidOperationException("æåæªåè£
");
|
| | | }
|
| | | dt_ProcessInfo.Height1 = Height1;
|
| | | dt_ProcessInfo.Height2 = Height2;
|
| | | dt_ProcessInfo.Height3 = Height3;
|
| | | _processInfoService.Repository.UpdateData(dt_ProcessInfo);
|
| | |
|
| | | }
|
| | | //æäº¤äºå¡
|
| | | uow.Commit();
|
| | |
|
| | | IsConnected19 = !portCommunicator19.Disconnect();
|
| | | IsConnected20 = !portCommunicator20.Disconnect();
|
| | | #endregion
|
| | | #endregion
|
| | | }
|
| | | catch (Exception ex)
|
| | | {
|
| | | WriteError(device.DeviceName, "æ£æµæ«ç æµç¨æ§è¡å¼å¸¸", ex);
|
| | | }
|
| | | }
|
| | | }
|
| | | else if (!Location3ScanStart && Location3ScanDone)
|
| | |
| | | var Location4ScanDone = device.GetValue<W_PLCDBName, bool>(W_PLCDBName.wboolLocation4ScanDone);
|
| | | if (Location4ScanStart && !Location4ScanDone)//æ§å¶æ«ç æªæ«ææçç ï¼æ ¹æ®æçç æ¥è¯¢ç»çæ°æ®ï¼å¤ææçç»å®æåæ¯å¦å·²ç»å®æææéé¶ä»¶
|
| | | {
|
| | | SerialPortCommunicator portCommunicator21 = new SerialPortCommunicator("COM21", 9600, "ä¸çº¿æ«ç æª");
|
| | | bool IsConnected21 = false;
|
| | | SerialPortCommunicator portCommunicator22 = new SerialPortCommunicator("COM22", 9600, "ä¸çº¿æ«ç æª");
|
| | | bool IsConnected22 = false;
|
| | | if (!IsConnected21) IsConnected21 = portCommunicator21.Connect();
|
| | | if (!IsConnected22) IsConnected22 = portCommunicator22.Connect();
|
| | | byte[] dataToSend1 = Encoding.ASCII.GetBytes(command);//转æåèæ°ç»
|
| | | portCommunicator21.Write(dataToSend1);
|
| | | string receiveData = portCommunicator22.ToString(Encoding.UTF8);
|
| | | byte[] dataToSend2 = Encoding.ASCII.GetBytes("PL106");//转æåèæ°ç»
|
| | | portCommunicator22.Write(dataToSend2);
|
| | | //}
|
| | | string PalletCode = portCommunicator21.ToString(Encoding.UTF8);
|
| | | var PalletCode = TcpClientExample.Start("192.168.2.123", 2001);
|
| | | using (var uow = _unitOfWorkManage.CreateUnitOfWork())
|
| | | {
|
| | | try
|
| | | {
|
| | | if (PalletCode.IsNotEmptyOrNull())
|
| | | if (!PalletCode.IsNotEmptyOrNull())
|
| | | {
|
| | | throw new InvalidOperationException("æç为空");
|
| | | }
|
| | | Dt_ProcessInfo dt_ProcessInfo = _processInfoService.Repository.QueryFirst(x => x.PalletCode == PalletCode);
|
| | | if (dt_ProcessInfo == null)
|
| | | {
|
| | | throw new InvalidOperationException("æåæªåè£
忣æµ");
|
| | | }
|
| | | Dt_Boxing dt_Boxing = _boxingService.Repository.QueryFirst(x => x.PalletCode == PalletCode);
|
| | | _boxingService.Repository.DeleteData(dt_Boxing);
|
| | | List<Dt_BoxingDetail> dt_BoxingDetails = _boxingDetailService.Repository.QueryData(x => x.BoxingId == dt_Boxing.Id);
|
| | | foreach (Dt_BoxingDetail dt_BoxingDetail in dt_BoxingDetails)
|
| | | _boxingDetailService.Repository.DeleteData(dt_BoxingDetails);
|
| | |
|
| | | Dt_ProcessInfoDetail dt_ProcessInfoDetail = new Dt_ProcessInfoDetail()
|
| | | {
|
| | | _boxingDetailService.Repository.DeleteDataById(dt_BoxingDetail.Id);
|
| | | }
|
| | | PalletCode = PalletCode,
|
| | | ProductCode = dt_ProcessInfo.ProductCode,
|
| | | ProductName = dt_ProcessInfo.ProductName,
|
| | | Creater = "admin",
|
| | | CreateDate = DateTime.Now
|
| | | };
|
| | | _processDetailInfoService.Repository.AddData(dt_ProcessInfoDetail);
|
| | | _processInfoService.DeleteData(dt_ProcessInfo);
|
| | | uow.Commit();
|
| | | //ä¸çº¿æ«ç 宿
|
| | | device.SetValue(W_PLCDBName.wboolLocation4ScanDone, true);
|
| | | }
|
| | | IsConnected21 = !portCommunicator21.Disconnect();
|
| | | IsConnected22 = !portCommunicator22.Disconnect();
|
| | | }
|
| | | catch (Exception ex)
|
| | | {
|