From d5c8d6545efe0ab2026a4127fde0fa2bad659ccd Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期三, 06 八月 2025 14:45:52 +0800
Subject: [PATCH] 1.实现EAP中ProceedWithCarrier和CarrierRelease的功能模拟及测试;

---
 SourceCode/Bond/Servo/PortConfigurationDlg.cpp |  220 +++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 158 insertions(+), 62 deletions(-)

diff --git a/SourceCode/Bond/Servo/PortConfigurationDlg.cpp b/SourceCode/Bond/Servo/PortConfigurationDlg.cpp
index b941707..8b0f98f 100644
--- a/SourceCode/Bond/Servo/PortConfigurationDlg.cpp
+++ b/SourceCode/Bond/Servo/PortConfigurationDlg.cpp
@@ -12,6 +12,9 @@
 #include "ServoCommo.h"
 
 
+
+#define CHECKBOX_ALL_ID        0x1234
+
 // CPortConfigurationDlg 瀵硅瘽妗�
 
 IMPLEMENT_DYNAMIC(CPortConfigurationDlg, CDialogEx)
@@ -24,10 +27,18 @@
     m_pPort[1] = dynamic_cast<SERVO::CLoadPort*>(theApp.m_model.m_master.getEquipment(EQ_ID_LOADPORT2));
     m_pPort[2] = dynamic_cast<SERVO::CLoadPort*>(theApp.m_model.m_master.getEquipment(EQ_ID_LOADPORT3));
     m_pPort[3] = dynamic_cast<SERVO::CLoadPort*>(theApp.m_model.m_master.getEquipment(EQ_ID_LOADPORT4));
+    m_nCurSelPort = -1;
+    m_pCheckBox = nullptr;
+    m_bCheckedAll = FALSE;
 }
 
 CPortConfigurationDlg::~CPortConfigurationDlg()
 {
+}
+
+void CPortConfigurationDlg::setCurSelPort(int sel)
+{
+    m_nCurSelPort = sel;
 }
 
 int CPortConfigurationDlg::GetLoadPortEqID(const std::string& strPortName)
@@ -57,19 +68,21 @@
             continue;
         }
 
-        SERVO::CGlass* pGlass = dynamic_cast<SERVO::CGlass*>(pSlot->getContext());
-        int nRow = i + 1;
 
         // 璁剧疆 Panel ID 鍜屽嬀閫夋
-        CGridCellCheck* pCheck = static_cast<CGridCellCheck*>(m_wndGrid.GetCell(nRow, 1));
-        if (pCheck && pGlass) {
-            pCheck->SetCheck(pSlot->isEnable() ? TRUE : FALSE);
-            pCheck->SetText(pGlass ? pGlass->getID().c_str() : _T(""));
+        SERVO::CGlass* pGlass = dynamic_cast<SERVO::CGlass*>(pSlot->getContext());
+        int nRow = i + 1;
+        if (pGlass != nullptr) {
+            m_wndGrid.SetItemState(nRow, 0, GVIS_READONLY);
+            m_wndGrid.SetItemText(nRow, 0, pSlot->getName().c_str());
+            m_wndGrid.SetCellType(nRow, 1, RUNTIME_CLASS(CGridCellCheck));
+            CGridCellCheck* pCheck = dynamic_cast<CGridCellCheck*>(m_wndGrid.GetCell(nRow, 1));
+            ASSERT(pCheck);
+            pCheck->SetCheck(pGlass->isScheduledForProcessing());
+            pCheck->SetText(pGlass->getID().c_str());
         }
-		else {
-			pCheck->SetCheck(FALSE);
-			pCheck->SetText(_T(""));
-		}
+        m_wndGrid.SetItemData(nRow, 0, (LPARAM)pGlass);
+
 
         // 鍥炲~ Job 淇℃伅锛堝彧鍙栫涓�涓湁鏁� Glass锛�
         if (!bJobInfoSet && pGlass) {
@@ -83,6 +96,7 @@
             }
         }
     }
+    m_pCheckBox->SetCheck(IsCheckedAll() ? BST_CHECKED : BST_UNCHECKED);
 }
 
 void CPortConfigurationDlg::InitGrid()
@@ -115,7 +129,8 @@
     m_wndGrid.SetColumnWidth(nColIdx, 50);
     m_wndGrid.SetItemText(0, nColIdx++, _T("Slot ID"));
     m_wndGrid.SetColumnWidth(nColIdx, 60);
-    m_wndGrid.SetItemText(0, nColIdx++, _T("鍚敤"));
+    m_wndGrid.SetItemText(0, nColIdx++, _T("Glass ID"));
+
 
     // 璁剧疆琛屼负鏍峰紡
     m_wndGrid.SetFixedRowSelection(FALSE);
@@ -139,32 +154,16 @@
         m_wndGrid.SetRowHeight(i, nEachRowHeight);
     }
 
-    FillGrid();
-}
-
-void CPortConfigurationDlg::FillGrid()
-{
-    //CStringArray recipeOptions;
-    //recipeOptions.Add(_T("Recipe A"));
-    //recipeOptions.Add(_T("Recipe B"));
-    //recipeOptions.Add(_T("Recipe C"));
-
-    for (int i = 1; i < 9; ++i) {
-        CString strIndex;
-        strIndex.Format(_T("%d"), i);
-        m_wndGrid.SetItemText(i, 0, strIndex);
-        m_wndGrid.SetItemState(i, 0, GVIS_READONLY);
-
-        // Checkbox
-        m_wndGrid.SetCellType(i, 1, RUNTIME_CLASS(CGridCellCheck));
-        CGridCellCheck* pCheck = static_cast<CGridCellCheck*>(m_wndGrid.GetCell(i, 1));
-        if (pCheck) {
-            pCheck->SetCheck(FALSE);
-        }
-    }
-
-    m_wndGrid.Invalidate();
-    m_wndGrid.UpdateWindow();
+    CRect rect;
+    BOOL bOK = m_wndGrid.GetCellRect(0, 1, rect);
+    m_pCheckBox = new CCustomCheckBox();
+    m_pCheckBox->Create(_T("閫夋嫨鎵�鏈�"),
+        WS_CHILD | WS_VISIBLE | BS_AUTOCHECKBOX, // 鑷姩鍕鹃��
+        CRect(0, 0, 150, 32), &m_wndGrid, CHECKBOX_ALL_ID);
+    m_pCheckBox->SetFont(GetFont());
+    m_pCheckBox->MoveWindow(rect.left + 5, rect.top + 3, 150, rect.Height() - 6);
+    m_pCheckBox->SetBackgroundColor(g_nGridFixCellColor);
+    m_pCheckBox->SetNotifyHwnd(GetSafeHwnd());
 }
 
 void CPortConfigurationDlg::DoDataExchange(CDataExchange* pDX)
@@ -180,6 +179,10 @@
 BEGIN_MESSAGE_MAP(CPortConfigurationDlg, CDialogEx)
     ON_CBN_SELCHANGE(IDC_COMBO_PORT, &CPortConfigurationDlg::OnSelchangeComboPort)
     ON_BN_CLICKED(IDC_BUTTON_APPLY, &CPortConfigurationDlg::OnBnClickedButtonApply)
+    ON_MESSAGE(WM_CHECKBOX_STATE_CHANGED, &CPortConfigurationDlg::OnCheckAllClicked)
+    ON_WM_DESTROY()
+    ON_BN_CLICKED(IDC_BUTTON_PROCESS_START, &CPortConfigurationDlg::OnBnClickedButtonProcessStart)
+    ON_BN_CLICKED(IDC_BUTTON_PROCESS_CANCEL, &CPortConfigurationDlg::OnBnClickedButtonProcessCancel)
 END_MESSAGE_MAP()
 
 
@@ -195,7 +198,13 @@
     for (const auto& item : ports) {
         m_comboPort.AddString(item);
     }
-    m_comboPort.SetCurSel(0); // 榛樿閫夋嫨绗竴涓鍙�
+    if (0 <= m_nCurSelPort && m_nCurSelPort <= 3) {
+        m_comboPort.SetCurSel(m_nCurSelPort);
+        m_comboPort.EnableWindow(FALSE);
+    }
+    else {
+        m_comboPort.SetCurSel(0);
+    }
 
     // 鍒濆鍖栭厤鏂逛笅鎷夋鍐呭
     std::vector<std::string> vecRecipe = RecipeManager::getInstance().getAllPPID();
@@ -216,7 +225,20 @@
 	LoadPortConfigToUI(m_pPort[0]);     // 榛樿鍔犺浇绗竴涓鍙g殑閰嶇疆
 
 	// 璁剧疆瀵硅瘽妗嗘爣棰�
-	SetWindowText(_T("Port Configuration"));
+    BOOL bAutoPopup = 0 <= m_nCurSelPort && m_nCurSelPort <= 3;
+    if (bAutoPopup) {
+        CString strTitle;
+        strTitle.Format(_T("%s Configuration"), ports[m_nCurSelPort]);
+        SetWindowText(strTitle);
+    }
+    else {
+        SetWindowText(_T("Port Configuration"));
+    }
+
+
+    // Porcess Start / Process Cancel 鎸夐挳鐘舵��
+    GetDlgItem(IDC_BUTTON_PROCESS_START)->EnableWindow(FALSE);
+    GetDlgItem(IDC_BUTTON_PROCESS_CANCEL)->EnableWindow(FALSE);
 
 	return TRUE;  // return TRUE unless you set the focus to a control
 	// 寮傚父: OCX 灞炴�ч〉搴旇繑鍥� FALSE
@@ -231,6 +253,12 @@
 	}
 
 	// 鍔犺浇閫変腑绔彛鐨勯厤缃埌 UI
+    for (int i = 1; i <= 8; i++) {
+        m_wndGrid.SetItemText(i, 0, "");
+        m_wndGrid.SetItemText(i, 1, "");
+        m_wndGrid.SetCellType(i, 1, RUNTIME_CLASS(CGridCellNumeric));
+    }
+    m_wndGrid.Invalidate();
 	LoadPortConfigToUI(m_pPort[selPort]);
 }
 
@@ -289,35 +317,103 @@
 	}
 
     // 鑾峰彇 Grid 琛ㄦ牸涓� Slot 鐘舵�侊紙绗�1~8琛岋級
-    for (int i = 1; i <= 8; ++i) {
-        SERVO::SlotConfig slot;
-        slot.nSlotID = i;
+    for (int i = 1; i <= SLOT_MAX; ++i) {
+        SERVO::CGlass* pGlass = (SERVO::CGlass*)m_wndGrid.GetItemData(i, 0);
+        if (pGlass != nullptr) {
+            CGridCellCheck* pCheck = dynamic_cast<CGridCellCheck*>(m_wndGrid.GetCell(i, 1));
+            ASSERT(pCheck);
+            pGlass->setScheduledForProcessing(pCheck->GetCheck());
+            pGlass->setType(static_cast<SERVO::MaterialsType>(config.nMaterialType));
 
-        CGridCellCheck* pCheck = static_cast<CGridCellCheck*>(m_wndGrid.GetCell(i, 1));
-        if (pCheck) {
-            slot.isEnabled = pCheck->GetCheck();
+            SERVO::CJobDataS* pJobDataS = pGlass->getJobDataS();
+            pJobDataS->setLotId(config.strLotID.c_str());
+            pJobDataS->setProductId(config.strProductID.c_str());
+            pJobDataS->setOperationId(config.strOperationID.c_str());
+            pJobDataS->setMaterialsType(config.nMaterialType);
+
+            RecipeInfo stRecipeInfo = RecipeManager::getInstance().getRecipeByPPID(config.strRecipe);
+            std::vector<DeviceRecipe> vecRecipeInfo = stRecipeInfo.vecDeviceList;
+
+            for (const auto& info : vecRecipeInfo) {
+                const std::string& name = info.strDeviceName;
+                short nRecipeID = (short)info.nRecipeID;
+
+                if (name == EQ_NAME_EFEM) {
+                    pJobDataS->setDeviceRecipeId(0, nRecipeID);
+                }
+                else if (name == EQ_NAME_BONDER1) {
+                    pJobDataS->setDeviceRecipeId(1, nRecipeID);
+                }
+                else if (name == EQ_NAME_BONDER2) {
+                    pJobDataS->setDeviceRecipeId(2, nRecipeID);
+                }
+                else if (name == EQ_NAME_BAKE_COOLING) {
+                    pJobDataS->setDeviceRecipeId(3, nRecipeID);
+                }
+                else if (name == EQ_NAME_VACUUMBAKE) {
+                    pJobDataS->setDeviceRecipeId(4, nRecipeID);
+                }
+                else if (name == EQ_NAME_MEASUREMENT) {
+                    pJobDataS->setDeviceRecipeId(5, nRecipeID);
+                }
+            }
         }
-
-        config.vecSlot.push_back(slot);
     }
 
-    int nEqID = GetLoadPortEqID(config.strPortName);
-    if (nEqID < 0) {
-        AfxMessageBox(_T("鏈煡鐨勭鍙e悕绉帮紒"));
-        return;
+    GetDlgItem(IDC_BUTTON_PROCESS_START)->EnableWindow(TRUE);
+    GetDlgItem(IDC_BUTTON_PROCESS_CANCEL)->EnableWindow(TRUE);
+}
+
+void CPortConfigurationDlg::OnDestroy()
+{
+    CDialogEx::OnDestroy();
+
+    if (m_pCheckBox != nullptr) {
+        m_pCheckBox->DestroyWindow();
+        delete m_pCheckBox;
+        m_pCheckBox = nullptr;
+    }
+}
+
+LRESULT  CPortConfigurationDlg::OnCheckAllClicked(WPARAM wParam, LPARAM lParam)
+{
+    UINT ctrlID = (UINT)wParam;
+    BOOL bChecked = (BOOL)lParam;
+    for (int i = 1; i <= SLOT_MAX; ++i) {
+        CGridCellCheck* pCheck = dynamic_cast<CGridCellCheck*>(m_wndGrid.GetCell(i, 1));
+        if (pCheck != nullptr) {
+            pCheck->SetCheck(bChecked);
+        }
     }
 
-    SERVO::CLoadPort* pPort = dynamic_cast<SERVO::CLoadPort*>(theApp.m_model.m_master.getEquipment(nEqID));
-    if (!pPort) {
-        AfxMessageBox(_T("鎵句笉鍒板搴旂殑 LoadPort 璁惧锛�"));
-        return;
+
+    return 0;
+}
+
+BOOL CPortConfigurationDlg::IsCheckedAll()
+{
+    for (int i = 1; i <= SLOT_MAX; ++i) {
+        CGridCellCheck* pCheck = dynamic_cast<CGridCellCheck*>(m_wndGrid.GetCell(i, 1));
+        if (pCheck != nullptr) {
+            if (!pCheck->GetCheck()) return FALSE;
+        }
     }
 
-    // 搴旂敤閰嶇疆锛堜緥濡傛祴璇曠敓鎴愮幓鐠冿級
-    if (pPort->testGenerateGlassListFromConfig(config) < 0) {
-		AfxMessageBox(_T("Failed to generate glass list from configuration!"));
-        return;
-	}
+    return TRUE;
+}
 
-    OnOK();
-}
\ No newline at end of file
+void CPortConfigurationDlg::OnBnClickedButtonProcessStart()
+{
+    int selPort = (0 <= m_nCurSelPort && m_nCurSelPort <= 3) ? m_nCurSelPort
+        : m_comboPort.GetCurSel();
+    if (selPort < 0 || selPort >= 4) return;
+    m_pPort[selPort]->sendCassetteCtrlCmd(CCC_PROCESS_START, nullptr, 0, 0, 0, nullptr, nullptr);
+}
+
+void CPortConfigurationDlg::OnBnClickedButtonProcessCancel()
+{
+    int selPort = (0 <= m_nCurSelPort && m_nCurSelPort <= 3) ? m_nCurSelPort
+        : m_comboPort.GetCurSel();
+    if (selPort < 0 || selPort >= 4) return;
+    m_pPort[selPort]->sendCassetteCtrlCmd(CCC_PROCESS_CANCEL, nullptr, 0, 0, 0, nullptr, nullptr);
+}

--
Gitblit v1.9.3