You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

357 lines
15 KiB
C#

using Admin.Core.Common.Config;
using Admin.Core.Common;
using Admin.Core.IService;
using Admin.Core.Model;
using log4net;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.Extensions.DependencyInjection;
using StackExchange.Profiling.Internal;
using Aucma.Core.HwPLc;
using Org.BouncyCastle.Asn1.Tsp;
using NetTaste;
using System.Windows.Media.Media3D;
using System.Windows.Forms;
using Admin.Core.Model.Model_New;
using static ICSharpCode.SharpZipLib.Zip.ExtendedUnixData;
namespace Aucma.Core.BoxFoam.Business
{
public class InStoreBusiness
{
#region 单例实现
private static readonly InStoreBusiness lazy = new InStoreBusiness();
public static InStoreBusiness Instance
{
get
{
return lazy;
}
}
#endregion
/// <summary>
/// 已下传的任务信息
/// </summary>
private List<RealTaskInfo> TaskInfos = new List<RealTaskInfo>();
private Dictionary<string, int> KeyValuePairs = new Dictionary<string, int>();
#region 事件
/// <summary>
/// 扫码信息刷新
/// </summary>
/// <param name="materialBarCode">条码</param>
/// <param name="materialCode">编码</param>
/// <param name="materialName">名称</param>
/// <param name="spaceName">货到名称</param>
public delegate Task RefreshDataGridDelegate();
public static event RefreshDataGridDelegate RefreshDataGridDelegateEvent;
/// <summary>
/// 扫码信息刷新
/// </summary>
/// <param name="materialBarCode">条码</param>
/// <param name="materialCode">编码</param>
/// <param name="materialName">名称</param>
/// <param name="spaceName">货到名称</param>
public delegate void RefreshScanMateriaCode(string materialBarCode, string materialCode, string materialName, string spaceName, string msg);
public static event RefreshScanMateriaCode RefreshScanMateriaCodeEvent;
/// <summary>
/// 初始化入库任务
/// </summary>
/// <param name="message"></param>
public delegate void RefreshInStoreTask(RealTaskInfo taskInfos);
public static event RefreshInStoreTask RefreshInStoreTaskEvent;
/// <summary>
/// 日志信息刷新
/// </summary>
/// <param name="message"></param>
public delegate void RefreshLogMessage(string message);
public static event RefreshLogMessage RefreshLogMessageEvent;
/// <summary>
/// 入库日志事件
/// </summary>
/// <param name="msg"></param>
public delegate void LogDelegate(string msg);
public static event LogDelegate LogDelegateEvent;
/// <summary>
/// 库存信息
/// </summary>
/// <param name="msg"></param>
public delegate void RefreshPageDelegate();
public static event RefreshPageDelegate RefreshPageDelegateEvent;
#endregion
private string storeCode = string.Empty;
private static readonly log4net.ILog logHelper = LogManager.GetLogger(typeof(InStoreBusiness));
#region 初始化
private readonly IBaseSpaceInfoServices? _baseSpaceInfoServices = App.ServiceProvider.GetService<IBaseSpaceInfoServices>();
private readonly IRealTaskInfoServices? _realTaskInfoService = App.ServiceProvider.GetService<IRealTaskInfoServices>();
private readonly IProductPlanInfoServices? _productPlanInfoServices = App.ServiceProvider.GetService<IProductPlanInfoServices>();
private readonly IRecordInStoreServices? _recordInstoreServices = App.ServiceProvider.GetService<IRecordInStoreServices>();
private readonly IBaseStoreInfoServices? _baseStoreInfoServices = App.ServiceProvider.GetService<IBaseStoreInfoServices>();
private readonly IBaseSpaceDetailServices? _baseSpaceDetailServices = App.ServiceProvider.GetService<IBaseSpaceDetailServices>();
// 过点数据表物料完成记录MaterialCompletion
private readonly IMaterialCompletionServices? _iMaterialCompletionServices = App.ServiceProvider.GetService<IMaterialCompletionServices>();
private readonly IPrintBarCodeServices? _printBarCodeServices = App.ServiceProvider.GetService<IPrintBarCodeServices>();
private readonly IBaseMaterialInfoServices? _baseMaterialInfoServices = App.ServiceProvider.GetService<IBaseMaterialInfoServices>();
#endregion
#region 初始化对象
private PlcSpaceConfig spaceConfig = PlcSpaceConfig.Instance;
private SemaphoreSlim semaphore = new SemaphoreSlim(0);
private List<BaseSpaceInfo> allSpaces = null;
private List<SpaceAddress> spaceAddresses = new List<SpaceAddress>();
private SemaphoreSlim _lock = new SemaphoreSlim(1);
#endregion
#region 构造函数
public InStoreBusiness()
{
MvCodeHelper.PQKReceiveCodeEvent += NewTask;
storeCode = Appsettings.app("StoreInfo", "BeforeStoreCode");//泡前库code
#region 更新库数据
Task.Run(async () =>
{
await RealTimeUpdateStore();
});
#endregion
}
#endregion
#region 根据条码入库
/// <summary>
/// 根据条码入库——泡前库始终只有一条任务在
/// </summary>
/// <param name="materialBarCode"></param>
/// <returns></returns>
public async Task NewTask(string materialBarCode)
{
if (string.IsNullOrEmpty(materialBarCode))
{
LogDelegateEvent?.Invoke("未扫到二维码信息!");
Console.WriteLine($"【{DateTime.Now}】未扫到二维码信息,请重新扫码!");
return;
}
bool flag = true;
//创建入库任务
Console.WriteLine($"【{DateTime.Now}】扫码成功,物料条码:{materialBarCode}");
logHelper.Info($"扫码成功,物料条码:{materialBarCode}");
LogDelegateEvent?.Invoke($"扫码成功,物料条码:{materialBarCode}");
#region 执行任务
string materialCode = SubString(materialBarCode);
var obj = PlcHelper.siemensList.FirstOrDefault(d => d.EquipName.Equals("PqPlc"));
if (obj != null)
{
if (obj.plc.IsConnected)
{
if (flag)
{
flag = false;
try
{
LogDelegateEvent?.Invoke($"获取物料编码:{materialCode}");
Console.WriteLine($"获取物料编码:{materialCode}");
bool r= obj.plc.WriteString("DB200.132", materialCode);//写入物料号
Console.WriteLine($"写入物料编码:{r}");
if (r)
{
//更新货道入库
await EnterStore(materialBarCode);
//更新过点数
await UpdateComplete(materialBarCode);
Console.WriteLine($"更新物料信息成功!");
}
else
{
Console.WriteLine($"向PLC写入物料编码失败");
}
}
catch (Exception ex)
{
logHelper.Error($"入库业务异常:{ex}");
LogDelegateEvent?.Invoke($"入库业务异常:{ex}");
Console.WriteLine($"入库业务异常:{ex.Message}");
}
finally
{
flag = true;
}
}
}
}
else
{
Console.WriteLine("PLC连接中...");
Thread.Sleep(3000);
}
#endregion
await Task.CompletedTask;
}
#endregion
#region 更新库数
public async Task RealTimeUpdateStore()
{
bool flag = true;
while (true)
{
try
{
if (flag)
{
flag = false;
var obj = PlcHelper.siemensList.FirstOrDefault(d => d.EquipName.Equals("PqPlc"));
if (obj != null)
{
if (obj.plc.IsConnected)
{
var storeList = await _baseSpaceInfoServices.QueryAsync(d => d.StoreCode == storeCode);
foreach (var item in storeList)
{
switch (item.SpaceCode)
{
case "PB01_001":
item.SpaceStock= obj.plc.ReadInt16("DB200.440");
item.OnRouteAmount = item.SpaceStock-obj.plc.ReadInt16("DB200.88");
break;
case "PB01_002":
item.SpaceStock = obj.plc.ReadInt16("DB200.442");
item.OnRouteAmount = item.SpaceStock - obj.plc.ReadInt16("DB200.90");
break;
case "PB01_003":
item.SpaceStock = obj.plc.ReadInt16("DB200.444");
item.OnRouteAmount = item.SpaceStock - obj.plc.ReadInt16("DB200.92");
break;
case "PB01_004":
item.SpaceStock = obj.plc.ReadInt16("DB200.446");
item.OnRouteAmount = item.SpaceStock - obj.plc.ReadInt16("DB200.94");
break;
case "PB01_005":
item.SpaceStock = obj.plc.ReadInt16("DB200.448");
item.OnRouteAmount = item.SpaceStock - obj.plc.ReadInt16("DB200.96");
break;
case "PB01_006":
item.SpaceStock = obj.plc.ReadInt16("DB200.450");
item.OnRouteAmount = item.SpaceStock - obj.plc.ReadInt16("DB200.98");
break;
default:
break;
}
item.UpdatedTime = DateTime.Now;
bool r= await _baseSpaceInfoServices.UpdateAsync(item);
if (r)
{
Console.WriteLine("更新库存信息成功!");
}
}
//刷新库存信息
RefreshPageDelegateEvent?.Invoke();
}
}
}
Thread.Sleep(1000);
}
catch (Exception ex)
{
Console.WriteLine($"异常:{ex.Message}");
}
finally { flag = true; }
}
}
#endregion
#region 更新过点数
/// <summary>
/// 更新过点数
/// </summary>
/// <param name="materialBarCode"></param>
/// <returns></returns>
public async Task UpdateComplete(string materialBarCode)
{
#region 更新过点数据
PrintBarCode print = await _printBarCodeServices.FirstAsync(x => x.MaterialBarcode == materialBarCode);
MaterialCompletion completion = new MaterialCompletion();
completion.OrderCode = print.OrderCode;
completion.MaterialBarcode = materialBarCode;
completion.MaterialCode = print.MaterialCode;
completion.MaterialName = print.MaterialName;
completion.StationName = "1004";
completion.ProductLineCode = "CX_02";
completion.isDownLine = 0;
completion.CompleteDate = DateTime.Now;
int i = await _iMaterialCompletionServices.AddAsync(completion);
Console.WriteLine($"过点数更新结果为{i > 0}");
#endregion
}
#endregion
#region 任务执行入库
public async Task EnterStore(string barCode)
{
//根据条码获取物料详情
var material = _printBarCodeServices.FirstAsync(d => d.MaterialBarcode == barCode).Result;
RecordInStore recordInstore = new RecordInStore();
recordInstore.StoreCode = storeCode;
recordInstore.StoreArea = "";
recordInstore.SpaceCode = "";
string materialType = SubString(barCode);//截取中间物料条码
recordInstore.MaterialType = materialType;
recordInstore.MaterialCode = barCode;
recordInstore.InStoreTime = DateTime.Now;
recordInstore.BarCodeCode = barCode;
recordInstore.MaterialName = material.MaterialName;
recordInstore.InStoreAmount =1;
recordInstore.EntryPattern = 0;
recordInstore.IsFlag = 0;
recordInstore.CreatedTime = DateTime.Now;
int result = await _recordInstoreServices.AddAsync(recordInstore);
if (result > 0)
{
string message = $"物料[{material.MaterialName}],入库成功!";
RefreshScanMateriaCodeEvent?.Invoke(material.MaterialCode, barCode, material.MaterialName, "", message); //刷新界面扫码信息
LogDelegateEvent?.Invoke($"物料[{material.MaterialName}], 入库成功!");
RefreshDataGridDelegateEvent?.Invoke();
}
else
{
LogDelegateEvent?.Invoke($"物料[{material.MaterialName}], 入库失败,任务回滚!");
logHelper.Error($"物料[{material.MaterialName}], 入库失败,任务回滚!");
}
}
#endregion
#region 截取物料编码
public string SubString(string barCode)
{
string result = string.Empty;
if (!string.IsNullOrEmpty(barCode))
{
result = barCode.Substring(7, 10);
}
return result;
}
#endregion
}
}