From 62bec5118f5e5fe750017cf2f12d4a428ab092df Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期三, 17 九月 2025 18:06:30 +0800
Subject: [PATCH] 1.继续CControlJobManagerDlg的功能实现;

---
 SourceCode/Bond/Servo/CControlJobManagerDlg.cpp |   38 ++++++++++++++++++--------------------
 1 files changed, 18 insertions(+), 20 deletions(-)

diff --git a/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp b/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
index da7db7e..6676d30 100644
--- a/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
+++ b/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
@@ -20,10 +20,10 @@
 
 CControlJobManagerDlg::~CControlJobManagerDlg()
 {
-	for (auto pj : m_processJobs) {
-		delete pj;
+	for (auto item : m_pjWarps) {
+		delete (SERVO::CProcessJob*)item.pj;
 	}
-	m_processJobs.clear();
+	m_pjWarps.clear();
 
 	if (m_pControlJob != nullptr) {
 		delete m_pControlJob;
@@ -60,7 +60,7 @@
 		}
 		else if (1 == code) {
 			if (contextType == 1) {
-				UpProcessJobId((SERVO::CProcessJob*)pContext);
+				UpProcessJobId((PJWarp*)pContext);
 			}
 		}
 	};
@@ -186,9 +186,9 @@
 	HTREEITEM hRoot = m_tree.InsertItem(m_pControlJob->id().c_str(), 0, 0);
 	m_tree.SetItemData(hRoot, (DWORD_PTR)m_pControlJob);
 	m_tree.SetItemState(hRoot, 0, TVIS_STATEIMAGEMASK);
-	for (auto pj : m_processJobs) {
-		HTREEITEM hItem = m_tree.InsertItem(pj->id().c_str(), 0, 0, hRoot);
-		m_tree.SetItemData(hItem, (DWORD_PTR)pj);
+	for (auto& item : m_pjWarps) {
+		HTREEITEM hItem = m_tree.InsertItem(((SERVO::CProcessJob*)item.pj)->id().c_str(), 0, 0, hRoot);
+		m_tree.SetItemData(hItem, (DWORD_PTR)&item);
 		m_tree.SetItemState(hItem, INDEXTOSTATEIMAGEMASK(false ? 2 : 1), TVIS_STATEIMAGEMASK);
 	}
 	m_tree.Expand(hRoot, TVE_EXPAND);
@@ -221,19 +221,13 @@
 			m_pages[2]->ShowWindow(SW_SHOW);
 		}
 		else if (m_tree.GetParentItem(hParent) == nullptr) {
-			SERVO::CProcessJob* pj = (SERVO::CProcessJob*)m_tree.GetItemData(hSel);
+			PJWarp* pjWarp = (PJWarp*)m_tree.GetItemData(hSel);
 			m_pages[0]->ShowWindow(SW_HIDE);
 			m_pages[1]->ShowWindow(SW_SHOW);
 			m_pages[2]->ShowWindow(SW_HIDE);
-			m_pages[1]->SetContext(pj, 1);
+			m_pages[1]->SetContext(pjWarp, 1);
 
-			std::vector<std::string> names;
-			for (auto item : m_processJobs) {
-				if (item != pj) {
-					names.push_back(item->id());
-				}
-			}
-			((CCjPage2*)m_pages[1])->SetExclusionNames(names);
+			((CCjPage2*)m_pages[1])->SetPjWarps(m_pjWarps);
 		}
 		else {
 			// 鏈夌鍏� 鈫� 绗笁灞傚強浠ヤ笅 鈫� Glass
@@ -262,7 +256,10 @@
 	for (int i = 0; i < 4; i++) {
 		sprintf_s(szBuffer, 256, "PJ%03d", i + 1);
 		SERVO::CProcessJob* pj = new SERVO::CProcessJob(std::string(szBuffer));
-		m_processJobs.push_back(pj);
+		PJWarp pjWarp;
+		pjWarp.pj = pj;
+		pjWarp.port = -1;
+		m_pjWarps.push_back(pjWarp);
 	}
 }
 
@@ -274,7 +271,7 @@
 	GetDlgItem(IDC_BUTTON_APPLY)->EnableWindow(FALSE);
 }
 
-void CControlJobManagerDlg::UpProcessJobId(SERVO::CProcessJob* pJob)
+void CControlJobManagerDlg::UpProcessJobId(PJWarp* pjWarp)
 {
 	// 鏇存柊鏍戞帶浠�
 	// 閬嶅巻鏍硅妭鐐�
@@ -284,8 +281,9 @@
 		HTREEITEM hChild = m_tree.GetChildItem(hRoot);
 		while (hChild) {
 			DWORD_PTR data = m_tree.GetItemData(hChild);
-			if ((void*)data == pJob) {
-				m_tree.SetItemText(hChild, pJob->id().c_str());
+			if ((void*)data == pjWarp) {
+				SERVO::CProcessJob* pj = (SERVO::CProcessJob*)pjWarp->pj;
+				m_tree.SetItemText(hChild, pj->id().c_str());
 				return; // 鎵惧埌灏辫繑鍥�
 			}
 			hChild = m_tree.GetNextSiblingItem(hChild);

--
Gitblit v1.9.3