| ¶Ô±ÈÐÂÎļþ |
| | |
| | | // CControlJobManagerDlg.cpp: å®ç°æä»¶ |
| | | // |
| | | |
| | | #include "stdafx.h" |
| | | #include "Servo.h" |
| | | #include "CControlJobManagerDlg.h" |
| | | #include "afxdialogex.h" |
| | | #include "ToolUnits.h" |
| | | #include "RecipeManager.h" |
| | | |
| | | |
| | | bool CControlJobManagerDlg::m_bHasState = false; |
| | | CControlJobManagerDlg::State CControlJobManagerDlg::m_state{}; |
| | | |
| | | // CControlJobManagerDlg å¯¹è¯æ¡ |
| | | |
| | | IMPLEMENT_DYNAMIC(CControlJobManagerDlg, CDialogEx) |
| | | |
| | | CControlJobManagerDlg::CControlJobManagerDlg(CWnd* pParent /*=nullptr*/) |
| | | : CDialogEx(IDD_DIALOG_CONTROL_JOB_MANAGER, pParent) |
| | | { |
| | | m_pControlJob = nullptr; |
| | | } |
| | | |
| | | CControlJobManagerDlg::~CControlJobManagerDlg() |
| | | { |
| | | |
| | | } |
| | | |
| | | 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_TREE1, m_tree); |
| | | } |
| | | |
| | | |
| | | BEGIN_MESSAGE_MAP(CControlJobManagerDlg, CDialogEx) |
| | | ON_WM_SIZE() |
| | | ON_WM_GETMINMAXINFO() |
| | | 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() |
| | | |
| | | |
| | | // CControlJobManagerDlg æ¶æ¯å¤çç¨åº |
| | | |
| | | |
| | | BOOL CControlJobManagerDlg::OnInitDialog() |
| | | { |
| | | CDialogEx::OnInitDialog(); |
| | | |
| | | auto onContentChanged = [&](void* pFrom, int code, void* pContext, int contextType) -> void { |
| | | if (0 == code) { |
| | | GetDlgItem(IDC_BUTTON_APPLY)->EnableWindow(TRUE); |
| | | } |
| | | else if (1 == code) { |
| | | if (contextType == 1) { |
| | | UpProcessJobId((PJWarp*)pContext); |
| | | } |
| | | else if (contextType == 2) { |
| | | UpControlJobId((SERVO::CControlJob*)pContext); |
| | | } |
| | | } |
| | | }; |
| | | |
| | | // page1 |
| | | CCjPage1* pPage1 = new CCjPage1(this); |
| | | pPage1->Create(IDD_CJ_PAGE1, this); |
| | | pPage1->SetTitle(_T("æªéæ©")); |
| | | pPage1->SetOnContentChanged(onContentChanged); |
| | | pPage1->ShowWindow(SW_SHOW); |
| | | m_pages.push_back(pPage1); |
| | | |
| | | // page2 |
| | | CCjPage2* pPage2 = new CCjPage2(this); |
| | | pPage2->Create(IDD_CJ_PAGE2, this); |
| | | pPage2->SetTitle(_T("ProcessJob")); |
| | | pPage2->SetOnContentChanged(onContentChanged); |
| | | m_pages.push_back(pPage2); |
| | | |
| | | // page3 |
| | | CCjPage3* pPage3 = new CCjPage3(this); |
| | | pPage3->Create(IDD_CJ_PAGE3, this); |
| | | pPage3->SetTitle(_T("ControlJob")); |
| | | pPage3->SetOnContentChanged(onContentChanged); |
| | | m_pages.push_back(pPage3); |
| | | |
| | | |
| | | // tree |
| | | m_tree.ModifyStyle(0, TVS_CHECKBOXES); |
| | | |
| | | |
| | | InitData(); |
| | | UpdateControlJob(); |
| | | UpdateCtrlState(); |
| | | Resize(); |
| | | |
| | | |
| | | return TRUE; // return TRUE unless you set the focus to a control |
| | | // å¼å¸¸: OCX 屿§é¡µåºè¿å FALSE |
| | | } |
| | | |
| | | void CControlJobManagerDlg::OnSize(UINT nType, int cx, int cy) |
| | | { |
| | | CDialogEx::OnSize(nType, cx, cy); |
| | | if (GetDlgItem(IDC_TREE1) == nullptr) return; |
| | | |
| | | Resize(); |
| | | } |
| | | |
| | | void CControlJobManagerDlg::Resize() |
| | | { |
| | | CWnd* pItem; |
| | | CRect rcClient, rcItem; |
| | | GetClientRect(&rcClient); |
| | | |
| | | GetDlgItem(IDCANCEL)->GetWindowRect(&rcItem); |
| | | ScreenToClient(&rcItem); |
| | | |
| | | const int LEFTWIDTH = 218; |
| | | int x = 12, y = 12; |
| | | int x2 = rcClient.right - 12; |
| | | int y2 = rcClient.bottom - 12; |
| | | |
| | | |
| | | // å
ç§»å¨æé® |
| | | 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_TREE1); |
| | | pItem->MoveWindow(x, y, LEFTWIDTH, y2 - y); |
| | | x += LEFTWIDTH; |
| | | x += 5; |
| | | |
| | | |
| | | // åé¡µé¢ |
| | | x2 = rcClient.right - 12; |
| | | for (auto page : m_pages) { |
| | | page->MoveWindow(x, 12, x2 - x, y2 - 12); |
| | | } |
| | | |
| | | } |
| | | |
| | | void CControlJobManagerDlg::OnGetMinMaxInfo(MINMAXINFO* lpMMI) |
| | | { |
| | | CDialogEx::OnGetMinMaxInfo(lpMMI); |
| | | |
| | | // 设置æå°å®½é«ï¼æ¯å¦ 400x300ï¼ |
| | | lpMMI->ptMinTrackSize.x = 600; |
| | | lpMMI->ptMinTrackSize.y = 400; |
| | | |
| | | // ä¹å¯ä»¥é¡ºä¾¿è®¾ç½®æå¤§å®½é« |
| | | // lpMMI->ptMaxTrackSize.x = 800; |
| | | // lpMMI->ptMaxTrackSize.y = 600; |
| | | } |
| | | |
| | | void CControlJobManagerDlg::UpdateCtrlState() |
| | | { |
| | | GetDlgItem(IDC_BUTTON_BATH_COMPLETION)->EnableWindow(true); |
| | | } |
| | | |
| | | void CControlJobManagerDlg::UpdateControlJob() |
| | | { |
| | | m_tree.DeleteAllItems(); |
| | | if (m_pControlJob == nullptr) return; |
| | | |
| | | 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& 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); |
| | | } |
| | | |
| | | bool CControlJobManagerDlg::AddPorcessJob(SERVO::CProcessJob* pj) |
| | | { |
| | | if (m_pControlJob == nullptr) return false; |
| | | return m_pControlJob->addPjPointer(pj); |
| | | } |
| | | |
| | | bool CControlJobManagerDlg::RemovePorcessJob(SERVO::CProcessJob* pj) |
| | | { |
| | | if (m_pControlJob == nullptr) return false; |
| | | return m_pControlJob->removePjPointer(pj->id()); |
| | | } |
| | | |
| | | void CControlJobManagerDlg::OnTvnItemChangedTree(NMHDR* pNMHDR, LRESULT* pResult) |
| | | { |
| | | auto* p = reinterpret_cast<LPNMTREEVIEW>(pNMHDR); |
| | | UINT oldState = p->itemOld.state, newState = p->itemNew.state; |
| | | HTREEITEM hItem = p->itemNew.hItem; |
| | | |
| | | 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::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); |
| | | |
| | | // ä½ çä¸å¡é»è¾ï¼ä¿®æ£äº 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); |
| | | 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) { |
| | | 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 = 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(); |
| | | delete page; |
| | | } |
| | | } |
| | | |
| | | 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) { |
| | | if (item->IsWindowVisible()) { |
| | | if (0 == item->OnApply()) { |
| | | GetDlgItem(IDC_BUTTON_APPLY)->EnableWindow(FALSE); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | void CControlJobManagerDlg::UpProcessJobId(PJWarp* pjWarp) |
| | | { |
| | | // æ´æ°æ æ§ä»¶ |
| | | // éåæ ¹èç¹ |
| | | HTREEITEM hRoot = m_tree.GetRootItem(); |
| | | while (hRoot) { |
| | | // éå第äºå±åèç¹ |
| | | HTREEITEM hChild = m_tree.GetChildItem(hRoot); |
| | | while (hChild) { |
| | | DWORD_PTR data = m_tree.GetItemData(hChild); |
| | | 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); |
| | | } |
| | | |
| | | hRoot = m_tree.GetNextSiblingItem(hRoot); |
| | | } |
| | | } |
| | | |
| | | 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; |
| | | |
| | | // æ 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() |
| | | { |
| | | // å
æ£æ¥å½åmaster |
| | | auto& master = theApp.m_model.getMaster(); |
| | | if (!master.canCreateControlJob()) { |
| | | AfxMessageBox("å½åMasterææªç»æ¹çJob, 请å
ç»æ¹å¤ç"); |
| | | 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; |
| | | } |
| | | |
| | | |
| | | 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; |
| | | 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::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 = pPorts[item.port]->getCassetteId(); |
| | | for (int i = 0; i < 8; i++) { |
| | | if (item.checkSlot[i]) { |
| | | SERVO::CGlass* pGlass = pPorts[item.port]->getGlassFromSlot(i+1); |
| | | if (pGlass != nullptr) { |
| | | csi.slots.push_back(i + 1); |
| | | } |
| | | } |
| | | } |
| | | carriers.push_back(csi); |
| | | pj->setCarriers(carriers); |
| | | pjs.push_back(pj); |
| | | bProcessStart[item.port] = true; |
| | | |
| | | 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); |
| | | |
| | | // 没æé®é¢çpjè¦éæ¾ |
| | | for (auto pj : pjs) { |
| | | if (!pj->issues().empty()) { |
| | | delete pj; |
| | | } |
| | | } |
| | | pjs.clear(); |
| | | |
| | | 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çglassä¸ï¼ç±»åç |
| | | 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 = pLoadPort->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(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); |
| | | |
| | | 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); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | |
| | | // process start |
| | | for (int p = 0; p < 4; p++) { |
| | | if (bProcessStart[p]) { |
| | | pPorts[p]->sendCassetteCtrlCmd(CCC_PROCESS_START, nullptr, 0, 0, 0, nullptr, nullptr); |
| | | Sleep(100); |
| | | } |
| | | } |
| | | } |