增加排料运动日志/周转盘状态显示

master
lhiven 2 years ago
parent 38206d24ed
commit 97fa17ce90

@ -121,6 +121,9 @@ namespace Rs.MotionPlat.Flow
int needGrabNum = 0;//需要拍照的吸嘴数量 int needGrabNum = 0;//需要拍照的吸嘴数量
int reGrabCount = 0;//重拍次数 int reGrabCount = 0;//重拍次数
ErrorCode errCode = ErrorCode.Ok; ErrorCode errCode = ErrorCode.Ok;
string logInfo = "";
List<TurnoverInfo> testLoadList = new List<TurnoverInfo>();
List<TurnoverInfo> testUnLoadList = new List<TurnoverInfo>();
public override void Run() public override void Run()
{ {
switch (flowStep) switch (flowStep)
@ -132,14 +135,23 @@ namespace Rs.MotionPlat.Flow
{ {
if(LoadAndUnloadTask.Instance.GetTaskNum(ETaskMode.TestLoad)>0) if(LoadAndUnloadTask.Instance.GetTaskNum(ETaskMode.TestLoad)>0)
{ {
logInfo = $"接收到测试工位上料任务";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
else if(LoadAndUnloadTask.Instance.GetTaskNum( ETaskMode.TestUnload)>0) else if(LoadAndUnloadTask.Instance.GetTaskNum( ETaskMode.TestUnload)>0)
{ {
logInfo = $"接收到测试工位下料任务";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
else else
{ {
logInfo = $"接收到排料任务";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
} }
@ -167,22 +179,29 @@ namespace Rs.MotionPlat.Flow
curSlotPoint = null; curSlotPoint = null;
if (curTask.FromType == TurnoverType.Turnover) if (curTask.FromType == TurnoverType.Turnover)
{ {
logInfo = $"吸嘴{curTask.FromIndex + 1} 去周转盘 {curTask.FromIndex + 1} 号穴位取料";
curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Turnover", curTask.FromIndex + 1, EPointType.RUN); curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Turnover", curTask.FromIndex + 1, EPointType.RUN);
MessageQueue.Instance.Insert($"吸嘴{curTask.FromIndex + 1} 去周转盘 {curTask.FromIndex + 1} 号穴位取料"); MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
} }
else if (curTask.FromType == TurnoverType.ToBeTested) else if (curTask.FromType == TurnoverType.ToBeTested)
{ {
TraySlot slot = GlobalTray.InputTray.GetSlot(ESlotStatus.Have); TraySlot slot = GlobalTray.InputTray.GetSlot(ESlotStatus.Have);
if (slot != null) if (slot != null)
{ {
logInfo = $"吸嘴{curNozzle.NozzleIndex} 去Input盘 {slot.Index} 号穴位取料";
curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Input", slot.Index, EPointType.BASE); curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Input", slot.Index, EPointType.BASE);
MessageQueue.Instance.Insert($"吸嘴{curNozzle.NozzleIndex} 去Input盘 {slot.Index} 号穴位取料"); MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
} }
else else
{ {
// Msg.ShowInfo("Input料盘缺料请手动切盘后点击确定"); // Msg.ShowInfo("Input料盘缺料请手动切盘后点击确定");
// GlobalTray.InputTray.ResetTray(); // GlobalTray.InputTray.ResetTray();
// GlobalTray.InputTray.Fill(); // GlobalTray.InputTray.Fill();
logInfo = "检测到Input料盘无料准备上料盘";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
TakeTrayFlow.Instance.Take(EStockType.Input, EStockType.Empty1, ELoadUnloadType.Unload); TakeTrayFlow.Instance.Take(EStockType.Input, EStockType.Empty1, ELoadUnloadType.Unload);
restoreFlowStep = EWorkFlowStep.; restoreFlowStep = EWorkFlowStep.;
flowStep = EWorkFlowStep.Input; flowStep = EWorkFlowStep.Input;
@ -214,7 +233,10 @@ namespace Rs.MotionPlat.Flow
} }
else else
{ {
Msg.ShowError("x y move isn't safe"); logInfo = "x y move isn't safe";
Msg.ShowError(logInfo);
LogHelper.Error(logInfo);
MessageQueue.Instance.Warn(logInfo);
} }
} }
@ -222,16 +244,20 @@ namespace Rs.MotionPlat.Flow
case EWorkFlowStep.: case EWorkFlowStep.:
if (Ops.IsStop("LoadX","LoadY", $"NozzleR{curNozzle.NozzleIndex}")) if (Ops.IsStop("LoadX","LoadY", $"NozzleR{curNozzle.NozzleIndex}"))
{ {
logInfo = "已运动到取料位上方";
Thread.Sleep(100); Thread.Sleep(100);
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
MessageQueue.Instance.Insert("已运动到取料位上方");
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
if(AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").HomeStatus== EHomeStatus.Finished) if(AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").HomeStatus== EHomeStatus.Finished)
{ {
MessageQueue.Instance.Insert("准备运动到取料位下方"); logInfo = "准备运动到取料位下方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
if (curTask.FromType == TurnoverType.Turnover) if (curTask.FromType == TurnoverType.Turnover)
{ {
errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(GetVacOffsetHeight(FetchNum) + SysConfigParam.GetValue<double>($"TurnoverNozzle{curNozzle.NozzleIndex}TakeHeight"), GlobalVar.WholeSpeed); errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(GetVacOffsetHeight(FetchNum) + SysConfigParam.GetValue<double>($"TurnoverNozzle{curNozzle.NozzleIndex}TakeHeight"), GlobalVar.WholeSpeed);
@ -247,49 +273,75 @@ namespace Rs.MotionPlat.Flow
} }
else else
{ {
Msg.ShowError($"NozzleZ{curNozzle.NozzleIndex} 不在原点,请手动回原后点击确定"); logInfo = $"NozzleZ{curNozzle.NozzleIndex} 不在原点,请手动回原后点击确定";
Msg.ShowError(logInfo);
LogHelper.Error(logInfo);
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}")) if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}"))
{ {
Thread.Sleep(GlobalVar.AxisArrivedWaittime); logInfo = "已运动到取料位下方";
MessageQueue.Instance.Insert("已运动到取料位下方"); MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
Ops.On($"{curNozzle.NozzleIndex}号吸嘴真空吸电磁阀"); Ops.On($"{curNozzle.NozzleIndex}号吸嘴真空吸电磁阀");
MessageQueue.Instance.Insert($"打开{curNozzle.NozzleIndex}号吸嘴真空吸");
Thread.Sleep(GlobalVar.LoadNozzleOpenVacSuctionDelaytime); Thread.Sleep(GlobalVar.LoadNozzleOpenVacSuctionDelaytime);
logInfo = $"打开{curNozzle.NozzleIndex}号吸嘴真空吸";
MessageQueue.Instance.Insert(logInfo);
LogHelper .Debug(logInfo);
if (curTask.FromType == TurnoverType.Turnover) if (curTask.FromType == TurnoverType.Turnover)
{ {
logInfo = $"关闭周转盘{curTask.FromIndex + 1}号穴位真空吸";
Ops.Off($"周转盘{curTask.FromIndex+1}号穴位真空吸"); Ops.Off($"周转盘{curTask.FromIndex+1}号穴位真空吸");
Thread.Sleep(GlobalVar.TurnoverTrayCloseVacSuctionDelaytime); Thread.Sleep(GlobalVar.TurnoverTrayCloseVacSuctionDelaytime);
MessageQueue.Instance.Insert(logInfo);
LogHelper .Debug(logInfo);
logInfo = $"打开周转盘{curTask.FromIndex + 1}号穴位真空破";
Ops.On($"周转盘{curTask.FromIndex + 1}号穴位真空破"); Ops.On($"周转盘{curTask.FromIndex + 1}号穴位真空破");
Thread.Sleep(GlobalVar.TurnoverTrayOpenVacBreakDelaytime); Thread.Sleep(GlobalVar.TurnoverTrayOpenVacBreakDelaytime);
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
logInfo = $"关闭周转盘{curTask.FromIndex + 1}号穴位真空破";
Ops.Off($"周转盘{curTask.FromIndex + 1}号穴位真空破"); Ops.Off($"周转盘{curTask.FromIndex + 1}号穴位真空破");
Thread.Sleep(GlobalVar.TurnoverTrayCloseVacBreakDelaytime); Thread.Sleep(GlobalVar.TurnoverTrayCloseVacBreakDelaytime);
MessageQueue.Instance.Insert(logInfo);
LogHelper .Debug(logInfo);
} }
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(0, GlobalVar.WholeSpeed); errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(0, GlobalVar.WholeSpeed);
if (errCode == ErrorCode.Ok) if (errCode == ErrorCode.Ok)
{ {
logInfo = "取料完成准备抬起";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug (logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}")) if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}"))
{ {
logInfo = "取料完成已运动到抬起位,准备真空检测";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
if (Ops.IsOn($"{curNozzle.NozzleIndex}号吸嘴真空吸检测") || GlobalVar.RunSpace) if (Ops.IsOn($"{curNozzle.NozzleIndex}号吸嘴真空吸检测") || GlobalVar.RunSpace)
{ {
FetchNum = 0;
logInfo = $"吸嘴{curNozzle.NozzleIndex}真空检测 OK";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
curNozzle.Status = ENozzleStatus.ToUnload; curNozzle.Status = ENozzleStatus.ToUnload;
curNozzle.FromType = curTask.FromType; curNozzle.FromType = curTask.FromType;
curNozzle.FromFloor = curTask.FromFloor; curNozzle.FromFloor = curTask.FromFloor;
@ -298,8 +350,6 @@ namespace Rs.MotionPlat.Flow
curNozzle.ToIndex = curTask.ToIndex; curNozzle.ToIndex = curTask.ToIndex;
curTask.SuckerNo = curNozzle.NozzleIndex ; curTask.SuckerNo = curNozzle.NozzleIndex ;
curNozzle.TurnoverGUID = curTask.GUID; curNozzle.TurnoverGUID = curTask.GUID;
FetchNum = 0;
if (curTask.FromType == TurnoverType.Turnover) if (curTask.FromType == TurnoverType.Turnover)
{ {
curNozzle.SN = curTask.SN; curNozzle.SN = curTask.SN;
@ -313,8 +363,12 @@ namespace Rs.MotionPlat.Flow
} }
curNozzle.Update(); curNozzle.Update();
curTask.Dealed = true; curTask.Dealed = true;
if (LoadAndUnloadTask.Instance.GetTaskNum(curTask.taskMode)>0 && NozzleManager.GetNozzlesByStatus(ENozzleStatus.IDLE).Count > 0) int undoTaskNum = LoadAndUnloadTask.Instance.GetTaskNum(curTask.taskMode);
if (undoTaskNum > 0 && NozzleManager.GetNozzlesByStatus(ENozzleStatus.IDLE).Count > 0)
{ {
logInfo = $"检测到还有{undoTaskNum}条任务未执行,继续执行";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
else else
@ -411,6 +465,9 @@ namespace Rs.MotionPlat.Flow
case EWorkFlowStep.: case EWorkFlowStep.:
if (XYCanMove()) if (XYCanMove())
{ {
logInfo = "到下相机拍照起始位";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
ImageProcess.ClearAutoTrigger(); ImageProcess.ClearAutoTrigger();
HikCamera.Instance.SetExposure("locationCamera", GlobalVar.FlyGrabExposureTime); HikCamera.Instance.SetExposure("locationCamera", GlobalVar.FlyGrabExposureTime);
HikCamera.Instance.SetGain("locationCamera", GlobalVar.FlyGrabGain); HikCamera.Instance.SetGain("locationCamera", GlobalVar.FlyGrabGain);
@ -432,6 +489,9 @@ namespace Rs.MotionPlat.Flow
case EWorkFlowStep.: case EWorkFlowStep.:
if (Ops.IsStop("LoadX", "LoadY")) if (Ops.IsStop("LoadX", "LoadY"))
{ {
logInfo = "已运动到下相机拍照起始位";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
Thread.Sleep(100); Thread.Sleep(100);
HikCamera.Instance.SetTrigger("locationCamera", ETriggerMode.Auto); HikCamera.Instance.SetTrigger("locationCamera", ETriggerMode.Auto);
List<double> grabPoints = new List<double>(); List<double> grabPoints = new List<double>();
@ -463,6 +523,9 @@ namespace Rs.MotionPlat.Flow
case EWorkFlowStep.: case EWorkFlowStep.:
if (XYCanMove()) if (XYCanMove())
{ {
logInfo = "到下相机拍照结束位";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
IoManager.Instance.WriteOut("下左相机光源触发", 1); IoManager.Instance.WriteOut("下左相机光源触发", 1);
Thread.Sleep(50); Thread.Sleep(50);
if (NozzleManager.GetNozzlesByStatus(ENozzleStatus.ToUnload)[0].ToType == TurnoverType.Turnover) if (NozzleManager.GetNozzlesByStatus(ENozzleStatus.ToUnload)[0].ToType == TurnoverType.Turnover)
@ -483,6 +546,10 @@ namespace Rs.MotionPlat.Flow
if (Ops.IsStop("LoadX")) if (Ops.IsStop("LoadX"))
{ {
logInfo = "已运动到下相机拍照结束位";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
AxisControl.LoadX.ClearCompare(1); AxisControl.LoadX.ClearCompare(1);
IoManager.Instance.WriteOut("下左相机光源触发", 0); IoManager.Instance.WriteOut("下左相机光源触发", 0);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
@ -493,6 +560,10 @@ namespace Rs.MotionPlat.Flow
imgs = ImageProcess.GetAutoImage(); imgs = ImageProcess.GetAutoImage();
if (imgs != null && imgs.Length == needGrabNum) if (imgs != null && imgs.Length == needGrabNum)
{ {
logInfo = "相机拍照完成,准备处理照片";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
if (NozzleManager.GetNozzlesByStatus(ENozzleStatus.ToUnload)[0].ToType == TurnoverType.Turnover) if (NozzleManager.GetNozzlesByStatus(ENozzleStatus.ToUnload)[0].ToType == TurnoverType.Turnover)
{ {
imgs = imgs.Reverse().ToArray(); imgs = imgs.Reverse().ToArray();
@ -524,6 +595,9 @@ namespace Rs.MotionPlat.Flow
mrs = VisionProcess.Instance.MatchDownCam(imgs); mrs = VisionProcess.Instance.MatchDownCam(imgs);
if (mrs != null && mrs.Count == imgs.Length && mrs.Where(m=>m.IsOK==true).Count()==imgs.Length) if (mrs != null && mrs.Count == imgs.Length && mrs.Where(m=>m.IsOK==true).Count()==imgs.Length)
{ {
logInfo = "图片处理完成,准备放料";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
//foreach (Nozzle nozzle in NozzleManager.GetNozzles()) //foreach (Nozzle nozzle in NozzleManager.GetNozzles())
//{ //{
// nozzle.SN = Guid.NewGuid().ToString(); // nozzle.SN = Guid.NewGuid().ToString();
@ -585,6 +659,7 @@ namespace Rs.MotionPlat.Flow
case EWorkFlowStep.: case EWorkFlowStep.:
if (XYCanMove()) if (XYCanMove())
{ {
turnoverOffsetPoint.Reset(); turnoverOffsetPoint.Reset();
tray = null; tray = null;
targetX = 0.0; targetX = 0.0;
@ -596,15 +671,22 @@ namespace Rs.MotionPlat.Flow
{ {
if (curNozzle.ToType == TurnoverType.Turnover) if (curNozzle.ToType == TurnoverType.Turnover)
{ {
logInfo = "到周转盘放料位上方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Turnover", curNozzle.ToIndex + 1, EPointType.RUN); curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Turnover", curNozzle.ToIndex + 1, EPointType.RUN);
turnoverOffsetPoint = TurnoverSlotOffset.GetOffsetPoint(curNozzle.ToIndex + 1); turnoverOffsetPoint = TurnoverSlotOffset.GetOffsetPoint(curNozzle.ToIndex + 1);
} }
else if (curNozzle.ToType == TurnoverType.ToBeTested) else if (curNozzle.ToType == TurnoverType.ToBeTested)
{ {
logInfo = "到input盘放料位上方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
downSlot = GlobalTray.InputTray.GetSlot(ESlotStatus.NotHave); downSlot = GlobalTray.InputTray.GetSlot(ESlotStatus.NotHave);
if (downSlot != null) if (downSlot != null)
{ {
curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Input", downSlot.Index, EPointType.RUN); curSlotPoint = TrayPointManager.GetSlotPoint(GlobalVar.CurRecipe, "Input", downSlot.Index, EPointType.BASE);
} }
else else
{ {
@ -619,6 +701,10 @@ namespace Rs.MotionPlat.Flow
} }
else if (curNozzle.ToType == TurnoverType.Passed) else if (curNozzle.ToType == TurnoverType.Passed)
{ {
logInfo = "到Pass盘放料位上方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
//OK料仓切盘 //OK料仓切盘
downSlot = GlobalTray.OkTary.GetSlot(ESlotStatus.NotHave); downSlot = GlobalTray.OkTary.GetSlot(ESlotStatus.NotHave);
if (downSlot != null) if (downSlot != null)
@ -641,6 +727,10 @@ namespace Rs.MotionPlat.Flow
} }
else if (curNozzle.ToType == TurnoverType.Failed) else if (curNozzle.ToType == TurnoverType.Failed)
{ {
logInfo = "到Ng盘放料位上方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
downSlot = GlobalTray.NgTray.GetSlot(ESlotStatus.NotHave); downSlot = GlobalTray.NgTray.GetSlot(ESlotStatus.NotHave);
if (downSlot != null) if (downSlot != null)
{ {
@ -660,6 +750,9 @@ namespace Rs.MotionPlat.Flow
} }
else if (curNozzle.ToType == TurnoverType.Multifunction) else if (curNozzle.ToType == TurnoverType.Multifunction)
{ {
logInfo = "到Multi盘放料位上方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
downSlot = GlobalTray.MultiTray.GetSlot(ESlotStatus.NotHave); downSlot = GlobalTray.MultiTray.GetSlot(ESlotStatus.NotHave);
if (downSlot != null) if (downSlot != null)
{ {
@ -716,12 +809,17 @@ namespace Rs.MotionPlat.Flow
if (Ops.IsStop("LoadX", "LoadY",$"NozzleR{curNozzle.NozzleIndex}")) if (Ops.IsStop("LoadX", "LoadY",$"NozzleR{curNozzle.NozzleIndex}"))
{ {
Thread.Sleep(100); Thread.Sleep(100);
logInfo = "已运动到放料位上方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
logInfo = "到放料位下方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
if (curNozzle.ToType == TurnoverType.Turnover) if (curNozzle.ToType == TurnoverType.Turnover)
{ {
errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(SysConfigParam.GetValue<double>($"TurnoverNozzle{curNozzle.NozzleIndex}TakeHeight"), GlobalVar.WholeSpeed); errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(SysConfigParam.GetValue<double>($"TurnoverNozzle{curNozzle.NozzleIndex}TakeHeight"), GlobalVar.WholeSpeed);
@ -739,6 +837,9 @@ namespace Rs.MotionPlat.Flow
case EWorkFlowStep.: case EWorkFlowStep.:
if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}")) if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}"))
{ {
logInfo = "已运动到放料位下方";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
if (curNozzle.ToType== TurnoverType.Turnover) if (curNozzle.ToType== TurnoverType.Turnover)
{ {
Ops.On($"周转盘{curNozzle.ToIndex + 1}号穴位真空吸"); Ops.On($"周转盘{curNozzle.ToIndex + 1}号穴位真空吸");
@ -800,12 +901,18 @@ namespace Rs.MotionPlat.Flow
errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(0, GlobalVar.WholeSpeed); errCode = AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").MovePos(0, GlobalVar.WholeSpeed);
if (errCode == ErrorCode.Ok) if (errCode == ErrorCode.Ok)
{ {
logInfo = "放料完成抬起";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}")) if (Ops.IsStop($"NozzleZ{curNozzle.NozzleIndex}"))
{ {
logInfo = "放料完成已运动到抬起位,准备真空检测";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
@ -814,10 +921,17 @@ namespace Rs.MotionPlat.Flow
{ {
if (Ops.IsOn($"周转盘{curNozzle.ToIndex + 1}号穴位真空吸检测") || GlobalVar.RunSpace) if (Ops.IsOn($"周转盘{curNozzle.ToIndex + 1}号穴位真空吸检测") || GlobalVar.RunSpace)
{ {
logInfo = $"周转盘{curNozzle.ToIndex + 1}号穴位真空吸检测 OK";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
else else
{ {
logInfo = $"放料时周转盘{curNozzle.ToIndex + 1}号穴位真空吸异常";
MessageQueue.Instance.Warn(logInfo);
LogHelper.Debug(logInfo);
DialogResult dr = Msg.ShowError($"周转盘{curNozzle.ToIndex + 1}号穴位真空吸异常,点击确定后跳过"); DialogResult dr = Msg.ShowError($"周转盘{curNozzle.ToIndex + 1}号穴位真空吸异常,点击确定后跳过");
if (dr == DialogResult.OK) if (dr == DialogResult.OK)
{ {
@ -831,6 +945,9 @@ namespace Rs.MotionPlat.Flow
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
logInfo = "放料任务完成";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").Home(); AxisControl.GetAxis($"NozzleZ{curNozzle.NozzleIndex}").Home();
//Ops.HomeAndGoStartPos($"NozzleR{NozzleIndex}"); //Ops.HomeAndGoStartPos($"NozzleR{NozzleIndex}");
if (curNozzle.ToType == TurnoverType.Turnover) if (curNozzle.ToType == TurnoverType.Turnover)
@ -874,6 +991,9 @@ namespace Rs.MotionPlat.Flow
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
logInfo = "任务结束到安全位";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
errCode = AxisControl.LoadX.MovePos(SysConfigParam.GetValue<double>("LoadXStartPos"), GlobalVar.WholeSpeed); errCode = AxisControl.LoadX.MovePos(SysConfigParam.GetValue<double>("LoadXStartPos"), GlobalVar.WholeSpeed);
if(errCode== ErrorCode.Ok) if(errCode== ErrorCode.Ok)
{ {
@ -887,16 +1007,27 @@ namespace Rs.MotionPlat.Flow
case EWorkFlowStep.: case EWorkFlowStep.:
if(Ops.IsStop("LoadX","LoadY")) if(Ops.IsStop("LoadX","LoadY"))
{ {
logInfo = "任务结束已回到安全位";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
if (TestCenter.Instance.LoadResult()) if (TestCenter.Instance.LoadResult())
{ {
logInfo = "通知中控任务完成";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
LoadAndUnloadTask.Instance.Clear(); LoadAndUnloadTask.Instance.Clear();
logInfo = "任务完成,清除任务";
MessageQueue.Instance.Insert(logInfo);
LogHelper.Debug(logInfo);
} }
MachineManage.Instance.RunState = ERunState.Waiting; MachineManage.Instance.RunState = ERunState.Waiting;
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
TurnoverFlow.Instance.PressLoad(LoadAndUnloadTask.Instance.GetTestLoadTasks()); testLoadList = LoadAndUnloadTask.Instance.GetTestLoadTasks();
TurnoverFlow.Instance.PressLoad(testLoadList);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
@ -906,35 +1037,45 @@ namespace Rs.MotionPlat.Flow
LoadAndUnloadTask.Instance.Clear(); LoadAndUnloadTask.Instance.Clear();
MachineManage.Instance.RunState = ERunState.Waiting; MachineManage.Instance.RunState = ERunState.Waiting;
//切换穴位状态 //切换穴位状态
for (int i = 1; i < 9; i++) foreach (TurnoverInfo turnoverInfo in testLoadList)
{
GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.NotHave);
}
for (int i = 17; i < 25; i++)
{ {
GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.NotHave); GlobalTray.TurnoverTray.ChangeStatus(turnoverInfo.FromIndex, ESlotStatus.NotHave);
} }
//for (int i = 1; i < 9; i++)
//{
// GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.NotHave);
//}
//for (int i = 17; i < 25; i++)
//{
// GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.NotHave);
//}
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
TurnoverFlow.Instance.PressUnload(LoadAndUnloadTask.Instance.GetTestUnLoadTasks()); testUnLoadList = LoadAndUnloadTask.Instance.GetTestUnLoadTasks();
TurnoverFlow.Instance.PressUnload(testUnLoadList);
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
break; break;
case EWorkFlowStep.: case EWorkFlowStep.:
if (TurnoverFlow.Instance.UnloadFinished()) if (TurnoverFlow.Instance.UnloadFinished())
{ {
//logInfo = string.Join(",",testUnLoadList.Select(t=>t.ToIndex).ToList());
TestCenter.Instance.LoadTestUnLoadResult(); TestCenter.Instance.LoadTestUnLoadResult();
LoadAndUnloadTask.Instance.Clear(); LoadAndUnloadTask.Instance.Clear();
//切换穴位状态 //切换穴位状态
for (int i = 9; i < 17; i++) foreach (TurnoverInfo turnoverInfo in testUnLoadList)
{ {
GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.Have); GlobalTray.TurnoverTray.ChangeStatus(turnoverInfo.ToIndex, ESlotStatus.Have);
}
for (int i = 25; i < 33; i++)
{
GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.Have);
} }
//for (int i = 9; i < 17; i++)
//{
// GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.Have);
//}
//for (int i = 25; i < 33; i++)
//{
// GlobalTray.TurnoverTray.ChangeStatus(i, ESlotStatus.Have);
//}
MachineManage.Instance.RunState = ERunState.Waiting; MachineManage.Instance.RunState = ERunState.Waiting;
flowStep = EWorkFlowStep.; flowStep = EWorkFlowStep.;
} }

Loading…
Cancel
Save