From e8a27bb203fe2aff70390a5eca002d7438da9b0f Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期三, 22 十月 2025 14:24:34 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 SourceCode/Bond/Servo/CControlJobManagerDlg.cpp |   60 ++++++++++++++++++++++++++++++++++++++++++++++--------------
 1 files changed, 46 insertions(+), 14 deletions(-)

diff --git a/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp b/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
index a791c3c..2e2d92c 100644
--- a/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
+++ b/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
@@ -78,6 +78,9 @@
 			if (contextType == 1) {
 				UpProcessJobId((PJWarp*)pContext);
 			}
+			else if (contextType == 2) {
+				UpControlJobId((SERVO::CControlJob*)pContext);
+			}
 		}
 	};
 
@@ -307,7 +310,8 @@
 			SERVO::CControlJob* cj = (SERVO::CControlJob*)m_tree.GetItemData(hSel);
 			ASSERT(m_pages.size() == 3);
 			if (0 == ShowPage(2)) {
-
+				SERVO::CControlJob* pControlJob = (SERVO::CControlJob*)m_tree.GetItemData(hSel);
+				m_pages[2]->SetContext(pControlJob, 2);
 			}
 		}
 		else if (m_tree.GetParentItem(hParent) == nullptr) {
@@ -406,6 +410,20 @@
 	}
 }
 
+void CControlJobManagerDlg::UpControlJobId(SERVO::CControlJob* pControlJob)
+{
+	// 鏇存柊鏍戞帶浠�
+	// 閬嶅巻鏍硅妭鐐�
+	HTREEITEM hRoot = m_tree.GetRootItem();
+	if (hRoot != nullptr) {
+		DWORD_PTR data = m_tree.GetItemData(hRoot);
+		if ((void*)data == pControlJob) {
+			m_tree.SetItemText(hRoot, pControlJob->id().c_str());
+			return; // 鎵惧埌灏辫繑鍥�
+		}
+	}
+}
+
 void CControlJobManagerDlg::LoadState()
 {
 	if (!m_bHasState) return;
@@ -454,11 +472,11 @@
 	}
 
 
-	SERVO::CLoadPort* pPort[4];
-	pPort[0] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT1);
-	pPort[1] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT2);
-	pPort[2] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT3);
-	pPort[3] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT4);
+	SERVO::CLoadPort* pPorts[4];
+	pPorts[0] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT1);
+	pPorts[1] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT2);
+	pPorts[2] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT3);
+	pPorts[3] = (SERVO::CLoadPort*)master.getEquipment(EQ_ID_LOADPORT4);
 
 	bool bProcessStart[] = {false, false, false, false};
 	std::vector<SERVO::CProcessJob*> pjs;
@@ -475,15 +493,25 @@
 		if (!bCheck) continue;
 
 		SERVO::CProcessJob* pScr = (SERVO::CProcessJob*)item.pj;
+		pScr->setPjWarp(item);
+		pScr->setLotId("LotID1");
+		pScr->setProductId("ProductId1");
+		pScr->setOperationId("OperationId");
+		pScr->setRecipe(SERVO::RecipeMethod::NoTuning, pScr->recipeSpec());
+
 		SERVO::CProcessJob * pj = new SERVO::CProcessJob(pScr->id());
+		pj->setPjWarp(item);
+		pj->setLotId("LotID1");
+		pj->setProductId("ProductId1");
+		pj->setOperationId("OperationId");
 		pj->setRecipe(SERVO::RecipeMethod::NoTuning, pScr->recipeSpec());
 
 		std::vector<SERVO::CarrierSlotInfo> carriers;
 		SERVO::CarrierSlotInfo csi;
-		csi.carrierId = pPort[item.port]->getCassetteId();
+		csi.carrierId = pPorts[item.port]->getCassetteId();
 		for (int i = 0; i < 8; i++) {
 			if (item.checkSlot[i]) {
-				SERVO::CGlass* pGlass = pPort[item.port]->getGlassFromSlot(i+1);
+				SERVO::CGlass* pGlass = pPorts[item.port]->getGlassFromSlot(i+1);
 				if (pGlass != nullptr) {
 					csi.slots.push_back(i + 1);
 				}
@@ -558,12 +586,16 @@
 
 	// 鎴愬姛锛岃鍒ゆ柇锛屽悓姝ュ埌slot鐨刧lass涓紝绫诲瀷绛�
 	for (int p = 0; p < 4; p++) {
+		if (m_pjWarps[p].port == -1) continue;
+		ASSERT(0 <= m_pjWarps[p].port && m_pjWarps[p].port <= 3);
+
+		SERVO::CLoadPort* pLoadPort = pPorts[m_pjWarps[p].port];
 		for (int i = 0; i < SLOT_MAX; ++i) {
-			SERVO::CSlot* pSlot = pPort[p]->getSlot(i);
+			SERVO::CSlot* pSlot = pLoadPort->getSlot(i);
 			if (!pSlot) {
 				continue;
 			}
-
+			
 			// 璁剧疆 Panel ID 鍜屽嬀閫夋
 			SERVO::CProcessJob* pj = (SERVO::CProcessJob*)m_pjWarps[p].pj;
 			int nRecipeID = RecipeManager::getInstance().getIdByPPID(pj->recipeSpec());
@@ -576,9 +608,9 @@
 				pGlass->setType(static_cast<SERVO::MaterialsType>(m_pjWarps[p].material[i]));
 
 				SERVO::CJobDataS* pJobDataS = pGlass->getJobDataS();
-				pJobDataS->setLotId("LotID1");
-				pJobDataS->setProductId("ProductId1");
-				pJobDataS->setOperationId("OPerationId");
+				pJobDataS->setLotId(pj->getLotId().c_str());
+				pJobDataS->setProductId(pj->getProductId().c_str());
+				pJobDataS->setOperationId(pj->getOperationId().c_str());
 				pJobDataS->setMaterialsType(m_pjWarps[p].material[i]);
 				pJobDataS->setMasterRecipe(nRecipeID);
 
@@ -613,7 +645,7 @@
 	// process start
 	for (int p = 0; p < 4; p++) {
 		if (bProcessStart[p]) {
-			pPort[p]->sendCassetteCtrlCmd(CCC_PROCESS_START, nullptr, 0, 0, 0, nullptr, nullptr);
+			pPorts[p]->sendCassetteCtrlCmd(CCC_PROCESS_START, nullptr, 0, 0, 0, nullptr, nullptr);
 			Sleep(100);
 		}
 	}

--
Gitblit v1.9.3