|
|
|
|
@ -15,6 +15,7 @@ using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Linq.Expressions;
|
|
|
|
|
using System.Security.Cryptography;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using TouchSocket.Core;
|
|
|
|
|
@ -22,6 +23,9 @@ using static System.Runtime.CompilerServices.RuntimeHelpers;
|
|
|
|
|
|
|
|
|
|
namespace Sln.Iot.Business
|
|
|
|
|
{
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// RFID01真空箱内
|
|
|
|
|
/// </summary>
|
|
|
|
|
public class RFID01Business
|
|
|
|
|
{
|
|
|
|
|
private Timer _timer;
|
|
|
|
|
@ -37,9 +41,7 @@ namespace Sln.Iot.Business
|
|
|
|
|
private UnitsDepartedEvent unitsDepartedEvent = new UnitsDepartedEvent();
|
|
|
|
|
|
|
|
|
|
private TrayBindingService trayBindingService = TrayBindingService.Instance;
|
|
|
|
|
private CFXConnect1 connect1 = CFXConnect1.Instance;
|
|
|
|
|
private CFXConnect2 connect2 = CFXConnect2.Instance;
|
|
|
|
|
private CFXConnect3 connect3 = CFXConnect3.Instance;
|
|
|
|
|
private CFXConnectVacuum connectVacuum = CFXConnectVacuum.Instance;
|
|
|
|
|
|
|
|
|
|
public RFID01Business()
|
|
|
|
|
{
|
|
|
|
|
@ -47,7 +49,7 @@ namespace Sln.Iot.Business
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// RFID01上料提升机数据处理流程业务刷新
|
|
|
|
|
/// RFID01真空箱内
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="state"></param>
|
|
|
|
|
public void TimerCallback(object? state)
|
|
|
|
|
@ -56,7 +58,7 @@ namespace Sln.Iot.Business
|
|
|
|
|
{
|
|
|
|
|
// 定时任务逻辑
|
|
|
|
|
//读取信号
|
|
|
|
|
OperateResult<short> signalRes = _plc.ReadInt16(_plc.DeltaInstance3, "D500");
|
|
|
|
|
OperateResult<short> signalRes = _plc.ReadInt16(_plc.PLC22, "D800");
|
|
|
|
|
//成功验证
|
|
|
|
|
if (signalRes.IsSuccess)
|
|
|
|
|
{
|
|
|
|
|
@ -65,11 +67,9 @@ namespace Sln.Iot.Business
|
|
|
|
|
if (signalValue == 1001)
|
|
|
|
|
{
|
|
|
|
|
//读取托盘码和产品码
|
|
|
|
|
OperateResult<byte[]> trayBytesResult = _plc.ReadBytes(_plc.DeltaInstance3, "D5000", 10);
|
|
|
|
|
OperateResult<byte[]> pordBytesResult1 = _plc.ReadBytes(_plc.DeltaInstance3, "D8000", 90);
|
|
|
|
|
OperateResult<byte[]> pordBytesResult2 = _plc.ReadBytes(_plc.DeltaInstance3, "D8090", 90);
|
|
|
|
|
OperateResult<byte[]> trayBytesResult = _plc.ReadBytes(_plc.PLC22, "D5000", 10);
|
|
|
|
|
//成功验证
|
|
|
|
|
if (trayBytesResult.IsSuccess && pordBytesResult1.IsSuccess && pordBytesResult2.IsSuccess)
|
|
|
|
|
if (trayBytesResult.IsSuccess)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
//转换托盘码
|
|
|
|
|
@ -77,56 +77,28 @@ namespace Sln.Iot.Business
|
|
|
|
|
traycode = traycode.Replace("?", "");
|
|
|
|
|
traycode = traycode.Replace("\0", "");
|
|
|
|
|
_log.Info($"托盘到达-RFID01-托盘号-[{traycode}]");
|
|
|
|
|
byte[] prodBytes = pordBytesResult1.Content.Concat(pordBytesResult2.Content).ToArray();
|
|
|
|
|
string[] prodcode = new string[6];
|
|
|
|
|
//分割转换产品码
|
|
|
|
|
for (int i = 0; i < 6; i++)
|
|
|
|
|
{
|
|
|
|
|
prodcode[i] = Encoding.ASCII.GetString(prodBytes[(i * 60)..(i * 60 + 60)]);
|
|
|
|
|
prodcode[i] = prodcode[i].Replace("\0", "");
|
|
|
|
|
if (!string.IsNullOrEmpty(prodcode[i]))
|
|
|
|
|
{
|
|
|
|
|
// 将相邻偶数位和奇数位字符对调
|
|
|
|
|
char[] chars = prodcode[i].ToCharArray();
|
|
|
|
|
for (int j = 0; j < chars.Length - 1; j += 2)
|
|
|
|
|
{
|
|
|
|
|
// 交换相邻的两个字符
|
|
|
|
|
char temp = chars[j];
|
|
|
|
|
chars[j] = chars[j + 1];
|
|
|
|
|
chars[j + 1] = temp;
|
|
|
|
|
}
|
|
|
|
|
prodcode[i] = new string(chars);
|
|
|
|
|
GlobalVar.Connect2Entity.InputQuantity++;
|
|
|
|
|
GlobalVar.Connect2Entity.PassQuantity++;
|
|
|
|
|
GlobalVar.Connect3Entity.InputQuantity++;
|
|
|
|
|
GlobalVar.Connect1Entity.InputQuantity++;
|
|
|
|
|
GlobalVar.Connect1Entity.PassQuantity++;
|
|
|
|
|
GlobalVar.Connect3Entity.PassQuantity++;
|
|
|
|
|
GlobalVar.Connect4Entity.InputQuantity++;
|
|
|
|
|
GlobalVar.Connect4Entity.PassQuantity++;
|
|
|
|
|
_log.Info($"{prodcode[i]}进入产线");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//connect1.SendValidateUnitsRequest("", traycode, prodcode);
|
|
|
|
|
|
|
|
|
|
//生成work唯一guid(tid)
|
|
|
|
|
Guid tid = Guid.NewGuid();
|
|
|
|
|
//sql更新
|
|
|
|
|
bool res = trayBindingService.TrayBindingRefresh(tid, traycode, prodcode);
|
|
|
|
|
if (!res)
|
|
|
|
|
{
|
|
|
|
|
_log.Error("上料提升机数据库写入异常");
|
|
|
|
|
}
|
|
|
|
|
//记录预热炉到达时间
|
|
|
|
|
trayBindingService.UpDateTime(DateTime.Now.ToString(), traycode, "1");
|
|
|
|
|
|
|
|
|
|
//写入完成信号
|
|
|
|
|
res = _plc.PlcWrite(_plc.DeltaInstance3, "D500", 1002, DataTypeEnum.UInt16).IsSuccess;
|
|
|
|
|
bool res = _plc.PlcWrite(_plc.PLC22, "D800", 1002, DataTypeEnum.UInt16).IsSuccess;
|
|
|
|
|
if (!res)
|
|
|
|
|
{
|
|
|
|
|
_log.Error("上料提升机PLC写入完成信号异常");
|
|
|
|
|
_log.Error("RFID01 读电子标签 PLC写入完成信号异常");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//取出work唯一guid(tid)
|
|
|
|
|
string stid = trayBindingService.TidGet(traycode);
|
|
|
|
|
if (!Guid.TryParse(stid, out Guid tid))
|
|
|
|
|
{
|
|
|
|
|
tid = Guid.Parse("11111111-1111-4111-9111-111111111111");
|
|
|
|
|
_log.Error("找不到对应的托盘信息,赋值默认GUID");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//读取托盘对应的产品码
|
|
|
|
|
string[] prodcode = trayBindingService.ProdCodeGet(traycode);
|
|
|
|
|
|
|
|
|
|
GlobalVar.Connect2Entity.CycleTime = CommonUtil.AddRandom(AppConfigSetting._config.CycleTime2, 5);
|
|
|
|
|
|
|
|
|
|
//CFX
|
|
|
|
|
@ -134,29 +106,33 @@ namespace Sln.Iot.Business
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
//单元抵达事件
|
|
|
|
|
connect1.PublishEvent(new CFXEnvelope(unitsArrivedEvent.Handle(traycode, prodcode)));
|
|
|
|
|
connect2.PublishEvent(new CFXEnvelope(unitsArrivedEvent.Handle(traycode, prodcode)));
|
|
|
|
|
connect3.PublishEvent(new CFXEnvelope(unitsArrivedEvent.Handle(traycode, prodcode)));
|
|
|
|
|
_log.Info($"{traycode} 抵达设备");
|
|
|
|
|
connectVacuum.PublishEvent(new CFXEnvelope(unitsArrivedEvent.Handle(traycode, prodcode)));
|
|
|
|
|
//工作开始事件
|
|
|
|
|
connect1.PublishEvent(new CFXEnvelope(workStartedEvent.Handle(tid, traycode, prodcode)));
|
|
|
|
|
connect2.PublishEvent(new CFXEnvelope(workStartedEvent.Handle(tid, traycode, prodcode)));
|
|
|
|
|
connect3.PublishEvent(new CFXEnvelope(workStartedEvent.Handle(tid, traycode, prodcode)));
|
|
|
|
|
connectVacuum.PublishEvent(new CFXEnvelope(workStartedEvent.Handle(tid, traycode, prodcode)));
|
|
|
|
|
_log.Info($"工作开始,ID:{tid}");
|
|
|
|
|
connect2.PublishEvent(new CFXEnvelope(workCompletedEvent.Handle(tid, traycode, prodcode)));
|
|
|
|
|
connect2.PublishEvent(new CFXEnvelope(unitsDepartedEvent.Handle(traycode, prodcode)));
|
|
|
|
|
|
|
|
|
|
//预热炉工段开启
|
|
|
|
|
connect3.PublishEvent(new CFXEnvelope(workStageStartedEvent.Handle(tid, "PreHeatOven", 1)));
|
|
|
|
|
_log.Info($"预热炉工段开始 ID:{tid}");
|
|
|
|
|
//真空箱工段开启
|
|
|
|
|
connectVacuum.PublishEvent(new CFXEnvelope(workStageStartedEvent.Handle(tid, "Vacuum", 1)));
|
|
|
|
|
_log.Info($"真空箱工段开始 ID:{tid}");
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
_log.Error($"PLC读取失败,原因1:{trayBytesResult.Message} 2:{pordBytesResult1.Message} 3:{pordBytesResult2.Message}");
|
|
|
|
|
_log.Error($"PLC读取失败,原因1:{trayBytesResult.Message} ");
|
|
|
|
|
}
|
|
|
|
|
//流程完成
|
|
|
|
|
}
|
|
|
|
|
else if (signalValue == 1003)
|
|
|
|
|
{
|
|
|
|
|
//TODO :读取参数
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//写入完成信号
|
|
|
|
|
bool res = _plc.PlcWrite(_plc.PLC22, "D800", 1004, DataTypeEnum.UInt16).IsSuccess;
|
|
|
|
|
if (!res)
|
|
|
|
|
{
|
|
|
|
|
_log.Error("RFID01 读胶机参数 PLC写入完成信号异常");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
|