From a1bf060d50da3c27b54bcc349e8b53769b39ef89 Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期二, 03 六月 2025 17:31:33 +0800
Subject: [PATCH] 1.增加Aligner --> Bonder1 | Bonder2的搬送检测逻辑; 2.优化搬送逻辑。搬送要分优先考虑的主类型和次要类型。一种情况,如果不分主次,一直搬G1, 等到Bonder1和Bonder2都放了G1, Aligner也放了G1, Bonder1和Bonder2需要的G2就过不来了(在Aligner阻塞了)。另外从生产效率上来说,也应该根据需求,尽快使其中一台Bonder的两片玻璃匹配以使其能尽快开始生产加工。
---
SourceCode/Bond/Servo/Servo.cpp | 51 ++++++++++++++++++++++++++++++++++++++++++---------
1 files changed, 42 insertions(+), 9 deletions(-)
diff --git a/SourceCode/Bond/Servo/Servo.cpp b/SourceCode/Bond/Servo/Servo.cpp
index d23cb02..657947a 100644
--- a/SourceCode/Bond/Servo/Servo.cpp
+++ b/SourceCode/Bond/Servo/Servo.cpp
@@ -7,7 +7,14 @@
#include "ServoDlg.h"
#include "ServoGraph.h"
#include "AlarmManager.h"
-#include "SECSConfigManager.h"
+#include "SECSRuntimeManager.h"
+#include "TransferManager.h"
+#include "VerticalLine.h"
+#include "HorizontalLine.h"
+#include "EqsGraphWnd.h"
+#include "MapPosWnd.h"
+#include "HmTab.h"
+
// 声明全局变量,用于管理 GDI+ 初始化
ULONG_PTR g_diplusToken;
@@ -46,7 +53,7 @@
BOOL CServoApp::InitInstance()
{
- // 如果一个运行在 Windows XP 上的应用程序清单指定要
+ // TODO: 调用 AfxInitRichEdit2() 以初始化 richedit2 库。\n" // 如果一个运行在 Windows XP 上的应用程序清单指定要
// 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
//则需要 InitCommonControlsEx()。 否则,将无法创建窗口。
INITCOMMONCONTROLSEX InitCtrls;
@@ -92,6 +99,11 @@
// 注册控件
CServoGraph::RegisterWndClass();
+ CVerticalLine::RegisterWndClass();
+ CHorizontalLine::RegisterWndClass();
+ CEqsGraphWnd::RegisterWndClass();
+ CMapPosWnd::RegisterWndClass();
+ CHmTab::RegisterWndClass();
// 初始化Rx库
@@ -101,6 +113,10 @@
// 初始化 GDI+
InitGDIPlus();
+
+
+ // 初始化 MFC RichEdit 控件
+ AfxInitRichEdit2();
// 初始化报警管理器
@@ -116,18 +132,32 @@
AfxMessageBox(errorMsg, MB_ICONERROR);
return FALSE;
}
+ AlarmManager::getInstance().insertMockData();
-
- // 初始化SECS设置管理库
+ // 初始化SECS运行设置管理库
try {
- if (!SECSConfigManager::getInstance().initSECSSetting()) {
- AfxMessageBox("初始化SECS设置管理库失败!");
+ if (!SECSRuntimeManager::getInstance().initRuntimeSetting()) {
+ AfxMessageBox("初始化SECS运行设置失败!");
return FALSE;
}
}
catch (const std::exception& ex) {
CString errorMsg;
- errorMsg.Format(_T("初始化SECS设置管理库失败:%s"), CString(ex.what()));
+ errorMsg.Format(_T("初始化SECS运行设置失败:%s"), CString(ex.what()));
+ AfxMessageBox(errorMsg, MB_ICONERROR);
+ return FALSE;
+ }
+
+ // 初始化搬运记录管理库
+ try {
+ if (!TransferManager::getInstance().initTransferTable()) {
+ AfxMessageBox("初始化搬运记录管理库设置失败!");
+ return FALSE;
+ }
+ }
+ catch (const std::exception& ex) {
+ CString errorMsg;
+ errorMsg.Format(_T("初始化搬运记录管理库设置失败:%s"), CString(ex.what()));
AfxMessageBox(errorMsg, MB_ICONERROR);
return FALSE;
}
@@ -175,8 +205,11 @@
// 销毁报警表
AlarmManager::getInstance().termAlarmTable();
- // 销毁SECS设置管理库
- SECSConfigManager::getInstance().termSECSSetting();
+ // 销毁SECS运行设置管理库
+ SECSRuntimeManager::getInstance().termRuntimeSetting();
+
+ // 销毁搬运记录管理库
+ TransferManager::getInstance().termTransferTable();
return CWinApp::ExitInstance();
}
--
Gitblit v1.9.3