This commit is contained in:
qianhao.xu
2024-11-07 21:27:56 +08:00
parent 54840baf1b
commit 7038d8a4d6
4 changed files with 61 additions and 24 deletions

View File

@@ -10,7 +10,7 @@ namespace DOAN.Service.PBL.IService
{
public interface IMESInteractionServcie
{
int TestPLC(int num);
bool MESLightUp(LightUpDto light);
bool MESLightDown(string scan_code);
}

View File

@@ -8,6 +8,7 @@ using Mapster;
using System.Runtime.InteropServices;
using SqlSugar;
using System.Security.Cryptography.X509Certificates;
using DOAN.Infrastructure.PLC;
namespace DOAN.Service.PBL
@@ -18,23 +19,32 @@ namespace DOAN.Service.PBL
[AppService(ServiceType = typeof(IMESInteractionServcie), ServiceLifetime = LifeTime.Transient)]
public class MESInteractionServcie : BaseService<Storagelocation>, IMESInteractionServcie
{
public int TestPLC(int num)
{
PCLTool.ConnectPLC();
int result = PCLTool.Write("VB100", num);
PCLTool.ConnectClose();
return result;
}
public bool MESLightUp(LightUpDto light)
{
// 1.记录MES交互记录
MES_Interation_Log item = light.Adapt<MES_Interation_Log>();
item.Id = XUEHUA;
item.CreatedTime= DateTime.Now;
item.CreatedTime = DateTime.Now;
Context.Insertable(item).ExecuteCommand();
// 2.根据总成零件号 ,版本 查询对应零件号,使得对应料架亮灯
//镜壳 料架
Storagelocation MirrorshellShelf = Context.Queryable<Storagelocation>().Where(it => it.Partnumber ==
SqlFunc.Subqueryable<Billofmaterials>().Where(It => It.Productcode == light.AssemblyPartNumber&&It.Version==light.Version).Select(it => it.MirrorshellCode)).First();
SqlFunc.Subqueryable<Billofmaterials>().Where(It => It.Productcode == light.AssemblyPartNumber && It.Version == light.Version).Select(it => it.MirrorshellCode)).First();
//镜体 料架
Storagelocation MirrorshellBody = Context.Queryable<Storagelocation>().Where(it => it.Partnumber ==
SqlFunc.Subqueryable<Billofmaterials>().Where(It => It.Productcode == light.AssemblyPartNumber&&It.Version == light.Version).Select(it => it.MirrorbodyCode)).First();
SqlFunc.Subqueryable<Billofmaterials>().Where(It => It.Productcode == light.AssemblyPartNumber && It.Version == light.Version).Select(it => it.MirrorbodyCode)).First();
// 3.对应料架亮灯
@@ -56,7 +66,7 @@ namespace DOAN.Service.PBL
light_Log.ShelfCode = MirrorshellShelf.RackCode;
}
light_Log.Operationer = "PBL";
light_Log.CreatedTime = DateTime.Now;
Light_Log light_Log2 = new Light_Log();
@@ -67,12 +77,12 @@ namespace DOAN.Service.PBL
light_Log2.ShelfCode = MirrorshellShelf.RackCode;
}
light_Log2.Operationer = "PBL";
light_Log2.CreatedTime = DateTime.Now;
Context.Insertable(light_Log2).ExecuteCommand();
int result = Context.Insertable(light_Log).ExecuteCommand();
return result > 0;
return result > 0;
}
@@ -82,33 +92,34 @@ namespace DOAN.Service.PBL
// 1.记录MES交互记录
MES_Interation_Log item = new MES_Interation_Log();
item.Id = XUEHUA;
item.ScanCode=scan_code;
item.ScanCode = scan_code;
item.CreatedTime = DateTime.Now;
Context.Insertable(item).ExecuteCommand();
//2 找到对应的料架 灭灯
Storagelocation storagelocation= Context.Queryable<Storagelocation>().Where(it => it.Partnumber == scan_code).First();
Storagelocation storagelocation = Context.Queryable<Storagelocation>().Where(it => it.Partnumber == scan_code).First();
//TODO PLC 交互
//亮灯日志
Light_Log light_Log = new Light_Log();
light_Log.Id = XUEHUA;
light_Log.LightOperation = 2;
if (storagelocation != null) {
light_Log.ShelfCode = storagelocation.RackCode ;
if (storagelocation != null)
{
light_Log.ShelfCode = storagelocation.RackCode;
}
light_Log.Operationer = "PBL";
light_Log.CreatedTime = DateTime.Now;
int result= Context.Insertable(light_Log).ExecuteCommand();
int result = Context.Insertable(light_Log).ExecuteCommand();
//3 扣减对应的库存
return result > 0;
}