From da96e6da0b677c6a4e96308aaecd3d619a8e4db2 Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期四, 26 六月 2025 08:46:11 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 SourceCode/Bond/Servo/CPageGraph2.cpp |  134 ++++++++++++++++++++++++++------------------
 1 files changed, 80 insertions(+), 54 deletions(-)

diff --git a/SourceCode/Bond/Servo/CPageGraph2.cpp b/SourceCode/Bond/Servo/CPageGraph2.cpp
index 83e917f..eb40345 100644
--- a/SourceCode/Bond/Servo/CPageGraph2.cpp
+++ b/SourceCode/Bond/Servo/CPageGraph2.cpp
@@ -9,7 +9,9 @@
 #include "CEquipmentPage1.h"
 #include "CEquipmentPage2.h"
 #include "CEquipmentPage3.h"
+#include "CPageLinkSignal.h"
 #include "CPagePortProperty.h"
+#include "CPagePortStatus.h"
 #include "CPageCassetteCtrlCmd.h"
 #include "CJobDataB.h"
 
@@ -64,7 +66,7 @@
 				SERVO::CEquipment* pEquipment = nullptr;
 				if (pAny->getPtrValue("ptr", (void*&)pEquipment)) {
 					if (pEquipment != nullptr) {
-						m_pEqsGraphWnd->ShowItemIndicator((DWORD_PTR)pEquipment, !pEquipment->isGlassListEmpty());
+						m_pEqsGraphWnd->ShowItemIndicator((DWORD_PTR)pEquipment, pEquipment->hasGlass());
 					}
 				}
 			}
@@ -125,19 +127,29 @@
 		ASSERT(pItem);
 		SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 
-		CHMPropertyDlg dlg(pEquipment->getName().c_str(), 600, 680);
+		CHMPropertyDlg dlg(pEquipment->getName().c_str(), 658, 788);
+
+		CPageLinkSignal* pPage1 = new CPageLinkSignal();
+		pPage1->setEquipment(pEquipment);
+		pPage1->Create(IDD_PAGE_LINK_SIGNAL);
+		dlg.addPage(pPage1, "Link Signal");
 
 		if (_strcmpi(pEquipment->getClassName(), "CLoadPort") == 0) {
-			CPagePortProperty* pPage1 = new CPagePortProperty();
-			pPage1->setLoadPort((SERVO::CLoadPort*)pEquipment);
-			pPage1->Create(IDD_PAGE_PORT_PROPERTY);
-			dlg.addPage(pPage1, "灞炴��");
+			CPagePortProperty* pPageA = new CPagePortProperty();
+			pPageA->setLoadPort((SERVO::CLoadPort*)pEquipment);
+			pPageA->Create(IDD_PAGE_PORT_PROPERTY);
+			dlg.addPage(pPageA, "灞炴��");
+
+			CPagePortStatus* pPageB = new CPagePortStatus();
+			pPageB->setLoadPort((SERVO::CLoadPort*)pEquipment);
+			pPageB->Create(IDD_PAGE_PORT_STATUS);
+			dlg.addPage(pPageB, "Status");
 		}
 
 		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();
@@ -198,22 +210,28 @@
 
 		// 娴嬭瘯
 		else if (nCmd == ID_EQSGRAPHITEM_TEST1) {
+			BOOL bTestGenerate = FALSE;
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
-			if (pEquipment->getID() == EQ_ID_LOADPORT1) {
-				((SERVO::CLoadPort*)pEquipment)->testGenerateGlassList(SERVO::MaterialsType::G1, 10, 
-					"P20250320G1X", 1);
+			if (pEquipment->getID() == EQ_ID_LOADPORT4 && !pEquipment->hasGlass()) {
+				((SERVO::CLoadPort*)pEquipment)->testGenerateGlassList(SERVO::MaterialsType::G1);
+				bTestGenerate = TRUE;
 			}
-			else if (pEquipment->getID() == EQ_ID_LOADPORT2) {
-				((SERVO::CLoadPort*)pEquipment)->testGenerateGlassList(SERVO::MaterialsType::G2, 10,
-					"P20250320G2X", 1);
+			/*
+			else if (pEquipment->getID() == EQ_ID_LOADPORT1 && !pEquipment->hasGlass()) {
+				((SERVO::CLoadPort*)pEquipment)->testGenerateGlassList(SERVO::MaterialsType::G2);
+				bTestGenerate = TRUE;
 			}
-			SERVO::CGlass* pGlass = pEquipment->getFrontGlass();
-			if (pGlass != nullptr) {
-				SERVO::CJobDataB* pJobDataB = pGlass->getJobDataB();
-				SERVO::CJobDataS* pJobDataS = pGlass->getJobDataS();
-				if (pJobDataB != nullptr && pJobDataS != nullptr) {
-					pEquipment->fetchedOutJob(pJobDataB);
-					pEquipment->onSentOutJob(0, pJobDataS);
+			*/
+			if (!bTestGenerate) {
+				SERVO::CRobotTask* pTask = theApp.m_model.getMaster().getActiveRobotTask();
+				if (pTask != nullptr) {
+					SERVO::CGlass* pGlass = (SERVO::CGlass*)pTask->getContext();
+					SERVO::CJobDataS* pJobDataS = pGlass->getJobDataS();
+					if (pJobDataS != nullptr) {
+						SERVO::CJobDataB jobDataB;
+						pEquipment->onFetchedOutJob(0, &pJobDataS->getJobDataB(jobDataB));
+						pEquipment->onSentOutJob(0, pJobDataS);
+					}
 				}
 			}
 		}
@@ -221,14 +239,14 @@
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 			SERVO::CArm* pArm = (SERVO::CArm*)pEquipment->getArm();
 			if (pArm != nullptr) {
-				SERVO::CGlass* pGlass = pArm->getFrontGlass();
+				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));
 					}
 				}
 			}
@@ -236,7 +254,7 @@
 		else if (nCmd == ID_EQSGRAPHITEM_TEST3) {
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 			if (pEquipment != nullptr) {
-				SERVO::CGlass* pGlass = pEquipment->getFrontGlass();
+				SERVO::CGlass* pGlass = pEquipment->getAnyGlass();
 				if (pGlass != nullptr) {
 					SERVO::CProcessData pd;
 					pd.setGlassId(pGlass->getID().c_str());
@@ -246,34 +264,42 @@
 		}
 		else if (nCmd == ID_EQSGRAPHITEM_TEST4) {
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
-
-			/* 娴嬭瘯 RobotCMD */
-			if (pEquipment->getID() == EQ_ID_EFEM) {
-				SERVO::CEFEM* pEFEM = (SERVO::CEFEM*)pEquipment;
-
-
-
-				SERVO::ROBOT_CMD_PARAM cmds[4];
-				cmds[0].sequenceNo = 1;
-				cmds[0].rcmd = (short)SERVO::RCMD::Move;
-				cmds[0].armNo = 1;
-				cmds[0].getPosition = 1;
-				cmds[0].putPosition = 2;
-				cmds[0].getSlotNo = 3;
-				cmds[0].putSlotNo = 4;
-				cmds[0].subCmd = 5;
-				cmds[1].sequenceNo = 2;
-				cmds[1].rcmd = (short)SERVO::RCMD::Transfer;
-				cmds[1].armNo = 2;
-				cmds[1].getPosition = 6;
-				cmds[1].putPosition = 7;
-				cmds[1].getSlotNo = 8;
-				cmds[1].putSlotNo = 9;
-				cmds[1].subCmd = 10;
-				pEFEM->robotCmds(cmds, 2);
+			if (pEquipment != nullptr) {
+				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
+				|| pEquipment->getID() == EQ_ID_Bonder2)) {
+				SERVO::CGlass* pGlass = pEquipment->getAnyGlass();
+				if (pGlass != nullptr) {
+					SERVO::CProcessData pd;
+					pd.setGlassId(pGlass->getID().c_str());
+					pEquipment->onProcessData(&pd);
+				}
+			}
+		}
+		else if (nCmd == ID_EQSGRAPHITEM_TEST5) {
+			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
+			if (pEquipment != nullptr) {
+				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) {
+			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 
 
 			// 娴嬭瘯涓嬪彂Cim Message
@@ -338,7 +364,7 @@
 			
 
 			/*
-			SERVO::CGlass* pGlass = pEquipment->getFrontGlass();
+			SERVO::CGlass* pGlass = pEquipment->getAnyGlass();
 			if (pGlass != nullptr) {
 				std::string strDescription;
 				SERVO::CPath* pPath = pGlass->getPath();
@@ -353,7 +379,7 @@
 
 			// 璇锋眰涓婚厤鏂瑰垪琛�
 			if (pEquipment != nullptr) {
-				pEquipment->masterRecipeListRequest(0);
+				pEquipment->masterRecipeListRequest(0, nullptr);
 			}			
 		}
 
@@ -444,7 +470,7 @@
 		m_pEqsGraphWnd->AddPin(pItem, OUTPIN, outPin->getName().c_str(), (DWORD_PTR)outPin);
 	}
 
-	m_pEqsGraphWnd->ShowItemIndicator((DWORD_PTR)pEquipment, !pEquipment->isGlassListEmpty());
+	m_pEqsGraphWnd->ShowItemIndicator((DWORD_PTR)pEquipment, pEquipment->hasGlass());
 }
 
 void CPageGraph2::OnTimer(UINT_PTR nIDEvent)

--
Gitblit v1.9.3