From 7034036d6ab7163a6ea0e5d712ba86d6cd9591bc Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期四, 24 七月 2025 16:37:27 +0800
Subject: [PATCH] 1. 根据文档更新JobDataS

---
 SourceCode/Bond/Servo/CPageGraph2.cpp |   71 ++++++++++++++---------------------
 1 files changed, 29 insertions(+), 42 deletions(-)

diff --git a/SourceCode/Bond/Servo/CPageGraph2.cpp b/SourceCode/Bond/Servo/CPageGraph2.cpp
index b16eae2..eca3e9e 100644
--- a/SourceCode/Bond/Servo/CPageGraph2.cpp
+++ b/SourceCode/Bond/Servo/CPageGraph2.cpp
@@ -9,6 +9,7 @@
 #include "CEquipmentPage1.h"
 #include "CEquipmentPage2.h"
 #include "CEquipmentPage3.h"
+#include "CPageLinkSignal.h"
 #include "CPagePortProperty.h"
 #include "CPagePortStatus.h"
 #include "CPageCassetteCtrlCmd.h"
@@ -126,11 +127,11 @@
 		ASSERT(pItem);
 		SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 
-		CHMPropertyDlg dlg(pEquipment->getName().c_str(), 658, 788);
+		CHMPropertyDlg dlg(pEquipment->getName().c_str(), 1258, 788);
 
-		CEquipmentPage1* pPage1 = new CEquipmentPage1();
+		CPageLinkSignal* pPage1 = new CPageLinkSignal();
 		pPage1->setEquipment(pEquipment);
-		pPage1->Create(IDD_PAGE_EQUIPMENT1);
+		pPage1->Create(IDD_PAGE_LINK_SIGNAL);
 		dlg.addPage(pPage1, "Link Signal");
 
 		if (_strcmpi(pEquipment->getClassName(), "CLoadPort") == 0) {
@@ -148,7 +149,7 @@
 		CEquipmentPage2* pPage2 = new CEquipmentPage2();
 		pPage2->setEquipment(pEquipment);
 		pPage2->Create(IDD_PAGE_EQUIPMENT2);
-		dlg.addPage(pPage2, "Glass");
+		dlg.addPage(pPage2, "Slots");
 
 		if (pEquipment->getID() == EQ_ID_EFEM) {
 			CEquipmentPage3* pPage3 = new CEquipmentPage3();
@@ -158,7 +159,9 @@
 		}
 
 		if (pEquipment->getID() == EQ_ID_LOADPORT1
-			|| pEquipment->getID() == EQ_ID_LOADPORT2) {
+			|| pEquipment->getID() == EQ_ID_LOADPORT2
+			|| pEquipment->getID() == EQ_ID_LOADPORT3
+			|| pEquipment->getID() == EQ_ID_LOADPORT4) {
 			CPageCassetteCtrlCmd* pPage = new CPageCassetteCtrlCmd();
 			pPage->setEquipment(pEquipment);
 			pPage->Create(IDD_PAGE_CASSETTE_CTRL_CMD);
@@ -209,31 +212,7 @@
 
 		// 娴嬭瘯
 		else if (nCmd == ID_EQSGRAPHITEM_TEST1) {
-			BOOL bTestGenerate = FALSE;
-			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
-			if (pEquipment->getID() == EQ_ID_LOADPORT1 && !pEquipment->hasGlass()) {
-				((SERVO::CLoadPort*)pEquipment)->testGenerateGlassList(SERVO::MaterialsType::G1, 
-					"P20250320G1X", 1);
-				bTestGenerate = TRUE;
-			}
-			else if (pEquipment->getID() == EQ_ID_LOADPORT2 && !pEquipment->hasGlass()) {
-				((SERVO::CLoadPort*)pEquipment)->testGenerateGlassList(SERVO::MaterialsType::G2,
-					"P20250320G2X", 1);
-				bTestGenerate = TRUE;
-			}
-			
-			if (!bTestGenerate) {
-				SERVO::CRobotTask* pTask = theApp.m_model.getMaster().getActiveRobotTask();
-				if (pTask != nullptr) {
-					SERVO::CGlass* pGlass = (SERVO::CGlass*)pTask->getContext();
-					SERVO::CJobDataB* pJobDataB = pGlass->getJobDataB();
-					SERVO::CJobDataS* pJobDataS = pGlass->getJobDataS();
-					if (pJobDataB != nullptr && pJobDataS != nullptr) {
-						pEquipment->onFetchedOutJob(0, pJobDataB);
-						pEquipment->onSentOutJob(0, pJobDataS);
-					}
-				}
-			}
+
 		}
 		else if (nCmd == ID_EQSGRAPHITEM_TEST2) {
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
@@ -241,12 +220,12 @@
 			if (pArm != nullptr) {
 				SERVO::CGlass* pGlass = pArm->getAnyGlass();
 				if (pGlass != nullptr) {
-					SERVO::CJobDataB* pJobDataB = pGlass->getJobDataB();
 					SERVO::CJobDataS* pJobDataS = pGlass->getJobDataS();
-					if (pJobDataB != nullptr && pJobDataS != nullptr) {
+					if (pJobDataS != nullptr) {
 						pEquipment->onReceivedJob(0, pJobDataS);
 						Sleep(600);
-						pEquipment->onStoredJob(0, pJobDataB);
+						SERVO::CJobDataB jobDataB;
+						pEquipment->onStoredJob(0, &pJobDataS->getJobDataB(jobDataB));
 					}
 				}
 			}
@@ -265,10 +244,14 @@
 		else if (nCmd == ID_EQSGRAPHITEM_TEST4) {
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 			if (pEquipment != nullptr) {
-				pEquipment->setLinkSignal(0, SIGNAL_UPSTREAM_INLINE, TRUE);
-				pEquipment->setLinkSignal(0, SIGNAL_UPSTREAM_TROUBLE, FALSE);
-				pEquipment->setLinkSignal(0, SIGNAL_INTERLOCK, TRUE);
-				pEquipment->setLinkSignal(0, SIGNAL_SEND_ABLE, TRUE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_UPSTREAM_INLINE, TRUE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_UPSTREAM_TROUBLE, FALSE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_INTERLOCK, TRUE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_SEND_ABLE, TRUE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_UPSTREAM_INLINE, TRUE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_UPSTREAM_TROUBLE, FALSE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_INTERLOCK, TRUE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_SEND_ABLE, TRUE);
 			}
 
 			if (pEquipment != nullptr && (pEquipment->getID() == EQ_ID_Bonder1
@@ -284,10 +267,14 @@
 		else if (nCmd == ID_EQSGRAPHITEM_TEST5) {
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 			if (pEquipment != nullptr) {
-				pEquipment->setLinkSignal(0, SIGNAL_UPSTREAM_INLINE, TRUE);
-				pEquipment->setLinkSignal(0, SIGNAL_UPSTREAM_TROUBLE, TRUE);
-				pEquipment->setLinkSignal(0, SIGNAL_INTERLOCK, TRUE);
-				pEquipment->setLinkSignal(0, SIGNAL_SEND_ABLE, FALSE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_UPSTREAM_INLINE, TRUE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_UPSTREAM_TROUBLE, TRUE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_INTERLOCK, TRUE);
+				pEquipment->setLinkSignalUpstream(0, SIGNAL_SEND_ABLE, FALSE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_UPSTREAM_INLINE, TRUE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_UPSTREAM_TROUBLE, TRUE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_INTERLOCK, TRUE);
+				pEquipment->setLinkSignalUpstream(1, SIGNAL_SEND_ABLE, FALSE);
 			}
 		}
 		else if (nCmd == ID_EQSGRAPHITEM_TEST6) {
@@ -371,7 +358,7 @@
 
 			// 璇锋眰涓婚厤鏂瑰垪琛�
 			if (pEquipment != nullptr) {
-				pEquipment->masterRecipeListRequest(0);
+				pEquipment->masterRecipeListRequest(0, nullptr);
 			}			
 		}
 

--
Gitblit v1.9.3