From 334b16b4abb4cbe3d1d4e4f211efd6f4468ae09f Mon Sep 17 00:00:00 2001
From: LAPTOP-SNT8I5JK\Boounion <Chenluhua@qq.com>
Date: 星期五, 19 九月 2025 15:12:52 +0800
Subject: [PATCH] 1.ControlJob和ProcessJob的中断操作,强制结批增加字符串描述原因,方便生产跟踪。
---
SourceCode/Bond/Servo/CControlJobManagerDlg.cpp | 526 ++++++++++++++++++++++++++++++++++++++++-----------------
1 files changed, 368 insertions(+), 158 deletions(-)
diff --git a/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp b/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
index 6783528..5b19f07 100644
--- a/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
+++ b/SourceCode/Bond/Servo/CControlJobManagerDlg.cpp
@@ -6,7 +6,11 @@
#include "CControlJobManagerDlg.h"
#include "afxdialogex.h"
#include "ToolUnits.h"
+#include "RecipeManager.h"
+
+bool CControlJobManagerDlg::m_bHasState = false;
+CControlJobManagerDlg::State CControlJobManagerDlg::m_state{};
// CControlJobManagerDlg 瀵硅瘽妗�
@@ -20,21 +24,27 @@
CControlJobManagerDlg::~CControlJobManagerDlg()
{
- for (auto pj : m_processJobs) {
- delete pj;
- }
- m_processJobs.clear();
- if (m_pControlJob != nullptr) {
- delete m_pControlJob;
- m_pControlJob = nullptr;
+}
+
+void CControlJobManagerDlg::FreeState()
+{
+ if (!m_bHasState) return;
+ for (auto item : m_state.pjWarps) {
+ delete (SERVO::CProcessJob*)item.pj;
}
+ m_state.pjWarps.clear();
+
+ if (m_state.pControlJob != nullptr) {
+ delete m_state.pControlJob;
+ m_state.pControlJob = nullptr;
+ }
+ m_bHasState = false;
}
void CControlJobManagerDlg::DoDataExchange(CDataExchange* pDX)
{
CDialogEx::DoDataExchange(pDX);
- DDX_Control(pDX, IDC_LIST1, m_listBox);
DDX_Control(pDX, IDC_TREE1, m_tree);
}
@@ -42,13 +52,14 @@
BEGIN_MESSAGE_MAP(CControlJobManagerDlg, CDialogEx)
ON_WM_SIZE()
ON_WM_GETMINMAXINFO()
- ON_BN_CLICKED(IDC_BUTTON_CREATE_CJ, &CControlJobManagerDlg::OnBnClickedCreateCJ)
- ON_BN_CLICKED(IDC_BUTTON_CREATE_PJ, &CControlJobManagerDlg::OnBnClickedButtonCreatePj)
- ON_CLBN_CHKCHANGE(IDC_LIST1, &CControlJobManagerDlg::OnListChkChange) // 澶嶉�夌姸鎬佸彉鏇撮�氱煡
- ON_LBN_SELCHANGE(IDC_LIST1, &CControlJobManagerDlg::OnLbnSelchangeList1)
- ON_NOTIFY(TVN_SELCHANGED, IDC_TREE1, &CControlJobManagerDlg::OnTvnSelchangedTree1)
+ ON_NOTIFY(TVN_ITEMCHANGED, IDC_TREE1, &CControlJobManagerDlg::OnTvnItemChangedTree)
+ ON_NOTIFY(NM_CLICK, IDC_TREE1, &CControlJobManagerDlg::OnTreeClick) // 鏂板
+ ON_NOTIFY(TVN_KEYDOWN, IDC_TREE1, &CControlJobManagerDlg::OnTreeKeyDown) // 鏂板
+ ON_MESSAGE(WM_AFTER_TVCHECK, &CControlJobManagerDlg::OnAfterTvCheck) // 鏂板
ON_WM_DESTROY()
ON_BN_CLICKED(IDC_BUTTON_APPLY, &CControlJobManagerDlg::OnBnClickedButtonApply)
+ ON_NOTIFY(TVN_SELCHANGING, IDC_TREE1, &CControlJobManagerDlg::OnTvnSelchangingTree1)
+ ON_BN_CLICKED(IDC_BUTTON_BATH_COMPLETION, &CControlJobManagerDlg::OnBnClickedButtonBathCompletion)
END_MESSAGE_MAP()
@@ -65,7 +76,7 @@
}
else if (1 == code) {
if (contextType == 1) {
- UpProcessJobId((SERVO::CProcessJob*)pContext);
+ UpProcessJobId((PJWarp*)pContext);
}
}
};
@@ -93,12 +104,12 @@
m_pages.push_back(pPage3);
- // ListBox
- m_listBox.ModifyStyle(0, LBS_OWNERDRAWFIXED | LBS_HASSTRINGS);
- m_listBox.SetCheckStyle(BS_AUTOCHECKBOX);
- m_listBox.SetItemHeight(0, max(22, ::GetSystemMetrics(SM_CYMENUCHECK) + 4));
+ // tree
+ m_tree.ModifyStyle(0, TVS_CHECKBOXES);
+ InitData();
+ UpdateControlJob();
UpdateCtrlState();
Resize();
@@ -131,50 +142,25 @@
// 鍏堢Щ鍔ㄦ寜閽�
- pItem = GetDlgItem(IDC_BUTTON_CREATE_PJ);
- pItem->GetWindowRect(&rcItem);
- pItem->MoveWindow(x, y2 - rcItem.Height(), rcItem.Width(), rcItem.Height());
- x += rcItem.Width();
- x += 8;
-
- pItem = GetDlgItem(IDC_BUTTON_CREATE_CJ);
- pItem->GetWindowRect(&rcItem);
- pItem->MoveWindow(x, y2 - rcItem.Height(), rcItem.Width(), rcItem.Height());
- x += rcItem.Width();
- x += 8;
-
- pItem = GetDlgItem(IDC_BUTTON_BATH_COMPLETION);
- pItem->GetWindowRect(&rcItem);
- pItem->MoveWindow(x, y2 - rcItem.Height(), rcItem.Width(), rcItem.Height());
- x += rcItem.Width();
- x += 8;
-
- pItem = GetDlgItem(IDC_BUTTON_BATH_DELETE);
- pItem->GetWindowRect(&rcItem);
- pItem->MoveWindow(x, y2 - rcItem.Height(), rcItem.Width(), rcItem.Height());
- x += rcItem.Width();
- x += 8;
-
pItem = GetDlgItem(IDC_BUTTON_APPLY);
pItem->GetWindowRect(&rcItem);
pItem->MoveWindow(x2 - rcItem.Width(), y2 - rcItem.Height(), rcItem.Width(), rcItem.Height());
+ x2 -= rcItem.Width();
+ x2 -= 8;
+
+ pItem = GetDlgItem(IDC_BUTTON_BATH_COMPLETION);
+ pItem->GetWindowRect(&rcItem);
+ pItem->MoveWindow(x2 - rcItem.Width(), y2 - rcItem.Height(), rcItem.Width(), rcItem.Height());
+ x += rcItem.Width();
+ x += 8;
+
y2 -= rcItem.Height();
y2 -= 8;
- // 鍒楄〃鎺т欢
- x = 12;
- y = 12;
- pItem = GetDlgItem(IDC_LIST1);
- pItem->MoveWindow(x, y, LEFTWIDTH, 180);
- x += LEFTWIDTH;
- x += 5;
- y += 180;
- y += 5;
-
-
// 鏍戞帶浠�
x = 12;
+ y = 12;
pItem = GetDlgItem(IDC_TREE1);
pItem->MoveWindow(x, y, LEFTWIDTH, y2 - y);
x += LEFTWIDTH;
@@ -182,6 +168,7 @@
// 瀛愰〉闈�
+ x2 = rcClient.right - 12;
for (auto page : m_pages) {
page->MoveWindow(x, 12, x2 - x, y2 - 12);
}
@@ -203,46 +190,7 @@
void CControlJobManagerDlg::UpdateCtrlState()
{
- auto& master = theApp.m_model.getMaster();
- auto cj = master.getControlJob();
- GetDlgItem(IDC_BUTTON_CREATE_PJ)->EnableWindow(TRUE);
- GetDlgItem(IDC_BUTTON_CREATE_CJ)->EnableWindow(
- m_pControlJob == nullptr
- );
- GetDlgItem(IDC_BUTTON_BATH_COMPLETION)->EnableWindow(false);
- GetDlgItem(IDC_BUTTON_BATH_DELETE)->EnableWindow(true);
-}
-
-
-void CControlJobManagerDlg::OnBnClickedButtonCreatePj()
-{
- static int index = 0;
- char szBuffer[256];
- sprintf_s(szBuffer, 256, "PJ%03d", ++index);
- SERVO::CProcessJob* pj = new SERVO::CProcessJob(std::string(szBuffer));
- m_processJobs.push_back(pj);
- UpdateProcessJobs();
- UpdateCtrlState();
-}
-
-void CControlJobManagerDlg::OnBnClickedCreateCJ()
-{
- if (m_pControlJob != nullptr) {
- return;
- }
-
- m_pControlJob = new SERVO::CControlJob("CJ" + CToolUnits::NowStrSec());
- UpdateControlJob();
- UpdateCtrlState();
-}
-
-void CControlJobManagerDlg::UpdateProcessJobs()
-{
- m_listBox.ResetContent();
- for (auto item : m_processJobs) {
- int index = m_listBox.InsertString(m_listBox.GetCount(), item->id().c_str());
- m_listBox.SetItemDataPtr(index, item);
- }
+ GetDlgItem(IDC_BUTTON_BATH_COMPLETION)->EnableWindow(true);
}
void CControlJobManagerDlg::UpdateControlJob()
@@ -252,31 +200,13 @@
HTREEITEM hRoot = m_tree.InsertItem(m_pControlJob->id().c_str(), 0, 0);
m_tree.SetItemData(hRoot, (DWORD_PTR)m_pControlJob);
- auto& pjs = m_pControlJob->getPjs();
- for (auto pj : pjs) {
- HTREEITEM hItem = m_tree.InsertItem(pj->id().c_str(), 0, 0, hRoot);
- m_tree.SetItemData(hItem, (DWORD_PTR)pj);
+ m_tree.SetItemState(hRoot, 0, TVIS_STATEIMAGEMASK);
+ 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(item.addToCj ? 2 : 1), TVIS_STATEIMAGEMASK);
}
m_tree.Expand(hRoot, TVE_EXPAND);
-}
-
-void CControlJobManagerDlg::OnListChkChange()
-{
- int idx = m_listBox.GetCurSel();
- if (idx != LB_ERR) {
- SERVO::CProcessJob* pj = (SERVO::CProcessJob*)m_listBox.GetItemDataPtr(idx);
- BOOL checked = m_listBox.GetCheck(idx); // 鑻ヤ笁鎬�: 0/1/2
- if (checked) {
- if (AddPorcessJob(pj)) {
- UpdateControlJob();
- }
- }
- else {
- if (RemovePorcessJob(pj)) {
- UpdateControlJob();
- }
- }
- }
}
bool CControlJobManagerDlg::AddPorcessJob(SERVO::CProcessJob* pj)
@@ -291,54 +221,133 @@
return m_pControlJob->removePjPointer(pj->id());
}
-void CControlJobManagerDlg::OnLbnSelchangeList1()
+void CControlJobManagerDlg::OnTvnItemChangedTree(NMHDR* pNMHDR, LRESULT* pResult)
{
- int idx = m_listBox.GetCurSel();
- if (idx != LB_ERR) {
- SERVO::CProcessJob* pj = (SERVO::CProcessJob*)m_listBox.GetItemDataPtr(idx);
-
- ASSERT(m_pages.size() == 3);
- m_pages[0]->ShowWindow(SW_HIDE);
- m_pages[1]->ShowWindow(SW_SHOW);
- m_pages[2]->ShowWindow(SW_HIDE);
+ auto* p = reinterpret_cast<LPNMTREEVIEW>(pNMHDR);
+ UINT oldState = p->itemOld.state, newState = p->itemNew.state;
+ HTREEITEM hItem = p->itemNew.hItem;
- m_pages[1]->SetContext(pj, 1);
+ if (((oldState ^ newState) & TVIS_STATEIMAGEMASK) != 0) {
+ const int idx = (newState & TVIS_STATEIMAGEMASK) >> 12; // 1=鏈��,2=宸查��
+ const bool checked = (idx == 2);
+
+ PJWarp* pjWarp = (PJWarp*)m_tree.GetItemData(hItem);
+ if (pjWarp != nullptr) {
+ CString s; s.Format("%s %d", ((SERVO::CProcessJob*)pjWarp->pj)->id().c_str(),
+ checked ? "" : "");
+ AfxMessageBox(s);
+ }
+ }
+
+
+ *pResult = 0;
+}
+
+// 鍛戒腑澶嶉�夋锛氱敤 NM_CLICK 鍋氬懡涓祴璇曪紝鐒跺悗鈥滄粸鍚庘�濊鍙栨柊鐘舵��
+void CControlJobManagerDlg::OnTreeClick(NMHDR* pNMHDR, LRESULT* pResult)
+{
+ *pResult = 0;
+
+ DWORD pos = ::GetMessagePos();
+ CPoint pt(GET_X_LPARAM(pos), GET_Y_LPARAM(pos));
+ m_tree.ScreenToClient(&pt);
+
+ TVHITTESTINFO ht{}; ht.pt = pt;
+ HTREEITEM hItem = m_tree.HitTest(&ht);
+ if (hItem && (ht.flags & TVHT_ONITEMSTATEICON)) {
+ // 璁� TreeView 鍏堝垏鎹紝鍐嶅紓姝ヨ鍙栨渶缁堢姸鎬�
+ PostMessage(WM_AFTER_TVCHECK, (WPARAM)hItem, 0);
}
}
-void CControlJobManagerDlg::OnTvnSelchangedTree1(NMHDR* pNMHDR, LRESULT* pResult)
+// 绌烘牸閿篃浼氬垏鎹㈠閫夋
+void CControlJobManagerDlg::OnTreeKeyDown(NMHDR* pNMHDR, LRESULT* pResult)
+{
+ *pResult = 0;
+ auto* p = reinterpret_cast<LPNMTVKEYDOWN>(pNMHDR);
+ if (p->wVKey == VK_SPACE) {
+ HTREEITEM hItem = m_tree.GetSelectedItem();
+ if (hItem) PostMessage(WM_AFTER_TVCHECK, (WPARAM)hItem, 0);
+ }
+}
+
+// 缁熶竴澶勭悊锛堣鏈�缁堢姸鎬� + 浣犵殑涓氬姟锛�
+LRESULT CControlJobManagerDlg::OnAfterTvCheck(WPARAM wParam, LPARAM /*lParam*/)
+{
+ HTREEITEM hItem = (HTREEITEM)wParam;
+ if (!hItem) return 0;
+
+ // 鍙鐞嗙浜屽眰锛氭牴鐨勭洿鎺ュ瓙鑺傜偣锛堝彲閫夛級
+ auto getLevel = [&](HTREEITEM h) {
+ int lv = 0; for (HTREEITEM p = m_tree.GetParentItem(h); p; p = m_tree.GetParentItem(p)) ++lv; return lv;
+ };
+ if (getLevel(hItem) != 1) return 0;
+
+ BOOL checked = m_tree.GetCheck(hItem);
+
+ // 浣犵殑涓氬姟閫昏緫锛堜慨姝d簡 CString::Format 鐨勫弬鏁扮被鍨嬶級
+ auto* pjWarp = reinterpret_cast<PJWarp*>(m_tree.GetItemData(hItem));
+ if (pjWarp) {
+ pjWarp->addToCj = checked;
+ }
+
+ return 0;
+}
+
+void CControlJobManagerDlg::OnTvnSelchangingTree1(NMHDR* pNMHDR, LRESULT* pResult)
{
LPNMTREEVIEW pNMTreeView = reinterpret_cast<LPNMTREEVIEW>(pNMHDR);
+ bool allow = FALSE;
+ HTREEITEM hOldSel = pNMTreeView->itemOld.hItem;
HTREEITEM hSel = pNMTreeView->itemNew.hItem;
if (hSel != nullptr) {
HTREEITEM hParent = m_tree.GetParentItem(hSel);
if (hParent == nullptr) {
SERVO::CControlJob* cj = (SERVO::CControlJob*)m_tree.GetItemData(hSel);
ASSERT(m_pages.size() == 3);
- m_pages[0]->ShowWindow(SW_HIDE);
- m_pages[1]->ShowWindow(SW_HIDE);
- m_pages[2]->ShowWindow(SW_SHOW);
+ if (0 == ShowPage(2)) {
+
+ }
}
else if (m_tree.GetParentItem(hParent) == nullptr) {
- SERVO::CProcessJob* pj = (SERVO::CProcessJob*)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);
+ if (0 == ShowPage(1)) {
+ PJWarp* pjWarp = (PJWarp*)m_tree.GetItemData(hSel);
+ ((CCjPage2*)m_pages[1])->SetPjWarps(m_pjWarps);
+ m_pages[1]->SetContext(pjWarp, 1);
+ }
+ else {
+ allow = TRUE;
+ }
}
else {
// 鏈夌鍏� 鈫� 绗笁灞傚強浠ヤ笅 鈫� Glass
}
}
- *pResult = 0;
+ *pResult = allow;
+}
+
+int CControlJobManagerDlg::ShowPage(int index)
+{
+ ASSERT(0 <= index && index <= 2);
+
+ for (int i = 0; i < 3; i++) {
+ if (m_pages[i]->IsWindowVisible()) {
+ int ret = m_pages[i]->OnApply();
+ if (ret != 0) return -1;
+ }
+
+ m_pages[i]->ShowWindow(index == i ? SW_SHOW : SW_HIDE);
+ }
+
+ return 0;
}
void CControlJobManagerDlg::OnDestroy()
{
CDialogEx::OnDestroy();
+ SaveState();
for (auto page : m_pages) {
page->DestroyWindow();
@@ -346,33 +355,37 @@
}
}
+void CControlJobManagerDlg::InitData()
+{
+ LoadState();
+ if (m_pControlJob != nullptr) return;
+
+ m_pControlJob = new SERVO::CControlJob("CJ" + CToolUnits::NowStrSec());
+
+ char szBuffer[256];
+ for (int i = 0; i < 4; i++) {
+ sprintf_s(szBuffer, 256, "PJ%03d", i + 1);
+ SERVO::CProcessJob* pj = new SERVO::CProcessJob(std::string(szBuffer));
+ PJWarp pjWarp = {};
+ pjWarp.pj = pj;
+ pjWarp.port = -1;
+ m_pjWarps.push_back(pjWarp);
+ }
+}
void CControlJobManagerDlg::OnBnClickedButtonApply()
{
for (auto item : m_pages) {
- item->OnApply();
- }
- GetDlgItem(IDC_BUTTON_APPLY)->EnableWindow(FALSE);
-}
-
-void CControlJobManagerDlg::UpProcessJobId(SERVO::CProcessJob* pJob)
-{
- // 鏇存柊listbox
- int count = m_listBox.GetCount();
- for (int idx = 0; idx < count; idx++) {
- if ((m_listBox.GetItemDataPtr(idx) == (void*)pJob)) {
- BOOL check = m_listBox.GetCheck(idx);
- BOOL wasCurSel = (m_listBox.GetCurSel() == idx); // 鍗曢�夋ā寮�
- m_listBox.DeleteString(idx);
- int newIdx = m_listBox.InsertString(idx, pJob->id().c_str());
- m_listBox.SetItemDataPtr(newIdx, pJob);
- m_listBox.SetCheck(newIdx, check);
- if (wasCurSel) {
- m_listBox.SetCurSel(newIdx);
+ if (item->IsWindowVisible()) {
+ if (0 == item->OnApply()) {
+ GetDlgItem(IDC_BUTTON_APPLY)->EnableWindow(FALSE);
}
}
}
+}
+void CControlJobManagerDlg::UpProcessJobId(PJWarp* pjWarp)
+{
// 鏇存柊鏍戞帶浠�
// 閬嶅巻鏍硅妭鐐�
HTREEITEM hRoot = m_tree.GetRootItem();
@@ -381,8 +394,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);
@@ -391,3 +405,199 @@
hRoot = m_tree.GetNextSiblingItem(hRoot);
}
}
+
+void CControlJobManagerDlg::LoadState()
+{
+ if (!m_bHasState) return;
+
+ // 鎶� s_state -> 鎴愬憳鍙橀噺
+ m_pControlJob = m_state.pControlJob;
+ m_pjWarps = m_state.pjWarps;
+}
+
+void CControlJobManagerDlg::SaveState()
+{
+ m_state.pControlJob = m_pControlJob;
+ m_state.pjWarps = m_pjWarps;
+ m_bHasState = true;
+}
+
+void CControlJobManagerDlg::OnBnClickedButtonBathCompletion()
+{
+ // 鍏堟鏌ュ綋鍓峬aster
+ auto& master = theApp.m_model.getMaster();
+ if (!master.canCreateControlJob()) {
+ AfxMessageBox("褰撳墠Master鏈夋湭缁撴壒鐨凧ob, 璇峰厛缁撴壒澶勭悊");
+ return;
+ }
+
+
+ // 鍏堝簲鐢�
+ for (int i = 0; i < 3; i++) {
+ if (m_pages[i]->IsWindowVisible()) {
+ int ret = m_pages[i]->OnApply();
+ if (ret != 0) return ;
+ }
+ }
+ GetDlgItem(IDC_BUTTON_APPLY)->EnableWindow(FALSE);
+
+
+ // 鍏堟鏌ユ暟鎹纭��
+ int checkCount = 0;
+ for (auto item : m_pjWarps) {
+ if (!item.addToCj) continue;
+ checkCount++;
+ }
+ if (checkCount == 0) {
+ AfxMessageBox(_T("鎮ㄦ病鏈夐�夋嫨瑕佽繘琛屽伐鑹哄鐞嗙殑Process Job!\n璇峰湪瑕佽繘琛屽伐鑹哄鐞嗙殑Process Job鍓嶆墦鍕俱��"));
+ return;
+ }
+
+
+
+
+ int EQID[] = { EQ_ID_LOADPORT1, EQ_ID_LOADPORT2, EQ_ID_LOADPORT3, EQ_ID_LOADPORT4 };
+ std::vector<SERVO::CProcessJob*> pjs;
+ for (auto item : m_pjWarps) {
+ if (!item.addToCj) continue;
+ if (item.port == -1) continue;
+ BOOL bCheck = FALSE;
+ for (int i = 0; i < 8; i++) {
+ if (item.checkSlot[i]) {
+ bCheck = TRUE;
+ break;
+ }
+ }
+ if (!bCheck) continue;
+
+ SERVO::CLoadPort* pPort = (SERVO::CLoadPort*)master.getEquipment(EQID[item.port]);
+ SERVO::CProcessJob* pScr = (SERVO::CProcessJob*)item.pj;
+ SERVO::CProcessJob * pj = new SERVO::CProcessJob(pScr->id());
+ pj->setRecipe(SERVO::RecipeMethod::NoTuning, pScr->recipeSpec());
+
+ std::vector<SERVO::CarrierSlotInfo> carriers;
+ SERVO::CarrierSlotInfo csi;
+ csi.carrierId = pPort->getCassetteId();
+ for (int i = 0; i < 8; i++) {
+ if (item.checkSlot[i]) {
+ csi.slots.push_back(i);
+ }
+ }
+ carriers.push_back(csi);
+ pj->setCarriers(carriers);
+ pjs.push_back(pj);
+
+ m_pControlJob->addPJ(pScr->id());
+ }
+
+
+ if (pjs.empty()) {
+ AfxMessageBox(_T("娌℃湁闇�瑕佽繘琛屽伐鑹哄鐞嗙殑Process Job!\n鍙兘鏈�夋嫨Port鎴栭�夋嫨浠讳綍鐗╂枡銆�"));
+ return;
+ }
+
+ m_pControlJob->setPJs(pjs);
+ m_pControlJob->clearIssues();
+ int nRet = master.setProcessJobs(pjs);
+ if (nRet <= 0) {
+ std::string msg("鍚屾Process Job澶辫触!");
+ for (auto pj : pjs) {
+ auto& issues = pj->issues();
+ if (!issues.empty()) {
+ msg.append("\n");
+ msg.append(pj->id());
+ msg.append(":\n");
+ for (auto i : issues) {
+ msg.append("[");
+ msg.append(std::to_string(i.code));
+ msg.append("]");
+ msg.append(i.text);
+ msg.append("\n");
+ }
+ }
+ }
+ AfxMessageBox(msg.c_str());
+
+ return;
+ }
+
+
+ nRet = master.setControlJob(*m_pControlJob);
+ if (nRet != 0) {
+ std::string msg("鍚屾ControlJob澶辫触!");
+ auto& issues = m_pControlJob->issues();
+ if (!issues.empty()) {
+ msg.append("\n");
+ for (auto i : issues) {
+ msg.append("[");
+ msg.append(std::to_string(i.code));
+ msg.append("]");
+ msg.append(i.text);
+ msg.append("\n");
+ }
+ }
+ AfxMessageBox(msg.c_str());
+ return;
+ }
+
+
+ // 鍋囪鎴愬姛锛岃鍒ゆ柇锛屽悓姝ュ埌slot鐨刧lass涓紝绫诲瀷绛�
+ if (true) {
+ auto& master = theApp.m_model.getMaster();
+ int EQID[] = { EQ_ID_LOADPORT1, EQ_ID_LOADPORT2, EQ_ID_LOADPORT3, EQ_ID_LOADPORT4 };
+ for (int p = 0; p < 4; p++) {
+ SERVO::CLoadPort* pPort = (SERVO::CLoadPort*)master.getEquipment(EQID[p]);
+ for (int i = 0; i < SLOT_MAX; ++i) {
+ SERVO::CSlot* pSlot = pPort->getSlot(i);
+ if (!pSlot) {
+ continue;
+ }
+
+ // 璁剧疆 Panel ID 鍜屽嬀閫夋
+ SERVO::CProcessJob* pj = (SERVO::CProcessJob*)m_pjWarps[p].pj;
+ int nRecipeID = RecipeManager::getInstance().getIdByPPID(pj->recipeSpec());
+ RecipeInfo stRecipeInfo = RecipeManager::getInstance().getRecipeByPPID(pj->recipeSpec());
+ std::vector<DeviceRecipe> vecRecipeInfo = stRecipeInfo.vecDeviceList;
+ SERVO::CGlass* pGlass = dynamic_cast<SERVO::CGlass*>(pSlot->getContext());
+ SERVO::CJobDataS* pJobDataS = pGlass->getJobDataS();
+ if (pGlass != nullptr && pJobDataS != nullptr) {
+ pGlass->setScheduledForProcessing(m_pjWarps[p].checkSlot[i]);
+ 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->setMaterialsType(m_pjWarps[p].material[i]);
+ pJobDataS->setMasterRecipe(nRecipeID);
+
+ 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);
+ }
+ }
+ }
+ }
+ }
+ }
+
+ AfxMessageBox("鏂偣妫�鏌ヤ竴涓嬫暟鎹�");
+}
--
Gitblit v1.9.3