636 lines
31 KiB
C#
Raw Normal View History

2024-10-30 17:49:05 +08:00
using JiShe.CollectBus.Common.Enums;
2024-10-29 16:28:14 +08:00
using JiShe.CollectBus.Common.Extensions;
using JiShe.CollectBus.Common.Models;
2024-09-30 17:10:43 +08:00
using JiShe.CollectBus.Protocol.Contracts.Interfaces;
2024-10-08 14:41:41 +08:00
using JiShe.CollectBus.Protocol.Contracts.Models;
2024-10-29 16:28:14 +08:00
using Microsoft.Extensions.Logging;
2024-09-30 17:10:43 +08:00
namespace JiShe.CollectBus.Protocol.Contracts.Abstracts
{
2024-10-30 17:49:05 +08:00
public abstract class BaseProtocolPlugin(ILogger<BaseProtocolPlugin> logger) : IProtocolPlugin
2024-09-30 17:10:43 +08:00
{
2024-11-08 14:53:36 +08:00
2024-10-29 16:28:14 +08:00
//头部字节长度
2024-11-08 14:53:36 +08:00
public const int hearderLen = 6;
2024-10-29 16:28:14 +08:00
public const int tPLen = 6;
2024-11-08 09:35:52 +08:00
public const string errorData = "EE";
2024-10-29 16:28:14 +08:00
2024-10-25 19:11:43 +08:00
public abstract Task<ProtocolInfo> GetAsync();
2024-09-30 17:10:43 +08:00
2024-10-29 16:28:14 +08:00
public abstract Task AnalyzeAsync(MessageReceivedEvent messageReceivedEvent, Action<byte[]>? sendAction = null);
/// <summary>
/// 登录帧解析
/// </summary>
/// <param name="messageReceivedEvent">报文</param>
/// <param name="sendAction">发送委托</param>
/// <returns></returns>
2024-10-30 17:49:05 +08:00
public virtual async Task LoginAsync(MessageReceivedLoginEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-10-29 16:28:14 +08:00
{
var hexStringList = messageReceivedEvent.MessageHexString.StringToPairs();
var aTuple = (Tuple<string, int>)hexStringList.GetAnalyzeValue(CommandChunkEnum.A);
var seq = (Seq)hexStringList.GetAnalyzeValue(CommandChunkEnum.SEQ);
var reqParam = new ReqParameter2
{
AFN = AFN.,
FunCode = (int)CFromStationFunCode.,
PRM = PRM.,
A = aTuple.Item1,
Seq = new Seq()
{
TpV = TpV.,
FIRFIN = FIRFIN.,
CON = CON.,
PRSEQ = seq.PRSEQ
},
MSA = aTuple.Item2,
Pn = 0,
Fn = 1
};
2024-11-08 14:53:36 +08:00
var bytes = HexStringExtensions.BuildSendCommandBytes(reqParam);
2024-10-29 16:28:14 +08:00
if (sendAction != null)
{
sendAction(bytes);
}
}
/// <summary>
/// 心跳帧解析
/// </summary>
/// <param name="messageReceivedEvent">报文</param>
/// <param name="sendAction">发送委托</param>
/// <returns></returns>
2024-10-30 17:49:05 +08:00
public virtual async Task HeartbeatAsync(MessageReceivedHeartbeatEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-10-29 16:28:14 +08:00
{
var hexStringList = messageReceivedEvent.MessageHexString.StringToPairs();
var aTuple = (Tuple<string,int>)hexStringList.GetAnalyzeValue(CommandChunkEnum.A);
var seq = (Seq)hexStringList.GetAnalyzeValue(CommandChunkEnum.SEQ);
if (seq.TpV == TpV.)
{
//解析
}
if (seq.CON == CON.)
{
var reqParam = new ReqParameter2()
{
AFN = AFN.,
FunCode = (int)CFromStationFunCode.,
PRM = PRM.,
A = aTuple.Item1,
Seq = new Seq()
{
TpV = TpV.,
FIRFIN = FIRFIN.,
CON = CON.,
PRSEQ = seq.PRSEQ,
},
MSA = aTuple.Item2,
Pn = 0,
Fn = 1
};
2024-11-08 14:53:36 +08:00
var bytes = HexStringExtensions.BuildSendCommandBytes(reqParam);
2024-10-29 16:28:14 +08:00
if (sendAction != null)
{
sendAction(bytes);
}
}
}
2024-11-06 16:48:44 +08:00
/// <summary>
2024-11-08 12:04:28 +08:00
/// 解析确认或否认数据
2024-11-06 16:48:44 +08:00
/// </summary>
/// <param name=""></param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public virtual async Task AnalyzeAnswerDataAsync(MessageReceivedHeartbeatEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-11-06 16:48:44 +08:00
{
var hexStringList = messageReceivedEvent.MessageHexString.StringToPairs();
var fn = hexStringList.GetAnalyzeValue(CommandChunkEnum.FN);
//1:全部确认
//2:全部否认
//3:按数据单元表示确认和否认
//4 硬件安全认证错误应答
}
/// <summary>
2024-11-08 12:04:28 +08:00
/// 解析电表档案读取数据
2024-11-06 16:48:44 +08:00
/// </summary>
/// <param name="messageReceivedEvent"></param>
/// <param name="sendAction"></param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public virtual async Task AnalyzeAmmeterParameterReadingDataAsync(MessageReceivedHeartbeatEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-11-06 16:48:44 +08:00
{
2024-11-07 19:39:05 +08:00
var hexDatas = GetHexDatas(messageReceivedEvent.MessageHexString);
2024-10-29 16:28:14 +08:00
2024-11-06 16:48:44 +08:00
var meterList = new List<AmmeterParameter>();
var count = (hexDatas[1] + hexDatas[0]).HexToDec();
//if (2 + count * 27 != hexDatas.Count - pWLen - tPLen - 2)
// return;
var index = 2;//数量
for (int i = 1; i <= count; i++)
{
var meterNumber = $"{hexDatas[index + 1]}{hexDatas[index]}".HexToDec();
index += 2;
var pn = $"{hexDatas[index + 1]}{hexDatas[index]}".HexToDec();
index += 2;
var baudRateAndPortBin = hexDatas[index].HexToBin().PadLeft(8, '0');
var baudRate = baudRateAndPortBin.Substring(0, 3).BinToDec();
var port = baudRateAndPortBin.Substring(3, 5).BinToDec();
index += 1;
var protocolType = (CommunicationProtocolType)hexDatas[index].HexToDec();
index += 1;
var addressHexList = hexDatas.Skip(index).Take(6).ToList();
addressHexList.Reverse();
var address = string.Join("", addressHexList);
index += 6;
var pwdHexList = hexDatas.Skip(index).Take(6).ToList();
pwdHexList.Reverse();
var password = string.Join("", pwdHexList.Take(3).ToList());
index += 6;
var rateNumberBin = hexDatas[index].HexToBin().PadLeft(8, '0');
var rateNumber = rateNumberBin.Substring(4).BinToDec();
index += 1;
var intBitAndDecBitNumberBin = hexDatas[index].HexToBin().PadLeft(8, '0');
var intBitNumber = intBitAndDecBitNumberBin.Substring(4, 2).BinToDec() + 4;
var decBitNumber = intBitAndDecBitNumberBin.Substring(6, 2).BinToDec() + 1;
index += 1;
// hexDatas.GetRange()
var collectorAddressHexList = hexDatas.Skip(index).Take(6).ToList();
collectorAddressHexList.Reverse();
var collectorAddress = string.Join("", collectorAddressHexList);
index += 6;
var userClassNumberBin = hexDatas[index].HexToBin().PadLeft(8, '0');
var userClass = userClassNumberBin.Substring(0, 4).BinToDec();
var userSubClass = userClassNumberBin.Substring(4, 4).BinToDec();
index += 1;
meterList.Add(new AmmeterParameter()
{
Pn = pn,
BaudRate = baudRate,
Port = port,
ProtocolType = protocolType,
Address = address,
Password = password,
RateNumber = rateNumber,
IntegerBitNumber = intBitNumber,
DecimalBitNumber = decBitNumber,
CollectorAddress = collectorAddress,
UserCategoryNumber = userClass,
UserSubclassNumber = userSubClass,
});
}
}
/// <summary>
2024-11-08 12:04:28 +08:00
/// 解析当前正向有功电能示值抄读数据
2024-11-06 16:48:44 +08:00
/// </summary>
/// <param name="messageReceivedEvent">报文</param>
/// <param name="sendAction">发送委托</param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public virtual async Task AnalyzeActivePowerIndicationReadingDataAsync(MessageReceivedHeartbeatEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-11-06 16:48:44 +08:00
{
2024-11-07 19:39:05 +08:00
var hexDatas = GetHexDatas(messageReceivedEvent.MessageHexString);
2024-11-06 16:48:44 +08:00
var minutes = Convert.ToInt32(hexDatas[0]); // 获取当前分钟数
var hours = Convert.ToInt32(hexDatas[1]); // 获取当前小时数
var day = Convert.ToInt32(hexDatas[2]); // 获取当前日期的日数
var month = Convert.ToInt32(hexDatas[3]); // 获取当前月份
var year = Convert.ToInt32(hexDatas[4]); // 获取当前日期的年份
var rateNumber = Convert.ToInt32(hexDatas[5]);
var kwhTotal = hexDatas.Skip(5).Take(5).ToList();
var kwhList = new List<decimal>();
var index = 11;
for (int i = 0; i < rateNumber; i++)
{
var kwhHexList = hexDatas.Skip(11).Take(5).ToList();
kwhHexList.Reverse();
var integerStr = $"{kwhHexList.Take(0)}{kwhHexList.Take(1)}{kwhHexList.Take(2)}";
var decimalValStr = $"{kwhHexList[3]}{kwhHexList[4]}";
var val = decimal.Parse($"{integerStr}{decimalValStr}");
kwhList.Add(val);
index += 5;
}
}
2024-11-08 12:04:28 +08:00
2024-11-06 16:48:44 +08:00
/// <summary>
2024-11-08 12:04:28 +08:00
/// 解析日冻结正向有功电能示值抄读数据
2024-11-06 16:48:44 +08:00
/// </summary>
/// <param name="messageReceivedEvent"></param>
/// <param name="sendAction"></param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public virtual async Task AnalyzeDailyFrozenReadingDataAsync(MessageReceivedHeartbeatEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-11-06 16:48:44 +08:00
{
2024-11-07 19:39:05 +08:00
var hexDatas = GetHexDatas(messageReceivedEvent.MessageHexString);
//附录A.20 日月年
var td_dHex= hexDatas.Take(3).ToList();
//附录A.15 分时日月年
var readingTimeHex = hexDatas.Skip(3).Take(5).ToList();
var rateNumberHex = hexDatas.Skip(8).Take(1).FirstOrDefault().HexToDec();
2024-11-08 12:04:28 +08:00
var datas = new List<decimal>();
2024-11-07 19:39:05 +08:00
//附录A.14 kWh 5字节
for (int i = 0; i < rateNumberHex; i++)
{
2024-11-08 12:04:28 +08:00
var skipCount = 9 + i * 5;
var dataHexs = hexDatas.Skip(skipCount).Take(5).ToList();
var data = AnalyzeDataAccordingToA14(dataHexs[0], dataHexs[1], dataHexs[2], dataHexs[3], dataHexs[4]);
datas.Add(data);
2024-11-07 19:39:05 +08:00
}
}
//接收<2024/11/7 17:34:42>: 68 3E 01 3E 01 68
//控制域 88
//地址域 20 32 90 26 1A
//AFN 0C
//Seq 62
//pn 01 01
//fn 01 03
//F0 16
//报文解析:计量点1数据
//++++++++ F25:当前三相及总有/无功功率功率因数 三相电压电流 零序电流 ++++++++
//终端抄表时间:2024年11月07日17时34分 34 17 07 11 24
//当前总有功功率:-0.0028 kW 28 00 80
//当前A相有功功率:0 kW 00 00 80
//当前B相有功功率:0 kW 00 00 80
//当前C相有功功率:-0.0027 kW 27 00 80
//当前总无功功率:-0.0047 kW 47 00 80
//当前A相无功功率:0 kW 00 00 00
//当前B相无功功率:0 kW 00 00 00
//当前C相无功功率:-0.0047 kW 47 00 80
//当前总功率因数:-51.8 % 18 85
//当前A相功率因数:0 % 00 80
//当前B相功率因数:0 % 00 80
//当前C相功率因数:-50 % 00 85
//当前A相电压:0.1 V 01 00
//当前B相电压:0.2 V 02 00
//当前C相电压:239 V 90 23
//当前A相电流:0 A 00 00 80
//当前B相电流:0 A 00 00 80
//当前C相电流:-0.024 A 24 00 80
//当前零序电流:Error: 数据不符合BCD码格式 A EE EE EE
//当前总视在功率:Error: 数据不符合BCD码格式 kVA EE EE EE
//当前A相视在功率:Error: 数据不符合BCD码格式 kVA EE EE EE
//当前B相视在功率:Error: 数据不符合BCD码格式 kVA EE EE EE
//当前C相视在功率:Error: 数据不符合BCD码格式 kVA EE EE EE
//++++++++++++++++++++++++++++++++++++
/// <summary>
/// 当前三相及总有/无功功率、功率因数、三相电压、电流、零序电流、视在功率
/// </summary>
/// <param name="messageReceivedEvent"></param>
/// <param name="sendAction"></param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public virtual async Task AnalyzeF25ReadingDataAsync(MessageReceivedHeartbeatEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-11-07 19:39:05 +08:00
{
var hexDatas = GetHexDatas(messageReceivedEvent.MessageHexString);
//A.15 分时日月年
var readingTimeHex = hexDatas.Take(5).ToList();
2024-11-08 12:04:28 +08:00
var readingTime = AnalyzeDataAccordingToA15(readingTimeHex[0], readingTimeHex[1], readingTimeHex[2], readingTimeHex[3], readingTimeHex[4]);
2024-11-08 10:30:54 +08:00
2024-11-07 19:39:05 +08:00
//A.9 kW
2024-11-08 10:30:54 +08:00
var crntTotalActivePowerHexs = hexDatas.Skip((int)F25DataItemEnum.CrntTotalActivePower).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntTotalActivePower = AnalyzeDataAccordingToA09(crntTotalActivePowerHexs[0], crntTotalActivePowerHexs[1], crntTotalActivePowerHexs[2]);
2024-11-08 10:30:54 +08:00
var crntActivePowerOfAHexs = hexDatas.Skip((int)F25DataItemEnum.CrntActivePowerOfA).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntActivePowerOfA = AnalyzeDataAccordingToA09(crntActivePowerOfAHexs[0], crntActivePowerOfAHexs[1], crntActivePowerOfAHexs[2]);
2024-11-08 10:30:54 +08:00
var crntActivePowerOfBHexs = hexDatas.Skip((int)F25DataItemEnum.CrntActivePowerOfB).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntActivePowerOfB = AnalyzeDataAccordingToA09(crntActivePowerOfBHexs[0], crntActivePowerOfBHexs[1], crntActivePowerOfBHexs[2]);
2024-11-08 10:30:54 +08:00
var crntActivePowerOfCHexs = hexDatas.Skip((int)F25DataItemEnum.CrntActivePowerOfC).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntActivePowerOfC = AnalyzeDataAccordingToA09(crntActivePowerOfCHexs[0], crntActivePowerOfCHexs[1], crntActivePowerOfCHexs[2]);
2024-11-08 10:30:54 +08:00
var crntTotalReactivePowerHexs = hexDatas.Skip((int)F25DataItemEnum.CrntTotalReactivePower).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntTotalReactivePower = AnalyzeDataAccordingToA09(crntTotalReactivePowerHexs[0], crntTotalReactivePowerHexs[1], crntTotalReactivePowerHexs[2]);
2024-11-08 10:30:54 +08:00
var crntReactivePowerOfAHexs = hexDatas.Skip((int)F25DataItemEnum.CrntReactivePowerOfA).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntReactivePowerOfA = AnalyzeDataAccordingToA09(crntReactivePowerOfAHexs[0], crntReactivePowerOfAHexs[1], crntReactivePowerOfAHexs[2]);
2024-11-08 10:30:54 +08:00
var crntReactivePowerOfBHexs = hexDatas.Skip((int)F25DataItemEnum.CrntReactivePowerOfB).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntReactivePowerOfB = AnalyzeDataAccordingToA09(crntReactivePowerOfBHexs[0], crntReactivePowerOfBHexs[1], crntReactivePowerOfBHexs[2]);
2024-11-08 10:30:54 +08:00
var crntReactivePowerOfCHexs = hexDatas.Skip((int)F25DataItemEnum.CrntReactivePowerOfC).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntReactivePowerOfC = AnalyzeDataAccordingToA09(crntReactivePowerOfCHexs[0], crntReactivePowerOfCHexs[1], crntReactivePowerOfCHexs[2]);
2024-11-07 19:39:05 +08:00
//A.5 %
2024-11-08 10:30:54 +08:00
var crntTotalPowerFactorHexs = hexDatas.Skip((int)F25DataItemEnum.CrntTotalPowerFactor).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntTotalPowerFactor = AnalyzeDataAccordingToA05(crntTotalPowerFactorHexs[0], crntTotalPowerFactorHexs[1]);
2024-11-08 10:30:54 +08:00
var crntPowerFactorOfAHexs = hexDatas.Skip((int)F25DataItemEnum.CrntPowerFactorOfA).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntPowerFactorOfA = AnalyzeDataAccordingToA05(crntPowerFactorOfAHexs[0], crntPowerFactorOfAHexs[1]);
2024-11-08 10:30:54 +08:00
var crntPowerFactorOfBHexs = hexDatas.Skip((int)F25DataItemEnum.CrntPowerFactorOfB).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntPowerFactorOfB = AnalyzeDataAccordingToA05(crntPowerFactorOfBHexs[0], crntPowerFactorOfBHexs[1]);
2024-11-08 10:30:54 +08:00
var crntPowerFactorOfCHexs = hexDatas.Skip((int)F25DataItemEnum.CrntPowerFactorOfC).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntPowerFactorOfC = AnalyzeDataAccordingToA05(crntPowerFactorOfCHexs[0], crntPowerFactorOfCHexs[1]);
2024-11-07 19:39:05 +08:00
//A.7 V
2024-11-08 10:30:54 +08:00
var crntVoltageOfAHexs = hexDatas.Skip((int)F25DataItemEnum.CrntVoltageOfA).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntVoltageOfA = AnalyzeDataAccordingToA07(crntVoltageOfAHexs[0], crntVoltageOfAHexs[1]);
2024-11-08 10:30:54 +08:00
var crntVoltageOfBHexs = hexDatas.Skip((int)F25DataItemEnum.CrntVoltageOfB).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntVoltageOfB = AnalyzeDataAccordingToA07(crntVoltageOfBHexs[0], crntVoltageOfBHexs[1]);
2024-11-08 10:30:54 +08:00
var crntVoltageOfCHexs = hexDatas.Skip((int)F25DataItemEnum.CrntVoltageOfC).Take(2).ToList();
2024-11-08 12:04:28 +08:00
var crntVoltageOfC = AnalyzeDataAccordingToA07(crntVoltageOfCHexs[0], crntVoltageOfCHexs[1]);
2024-11-07 19:39:05 +08:00
//A.25 A
2024-11-08 10:30:54 +08:00
var crntCurrentOfAHexs = hexDatas.Skip((int)F25DataItemEnum.CrntCurrentOfA).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntCurrentOfA = AnalyzeDataAccordingToA25(crntCurrentOfAHexs[0], crntCurrentOfAHexs[1], crntCurrentOfAHexs[2]);
2024-11-08 10:30:54 +08:00
var crntCurrentOfBHexs = hexDatas.Skip((int)F25DataItemEnum.CrntCurrentOfB).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntCurrentOfB = AnalyzeDataAccordingToA25(crntCurrentOfBHexs[0], crntCurrentOfBHexs[1], crntCurrentOfBHexs[2]);
2024-11-08 10:30:54 +08:00
var crntCurrentOfCHexs = hexDatas.Skip((int)F25DataItemEnum.CrntCurrentOfC).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntCurrentOfC = AnalyzeDataAccordingToA25(crntCurrentOfCHexs[0], crntCurrentOfCHexs[1], crntCurrentOfCHexs[2]);
2024-11-07 19:39:05 +08:00
2024-11-08 10:30:54 +08:00
var crntZeroSequenceCurrentHexs = hexDatas.Skip((int)F25DataItemEnum.CrntZeroSequenceCurrent).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntZeroSequenceCurrent = AnalyzeDataAccordingToA25(crntZeroSequenceCurrentHexs[0], crntZeroSequenceCurrentHexs[1], crntZeroSequenceCurrentHexs[2]);
2024-11-08 10:30:54 +08:00
2024-11-07 19:39:05 +08:00
//A.9 kVA
2024-11-08 10:30:54 +08:00
var crntTotalApparentPowerHexs = hexDatas.Skip((int)F25DataItemEnum.CrntTotalApparentPower).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntTotalApparentPower = AnalyzeDataAccordingToA09(crntTotalApparentPowerHexs[0], crntTotalApparentPowerHexs[1], crntTotalApparentPowerHexs[2]);
2024-11-08 10:30:54 +08:00
var crntApparentPowerOfAHexs = hexDatas.Skip((int)F25DataItemEnum.CrntApparentPowerOfA).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntApparentPowerOfA = AnalyzeDataAccordingToA09(crntApparentPowerOfAHexs[0], crntApparentPowerOfAHexs[1], crntApparentPowerOfAHexs[2]);
2024-11-08 10:30:54 +08:00
var crntApparentPowerOfBHexs = hexDatas.Skip((int)F25DataItemEnum.CrntApparentPowerOfB).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntApparentPowerOfB = AnalyzeDataAccordingToA09(crntApparentPowerOfBHexs[0], crntApparentPowerOfBHexs[1], crntApparentPowerOfBHexs[2]);
2024-11-08 10:30:54 +08:00
var crntApparentPowerOfCHexs = hexDatas.Skip((int)F25DataItemEnum.CrntApparentPowerOfC).Take(3).ToList();
2024-11-08 12:04:28 +08:00
var crntApparentPowerOfC = AnalyzeDataAccordingToA09(crntApparentPowerOfCHexs[0], crntApparentPowerOfCHexs[1], crntApparentPowerOfCHexs[2]);
2024-11-07 19:39:05 +08:00
}
/// <summary>
2024-11-08 12:04:28 +08:00
/// 解析透明转发 应答结果
2024-11-07 19:39:05 +08:00
/// </summary>
/// <param name="messageReceivedEvent"></param>
/// <param name="sendAction"></param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public virtual async Task AnalyzeTransparentForwardingAnswerResultAsync(MessageReceivedHeartbeatEvent messageReceivedEvent, Action<byte[]>? sendAction = null)
2024-11-07 19:39:05 +08:00
{
var hexDatas = GetHexDatas(messageReceivedEvent.MessageHexString);
var port = hexDatas[0].HexToDec();
//A.12
var a = hexDatas.Skip(1).Take(6).ToList();
var result = hexDatas.Skip(7).Take(1).FirstOrDefault().HexToDec();
var transparentForwardingFlag = (TransparentForwardingFlagEnum)result;
}
2024-11-08 12:04:28 +08:00
/// <summary>
/// 获取命令数据单元-数据体
/// </summary>
/// <param name="messageHexString"></param>
/// <returns></returns>
public static List<string> GetHexDatas(string messageHexString)
2024-11-07 19:39:05 +08:00
{
var hexStringList = messageHexString.StringToPairs();
2024-11-06 16:48:44 +08:00
var hexDatas = (List<string>)hexStringList.GetAnalyzeValue(CommandChunkEnum.Data);
2024-11-07 19:39:05 +08:00
return hexDatas;
}
/// <summary>
/// 解析时间标签
/// </summary>
/// <param name="hexDatas"></param>
2024-11-08 12:04:28 +08:00
public void AnalysisTp(List<string> hexDatas)
2024-11-07 19:39:05 +08:00
{
var pFC = hexDatas[0].HexToDec();//启动帧帧序号计数器
var seconds = Convert.ToInt32(hexDatas[1]); // 获取当前秒数
var minutes = Convert.ToInt32(hexDatas[2]); // 获取当前分钟数
var hours = Convert.ToInt32(hexDatas[3]); // 获取当前小时数
var day = Convert.ToInt32(hexDatas[4]); // 获取当前日期的日数
var delayTime = hexDatas[5].HexToDec();//延迟时间 min
}
2024-11-08 12:04:28 +08:00
#region
2024-11-07 19:39:05 +08:00
/// <summary>
2024-11-08 12:04:28 +08:00
/// 根据A05解析数据
2024-11-07 19:39:05 +08:00
/// </summary>
2024-11-07 21:18:54 +08:00
/// <param name="singleDigitNumberAndDeciles">个位和十分位</param>
/// <param name="hundredDigitNumbersAndTenDigitNumber">百位和十位</param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public decimal AnalyzeDataAccordingToA05(string singleDigitNumberAndDeciles, string hundredDigitNumbersAndTenDigitNumber)
2024-11-07 19:39:05 +08:00
{
2024-11-08 12:04:28 +08:00
if (singleDigitNumberAndDeciles.IsErrorData() && hundredDigitNumbersAndTenDigitNumber.IsErrorData())
2024-11-08 09:35:52 +08:00
{
return 0;
}
2024-11-07 21:18:54 +08:00
var bin1 = hundredDigitNumbersAndTenDigitNumber.HexToBin().PadLeft(8, '0');
2024-11-07 19:39:05 +08:00
var hundredDigitNumbers = bin1.Substring(1, 3).BinToDec();//百位
var tenDigitNumber = bin1.Substring(4).BinToDec();//十位
2024-11-08 12:04:28 +08:00
var bin2 = singleDigitNumberAndDeciles.HexToBin().PadLeft(8, '0');
2024-11-07 19:39:05 +08:00
var singleDigitNumber = bin1.Substring(0, 4).BinToDec();//个位
var deciles = bin1.Substring(4).BinToDec();//十分位
var value = decimal.Parse($"{hundredDigitNumbers}{tenDigitNumber}{singleDigitNumber}.{deciles}");
return value;
}
2024-11-06 16:48:44 +08:00
2024-11-07 19:39:05 +08:00
/// <summary>
/// 数据格式07
/// </summary>
2024-11-07 21:18:54 +08:00
/// <param name="singleDigitNumberAndDeciles">个位、十分位</param>
/// <param name="hundredDigitNumbersAndTenDigitNumber">百位、十位</param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public decimal AnalyzeDataAccordingToA07(string singleDigitNumberAndDeciles, string hundredDigitNumbersAndTenDigitNumber)
2024-11-07 19:39:05 +08:00
{
2024-11-08 12:04:28 +08:00
if (singleDigitNumberAndDeciles.IsErrorData() && hundredDigitNumbersAndTenDigitNumber.IsErrorData())
2024-11-08 09:35:52 +08:00
{
return 0;
}
2024-11-07 21:18:54 +08:00
var bin1 = hundredDigitNumbersAndTenDigitNumber.HexToBin().PadLeft(8, '0');
var hundredDigitNumbers = bin1.Substring(1, 3).BinToDec();//百位
var tenDigitNumber = bin1.Substring(4).BinToDec();//十位
2024-11-06 16:48:44 +08:00
2024-11-07 21:18:54 +08:00
var bin2 = singleDigitNumberAndDeciles.HexToBin().PadLeft(8, '0');
var singleDigitNumber = bin2.Substring(0, 4).BinToDec();//个位
var deciles = bin2.Substring(4).BinToDec();//十分位
2024-11-07 19:39:05 +08:00
2024-11-07 21:18:54 +08:00
var value = decimal.Parse($"{hundredDigitNumbers}{tenDigitNumber}{singleDigitNumber}.{deciles}");
2024-11-07 19:39:05 +08:00
return value;
2024-11-06 16:48:44 +08:00
}
2024-11-07 19:39:05 +08:00
/// <summary>
2024-11-07 21:18:54 +08:00
/// 数据格式09
2024-11-07 19:39:05 +08:00
/// </summary>
2024-11-07 21:18:54 +08:00
/// <param name="thousandthPercentileAndTenThousandPositions">千分位和万分位</param>
/// <param name="decilesAndPercentile">十分位和百分位</param>
/// <param name="tenAndSingleDigit">十位和个位</param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public decimal AnalyzeDataAccordingToA09(string thousandthPercentileAndTenThousandPositions, string decilesAndPercentile, string tenAndSingleDigit)
2024-11-07 19:39:05 +08:00
{
2024-11-08 12:04:28 +08:00
if (thousandthPercentileAndTenThousandPositions.IsErrorData() && decilesAndPercentile.IsErrorData() && tenAndSingleDigit.IsErrorData())
2024-11-08 09:35:52 +08:00
{
return 0;
}
2024-11-07 19:39:05 +08:00
var bin3 = tenAndSingleDigit.HexToBin().PadLeft(8, '0');
var tenDigitNumber = bin3.Substring(1, 3).BinToDec();//十位
var singleDigitNumber = bin3.Substring(4).BinToDec();//个位
2024-11-07 21:18:54 +08:00
var value = decimal.Parse($"{tenDigitNumber}{singleDigitNumber}.{decilesAndPercentile}{thousandthPercentileAndTenThousandPositions}");
2024-11-07 19:39:05 +08:00
return value;
//var bin3 = hex3.HexToBin().PadLeft(8, '0');
//var thousandthPercentile = bin3.Substring(0, 4).BinToDec();//千分位
//var tenThousandPositions = bin3.Substring(4).BinToDec();//万分位
//var bin2 = hex2.HexToBin().PadLeft(8, '0');
//var deciles = bin2.Substring(0, 4).BinToDec();//十分位
//var percentile = bin2.Substring(4).BinToDec();//百分位
2024-11-08 12:04:28 +08:00
2024-11-07 19:39:05 +08:00
}
/// <summary>
2024-11-08 12:04:28 +08:00
/// 数据格式12
2024-11-07 19:39:05 +08:00
/// </summary>
2024-11-08 09:35:52 +08:00
/// <param name="tenDigitAndSingleDigitNumber">十位 个位</param>
/// <param name="thousandAndHundredsOfPosition">千位 百位</param>
/// <param name="hundredThousandAndTenThousandOfPosition">十万位 万位</param>
/// <param name="millionsAndMillionOfPosition">千万位 百万位</param>
/// <param name="hundredMillionAndBillionOfPosition">十亿位 亿位</param>
/// <param name="hundredBillionsAndBillionsOfPosition">千亿位 百亿位</param>
2024-11-07 19:39:05 +08:00
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public string AnalyzeDataAccordingToA12(string tenDigitAndSingleDigitNumber, string thousandAndHundredsOfPosition, string hundredThousandAndTenThousandOfPosition,
2024-11-08 09:35:52 +08:00
string millionsAndMillionOfPosition, string hundredMillionAndBillionOfPosition, string hundredBillionsAndBillionsOfPosition)
2024-11-08 12:04:28 +08:00
{
2024-11-08 09:35:52 +08:00
var value = $"{hundredBillionsAndBillionsOfPosition}{hundredMillionAndBillionOfPosition}{millionsAndMillionOfPosition}" +
$"{hundredThousandAndTenThousandOfPosition}{thousandAndHundredsOfPosition}{tenDigitAndSingleDigitNumber}";
2024-11-07 19:39:05 +08:00
return value;
}
/// <summary>
/// 数据格式14
/// </summary>
2024-11-07 21:18:54 +08:00
/// <param name="tenThousandPositionsAndThousandthPercentile">千分,万分</param>
/// <param name="decilesAndPercentile">十分、百分</param>
/// <param name="tenDigitNumberAndSingleDigitNumber">十位、个位</param>
2024-11-08 09:35:52 +08:00
/// <param name="thousandAndHundredsOfPosition">千位、百位</param>
/// <param name="hundredThousandAndTenThousandOfPosition">十万位、万位</param>
2024-11-07 19:39:05 +08:00
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public decimal AnalyzeDataAccordingToA14(string tenThousandPositionsAndThousandthPercentile, string decilesAndPercentile,
2024-11-08 09:35:52 +08:00
string tenDigitNumberAndSingleDigitNumber, string thousandAndHundredsOfPosition, string hundredThousandAndTenThousandOfPosition)
2024-11-07 19:39:05 +08:00
{
2024-11-08 12:04:28 +08:00
if (tenThousandPositionsAndThousandthPercentile.IsErrorData() && decilesAndPercentile.IsErrorData() && tenDigitNumberAndSingleDigitNumber.IsErrorData()
&& thousandAndHundredsOfPosition.IsErrorData() && hundredThousandAndTenThousandOfPosition.IsErrorData())
2024-11-08 09:35:52 +08:00
return 0;
var value = decimal.Parse($"{hundredThousandAndTenThousandOfPosition}{thousandAndHundredsOfPosition}" +
2024-11-07 21:18:54 +08:00
$"{tenDigitNumberAndSingleDigitNumber}.{decilesAndPercentile}{tenThousandPositionsAndThousandthPercentile}");
2024-11-07 19:39:05 +08:00
return value;
}
/// <summary>
/// 数据格式A.15
/// </summary>
2024-11-07 21:18:54 +08:00
/// <param name="minuteHex"></param>
/// <param name="hourHex"></param>
/// <param name="dayHex"></param>
/// <param name="monthHex"></param>
/// <param name="yearHex"></param>
2024-11-07 19:39:05 +08:00
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public DateTime AnalyzeDataAccordingToA15(string minuteHex, string hourHex, string dayHex, string monthHex, string yearHex)
{
2024-11-07 19:39:05 +08:00
var centuryString = (DateTime.Now.Year / 100).ToString();
2024-11-07 21:18:54 +08:00
var time = DateTime.Parse($"{centuryString}{yearHex}-{monthHex}-{dayHex} {hourHex}:{minuteHex}:00");
2024-11-07 19:39:05 +08:00
return time;
//正常转换方式
//var bin1 = hex1.HexToBin().PadLeft(8, '0');
//var tenDigitNumberOfMinute = bin1.Substring(0, 4).BinToDec();//十位
//var singleDigitNumberOfMinute = bin1.Substring(4).BinToDec();//个位
//var minute = Convert.ToInt32($"{tenDigitNumberOfMinute}{singleDigitNumberOfMinute}");
//var bin2 = hex2.HexToBin().PadLeft(8, '0');
//var tenDigitNumberOfHour = bin2.Substring(0, 4).BinToDec();//十位
//var singleDigitNumberOfHour = bin2.Substring(4).BinToDec();//个位
//var bin3 = hex3.HexToBin().PadLeft(8, '0');
//var tenDigitNumberOfDay = bin3.Substring(0, 4).BinToDec();//十位
//var singleDigitNumberOfDay = bin3.Substring(4).BinToDec();//个位
//var bin4 = hex4.HexToBin().PadLeft(8, '0');
//var tenDigitNumberOfMonth = bin4.Substring(0, 4).BinToDec();//十位
//var singleDigitNumberOfMonth = bin4.Substring(4).BinToDec();//个位
//var bin5 = hex5.HexToBin().PadLeft(8, '0');
//var tenDigitNumberOfYear = bin5.Substring(0, 4).BinToDec();//十位
//var singleDigitNumberOfYear = bin5.Substring(4).BinToDec();//个位
}
2024-11-07 21:18:54 +08:00
/// <summary>
/// 数据格式20
/// </summary>
/// <param name="dayHex"></param>
/// <param name="monthHex"></param>
/// <param name="yearHex"></param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public DateTime AnalyzeDataAccordingToA20(string dayHex, string monthHex, string yearHex)
2024-11-07 19:39:05 +08:00
{
2024-11-07 21:18:54 +08:00
var centuryString = (DateTime.Now.Year / 100).ToString();
var time = DateTime.Parse($"{centuryString}{yearHex}-{monthHex}-{dayHex}");
return time;
2024-11-07 19:39:05 +08:00
}
/// <summary>
/// 数据格式25
/// </summary>
2024-11-07 21:18:54 +08:00
/// <param name="percentileAndThousandthPercentile">百分、千分位</param>
/// <param name="singleDigitNumberAndDeciles">个位、十分位</param>
/// <param name="hundredDigitNumbersAndTenDigitNumber">百位、十位</param>
/// <returns></returns>
2024-11-08 12:04:28 +08:00
public decimal AnalyzeDataAccordingToA25(string percentileAndThousandthPercentile, string singleDigitNumberAndDeciles, string hundredDigitNumbersAndTenDigitNumber)
2024-11-07 19:39:05 +08:00
{
2024-11-08 12:04:28 +08:00
if (percentileAndThousandthPercentile.IsErrorData() && singleDigitNumberAndDeciles.IsErrorData() && hundredDigitNumbersAndTenDigitNumber.IsErrorData())
2024-11-08 09:35:52 +08:00
return 0;
2024-11-07 21:18:54 +08:00
var bin1 = hundredDigitNumbersAndTenDigitNumber.HexToBin().PadLeft(8, '0');
2024-11-07 19:39:05 +08:00
var hundredDigitNumbers = bin1.Substring(1, 3).BinToDec();//百位
var tenDigitNumber = bin1.Substring(4).BinToDec();//十位
2024-11-07 21:18:54 +08:00
var bin2 = singleDigitNumberAndDeciles.HexToBin().PadLeft(8, '0');
var singleDigitNumber = bin2.Substring(0, 4).BinToDec();//个位
2024-11-07 19:39:05 +08:00
var deciles = bin1.Substring(4).BinToDec();//十分位
2024-11-07 21:18:54 +08:00
var value = decimal.Parse($"{hundredDigitNumbers}{tenDigitNumber}{singleDigitNumber}.{deciles}{percentileAndThousandthPercentile}");
2024-11-07 19:39:05 +08:00
return value;
}
2024-11-08 12:04:28 +08:00
#endregion
2024-11-22 14:12:43 +08:00
2024-10-29 16:28:14 +08:00
2024-09-30 17:10:43 +08:00
}
}