From 331f447bb0e5eccf0b3161ab287c1372b14b8480 Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期五, 08 八月 2025 11:53:58 +0800
Subject: [PATCH] 1.增加千传计数,保存计数,重启软件时恢复; 2.千传测试模式,打印相关日志,方便后期提取,用于统计; 3.千传模式时烘烤两腔体都要进入; 4.千传模式时,Fliper到Bonder修改为用手臂2取料; 5.修复千传模式不计运行时的问题; 6.千传模式,最后收料强制放入第一层; 6.修复Buf, 当任务未生成(在符合条件后仍有1秒间隙)而机器单元发送FetchOutJob时,数据检验失败的问题,增加Sleep, 缩小间隙;

---
 SourceCode/Bond/Servo/Servo.cpp |   79 ++++++++++++++++++++++++++++++---------
 1 files changed, 60 insertions(+), 19 deletions(-)

diff --git a/SourceCode/Bond/Servo/Servo.cpp b/SourceCode/Bond/Servo/Servo.cpp
index 657947a..be05f20 100644
--- a/SourceCode/Bond/Servo/Servo.cpp
+++ b/SourceCode/Bond/Servo/Servo.cpp
@@ -7,8 +7,10 @@
 #include "ServoDlg.h"
 #include "ServoGraph.h"
 #include "AlarmManager.h"
-#include "SECSRuntimeManager.h"
 #include "TransferManager.h"
+#include "SystemLogManager.h"
+#include "UserManager.h"
+#include "RecipeManager.h"
 #include "VerticalLine.h"
 #include "HorizontalLine.h"
 #include "EqsGraphWnd.h"
@@ -132,21 +134,6 @@
 		AfxMessageBox(errorMsg, MB_ICONERROR);
 		return FALSE;
 	}
-	AlarmManager::getInstance().insertMockData();
-
-	// 初始化SECS运行设置管理库
-	try {
-		if (!SECSRuntimeManager::getInstance().initRuntimeSetting()) {
-			AfxMessageBox("初始化SECS运行设置失败!");
-			return FALSE;
-		}
-	}
-	catch (const std::exception& ex) {
-		CString errorMsg;
-		errorMsg.Format(_T("初始化SECS运行设置失败:%s"), CString(ex.what()));
-		AfxMessageBox(errorMsg, MB_ICONERROR);
-		return FALSE;
-	}
 
 	// 初始化搬运记录管理库
 	try {
@@ -158,6 +145,50 @@
 	catch (const std::exception& ex) {
 		CString errorMsg;
 		errorMsg.Format(_T("初始化搬运记录管理库设置失败:%s"), CString(ex.what()));
+		AfxMessageBox(errorMsg, MB_ICONERROR);
+		return FALSE;
+	}
+
+	// 初始化运行日志管理库
+	try {
+		if (!SystemLogManager::getInstance().initSystemLogTable()) {
+			AfxMessageBox("初始化运行日志管理库失败!");
+			return FALSE;
+		}
+	}
+	catch (const std::exception& ex) {
+		CString errorMsg;
+		errorMsg.Format(_T("初始化运行日志管理库失败:%s"), CString(ex.what()));
+		AfxMessageBox(errorMsg, MB_ICONERROR);
+		return FALSE;
+	}
+
+	// 初始化用户管理库
+	try {
+		UserManager& userManager = UserManager::getInstance();
+#if !defined(_DEBUG)
+		userManager.initializeIdleDetection(AfxGetMainWnd()->m_hWnd);
+		SetTimer(1, 60000, nullptr);
+#endif
+		userManager.loadSession();
+	}
+	catch (const std::exception& ex) {
+		CString errorMsg;
+		errorMsg.Format(_T("初始化用户管理库失败:%s"), CString(ex.what()));
+		AfxMessageBox(errorMsg, MB_ICONERROR);
+		return FALSE;
+	}
+
+	// 初始化配方管理库
+	try {
+		if (!RecipeManager::getInstance().initRecipeTable()) {
+			AfxMessageBox("初始化配方管理库失败!");
+			return FALSE;
+		}
+	}
+	catch (const std::exception& ex) {
+		CString errorMsg;
+		errorMsg.Format(_T("初始化配方管理库失败:%s"), CString(ex.what()));
 		AfxMessageBox(errorMsg, MB_ICONERROR);
 		return FALSE;
 	}
@@ -205,12 +236,22 @@
 	// 销毁报警表
 	AlarmManager::getInstance().termAlarmTable();
 
-	// 销毁SECS运行设置管理库
-	SECSRuntimeManager::getInstance().termRuntimeSetting();
-
 	// 销毁搬运记录管理库
 	TransferManager::getInstance().termTransferTable();
 
+	// 销毁运行日志
+	SystemLogManager::getInstance().termSystemLogTable();
+
+	// 销毁用户表
+#if !defined(_DEBUG)
+// 清除 UserManager 的无操作检测
+	UserManager::getInstance().terminateIdleDetection();
+	KillTimer(1);
+#endif
+
+	// 销毁配方表
+	RecipeManager::getInstance().termRecipeTable();
+
 	return CWinApp::ExitInstance();
 }
 

--
Gitblit v1.9.3