From bea6407b376a4e426f0b120bae569fba6ab867db Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期六, 08 十一月 2025 17:55:47 +0800
Subject: [PATCH] 1.CMaster.cpp 第 1644/1667/1691 行在记录 SV 曲线时通过 getGlassFromSlot(0) 取玻璃,而各设备的 initSlots() 都是从 1 开始编号(例如 CBonder.cpp (line 408)、CVacuumBake.cpp (line 415) 等)。槽位 0 永远不存在,所以 pGlass 始终是 nullptr,pGlass->addSVData(...) 的分支从未执行。结果 SERVO::CGlass::m_svDatas 里没有任何曲线数据,GlassJson::ToPrettyString 生成的 pretty 字符串也就没有 sv_datas,导出 CSV 时自然读不到曲线。 同一段代码还有一个潜在 Bug:虽然判断了 channel - 1 < bonderTypes.size(),但真正索引却用的是 bonderTypes[channel]。索引偏移会导致数据类型错位,最后一个通道甚至可能越界。即使修正了槽位,这里也需要同步改成 bonderTypes[channel - 1](另外两处 vacuumbakeTypes、coolingTypes 也一样)。
---
SourceCode/Bond/Servo/Servo.cpp | 115 ++++++++++++++++++++++++++++++++++++++++-----------------
1 files changed, 81 insertions(+), 34 deletions(-)
diff --git a/SourceCode/Bond/Servo/Servo.cpp b/SourceCode/Bond/Servo/Servo.cpp
index c3d5bce..33f8657 100644
--- a/SourceCode/Bond/Servo/Servo.cpp
+++ b/SourceCode/Bond/Servo/Servo.cpp
@@ -7,12 +7,16 @@
#include "ServoDlg.h"
#include "ServoGraph.h"
#include "AlarmManager.h"
-#include "SECSRuntimeManager.h"
-#include "ProductionLogManager.h"
+#include "TransferManager.h"
+#include "SystemLogManager.h"
+#include "UserManager.h"
+#include "RecipeManager.h"
#include "VerticalLine.h"
+#include "HorizontalLine.h"
#include "EqsGraphWnd.h"
#include "MapPosWnd.h"
#include "HmTab.h"
+#include "CControlJobManagerDlg.h"
// 声明全局变量,用于管理 GDI+ 初始化
@@ -52,7 +56,7 @@
BOOL CServoApp::InitInstance()
{
- // 如果一个运行在 Windows XP 上的应用程序清单指定要
+ // TODO: 调用 AfxInitRichEdit2() 以初始化 richedit2 库。\n" // 如果一个运行在 Windows XP 上的应用程序清单指定要
// 使用 ComCtl32.dll 版本 6 或更高版本来启用可视化方式,
//则需要 InitCommonControlsEx()。 否则,将无法创建窗口。
INITCOMMONCONTROLSEX InitCtrls;
@@ -99,6 +103,7 @@
// 注册控件
CServoGraph::RegisterWndClass();
CVerticalLine::RegisterWndClass();
+ CHorizontalLine::RegisterWndClass();
CEqsGraphWnd::RegisterWndClass();
CMapPosWnd::RegisterWndClass();
CHmTab::RegisterWndClass();
@@ -111,6 +116,10 @@
// 初始化 GDI+
InitGDIPlus();
+
+
+ // 初始化 MFC RichEdit 控件
+ AfxInitRichEdit2();
// 初始化报警管理器
@@ -126,37 +135,64 @@
AfxMessageBox(errorMsg, MB_ICONERROR);
return FALSE;
}
- AlarmManager::getInstance().insertMockData();
+ // 初始化搬运记录管理库
+ 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;
+ }
- // 初始化生产履历管理器
- //try {
- // if (!ProductionLogManager::getInstance().initProductionTable()) {
- // AfxMessageBox("初始化生产履历管理器失败!");
- // return FALSE;
- // }
- //}
- //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;
+ }
- // 初始化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 {
+ 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;
+ }
CServoDlg dlg;
@@ -191,6 +227,7 @@
int CServoApp::ExitInstance()
{
+ CControlJobManagerDlg::FreeState();
m_model.term();
HSMS_Term();
RX_Term();
@@ -201,11 +238,21 @@
// 销毁报警表
AlarmManager::getInstance().termAlarmTable();
- // 销毁生产表
- ProductionLogManager::getInstance().termProductionTable();
+ // 销毁搬运记录管理库
+ TransferManager::getInstance().termTransferTable();
- // 销毁SECS运行设置管理库
- SECSRuntimeManager::getInstance().termRuntimeSetting();
+ // 销毁运行日志
+ SystemLogManager::getInstance().termSystemLogTable();
+
+ // 销毁用户表
+#if !defined(_DEBUG)
+// 清除 UserManager 的无操作检测
+ UserManager::getInstance().terminateIdleDetection();
+ KillTimer(1);
+#endif
+
+ // 销毁配方表
+ RecipeManager::getInstance().termRecipeTable();
return CWinApp::ExitInstance();
}
--
Gitblit v1.9.3