From 0569c29b19e4d23f055845a167c706f11590fa2a Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期二, 19 八月 2025 15:55:00 +0800
Subject: [PATCH] 1.CControlJob和CProcessJob的序列化和反序列化;

---
 SourceCode/Bond/Servo/CPageGraph2.cpp |   83 ++++++++++++++++++++++-------------------
 1 files changed, 45 insertions(+), 38 deletions(-)

diff --git a/SourceCode/Bond/Servo/CPageGraph2.cpp b/SourceCode/Bond/Servo/CPageGraph2.cpp
index 6ef9a57..cb4d449 100644
--- a/SourceCode/Bond/Servo/CPageGraph2.cpp
+++ b/SourceCode/Bond/Servo/CPageGraph2.cpp
@@ -8,8 +8,12 @@
 #include "CHMPropertyDlg.h"
 #include "CEquipmentPage1.h"
 #include "CEquipmentPage2.h"
+#include "CEquipmentPage3.h"
+#include "CPageLinkSignal.h"
 #include "CPagePortProperty.h"
+#include "CPagePortStatus.h"
 #include "CPageCassetteCtrlCmd.h"
+#include "CJobDataB.h"
 
 
 // CPageGraph2 瀵硅瘽妗�
@@ -62,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());
 					}
 				}
 			}
@@ -123,22 +127,41 @@
 		ASSERT(pItem);
 		SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
 
-		CHMPropertyDlg dlg(pEquipment->getName().c_str(), 600, 680);
+		CHMPropertyDlg dlg(pEquipment->getName().c_str(), 1258, 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();
+			pPage3->setEquipment(pEquipment);
+			pPage3->Create(IDD_PAGE_EQUIPMENT3);
+			dlg.addPage(pPage3, "Dispatching Mode");
+		}
 
 		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);
@@ -189,18 +212,18 @@
 
 		// 娴嬭瘯
 		else if (nCmd == ID_EQSGRAPHITEM_TEST1) {
-			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
-			if (pEquipment->getID() == EQ_ID_LOADPORT1) {
-				pEquipment->outputGlass(1);
-			}
-			pEquipment->fetchedOut("P20250320A1A2");
 		}
 		else if (nCmd == ID_EQSGRAPHITEM_TEST2) {
-			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
-			pEquipment->storedJob("P20250320A1A2");
 		}
 		else if (nCmd == ID_EQSGRAPHITEM_TEST3) {
+		}
+		else if (nCmd == ID_EQSGRAPHITEM_TEST4) {
+		}
+		else if (nCmd == ID_EQSGRAPHITEM_TEST5) {
+		}
+		else if (nCmd == ID_EQSGRAPHITEM_TEST6) {
 			SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)pItem->pData;
+
 
 			// 娴嬭瘯涓嬪彂Cim Message
 			/*
@@ -233,8 +256,7 @@
 
 			// 娴嬭瘯璁剧疆鏃堕棿
 			/*
-			if (pEquipment->getID() == EQ_ID_Bonder1
-				|| pEquipment->getID() == EQ_ID_Bonder2) {
+			if (pEquipment->getID() == EQ_ID_EFEM) {
 				CTime time = CTime::GetCurrentTime();
 				pEquipment->setDateTime((short)time.GetYear(),
 					(short)time.GetMonth(),
@@ -244,7 +266,6 @@
 					(short)time.GetSecond());
 			}
 			*/
-
 			
 			// 娴嬭瘯璁剧疆cim mode
 			/*
@@ -255,32 +276,18 @@
 			}
 			*/
 			
-			
+			/*
 			if (pEquipment->getID() == EQ_ID_Bonder1
 				|| pEquipment->getID() == EQ_ID_Bonder2) {
 				static int ii = 0; ii++;
 				pEquipment->setEqMode((ii % 5) + 1);
 			}
-			
-
-			/*
-			SERVO::CGlass* pGlass = pEquipment->getFrontGlass();
-			if (pGlass != nullptr) {
-				std::string strDescription;
-				SERVO::CPath* pPath = pGlass->getPath();
-				while (pPath != nullptr) {
-					pPath->getDescription(strDescription);
-					AfxMessageBox(strDescription.c_str());
-					pPath = pPath->getNext();
-				}
-			}
 			*/
 
-
-			// 璇锋眰涓婚厤鏂瑰垪琛�
-			if (pEquipment != nullptr) {
-				pEquipment->masterRecipeListRequest(0);
-			}			
+			static int i = 0;
+			i++;
+			static char* pszText[] = {"123", "456", "789", "abc", "def"};
+			theApp.m_model.m_hsmsPassive.requestAlarmReport(i%3, i, pszText[i%5]);
 		}
 
 
@@ -370,7 +377,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