parent
131c4f536c
commit
53c2307b80
@ -0,0 +1,128 @@
|
||||
using Entity.DbModel.Station;
|
||||
using HybirdFrameworkCore.Autofac.Attribute;
|
||||
using HybirdFrameworkCore.AutoTask;
|
||||
using HybirdFrameworkCore.Entity;
|
||||
using log4net;
|
||||
using Repository.Station;
|
||||
using Service.Execute;
|
||||
using Service.Execute.Api;
|
||||
using Service.Execute.Model.Tbox;
|
||||
using Service.Plc.Client;
|
||||
using Service.Plc.Msg;
|
||||
using Service.Station;
|
||||
using System.Reflection.PortableExecutable;
|
||||
|
||||
namespace Service.MyTask;
|
||||
|
||||
/// <summary>
|
||||
/// 电池充电是风扇启停
|
||||
/// </summary>
|
||||
[Scope]
|
||||
public class PlcRealTimeTask : ITask
|
||||
{
|
||||
private static readonly ILog Log = LogManager.GetLogger(typeof(PlcRealTimeTask));
|
||||
|
||||
|
||||
public BinInfoRepository _binInfoRepository { get; set; }
|
||||
|
||||
private volatile bool _stop;
|
||||
|
||||
public static bool cameraTask=false;//相机偏移记录任务(查看通道状态开始,行车回归安全位置结束)
|
||||
public static bool VehicleParkingStatusTask= false;//车辆驻车状态下发任务
|
||||
public static bool LockStatusTask = false;//电池包锁状态下发任务
|
||||
|
||||
public static bool RollerShutterTask = false;//卷帘门是否保持开启状态
|
||||
|
||||
public string Name()
|
||||
{
|
||||
return "PlcRealTimeTask";
|
||||
}
|
||||
|
||||
public int Interval()
|
||||
{
|
||||
return 1000 * 3;
|
||||
}
|
||||
|
||||
|
||||
public void Handle()
|
||||
{
|
||||
try
|
||||
{
|
||||
if (cameraTask)
|
||||
{
|
||||
if (PlcMgr.PlcToHostData != null)
|
||||
{
|
||||
Log.Info($"PlcRealTimeTask.CameraOffsetValue DeviationX={PlcMgr.PlcToHostData.DeviationX.Value}, DeviationY={PlcMgr.PlcToHostData.DeviationY.Value}" +
|
||||
$",DeviationZ={PlcMgr.PlcToHostData.DeviationZ.Value},DeviationR={PlcMgr.PlcToHostData.DeviationR.Value},DeviationX2={PlcMgr.PlcToHostData.DeviationX2.Value}," +
|
||||
$" DeviationY2={PlcMgr.PlcToHostData.DeviationY2.Value},DeviationZ2={PlcMgr.PlcToHostData.DeviationZ2.Value},DeviationR2={PlcMgr.PlcToHostData.DeviationR2.Value}");
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
var resultHeartBeatMsg = StationSoftMgr.SwappingStateMachine.BoxCarInfoModel?.CarStatus;
|
||||
|
||||
if (VehicleParkingStatusTask)
|
||||
{
|
||||
|
||||
ushort vehicleParkingStatus = 0;
|
||||
if (resultHeartBeatMsg != null)
|
||||
{
|
||||
if (resultHeartBeatMsg?.PowerStatus == 2 && resultHeartBeatMsg.Break == 1)
|
||||
{
|
||||
vehicleParkingStatus = 2;
|
||||
}
|
||||
else
|
||||
{
|
||||
vehicleParkingStatus = 1;
|
||||
}
|
||||
}
|
||||
|
||||
PlcMgr.WriteVehicleParkingStatus(vehicleParkingStatus);
|
||||
|
||||
}
|
||||
if (LockStatusTask)
|
||||
{
|
||||
ushort lockStatus = 0;
|
||||
|
||||
if (resultHeartBeatMsg != null)
|
||||
{
|
||||
lockStatus = (ushort)(resultHeartBeatMsg?.LockStatus == 1 ? 1000 : 0);
|
||||
}
|
||||
|
||||
PlcMgr.WriteStopCommand(lockStatus);
|
||||
}
|
||||
|
||||
if (RollerShutterTask)
|
||||
{
|
||||
if (!PlcMgr.RollerShutterRadar())
|
||||
{
|
||||
PlcMgr.WriteRollerShutter(1000);
|
||||
}
|
||||
}
|
||||
//else//需要关闭吗
|
||||
//{
|
||||
// PlcMgr.WriteRollerShutter(1010);
|
||||
//}
|
||||
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Log.Error($" PlcRealTimeTask err e={e}");
|
||||
}
|
||||
}
|
||||
|
||||
public bool Stoped()
|
||||
{
|
||||
return _stop;
|
||||
}
|
||||
|
||||
public void Stop()
|
||||
{
|
||||
_stop = true;
|
||||
}
|
||||
|
||||
public void ResetStop()
|
||||
{
|
||||
_stop = false;
|
||||
}
|
||||
}
|
Loading…
Reference in new issue