1.合并刘洋的修改,主要是将警告和日志窗口上移,方便查看和调试。
| | |
| | | GetDlgItem(IDC_BUTTON_NEXT_PAGE)->EnableWindow(m_nCurPage < m_nTotalPages); |
| | | } |
| | | |
| | | static char* pszAlarmLevel[] = {"Warning", "Error"}; |
| | | void CAlarmDlg::FillDataToListCtrl(CListCtrl* pListCtrl, const std::vector<AlarmData>& vecData) |
| | | { |
| | | if (pListCtrl == nullptr || pListCtrl->m_hWnd == nullptr) { |
| | |
| | | |
| | | // éåæ°æ®å¹¶æå
¥å°CListCtrlä¸ |
| | | for (const auto& alarm : vecData) { |
| | | int nItem = pListCtrl->InsertItem(pListCtrl->GetItemCount(), _T("")); // æå
¥æ°è¡ |
| | | CString str; |
| | | // 设置åå
容 |
| | | str.Format(_T("%d"), alarm.nId); |
| | | pListCtrl->SetItemText(nItem, 1, str); // æ¥è¦ID |
| | | pListCtrl->SetItemText(nItem, 2, pszAlarmLevel[alarm.nSeverityLevel % 2]); // ç级 |
| | | pListCtrl->SetItemText(nItem, 3, alarm.strDeviceName.c_str()); // 设å¤åç§° |
| | | pListCtrl->SetItemText(nItem, 4, alarm.strUnitName.c_str()); // åå
åç§° |
| | | pListCtrl->SetItemText(nItem, 5, alarm.strStartTime.c_str()); // å¼å§æ¶é´ |
| | | pListCtrl->SetItemText(nItem, 6, alarm.strEndTime.c_str()); // ç»ææ¶é´ |
| | | pListCtrl->SetItemText(nItem, 7, alarm.strDescription.c_str()); // æè¿° |
| | | InsertAlarmData(pListCtrl, alarm); |
| | | } |
| | | |
| | | // è·ååæ° |
| | |
| | | pListCtrl->SetColumnWidth(nColCount - 1, LVSCW_AUTOSIZE_USEHEADER); |
| | | } |
| | | |
| | | static char* pszAlarmLevel[] = { "Warning", "Error" }; |
| | | void CAlarmDlg::InsertAlarmData(CListCtrl* pListCtrl, const AlarmData& alarmData) |
| | | { |
| | | if (pListCtrl == nullptr || pListCtrl->m_hWnd == nullptr) { |
| | |
| | | ON_WM_DESTROY() |
| | | ON_WM_CLOSE() |
| | | ON_WM_SIZE() |
| | | ON_WM_TIMER() |
| | | ON_CBN_SELCHANGE(IDC_COMBO_DATETIME, &CAlarmDlg::OnCbnSelchangeComboDatetime) |
| | | ON_BN_CLICKED(IDC_BUTTON_SEARCH, &CAlarmDlg::OnBnClickedButtonSearch) |
| | | ON_BN_CLICKED(IDC_BUTTON_EXPORT, &CAlarmDlg::OnBnClickedButtonExport) |
| | |
| | | BOOL CAlarmDlg::OnInitDialog() |
| | | { |
| | | CDialogEx::OnInitDialog(); |
| | | InitRxWindow(); |
| | | SetTimer(1, 3000, nullptr); |
| | | |
| | | // ä¸ææ¡æ§ä»¶ |
| | | CComboBox* pComboBox = (CComboBox*)GetDlgItem(IDC_COMBO_DATETIME); |
| | |
| | | pListCtrl->InsertColumn(6, _T("è§£é¤æ¶é´"), LVCFMT_LEFT, width[6]); |
| | | pListCtrl->InsertColumn(7, _T("æè¿°"), LVCFMT_LEFT, width[7]); |
| | | pListCtrl->SetColumnWidth(7, LVSCW_AUTOSIZE_USEHEADER); |
| | | |
| | | |
| | | |
| | | // è®¡ç®æ»é¡µæ° |
| | |
| | | Resize(); |
| | | } |
| | | |
| | | void CAlarmDlg::OnTimer(UINT_PTR nIDEvent) |
| | | { |
| | | if (1 == nIDEvent) { |
| | | KillTimer(1); |
| | | InitRxWindow(); |
| | | } |
| | | } |
| | | |
| | | void CAlarmDlg::OnCbnSelchangeComboDatetime() |
| | | { |
| | | CComboBox* pComboBox = (CComboBox*)GetDlgItem(IDC_COMBO_DATETIME); |
| | |
| | | afx_msg void OnDestroy(); |
| | | afx_msg void OnClose(); |
| | | afx_msg void OnSize(UINT nType, int cx, int cy); |
| | | afx_msg void OnTimer(UINT_PTR nIDEvent); |
| | | afx_msg void OnCbnSelchangeComboDatetime(); |
| | | afx_msg void OnBnClickedButtonSearch(); |
| | | afx_msg void OnBnClickedButtonExport(); |
| | |
| | | Invalidate(); |
| | | } |
| | | |
| | | void CPageGraph1::BindEquipmentToGraph() |
| | | { |
| | | struct EquipmentBindInfo |
| | | { |
| | | int nEquipmentID; |
| | | int nIndicateID; |
| | | }; |
| | | |
| | | static const EquipmentBindInfo EQUIPMENT_BIND_LIST[] = { |
| | | { EQ_ID_EFEM, INDICATE_ROBOT_ARM1 }, |
| | | { EQ_ID_EFEM, INDICATE_ROBOT_ARM2 }, |
| | | { EQ_ID_Bonder1, INDICATE_BONDER1 }, |
| | | { EQ_ID_Bonder2, INDICATE_BONDER2 }, |
| | | { EQ_ID_LOADPORT1, INDICATE_LPORT1 }, |
| | | { EQ_ID_LOADPORT2, INDICATE_LPORT2 }, |
| | | { EQ_ID_LOADPORT3, INDICATE_LPORT3 }, |
| | | { EQ_ID_LOADPORT4, INDICATE_LPORT4 }, |
| | | { EQ_ID_FLIPER, INDICATE_FLIPER }, |
| | | { EQ_ID_VACUUMBAKE, INDICATE_VACUUM_BAKE }, |
| | | { EQ_ID_ALIGNER, INDICATE_ALIGNER }, |
| | | { EQ_ID_BAKE_COOLING, INDICATE_BAKE_COOLING } |
| | | }; |
| | | |
| | | for (const auto& stBindInfo : EQUIPMENT_BIND_LIST) |
| | | { |
| | | SERVO::CEquipment* pEquipment = theApp.m_model.m_master.getEquipment(stBindInfo.nEquipmentID); |
| | | m_pGraph->SetIndicateBoxData(stBindInfo.nIndicateID, pEquipment); |
| | | } |
| | | } |
| | | |
| | | void CPageGraph1::OnGraphItemClicked(NMHDR* pNMHDR, LRESULT* pResult) |
| | | { |
| | | BYSERVOGRAPH_NMHDR* pGraphNmhdr = reinterpret_cast<BYSERVOGRAPH_NMHDR*>(pNMHDR); |
| | | CString s; s.Format(_T("OnGraphItemClicked %d"), pGraphNmhdr->dwData); |
| | | SERVO::CEquipment* pEquipment = (SERVO::CEquipment*)m_pGraph->GetIndicateBoxData(pGraphNmhdr->dwData); |
| | | if (pEquipment != nullptr) { |
| | | AfxMessageBox(pEquipment->getName().c_str()); |
| | | theApp.m_model.notifyPtr(RX_CODE_SELECT_EQUIPMENT, pEquipment); |
| | | } |
| | | |
| | | |
| | | *pResult = 0; |
| | | } |
| | |
| | | void UpdateDeviceStatus(int id, DeviceStatus status); |
| | | void UpdateRobotPosition(float percentage); |
| | | void RotateRobot(float angleInDegrees); |
| | | void BindEquipmentToGraph(); |
| | | |
| | | private: |
| | | IObserver* m_pObserver; |
| | |
| | | std::list<SERVO::CEquipment*>& eqs = theApp.m_model.m_master.getEquipmentList(); |
| | | for (auto item : eqs) { |
| | | EQITEM* pEqItem = m_pEqsGraphWnd->GetItem((DWORD_PTR)item); |
| | | if (nullptr == pEqItem) { |
| | | continue; |
| | | } |
| | | |
| | | strValue.Format(_T("%d"), pEqItem->rect.left); |
| | | WritePrivateProfileString(item->getName().c_str(), _T("Left"), |
| | |
| | | BEGIN_MESSAGE_MAP(CLogDlg, CDialogEx) |
| | | ON_WM_CTLCOLOR() |
| | | ON_WM_SIZE() |
| | | ON_WM_TIMER() |
| | | ON_WM_DESTROY() |
| | | ON_WM_CLOSE() |
| | | ON_NOTIFY(BLBUTTON_MENU_ITEM_CLICKED, IDC_BUTTON_LEVEL, &CLogDlg::OnButtonLevelMenuClicked) |
| | |
| | | BOOL CLogDlg::OnInitDialog() |
| | | { |
| | | CDialogEx::OnInitDialog(); |
| | | SetTimer(1, 3000, nullptr); |
| | | |
| | | |
| | | // ç¼å |
| | |
| | | m_logEdit.SetLimitText(-1); |
| | | |
| | | |
| | | InitRxWindow(); |
| | | Resize(); |
| | | |
| | | |
| | |
| | | Resize(); |
| | | } |
| | | |
| | | void CLogDlg::OnTimer(UINT_PTR nIDEvent) |
| | | { |
| | | if (1 == nIDEvent) { |
| | | KillTimer(1); |
| | | InitRxWindow(); |
| | | } |
| | | } |
| | | |
| | | void CLogDlg::Resize() |
| | | { |
| | | int x, y, y2, temp; |
| | |
| | | CWnd* pItem; |
| | | GetClientRect(&rcClient); |
| | | |
| | | y = 0; |
| | | y = 12; |
| | | x = 8; |
| | | pItem = GetDlgItem(IDC_BUTTON_LEVEL); |
| | | pItem->GetWindowRect(&rcItem); |
| | |
| | | public: |
| | | virtual BOOL OnInitDialog(); |
| | | afx_msg void OnSize(UINT nType, int cx, int cy); |
| | | afx_msg void OnTimer(UINT_PTR nIDEvent); |
| | | afx_msg void OnDestroy(); |
| | | afx_msg void OnClose(); |
| | | afx_msg HBRUSH OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor); |
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | // ProductionLogDlg.cpp: å®ç°æä»¶ |
| | | // |
| | | |
| | | #include "stdafx.h" |
| | | #include "Servo.h" |
| | | #include "afxdialogex.h" |
| | | #include "ProductionLogDlg.h" |
| | | #include "Common.h" |
| | | #include <iomanip> |
| | | |
| | | #define PAGE_SIZE 100 |
| | | #define PAGE_BACKGROUND_COLOR RGB(252, 252, 255) |
| | | |
| | | // CProductionLogDlg å¯¹è¯æ¡ |
| | | |
| | | //IMPLEMENT_DYNAMIC(CProductionLogDlg, CDialogEx) |
| | | // |
| | | //CProductionLogDlg::CProductionLogDlg(CWnd* pParent /*=nullptr*/) |
| | | // : CDialogEx(IDD_DIALOG_PRODUCTION_LOG, pParent) |
| | | //{ |
| | | // m_crBkgnd = PAGE_BACKGROUND_COLOR; |
| | | // m_hbrBkgnd = nullptr; |
| | | // m_pObserver = nullptr; |
| | | // |
| | | // m_strKeyword = ""; |
| | | // m_strProductId = ""; |
| | | // m_strBatchNo = ""; |
| | | // m_strDeviceId = ""; |
| | | // m_strOperatorName = ""; |
| | | // m_strStatus = ""; |
| | | // |
| | | // m_nCurPage = 0; |
| | | // m_nTotalPages = 0; |
| | | // m_nDateTimeFlag = 0; |
| | | // |
| | | // memset(m_szTimeStart, 0, sizeof(m_szTimeStart)); |
| | | // memset(m_szTimeEnd, 0, sizeof(m_szTimeEnd)); |
| | | // m_szTimeStart[0] = '\0'; |
| | | // m_szTimeEnd[0] = '\0'; |
| | | //} |
| | | |
| | | //CProductionLogDlg::~CProductionLogDlg() |
| | | //{ |
| | | //} |
| | | // |
| | | //void CProductionLogDlg::InitRxWindow() |
| | | //{ |
| | | // /* code */ |
| | | // // 订é
æ°æ® |
| | | // IRxWindows* pRxWindows = RX_GetRxWindows(); |
| | | // pRxWindows->enableLog(5); |
| | | // if (m_pObserver == NULL) { |
| | | // m_pObserver = pRxWindows->allocObserver([&](IAny* pAny) -> void { |
| | | // // onNext |
| | | // pAny->addRef(); |
| | | // int code = pAny->getCode(); |
| | | // |
| | | // //if (RX_CODE_ALARM_SET == code) { |
| | | // //} |
| | | // |
| | | // pAny->release(); |
| | | // }, [&]() -> void { |
| | | // // onComplete |
| | | // }, [&](IThrowable* pThrowable) -> void { |
| | | // // onErrorm |
| | | // pThrowable->printf(); |
| | | // }); |
| | | // |
| | | // theApp.m_model.getObservable()->observeOn(pRxWindows->mainThread())->subscribe(m_pObserver); |
| | | // } |
| | | //} |
| | | |
| | | /* |
| | | void CProductionLogDlg::Resize() |
| | | { |
| | | CRect rcClient; |
| | | GetClientRect(&rcClient); |
| | | |
| | | m_listCtrl.MoveWindow(12, 58, rcClient.Width() - 24, rcClient.Height() - 64); |
| | | } |
| | | |
| | | void CProductionLogDlg::UpdatePageData() |
| | | { |
| | | // æ ¹æ®è¿æ»¤æ¡ä»¶å è½½æ°æ®ï¼æ¯æåé¡µãæ¨¡ç³æ¥è¯¢ãæ¶é´èå´ï¼ |
| | | auto vecData = ProductionLogManager::getInstance().getFilteredSteps( |
| | | m_strProductId, // 产åID |
| | | m_strBatchNo, // æ¹æ¬¡å· |
| | | m_strDeviceId, // 设å¤ID |
| | | m_strOperatorName, // æä½å |
| | | m_strStatus, // ç¶æ |
| | | m_szTimeStart, // èµ·å§æ¶é´ |
| | | m_szTimeEnd, // ç»ææ¶é´ |
| | | m_nCurPage, // å½å页ç |
| | | PAGE_SIZE // æ¯é¡µæ¡æ° |
| | | ); |
| | | |
| | | // å¡«å
æ°æ®å°å表æ§ä»¶ |
| | | FillDataToListCtrl(&m_listCtrl, vecData); |
| | | |
| | | // æ´æ°å页æ§ä»¶ |
| | | UpdatePageControls(); |
| | | } |
| | | |
| | | void CProductionLogDlg::UpdatePageControls() |
| | | { |
| | | // æ´æ°åé¡µä¿¡æ¯ |
| | | CString strPage; |
| | | strPage.Format(_T("第 %d 页"), m_nCurPage); |
| | | SetDlgItemText(IDC_LABEL_PAGE_NUMBER, strPage); |
| | | |
| | | // å¯ç¨/ç¦ç¨ç¿»é¡µæé® |
| | | GetDlgItem(IDC_BUTTON_PREV_PAGE)->EnableWindow(m_nCurPage > 1); |
| | | GetDlgItem(IDC_BUTTON_NEXT_PAGE)->EnableWindow(m_nCurPage < m_nTotalPages); |
| | | } |
| | | |
| | | void CProductionLogDlg::FillDataToListCtrl(CListCtrl* pListCtrl, const std::vector<ProductionStep>& vecSteps) |
| | | { |
| | | if (pListCtrl == nullptr || pListCtrl->m_hWnd == nullptr) { |
| | | return; |
| | | } |
| | | |
| | | // æ¸
空å½åCListCtrlä¸çææé¡¹ |
| | | pListCtrl->DeleteAllItems(); |
| | | |
| | | // éåæ°æ®å¹¶æå
¥å°CListCtrlä¸ |
| | | for (const auto& step : vecSteps) { |
| | | InsertStepData(pListCtrl, step); |
| | | } |
| | | |
| | | // è·ååæ° |
| | | int nColCount = pListCtrl->GetHeaderCtrl()->GetItemCount(); |
| | | pListCtrl->SetColumnWidth(nColCount - 1, LVSCW_AUTOSIZE_USEHEADER); |
| | | } |
| | | |
| | | void CProductionLogDlg::InsertStepData(CListCtrl* pListCtrl, const ProductionStep& step) |
| | | { |
| | | if (pListCtrl == nullptr || pListCtrl->m_hWnd == nullptr) { |
| | | return; |
| | | } |
| | | |
| | | int nRowCount = pListCtrl->GetItemCount(); |
| | | if (nRowCount >= PAGE_SIZE) { |
| | | pListCtrl->DeleteItem(nRowCount - 1); |
| | | } |
| | | |
| | | CString str; |
| | | int nNewItem = pListCtrl->InsertItem(0, _T("")); |
| | | str.Format(_T("%d"), step.nStepId); pListCtrl->SetItemText(nNewItem, 1, str); |
| | | pListCtrl->SetItemText(nNewItem, 2, step.strProductId.c_str()); |
| | | pListCtrl->SetItemText(nNewItem, 3, step.strBatchNo.c_str()); |
| | | str.Format(_T("%d"), step.nDeviceId); pListCtrl->SetItemText(nNewItem, 4, str); |
| | | pListCtrl->SetItemText(nNewItem, 5, step.strOperator.c_str()); |
| | | pListCtrl->SetItemText(nNewItem, 6, step.strStartTime.c_str()); |
| | | pListCtrl->SetItemText(nNewItem, 7, step.strEndTime.c_str()); |
| | | str.Format(_T("%d"), step.nYield); pListCtrl->SetItemText(nNewItem, 8, str); |
| | | str.Format(_T("%d"), step.nGoodCount); pListCtrl->SetItemText(nNewItem, 9, str); |
| | | str.Format(_T("%d"), step.nBadCount); pListCtrl->SetItemText(nNewItem, 10, str); |
| | | pListCtrl->SetItemText(nNewItem, 11, step.strStatus.c_str()); |
| | | } |
| | | |
| | | std::string CProductionLogDlg::getCurrentTimeString() |
| | | { |
| | | auto now = std::chrono::system_clock::now(); |
| | | auto time_t_now = std::chrono::system_clock::to_time_t(now); |
| | | |
| | | std::tm tm_now = {}; |
| | | localtime_s(&tm_now, &time_t_now); |
| | | |
| | | std::stringstream ss; |
| | | ss << std::put_time(&tm_now, "%Y-%m-%d %H:%M:%S"); |
| | | return ss.str(); |
| | | } |
| | | |
| | | void CProductionLogDlg::DoDataExchange(CDataExchange* pDX) |
| | | { |
| | | DDX_Control(pDX, IDC_DATETIMEPICKER_START, m_dateTimeStart); |
| | | DDX_Control(pDX, IDC_DATETIMEPICKER_END, m_dateTimeEnd); |
| | | DDX_Control(pDX, IDC_LIST_PRODUCTION_LOG, m_listCtrl); |
| | | CDialogEx::DoDataExchange(pDX); |
| | | } |
| | | |
| | | BEGIN_MESSAGE_MAP(CProductionLogDlg, CDialogEx) |
| | | ON_WM_CTLCOLOR() |
| | | ON_WM_DESTROY() |
| | | ON_WM_CLOSE() |
| | | ON_WM_SIZE() |
| | | ON_CBN_SELCHANGE(IDC_COMBO_DATETIME, &CProductionLogDlg::OnCbnSelchangeComboDatetime) |
| | | ON_BN_CLICKED(IDC_BUTTON_SEARCH, &CProductionLogDlg::OnBnClickedButtonSearch) |
| | | ON_BN_CLICKED(IDC_BUTTON_EXPORT, &CProductionLogDlg::OnBnClickedButtonExport) |
| | | ON_BN_CLICKED(IDC_BUTTON_PREV_PAGE, &CProductionLogDlg::OnBnClickedButtonPrevPage) |
| | | ON_BN_CLICKED(IDC_BUTTON_NEXT_PAGE, &CProductionLogDlg::OnBnClickedButtonNextPage) |
| | | END_MESSAGE_MAP() |
| | | |
| | | // CProductionLogDlg æ¶æ¯å¤çç¨åº |
| | | BOOL CProductionLogDlg::OnInitDialog() |
| | | { |
| | | CDialogEx::OnInitDialog(); |
| | | InitRxWindow(); |
| | | |
| | | // åå§åæ¶é´èå´éæ© |
| | | CComboBox* pComboBox = (CComboBox*)GetDlgItem(IDC_COMBO_DATETIME); |
| | | pComboBox->AddString(_T("ä¸é")); |
| | | pComboBox->AddString(_T("ä»å¤©")); |
| | | pComboBox->AddString(_T("ä¸å¤©å
")); |
| | | pComboBox->AddString(_T("æ¬æ")); |
| | | pComboBox->AddString(_T("ä»å¹´")); |
| | | pComboBox->AddString(_T("èªå®ä¹")); |
| | | pComboBox->SetCurSel(0); |
| | | |
| | | m_dateTimeStart.EnableWindow(FALSE); |
| | | m_dateTimeEnd.EnableWindow(FALSE); |
| | | |
| | | // 读åå宽é
ç½® |
| | | CString strIniFile, strItem; |
| | | strIniFile.Format(_T("%s\\configuration.ini"), (LPCTSTR)theApp.m_strAppDir); |
| | | int width[12] = { 0, 60, 100, 100, 70, 100, 140, 140, 60, 60, 60, 80 }; |
| | | for (int i = 0; i < 12; ++i) { |
| | | strItem.Format(_T("Col_%d_Width"), i); |
| | | width[i] = GetPrivateProfileInt("ProductionListCtrl", strItem, width[i], strIniFile); |
| | | } |
| | | |
| | | // åå§åå表æ§ä»¶ |
| | | CListCtrl* pListCtrl = (CListCtrl*)GetDlgItem(IDC_LIST_PRODUCTION_LOG); |
| | | DWORD dwStyle = pListCtrl->GetExtendedStyle(); |
| | | dwStyle |= LVS_EX_FULLROWSELECT | LVS_EX_GRIDLINES; |
| | | pListCtrl->SetExtendedStyle(dwStyle); |
| | | |
| | | HIMAGELIST imageList = ImageList_Create(24, 24, ILC_COLOR24, 1, 1); |
| | | ListView_SetImageList(pListCtrl->GetSafeHwnd(), imageList, LVSIL_SMALL); |
| | | |
| | | pListCtrl->InsertColumn(0, _T(""), LVCFMT_RIGHT, width[0]); |
| | | pListCtrl->InsertColumn(1, _T("æ¥éª¤ID"), LVCFMT_LEFT, width[1]); |
| | | pListCtrl->InsertColumn(2, _T("产åID"), LVCFMT_LEFT, width[2]); |
| | | pListCtrl->InsertColumn(3, _T("æ¹æ¬¡å·"), LVCFMT_LEFT, width[3]); |
| | | pListCtrl->InsertColumn(4, _T("设å¤ID"), LVCFMT_LEFT, width[4]); |
| | | pListCtrl->InsertColumn(5, _T("æä½å"), LVCFMT_LEFT, width[5]); |
| | | pListCtrl->InsertColumn(6, _T("å¼å§æ¶é´"), LVCFMT_LEFT, width[6]); |
| | | pListCtrl->InsertColumn(7, _T("ç»ææ¶é´"), LVCFMT_LEFT, width[7]); |
| | | pListCtrl->InsertColumn(8, _T("产é"), LVCFMT_LEFT, width[8]); |
| | | pListCtrl->InsertColumn(9, _T("è¯åæ°"), LVCFMT_LEFT, width[9]); |
| | | pListCtrl->InsertColumn(10, _T("ä¸è¯åæ°"), LVCFMT_LEFT, width[10]); |
| | | pListCtrl->InsertColumn(11, _T("ç¶æ"), LVCFMT_LEFT, width[11]); |
| | | |
| | | // åå§ååé¡µæ°æ® |
| | | int totalRecords = ProductionLogManager::getInstance().getTotalStepCount( |
| | | m_strProductId, m_strBatchNo, m_strDeviceId, m_strOperatorName, |
| | | m_strStatus, m_szTimeStart, m_szTimeEnd); |
| | | m_nTotalPages = (totalRecords + PAGE_SIZE - 1) / PAGE_SIZE; |
| | | m_nCurPage = 1; |
| | | |
| | | Resize(); |
| | | UpdatePageData(); |
| | | |
| | | return TRUE; // return TRUE unless you set the focus to a control |
| | | // å¼å¸¸: OCX 屿§é¡µåºè¿å FALSE |
| | | } |
| | | |
| | | HBRUSH CProductionLogDlg::OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor) |
| | | { |
| | | HBRUSH hbr = CDialogEx::OnCtlColor(pDC, pWnd, nCtlColor); |
| | | |
| | | if (nCtlColor == CTLCOLOR_STATIC) { |
| | | pDC->SetBkColor(m_crBkgnd); |
| | | } |
| | | |
| | | if (m_hbrBkgnd == nullptr) { |
| | | m_hbrBkgnd = CreateSolidBrush(m_crBkgnd); |
| | | } |
| | | |
| | | return m_hbrBkgnd; |
| | | } |
| | | |
| | | void CProductionLogDlg::OnDestroy() |
| | | { |
| | | CDialogEx::OnDestroy(); |
| | | |
| | | // ä¿åå宽 |
| | | CString strIniFile, strItem, strTemp; |
| | | strIniFile.Format(_T("%s\\configuration.ini"), (LPCTSTR)theApp.m_strAppDir); |
| | | CHeaderCtrl* pHeader = m_listCtrl.GetHeaderCtrl(); |
| | | for (int i = 0; i < pHeader->GetItemCount(); ++i) { |
| | | RECT rect; |
| | | pHeader->GetItemRect(i, &rect); |
| | | strItem.Format(_T("Col_%d_Width"), i); |
| | | strTemp.Format(_T("%d"), rect.right - rect.left); |
| | | WritePrivateProfileString("ProductionListCtrl", strItem, strTemp, strIniFile); |
| | | } |
| | | |
| | | if (m_hbrBkgnd != nullptr) { |
| | | ::DeleteObject(m_hbrBkgnd); |
| | | } |
| | | |
| | | if (m_pObserver != NULL) { |
| | | m_pObserver->unsubscribe(); |
| | | m_pObserver = NULL; |
| | | } |
| | | } |
| | | |
| | | void CProductionLogDlg::OnClose() |
| | | { |
| | | ShowWindow(SW_HIDE); |
| | | //GetParent()->PostMessage(ID_MSG_ALARMDLG_HIDE, 0, 0); |
| | | CDialogEx::OnClose(); |
| | | } |
| | | |
| | | void CProductionLogDlg::OnSize(UINT nType, int cx, int cy) |
| | | { |
| | | CDialogEx::OnSize(nType, cx, cy); |
| | | if (GetDlgItem(IDC_LIST_PRODUCTION_LOG) == nullptr) return; |
| | | Resize(); |
| | | } |
| | | |
| | | void CProductionLogDlg::OnCbnSelchangeComboDatetime() |
| | | { |
| | | CComboBox* pComboBox = (CComboBox*)GetDlgItem(IDC_COMBO_DATETIME); |
| | | int nIndex = pComboBox->GetCurSel(); |
| | | int nCount = pComboBox->GetCount(); |
| | | m_dateTimeStart.EnableWindow(nIndex == nCount - 1); |
| | | m_dateTimeEnd.EnableWindow(nIndex == nCount - 1); |
| | | } |
| | | |
| | | void CProductionLogDlg::OnBnClickedButtonSearch() |
| | | { |
| | | // è·åå
³é®å |
| | | CString cstrKeyword; |
| | | GetDlgItemText(IDC_EDIT_KEYWORD, cstrKeyword); |
| | | m_strKeyword = CT2A(cstrKeyword); |
| | | |
| | | // è·åæ¥æ |
| | | CComboBox* pComboBox = (CComboBox*)GetDlgItem(IDC_COMBO_DATETIME); |
| | | m_nDateTimeFlag = pComboBox->GetCurSel(); |
| | | if (m_nDateTimeFlag == 0) { |
| | | memset(m_szTimeStart, 0, sizeof(m_szTimeStart)); |
| | | memset(m_szTimeEnd, 0, sizeof(m_szTimeEnd)); |
| | | m_szTimeStart[0] = '\0'; |
| | | m_szTimeEnd[0] = '\0'; |
| | | } |
| | | else { |
| | | CTime time = CTime::GetCurrentTime(); |
| | | if (m_nDateTimeFlag == 1) { |
| | | // ä»å¤© |
| | | sprintf_s(m_szTimeStart, 64, "%d-%02d-%02d 00:00:00", time.GetYear(), time.GetMonth(), time.GetDay()); |
| | | sprintf_s(m_szTimeEnd, 64, "%d-%02d-%02d 23:59:59", time.GetYear(), time.GetMonth(), time.GetDay()); |
| | | } |
| | | else if (m_nDateTimeFlag == 2) { |
| | | // 7天å
|
| | | CTime time2 = time - CTimeSpan(7, 0, 0, 0); |
| | | sprintf_s(m_szTimeStart, 64, "%d-%02d-%02d 00:00:00", time2.GetYear(), time2.GetMonth(), time2.GetDay()); |
| | | sprintf_s(m_szTimeEnd, 64, "%d-%02d-%02d 23:59:59", time.GetYear(), time.GetMonth(), time.GetDay()); |
| | | } |
| | | else if (m_nDateTimeFlag == 3) { |
| | | // æ¬æ |
| | | sprintf_s(m_szTimeStart, 64, "%d-%02d-01 00:00:00", time.GetYear(), time.GetMonth()); |
| | | sprintf_s(m_szTimeEnd, 64, "%d-%02d-%02d 23:59:59", time.GetYear(), time.GetMonth(), time.GetDay()); |
| | | } |
| | | else if (m_nDateTimeFlag == 4) { |
| | | // ä»å¹´ |
| | | sprintf_s(m_szTimeStart, 64, "%d-01-01 00:00:00", time.GetYear()); |
| | | sprintf_s(m_szTimeEnd, 64, "%d-12-31 23:59:59", time.GetYear()); |
| | | } |
| | | else if (m_nDateTimeFlag == 5) { |
| | | // èªå®ä¹ |
| | | SYSTEMTIME t1, t2; |
| | | m_dateTimeStart.GetTime(&t1); |
| | | m_dateTimeEnd.GetTime(&t2); |
| | | |
| | | sprintf_s(m_szTimeStart, 64, "%d-%02d-%02d %02d:%02d:%02d", |
| | | t1.wYear, t1.wMonth, t1.wDay, t1.wHour, t1.wMinute, t1.wSecond); |
| | | sprintf_s(m_szTimeEnd, 64, "%d-%02d-%02d %02d:%02d:%02d", |
| | | t2.wYear, t2.wMonth, t2.wDay, t2.wHour, t2.wMinute, t2.wSecond); |
| | | } |
| | | } |
| | | |
| | | // è®¡ç®æ»é¡µæ° |
| | | int totalRecords = ProductionLogManager::getInstance().getTotalStepCount( |
| | | m_strProductId, m_strBatchNo, m_strDeviceId, m_strOperatorName, |
| | | m_strStatus, m_szTimeStart, m_szTimeEnd); |
| | | m_nTotalPages = (totalRecords + PAGE_SIZE - 1) / PAGE_SIZE; |
| | | m_nCurPage = 1; |
| | | |
| | | UpdatePageData(); // è°ç¨åé¡µæ´æ°å½æ° |
| | | } |
| | | |
| | | void CProductionLogDlg::OnBnClickedButtonExport() |
| | | { |
| | | CFileDialog fileDialog(FALSE, "csv", "", OFN_HIDEREADONLY, "CSV Files (*.csv)|*.csv||"); |
| | | if (fileDialog.DoModal() != IDOK) { |
| | | return; |
| | | } |
| | | |
| | | CStdioFile file; |
| | | if (!file.Open(fileDialog.GetPathName(), CFile::modeCreate | CFile::modeWrite | CFile::typeText)) { |
| | | CString err; |
| | | err.Format(_T("æ æ³å建æä»¶: %s"), fileDialog.GetPathName()); |
| | | AfxMessageBox(err); |
| | | return; |
| | | } |
| | | |
| | | const int MAX_COLS = 32; |
| | | char szItem[256] = { 0 }; |
| | | HDITEM hdItem[MAX_COLS]; |
| | | |
| | | for (int i = 0; i < MAX_COLS; i++) { |
| | | hdItem[i].pszText = szItem; |
| | | hdItem[i].cchTextMax = 256; |
| | | hdItem[i].mask = HDI_TEXT | HDI_WIDTH; |
| | | } |
| | | |
| | | // è·ååæ° |
| | | CHeaderCtrl* pHeader = m_listCtrl.GetHeaderCtrl(); |
| | | int nSubItemCount = min(pHeader->GetItemCount(), MAX_COLS); |
| | | |
| | | // 表头 |
| | | CString strHeader; |
| | | for (int i = 0; i < nSubItemCount; i++) { |
| | | pHeader->GetItem(i, &hdItem[i]); |
| | | if (hdItem[i].cxy > 0) { |
| | | if (!strHeader.IsEmpty()) strHeader += ","; |
| | | strHeader += CString(hdItem[i].pszText); |
| | | } |
| | | } |
| | | strHeader += "\n"; |
| | | file.WriteString(strHeader); |
| | | |
| | | // è¡¨æ ¼å
容 |
| | | int nItemCount = m_listCtrl.GetItemCount(); |
| | | for (int i = 0; i < nItemCount; i++) { |
| | | CStringArray arrRow; |
| | | for (int j = 0; j < nSubItemCount; j++) { |
| | | if (hdItem[j].cxy > 0) { |
| | | CString strText = m_listCtrl.GetItemText(i, j); |
| | | strText.Replace(_T("* "), _T("")); |
| | | // 妿忮µä¸å«éå·ï¼å
裹åå¼å· |
| | | if (strText.Find(',') != -1) { |
| | | strText = _T("\"") + strText + _T("\""); |
| | | } |
| | | arrRow.Add(strText); |
| | | } |
| | | } |
| | | |
| | | CString strRow; |
| | | for (int k = 0; k < arrRow.GetCount(); ++k) { |
| | | if (k > 0) strRow += ","; |
| | | strRow += arrRow[k]; |
| | | } |
| | | strRow += "\n"; |
| | | file.WriteString(strRow); |
| | | } |
| | | |
| | | file.Close(); |
| | | } |
| | | |
| | | void CProductionLogDlg::OnBnClickedButtonPrevPage() |
| | | { |
| | | // ç¹å»ä¸ä¸é¡µ |
| | | m_nCurPage--; |
| | | UpdatePageData(); // è°ç¨åé¡µæ´æ°å½æ° |
| | | } |
| | | |
| | | void CProductionLogDlg::OnBnClickedButtonNextPage() |
| | | { |
| | | // ç¹å»ä¸ä¸é¡µ |
| | | m_nCurPage++; |
| | | UpdatePageData(); // è°ç¨åé¡µæ´æ°å½æ° |
| | | } |
| | | */ |
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | #pragma once |
| | | #include "afxdialogex.h" |
| | | #include "ListCtrlEx.h" |
| | | #include "ProductionLogManager.h" |
| | | |
| | | |
| | | // CProductionLogDlg å¯¹è¯æ¡ |
| | | /* |
| | | class CProductionLogDlg : public CDialogEx |
| | | { |
| | | DECLARE_DYNAMIC(CProductionLogDlg) |
| | | |
| | | public: |
| | | CProductionLogDlg(CWnd* pParent = nullptr); // æ åæé 彿° |
| | | virtual ~CProductionLogDlg(); |
| | | |
| | | private: |
| | | void InitRxWindow(); |
| | | void Resize(); |
| | | void UpdatePageData(); |
| | | void UpdatePageControls(); |
| | | void FillDataToListCtrl(CListCtrl* pListCtrl, const std::vector<ProductionStep>& vecSteps); |
| | | void InsertStepData(CListCtrl* pListCtrl, const ProductionStep& step); |
| | | std::string getCurrentTimeString(); |
| | | |
| | | private: |
| | | COLORREF m_crBkgnd; |
| | | HBRUSH m_hbrBkgnd; |
| | | IObserver* m_pObserver; |
| | | |
| | | // æç´¢å
³é®å |
| | | std::string m_strKeyword; |
| | | std::string m_strProductId; |
| | | std::string m_strBatchNo; |
| | | std::string m_strDeviceId; |
| | | std::string m_strOperatorName; |
| | | std::string m_strStatus; |
| | | |
| | | // 页ç |
| | | int m_nCurPage; |
| | | int m_nTotalPages; |
| | | |
| | | // æ¥æ |
| | | int m_nDateTimeFlag; |
| | | char m_szTimeStart[64]; |
| | | char m_szTimeEnd[64]; |
| | | |
| | | // æ§ä»¶ |
| | | CDateTimeCtrl m_dateTimeStart; |
| | | CDateTimeCtrl m_dateTimeEnd; |
| | | CListCtrlEx m_listCtrl; |
| | | |
| | | // å¯¹è¯æ¡æ°æ® |
| | | #ifdef AFX_DESIGN_TIME |
| | | enum { IDD = IDD_DIALOG_PRODUCTION_LOG }; |
| | | #endif |
| | | |
| | | protected: |
| | | virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV æ¯æ |
| | | virtual BOOL OnInitDialog(); |
| | | afx_msg HBRUSH OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor); |
| | | afx_msg void OnDestroy(); |
| | | afx_msg void OnClose(); |
| | | afx_msg void OnSize(UINT nType, int cx, int cy); |
| | | afx_msg void OnCbnSelchangeComboDatetime(); |
| | | afx_msg void OnBnClickedButtonSearch(); |
| | | afx_msg void OnBnClickedButtonExport(); |
| | | afx_msg void OnBnClickedButtonPrevPage(); |
| | | afx_msg void OnBnClickedButtonNextPage(); |
| | | DECLARE_MESSAGE_MAP() |
| | | }; |
| | | */ |
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | #include "stdafx.h" |
| | | #include "ProductionLogManager.h" |
| | | #include <sstream> |
| | | #include <fstream> |
| | | #include <iostream> |
| | | #include <stdexcept> |
| | | #include <iomanip> |
| | | |
| | | const std::string PRODUCTION_DB_FILE = R"(ProductionLog.db)"; |
| | | std::mutex ProductionLogManager::m_mutex; |
| | | |
| | | ProductionLogManager& ProductionLogManager::getInstance() { |
| | | static ProductionLogManager instance; |
| | | return instance; |
| | | } |
| | | |
| | | ProductionLogManager::ProductionLogManager() { |
| | | m_pDB = new BL::SQLiteDatabase(); |
| | | } |
| | | |
| | | ProductionLogManager::~ProductionLogManager() { |
| | | if (m_pDB) { |
| | | delete m_pDB; |
| | | m_pDB = nullptr; |
| | | } |
| | | } |
| | | |
| | | bool ProductionLogManager::initProductionTable() { |
| | | char path[MAX_PATH]; |
| | | GetModuleFileName(NULL, path, MAX_PATH); |
| | | std::string exePath(path); |
| | | std::string dbFileDir = exePath.substr(0, exePath.find_last_of("\\/")) + "\\DB"; |
| | | if (!CreateDirectory(dbFileDir.c_str(), NULL) && GetLastError() != ERROR_ALREADY_EXISTS) { |
| | | throw std::runtime_error("Failed to create DB directory."); |
| | | } |
| | | |
| | | std::string dbFilePath = dbFileDir + "\\" + PRODUCTION_DB_FILE; |
| | | if (!m_pDB->connect(dbFilePath, true)) { |
| | | throw std::runtime_error("Failed to connect to production database."); |
| | | } |
| | | |
| | | const std::string createTableQuery = R"( |
| | | CREATE TABLE IF NOT EXISTS production_log ( |
| | | step_id INTEGER PRIMARY KEY AUTOINCREMENT, |
| | | product_id TEXT NOT NULL, |
| | | batch_no TEXT NOT NULL, |
| | | device_id INTEGER NOT NULL, |
| | | prev_device_id INTEGER, |
| | | next_device_id INTEGER, |
| | | operator_name TEXT, |
| | | start_time DATETIME, |
| | | end_time DATETIME, |
| | | yield INTEGER, |
| | | good_count INTEGER, |
| | | bad_count INTEGER, |
| | | status TEXT, |
| | | note TEXT |
| | | ) |
| | | )"; |
| | | return m_pDB->executeQuery(createTableQuery); |
| | | } |
| | | |
| | | void ProductionLogManager::termProductionTable() { |
| | | if (m_pDB) { |
| | | m_pDB->disconnect(); |
| | | } |
| | | } |
| | | |
| | | bool ProductionLogManager::destroyProductionTable() { |
| | | if (!m_pDB) return false; |
| | | const std::string query = "DROP TABLE IF EXISTS production_log"; |
| | | return m_pDB->executeQuery(query); |
| | | } |
| | | |
| | | void ProductionLogManager::insertMockData() { |
| | | // TODO: å®ç°æ¨¡ææ°æ®æå
¥é»è¾ï¼ä½¿ç¨ std::ostringstreamï¼ |
| | | ProductionStep step; |
| | | step.strProductId = "P888"; |
| | | step.strBatchNo = "B999"; |
| | | step.nDeviceId = 3; |
| | | step.nPrevDeviceId = 2; |
| | | step.nNextDeviceId = 4; |
| | | step.strOperator = "MockUser"; |
| | | step.strStartTime = "2025-04-02 10:00:00"; |
| | | step.strEndTime = "2025-04-02 10:20:00"; |
| | | step.nYield = 100; |
| | | step.nGoodCount = 98; |
| | | step.nBadCount = 2; |
| | | step.strStatus = "æµè¯"; |
| | | step.strNote = "è¿æ¯æ¨¡æå±¥å"; |
| | | int id = 0; |
| | | addProductionStep(id, step); |
| | | } |
| | | |
| | | bool ProductionLogManager::addProductionStep(int stepId, const ProductionStep& stepData) { |
| | | std::ostringstream query; |
| | | query << "INSERT INTO production_log (product_id, batch_no, device_id, prev_device_id, next_device_id, operator_name, start_time, end_time, yield, good_count, bad_count, status, note) " |
| | | << "VALUES ('" << stepData.strProductId << "', '" << stepData.strBatchNo << "', " << stepData.nDeviceId << ", " |
| | | << stepData.nPrevDeviceId << ", " << stepData.nNextDeviceId << ", '" << stepData.strOperator << "', '" |
| | | << stepData.strStartTime << "', '" << stepData.strEndTime << "', " << stepData.nYield << ", " |
| | | << stepData.nGoodCount << ", " << stepData.nBadCount << ", '" << stepData.strStatus << "', '" |
| | | << stepData.strNote << "') RETURNING step_id;"; |
| | | |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | auto results = m_pDB->fetchResults(query.str()); |
| | | if (!results.empty() && !results[0].empty()) { |
| | | try { |
| | | stepId = std::stoi(results[0][0]); |
| | | m_mapStepCache[stepId] = stepData; |
| | | return true; |
| | | } |
| | | catch (...) { |
| | | return false; |
| | | } |
| | | } |
| | | return false; |
| | | } |
| | | |
| | | std::vector<ProductionStep> ProductionLogManager::getAllSteps() { |
| | | const std::string query = R"( |
| | | SELECT step_id, product_id, batch_no, device_id, prev_device_id, next_device_id, |
| | | operator_name, start_time, end_time, yield, good_count, bad_count, status, note |
| | | FROM production_log |
| | | )"; |
| | | |
| | | auto results = m_pDB->fetchResults(query); |
| | | std::vector<ProductionStep> steps; |
| | | for (const auto& row : results) { |
| | | ProductionStep step; |
| | | step.nStepId = std::stoi(row[0]); |
| | | step.strProductId = row[1]; |
| | | step.strBatchNo = row[2]; |
| | | step.nDeviceId = std::stoi(row[3]); |
| | | step.nPrevDeviceId = std::stoi(row[4]); |
| | | step.nNextDeviceId = std::stoi(row[5]); |
| | | step.strOperator = row[6]; |
| | | step.strStartTime = row[7]; |
| | | step.strEndTime = row[8]; |
| | | step.nYield = std::stoi(row[9]); |
| | | step.nGoodCount = std::stoi(row[10]); |
| | | step.nBadCount = std::stoi(row[11]); |
| | | step.strStatus = row[12]; |
| | | step.strNote = row[13]; |
| | | steps.push_back(step); |
| | | } |
| | | return steps; |
| | | } |
| | | |
| | | std::vector<ProductionStep> ProductionLogManager::getStepsByProductId(const std::string& productId) { |
| | | std::ostringstream query; |
| | | query << "SELECT * FROM production_log WHERE product_id = '" << productId << "'"; |
| | | auto results = m_pDB->fetchResults(query.str()); |
| | | std::vector<ProductionStep> steps; |
| | | for (const auto& row : results) { |
| | | ProductionStep step; |
| | | step.nStepId = std::stoi(row[0]); |
| | | step.strProductId = row[1]; |
| | | step.strBatchNo = row[2]; |
| | | step.nDeviceId = std::stoi(row[3]); |
| | | step.nPrevDeviceId = std::stoi(row[4]); |
| | | step.nNextDeviceId = std::stoi(row[5]); |
| | | step.strOperator = row[6]; |
| | | step.strStartTime = row[7]; |
| | | step.strEndTime = row[8]; |
| | | step.nYield = std::stoi(row[9]); |
| | | step.nGoodCount = std::stoi(row[10]); |
| | | step.nBadCount = std::stoi(row[11]); |
| | | step.strStatus = row[12]; |
| | | step.strNote = row[13]; |
| | | steps.push_back(step); |
| | | } |
| | | return steps; |
| | | } |
| | | |
| | | std::vector<ProductionStep> ProductionLogManager::getStepsByBatchNo(const std::string& batchNo) { |
| | | std::ostringstream query; |
| | | query << "SELECT * FROM production_log WHERE batch_no = '" << batchNo << "'"; |
| | | auto results = m_pDB->fetchResults(query.str()); |
| | | std::vector<ProductionStep> steps; |
| | | for (const auto& row : results) { |
| | | ProductionStep step; |
| | | step.nStepId = std::stoi(row[0]); |
| | | step.strProductId = row[1]; |
| | | step.strBatchNo = row[2]; |
| | | step.nDeviceId = std::stoi(row[3]); |
| | | step.nPrevDeviceId = std::stoi(row[4]); |
| | | step.nNextDeviceId = std::stoi(row[5]); |
| | | step.strOperator = row[6]; |
| | | step.strStartTime = row[7]; |
| | | step.strEndTime = row[8]; |
| | | step.nYield = std::stoi(row[9]); |
| | | step.nGoodCount = std::stoi(row[10]); |
| | | step.nBadCount = std::stoi(row[11]); |
| | | step.strStatus = row[12]; |
| | | step.strNote = row[13]; |
| | | steps.push_back(step); |
| | | } |
| | | return steps; |
| | | } |
| | | |
| | | std::vector<ProductionStep> ProductionLogManager::getStepsByDeviceId(int nDeviceId) { |
| | | std::ostringstream query; |
| | | query << "SELECT * FROM production_log WHERE device_id = " << nDeviceId; |
| | | auto results = m_pDB->fetchResults(query.str()); |
| | | std::vector<ProductionStep> steps; |
| | | for (const auto& row : results) { |
| | | ProductionStep step; |
| | | step.nStepId = std::stoi(row[0]); |
| | | step.strProductId = row[1]; |
| | | step.strBatchNo = row[2]; |
| | | step.nDeviceId = std::stoi(row[3]); |
| | | step.nPrevDeviceId = std::stoi(row[4]); |
| | | step.nNextDeviceId = std::stoi(row[5]); |
| | | step.strOperator = row[6]; |
| | | step.strStartTime = row[7]; |
| | | step.strEndTime = row[8]; |
| | | step.nYield = std::stoi(row[9]); |
| | | step.nGoodCount = std::stoi(row[10]); |
| | | step.nBadCount = std::stoi(row[11]); |
| | | step.strStatus = row[12]; |
| | | step.strNote = row[13]; |
| | | steps.push_back(step); |
| | | } |
| | | return steps; |
| | | } |
| | | |
| | | std::vector<ProductionStep> ProductionLogManager::getStepsByTimeRange(const std::string& startTime, const std::string& endTime) { |
| | | std::ostringstream query; |
| | | query << "SELECT * FROM production_log WHERE start_time >= '" << startTime << "' AND end_time <= '" << endTime << "'"; |
| | | auto results = m_pDB->fetchResults(query.str()); |
| | | std::vector<ProductionStep> steps; |
| | | for (const auto& row : results) { |
| | | ProductionStep step; |
| | | step.nStepId = std::stoi(row[0]); |
| | | step.strProductId = row[1]; |
| | | step.strBatchNo = row[2]; |
| | | step.nDeviceId = std::stoi(row[3]); |
| | | step.nPrevDeviceId = std::stoi(row[4]); |
| | | step.nNextDeviceId = std::stoi(row[5]); |
| | | step.strOperator = row[6]; |
| | | step.strStartTime = row[7]; |
| | | step.strEndTime = row[8]; |
| | | step.nYield = std::stoi(row[9]); |
| | | step.nGoodCount = std::stoi(row[10]); |
| | | step.nBadCount = std::stoi(row[11]); |
| | | step.strStatus = row[12]; |
| | | step.strNote = row[13]; |
| | | steps.push_back(step); |
| | | } |
| | | return steps; |
| | | } |
| | | |
| | | std::vector<ProductionStep> ProductionLogManager::getFilteredSteps( |
| | | const std::string& productId, |
| | | const std::string& batchNo, |
| | | const std::string& deviceId, |
| | | const std::string& operatorName, |
| | | const std::string& status, |
| | | const std::string& startTime, |
| | | const std::string& endTime, |
| | | int pageNumber, |
| | | int pageSize) { |
| | | |
| | | std::ostringstream query; |
| | | query << "SELECT * FROM production_log WHERE 1=1"; |
| | | |
| | | if (!productId.empty()) { |
| | | query << " AND product_id LIKE '%" << productId << "%'"; |
| | | } |
| | | if (!batchNo.empty()) { |
| | | query << " AND batch_no LIKE '%" << batchNo << "%'"; |
| | | } |
| | | if (!deviceId.empty()) { |
| | | query << " AND device_id = " << deviceId; |
| | | } |
| | | if (!operatorName.empty()) { |
| | | query << " AND operator_name LIKE '%" << operatorName << "%'"; |
| | | } |
| | | if (!status.empty()) { |
| | | query << " AND status LIKE '%" << status << "%'"; |
| | | } |
| | | if (!startTime.empty()) { |
| | | query << " AND start_time >= '" << startTime << "'"; |
| | | } |
| | | if (!endTime.empty()) { |
| | | query << " AND end_time <= '" << endTime << "'"; |
| | | } |
| | | |
| | | int offset = (pageNumber - 1) * pageSize; |
| | | query << " ORDER BY start_time DESC LIMIT " << pageSize << " OFFSET " << offset; |
| | | |
| | | auto results = m_pDB->fetchResults(query.str()); |
| | | std::vector<ProductionStep> steps; |
| | | for (const auto& row : results) { |
| | | ProductionStep step; |
| | | step.nStepId = std::stoi(row[0]); |
| | | step.strProductId = row[1]; |
| | | step.strBatchNo = row[2]; |
| | | step.nDeviceId = std::stoi(row[3]); |
| | | step.nPrevDeviceId = std::stoi(row[4]); |
| | | step.nNextDeviceId = std::stoi(row[5]); |
| | | step.strOperator = row[6]; |
| | | step.strStartTime = row[7]; |
| | | step.strEndTime = row[8]; |
| | | step.nYield = std::stoi(row[9]); |
| | | step.nGoodCount = std::stoi(row[10]); |
| | | step.nBadCount = std::stoi(row[11]); |
| | | step.strStatus = row[12]; |
| | | step.strNote = row[13]; |
| | | steps.push_back(step); |
| | | } |
| | | return steps; |
| | | } |
| | | |
| | | int ProductionLogManager::getTotalStepCount( |
| | | const std::string& productId, |
| | | const std::string& batchNo, |
| | | const std::string& deviceId, |
| | | const std::string& operatorName, |
| | | const std::string& status, |
| | | const std::string& startTime, |
| | | const std::string& endTime) { |
| | | |
| | | std::ostringstream query; |
| | | query << "SELECT COUNT(*) FROM production_log WHERE 1=1"; |
| | | |
| | | if (!productId.empty()) { |
| | | query << " AND product_id LIKE '%" << productId << "%'"; |
| | | } |
| | | if (!batchNo.empty()) { |
| | | query << " AND batch_no LIKE '%" << batchNo << "%'"; |
| | | } |
| | | if (!deviceId.empty()) { |
| | | query << " AND device_id = " << deviceId; |
| | | } |
| | | if (!operatorName.empty()) { |
| | | query << " AND operator_name LIKE '%" << operatorName << "%'"; |
| | | } |
| | | if (!status.empty()) { |
| | | query << " AND status LIKE '%" << status << "%'"; |
| | | } |
| | | if (!startTime.empty()) { |
| | | query << " AND start_time >= '" << startTime << "'"; |
| | | } |
| | | if (!endTime.empty()) { |
| | | query << " AND end_time <= '" << endTime << "'"; |
| | | } |
| | | |
| | | auto results = m_pDB->fetchResults(query.str()); |
| | | if (!results.empty() && !results[0].empty()) { |
| | | return std::stoi(results[0][0]); |
| | | } |
| | | return 0; |
| | | } |
| | | |
| | | bool ProductionLogManager::updateStepEndTime(int nStepId, const std::string& newEndTime) { |
| | | std::ostringstream query; |
| | | query << "UPDATE production_log SET end_time = '" << newEndTime << "' WHERE step_id = " << nStepId; |
| | | return m_pDB->executeQuery(query.str()); |
| | | } |
| | | |
| | | bool ProductionLogManager::saveProductionFile(const std::string& filename) { |
| | | std::ofstream file(filename); |
| | | if (!file.is_open()) return false; |
| | | file << "StepID,ProductID,BatchNo,DeviceID,PrevDeviceID,NextDeviceID,Operator,StartTime,EndTime,Yield,Good,Bad,Status,Note\n"; |
| | | for (auto it = m_mapStepCache.begin(); it != m_mapStepCache.end(); ++it) { |
| | | const int id = it->first; |
| | | const ProductionStep& step = it->second; |
| | | |
| | | file << id << "," << step.strProductId << "," << step.strBatchNo << "," |
| | | << step.nDeviceId << "," << step.nPrevDeviceId << "," << step.nNextDeviceId << "," |
| | | << step.strOperator << "," << step.strStartTime << "," << step.strEndTime << "," |
| | | << step.nYield << "," << step.nGoodCount << "," << step.nBadCount << "," |
| | | << step.strStatus << "," << step.strNote << "\n"; |
| | | } |
| | | file.close(); |
| | | return true; |
| | | } |
| | | |
| | | bool ProductionLogManager::readProductionFile(const std::string& filename) { |
| | | std::ifstream file(filename); |
| | | if (!file.is_open()) return false; |
| | | std::string line; |
| | | bool first = true; |
| | | while (std::getline(file, line)) { |
| | | if (first) { first = false; continue; } |
| | | std::stringstream ss(line); |
| | | std::string cell; |
| | | ProductionStep step; |
| | | std::getline(ss, cell, ','); step.nStepId = std::stoi(cell); |
| | | std::getline(ss, step.strProductId, ','); |
| | | std::getline(ss, step.strBatchNo, ','); |
| | | std::getline(ss, cell, ','); step.nDeviceId = std::stoi(cell); |
| | | std::getline(ss, cell, ','); step.nPrevDeviceId = std::stoi(cell); |
| | | std::getline(ss, cell, ','); step.nNextDeviceId = std::stoi(cell); |
| | | std::getline(ss, step.strOperator, ','); |
| | | std::getline(ss, step.strStartTime, ','); |
| | | std::getline(ss, step.strEndTime, ','); |
| | | std::getline(ss, cell, ','); step.nYield = std::stoi(cell); |
| | | std::getline(ss, cell, ','); step.nGoodCount = std::stoi(cell); |
| | | std::getline(ss, cell, ','); step.nBadCount = std::stoi(cell); |
| | | std::getline(ss, step.strStatus, ','); |
| | | std::getline(ss, step.strNote); |
| | | m_mapStepCache[step.nStepId] = step; |
| | | } |
| | | return true; |
| | | } |
| ¶Ô±ÈÐÂÎļþ |
| | |
| | | #ifndef PRODUCTION_LOG_MANAGER_H |
| | | #define PRODUCTION_LOG_MANAGER_H |
| | | |
| | | #include <string> |
| | | #include <vector> |
| | | #include <mutex> |
| | | #include <unordered_map> |
| | | #include "Database.h" |
| | | |
| | | // åæ¡ç产履åè®°å½ |
| | | struct ProductionStep { |
| | | int nStepId; // æ¥éª¤IDï¼ä¸»é®ï¼ |
| | | std::string strProductId; // 产åID |
| | | std::string strBatchNo; // æ¹æ¬¡å· |
| | | int nDeviceId; // å½å设å¤ID |
| | | std::string strDeviceName; // å½å设å¤åç§° |
| | | int nPrevDeviceId; // ä¸ä¸ä¸ªè®¾å¤ID |
| | | std::string strPrevDeviceName; // ä¸ä¸ä¸ªè®¾å¤åç§° |
| | | int nNextDeviceId; // ä¸ä¸ä¸ªè®¾å¤ID |
| | | std::string strNextDeviceName; // ä¸ä¸ä¸ªè®¾å¤åç§° |
| | | std::string strOperator; // æä½å |
| | | std::string strStartTime; // å·¥åºå¼å§æ¶é´ |
| | | std::string strEndTime; // å·¥åºç»ææ¶é´ |
| | | int nYield; // æ»äº§é |
| | | int nGoodCount; // è¯åæ° |
| | | int nBadCount; // ä¸è¯åæ° |
| | | std::string strStatus; // ç¶æï¼å®æãæåãå¼å¸¸çï¼ |
| | | std::string strNote; // 夿³¨ä¿¡æ¯ |
| | | }; |
| | | |
| | | using ProductionStepMap = std::unordered_map<int, ProductionStep>; |
| | | |
| | | class ProductionLogManager { |
| | | public: |
| | | // è·ååä¾å®ä¾ |
| | | static ProductionLogManager& getInstance(); |
| | | |
| | | // åå§åç产履å表 |
| | | bool initProductionTable(); |
| | | |
| | | // å
³éæ°æ®åºè¿æ¥ |
| | | void termProductionTable(); |
| | | |
| | | // å é¤ç产履å表 |
| | | bool destroyProductionTable(); |
| | | |
| | | // æå
¥æ¨¡ææ°æ® |
| | | void insertMockData(); |
| | | |
| | | // æ·»å ç产履åè®°å½ |
| | | bool addProductionStep(int stepId, const ProductionStep& stepData); |
| | | |
| | | // æ¥è¯¢ææç产履å |
| | | std::vector<ProductionStep> getAllSteps(); |
| | | |
| | | // æ ¹æ®äº§åIDæ¥è¯¢ |
| | | std::vector<ProductionStep> getStepsByProductId(const std::string& productId); |
| | | |
| | | // æ ¹æ®æ¹æ¬¡å·æ¥è¯¢ |
| | | std::vector<ProductionStep> getStepsByBatchNo(const std::string& batchNo); |
| | | |
| | | // æ ¹æ®è®¾å¤IDæ¥è¯¢ |
| | | std::vector<ProductionStep> getStepsByDeviceId(int nDeviceId); |
| | | |
| | | // æ ¹æ®æ¶é´èå´æ¥è¯¢ |
| | | std::vector<ProductionStep> getStepsByTimeRange(const std::string& startTime, const std::string& endTime); |
| | | |
| | | // å页æ¥è¯¢ + 夿¡ä»¶è¿æ»¤ |
| | | std::vector<ProductionStep> getFilteredSteps( |
| | | const std::string& productId, |
| | | const std::string& batchNo, |
| | | const std::string& deviceId, |
| | | const std::string& operatorName, |
| | | const std::string& status, |
| | | const std::string& startTime, |
| | | const std::string& endTime, |
| | | int pageNumber, |
| | | int pageSize); |
| | | |
| | | // è·å满足æ¡ä»¶çæ»æ° |
| | | int getTotalStepCount( |
| | | const std::string& productId, |
| | | const std::string& batchNo, |
| | | const std::string& deviceId, |
| | | const std::string& operatorName, |
| | | const std::string& status, |
| | | const std::string& startTime, |
| | | const std::string& endTime); |
| | | |
| | | // æ´æ°æä¸å±¥åçç»ææ¶é´ |
| | | bool updateStepEndTime(int nStepId, const std::string& newEndTime); |
| | | |
| | | // ä¿åå°CSVæä»¶ |
| | | bool saveProductionFile(const std::string& filename); |
| | | |
| | | // ä»CSVæä»¶å¯¼å
¥ |
| | | bool readProductionFile(const std::string& filename); |
| | | |
| | | private: |
| | | ProductionLogManager(); |
| | | ~ProductionLogManager(); |
| | | |
| | | // ç¦ç¨æ·è´æé åèµå¼ |
| | | ProductionLogManager(const ProductionLogManager&) = delete; |
| | | ProductionLogManager& operator=(const ProductionLogManager&) = delete; |
| | | |
| | | private: |
| | | BL::Database* m_pDB; |
| | | ProductionStepMap m_mapStepCache; |
| | | static std::mutex m_mutex; |
| | | }; |
| | | |
| | | #endif // PRODUCTION_LOG_MANAGER_H |
| | |
| | | return 1; |
| | | } |
| | | |
| | | // æå»ºå é¤æææ°æ®ç SQL è¯å¥ |
| | | std::string deleteSQL = "DELETE FROM " + tableName + ";"; |
| | | // æå»ºå é¤æææ°æ®ç SQL è¯å¥, éç½®èªå¢ ID |
| | | std::string deleteSQL = "TRUNCATE TABLE " + tableName + ";"; |
| | | if (!m_pDB->executeQuery(deleteSQL)) { |
| | | return 2; |
| | | } |
| | |
| | | } |
| | | } |
| | | |
| | | // æ·»å SystemEC æ°æ® |
| | | int SECSRuntimeManager::addSystemEC(int nID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultVal, const std::string& sUnit, const std::string& sRemark, int nSystemID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; // æ°æ®åºæªè¿æ¥ |
| | | } |
| | | |
| | | if (isIDDuplicate(nID)) { |
| | | return 2; // ID éå¤ |
| | | } |
| | | |
| | | if (isNameDuplicate(sName)) { |
| | | return 3; // Name éå¤ |
| | | } |
| | | |
| | | // æå»ºæå
¥ SQL è¯å¥ |
| | | std::string insertSQL = "INSERT INTO SystemEC (ID, Name, DataType, MinValue, MaxValue, DefaultVal, Unit, Remark, SystemID) VALUES (" |
| | | + std::to_string(nID) + ", '" + sName + "', '" + sDataType + "', " |
| | | + (nMinValue >= 0 ? std::to_string(nMinValue) : "NULL") + ", " |
| | | + (nMaxValue >= 0 ? std::to_string(nMaxValue) : "NULL") + ", " |
| | | + (nDefaultVal >= 0 ? std::to_string(nDefaultVal) : "NULL") + ", " |
| | | + ((sUnit == "NULL" || sUnit.empty()) ? "NULL" : "'" + sUnit + "'") + ", '" |
| | | + sRemark + "', " + std::to_string(nSystemID) + ");"; |
| | | |
| | | if (!m_pDB->executeQuery(insertSQL)) { |
| | | return 4; // æå
¥å¤±è´¥ |
| | | } |
| | | |
| | | return 0; // æå
¥æå |
| | | } |
| | | |
| | | // æ¥è¯¢æå® ID ç SystemEC æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getSystemECByID(int nID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM SystemEC WHERE ID = " + std::to_string(nID) + ";"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ¥è¯¢ææ SystemEC æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getAllSystemEC() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM SystemEC;"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ´æ°æå® ID ç SystemEC æ°æ® |
| | | int SECSRuntimeManager::updateSystemEC(int nID, int nNewID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultVal, const std::string& sUnit, const std::string& sRemark, int nSystemID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; |
| | | } |
| | | |
| | | // æ£æ¥æ¯å¦åå¨è¯¥ ID |
| | | if (!isIDDuplicate(nID)) { |
| | | return 2; |
| | | } |
| | | |
| | | // æ£æ¥æ°ç ID æ¯å¦å·²åå¨ |
| | | if (isIDDuplicate(nNewID) && nNewID != nID) { |
| | | return 3; |
| | | } |
| | | |
| | | // æå»ºæ´æ° SQL è¯å¥ |
| | | std::string updateSQL = "UPDATE SystemEC SET "; |
| | | |
| | | bool firstField = true; |
| | | |
| | | if (nNewID > 0 && nNewID != nID) { |
| | | updateSQL += "ID = " + std::to_string(nNewID); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sName.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Name = '" + sName + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sDataType.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "DataType = '" + sDataType + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nMinValue >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "MinValue = " + std::to_string(nMinValue); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nMaxValue >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "MaxValue = " + std::to_string(nMaxValue); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nDefaultVal >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "DefaultVal = " + std::to_string(nDefaultVal); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (sUnit != "NULL" && !sUnit.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Unit = '" + sUnit + "'"; |
| | | firstField = false; |
| | | } |
| | | else if (sUnit == "NULL") { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Unit = NULL"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sRemark.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Remark = '" + sRemark + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nSystemID > 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "SystemID = " + std::to_string(nSystemID); |
| | | } |
| | | |
| | | updateSQL += " WHERE ID = " + std::to_string(nID) + ";"; |
| | | |
| | | if (!m_pDB->executeQuery(updateSQL)) { |
| | | return 4; |
| | | } |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | // å é¤æå® ID ç SystemEC æ°æ® |
| | | int SECSRuntimeManager::deleteSystemECByID(int nID) { |
| | | return deleteDataByID("SystemEC", nID); |
| | | } |
| | | |
| | | // å 餿æ SystemEC æ°æ® |
| | | int SECSRuntimeManager::deleteAllSystemEC() { |
| | | return deleteAllDataFromTable("SystemEC"); |
| | | } |
| | | |
| | | // åå§å EqpEC 表 |
| | | void SECSRuntimeManager::initEqpECTable() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | |
| | | } |
| | | } |
| | | |
| | | // æ·»å EqpEC æ°æ® |
| | | int SECSRuntimeManager::addEqpEC(int nID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultValue, const std::string& sUnit, const std::string& sRemark, int nSeqNo, int nLength, int bCanUpdateByHost) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; // æ°æ®åºæªè¿æ¥ |
| | | } |
| | | |
| | | if (isIDDuplicate(nID)) { |
| | | return 2; // ID éå¤ |
| | | } |
| | | |
| | | if (isNameDuplicate(sName)) { |
| | | return 3; // Name éå¤ |
| | | } |
| | | |
| | | // æå»ºæå
¥ SQL è¯å¥ |
| | | std::string insertSQL = "INSERT INTO EqpEC (ID, Name, DataType, MinValue, MaxValue, DefaultValue, Unit, Remark, SeqNo, Length, CanUpdateByHost) VALUES (" |
| | | + std::to_string(nID) + ", '" + sName + "', '" + sDataType + "', " |
| | | + (nMinValue >= 0 ? std::to_string(nMinValue) : "NULL") + ", " |
| | | + (nMaxValue >= 0 ? std::to_string(nMaxValue) : "NULL") + ", " |
| | | + (nDefaultValue >= 0 ? std::to_string(nDefaultValue) : "NULL") + ", " |
| | | + ((sUnit == "NULL" || sUnit.empty()) ? "NULL" : "'" + sUnit + "'") + ", '" |
| | | + sRemark + "', " + std::to_string(nSeqNo) + ", " |
| | | + std::to_string(nLength) + ", " + std::to_string(bCanUpdateByHost) + ");"; |
| | | |
| | | if (!m_pDB->executeQuery(insertSQL)) { |
| | | return 4; // æå
¥å¤±è´¥ |
| | | } |
| | | |
| | | return 0; // æå
¥æå |
| | | } |
| | | |
| | | // æ¥è¯¢æå® ID ç EqpEC æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getEqpECByID(int nID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM EqpEC WHERE ID = " + std::to_string(nID) + ";"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ¥è¯¢ææ EqpEC æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getAllEqpEC() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM EqpEC;"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ´æ°æå® ID ç EqpEC æ°æ® |
| | | int SECSRuntimeManager::updateEqpEC(int nID, int nNewID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultValue, const std::string& sUnit, const std::string& sRemark, int nSeqNo, int nLength, int bCanUpdateByHost) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; |
| | | } |
| | | |
| | | // æ£æ¥æ¯å¦åå¨è¯¥ ID |
| | | if (!isIDDuplicate(nID)) { |
| | | return 2; |
| | | } |
| | | |
| | | // æ£æ¥æ°ç ID æ¯å¦å·²åå¨ |
| | | if (isIDDuplicate(nNewID) && nNewID != nID) { |
| | | return 3; |
| | | } |
| | | |
| | | // æå»ºæ´æ° SQL è¯å¥ |
| | | std::string updateSQL = "UPDATE EqpEC SET "; |
| | | |
| | | bool firstField = true; |
| | | |
| | | if (nNewID > 0 && nNewID != nID) { |
| | | updateSQL += "ID = " + std::to_string(nNewID); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sName.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Name = '" + sName + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sDataType.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "DataType = '" + sDataType + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nMinValue >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "MinValue = " + std::to_string(nMinValue); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nMaxValue >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "MaxValue = " + std::to_string(nMaxValue); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nDefaultValue >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "DefaultValue = " + std::to_string(nDefaultValue); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (sUnit != "NULL" && !sUnit.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Unit = '" + sUnit + "'"; |
| | | firstField = false; |
| | | } |
| | | else if (sUnit == "NULL") { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Unit = NULL"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sRemark.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Remark = '" + sRemark + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nSeqNo > 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "SeqNo = " + std::to_string(nSeqNo); |
| | | } |
| | | |
| | | if (nLength > 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Length = " + std::to_string(nLength); |
| | | } |
| | | |
| | | if (bCanUpdateByHost >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "CanUpdateByHost = " + std::to_string(bCanUpdateByHost); |
| | | } |
| | | |
| | | updateSQL += " WHERE ID = " + std::to_string(nID) + ";"; |
| | | |
| | | if (!m_pDB->executeQuery(updateSQL)) { |
| | | return 4; |
| | | } |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | // å é¤æå® ID ç EqpEC æ°æ® |
| | | int SECSRuntimeManager::deleteEqpECByID(int nID) { |
| | | return deleteDataByID("EqpEC", nID); |
| | | } |
| | | |
| | | // å 餿æ EqpEC æ°æ® |
| | | int SECSRuntimeManager::deleteAllEqpEC() { |
| | | return deleteAllDataFromTable("EqpEC"); |
| | | } |
| | | |
| | | // åå§å SystemEvent 表 |
| | | void SECSRuntimeManager::initSystemEventTable() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | |
| | | } |
| | | } |
| | | |
| | | // æ·»å SystemEvent æ°æ® |
| | | int SECSRuntimeManager::addSystemEvent(int nCEID, const std::string& sName, const std::string& sRemark, int nSystemID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; // æ°æ®åºæªè¿æ¥ |
| | | } |
| | | |
| | | // æå»º SQL æå
¥è¯å¥ |
| | | std::string insertSQL = "INSERT INTO SystemEvent (CEID, Name, Remark, SystemID) VALUES (" |
| | | + std::to_string(nCEID) + ", '" + sName + "', '" + sRemark + "', " + std::to_string(nSystemID) + ");"; |
| | | |
| | | if (!m_pDB->executeQuery(insertSQL)) { |
| | | return 2; // æå
¥å¤±è´¥ |
| | | } |
| | | |
| | | return 0; // æå
¥æå |
| | | } |
| | | |
| | | // æ¥è¯¢æå® CEID ç SystemEvent æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getSystemEventByID(int nCEID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM SystemEvent WHERE CEID = " + std::to_string(nCEID) + ";"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ¥è¯¢ææ SystemEvent æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getAllSystemEvents() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM SystemEvent;"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ´æ°æå® CEID ç SystemEvent æ°æ® |
| | | int SECSRuntimeManager::updateSystemEvent(int nCEID, int nNewCEID, const std::string& sName, const std::string& sRemark, int nSystemID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; |
| | | } |
| | | |
| | | // æå»ºæ´æ° SQL è¯å¥ |
| | | std::string updateSQL = "UPDATE SystemEvent SET "; |
| | | |
| | | bool firstField = true; |
| | | |
| | | if (nNewCEID > 0 && nNewCEID != nCEID) { |
| | | updateSQL += "CEID = " + std::to_string(nNewCEID); |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sName.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Name = '" + sName + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sRemark.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Remark = '" + sRemark + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nSystemID > 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "SystemID = " + std::to_string(nSystemID); |
| | | } |
| | | |
| | | updateSQL += " WHERE CEID = " + std::to_string(nCEID) + ";"; |
| | | |
| | | if (!m_pDB->executeQuery(updateSQL)) { |
| | | return 2; |
| | | } |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | // å é¤æå® CEID ç SystemEvent æ°æ® |
| | | int SECSRuntimeManager::deleteSystemEventByID(int nCEID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; // æ°æ®åºæªè¿æ¥ï¼è¿å 1 |
| | | } |
| | | |
| | | // æå»ºå é¤ SQL è¯å¥ |
| | | std::string deleteSQL = "DELETE FROM SystemEvent WHERE CEID = " + std::to_string(nCEID) + ";"; |
| | | if (!m_pDB->executeQuery(deleteSQL)) { |
| | | return 2; // å é¤å¤±è´¥ï¼è¿å 2 |
| | | } |
| | | |
| | | return 0; // å 餿åï¼è¿å 0 |
| | | } |
| | | |
| | | // å 餿æ SystemEvent æ°æ® |
| | | int SECSRuntimeManager::deleteAllSystemEvents() { |
| | | return deleteAllDataFromTable("SystemEvent"); |
| | | } |
| | | |
| | | // åå§å EqpEvent 表 |
| | | void SECSRuntimeManager::initEqpEventTable() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | |
| | | } |
| | | } |
| | | |
| | | // æ·»å EqpEvent æ°æ® |
| | | int SECSRuntimeManager::addEqpEvent(const std::string& sName, const std::string& sRemark, int nBitNo) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; // æ°æ®åºæªè¿æ¥ |
| | | } |
| | | |
| | | // æå»º SQL æå
¥è¯å¥ |
| | | std::string insertSQL = "INSERT INTO EqpEvent (Name, Remark, BitNo) VALUES ('" |
| | | + sName + "', '" + sRemark + "', " + std::to_string(nBitNo) + ");"; |
| | | |
| | | if (!m_pDB->executeQuery(insertSQL)) { |
| | | return 2; // æå
¥å¤±è´¥ |
| | | } |
| | | |
| | | return 0; // æå
¥æå |
| | | } |
| | | |
| | | // æ¥è¯¢æå® CEID ç EqpEvent æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getEqpEventByID(int nCEID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM EqpEvent WHERE CEID = " + std::to_string(nCEID) + ";"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ¥è¯¢ææ EqpEvent æ°æ® |
| | | std::vector<std::vector<std::string>> SECSRuntimeManager::getAllEqpEvents() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return {}; |
| | | } |
| | | |
| | | std::string querySQL = "SELECT * FROM EqpEvent;"; |
| | | return m_pDB->fetchResults(querySQL); |
| | | } |
| | | |
| | | // æ´æ°æå® CEID ç EqpEvent æ°æ® |
| | | int SECSRuntimeManager::updateEqpEvent(int nCEID, const std::string& sName, const std::string& sRemark, int nBitNo) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; |
| | | } |
| | | |
| | | // æå»ºæ´æ° SQL è¯å¥ |
| | | std::string updateSQL = "UPDATE EqpEvent SET "; |
| | | |
| | | bool firstField = true; |
| | | |
| | | if (!sName.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Name = '" + sName + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (!sRemark.empty()) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "Remark = '" + sRemark + "'"; |
| | | firstField = false; |
| | | } |
| | | |
| | | if (nBitNo >= 0) { |
| | | if (!firstField) updateSQL += ", "; |
| | | updateSQL += "BitNo = " + std::to_string(nBitNo); |
| | | } |
| | | |
| | | updateSQL += " WHERE CEID = " + std::to_string(nCEID) + ";"; |
| | | |
| | | if (!m_pDB->executeQuery(updateSQL)) { |
| | | return 2; |
| | | } |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | // å é¤æå® CEID ç EqpEvent æ°æ® |
| | | int SECSRuntimeManager::deleteEqpEventByID(int nCEID) { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | | if (m_pDB == nullptr) { |
| | | return 1; // æ°æ®åºæªè¿æ¥ï¼è¿å 1 |
| | | } |
| | | |
| | | // æå»ºå é¤ SQL è¯å¥ |
| | | std::string deleteSQL = "DELETE FROM EqpEvent WHERE CEID = " + std::to_string(nCEID) + ";"; |
| | | if (!m_pDB->executeQuery(deleteSQL)) { |
| | | return 2; // å é¤å¤±è´¥ï¼è¿å 2 |
| | | } |
| | | |
| | | return 0; // å 餿åï¼è¿å 0 |
| | | } |
| | | |
| | | // å 餿æ EqpEvent æ°æ® |
| | | int SECSRuntimeManager::deleteAllEqpEvents() { |
| | | return deleteAllDataFromTable("EqpEvent"); |
| | | } |
| | | |
| | | // åå§å EventLink 表 |
| | | void SECSRuntimeManager::initEventLinkTable() { |
| | | std::lock_guard<std::mutex> lock(m_mutex); |
| | |
| | | */ |
| | | void initSystemECTable(); |
| | | |
| | | int addSystemEC(int nID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultVal, const std::string& sUnit, const std::string& sRemark, int nSystemID); |
| | | |
| | | std::vector<std::vector<std::string>> getSystemECByID(int nID); |
| | | |
| | | std::vector<std::vector<std::string>> getAllSystemEC(); |
| | | |
| | | int updateSystemEC(int nID, int nNewID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultVal, const std::string& sUnit, const std::string& sRemark, int nSystemID); |
| | | |
| | | int deleteSystemECByID(int nID); |
| | | |
| | | int deleteAllSystemEC(); |
| | | |
| | | /** |
| | | * åå§å EqpEC 表 |
| | | */ |
| | | void initEqpECTable(); |
| | | |
| | | int addEqpEC(int nID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultValue, const std::string& sUnit, const std::string& sRemark, int nSeqNo, int nLength, int bCanUpdateByHost); |
| | | |
| | | std::vector<std::vector<std::string>> getEqpECByID(int nID); |
| | | |
| | | std::vector<std::vector<std::string>> getAllEqpEC(); |
| | | |
| | | int updateEqpEC(int nID, int nNewID, const std::string& sName, const std::string& sDataType, int nMinValue, int nMaxValue, int nDefaultValue, const std::string& sUnit, const std::string& sRemark, int nSeqNo, int nLength, int bCanUpdateByHost); |
| | | |
| | | int deleteEqpECByID(int nID); |
| | | |
| | | int deleteAllEqpEC(); |
| | | |
| | | /** |
| | | * åå§å SystemEvent 表 |
| | | */ |
| | | void initSystemEventTable(); |
| | | |
| | | int addSystemEvent(int nCEID, const std::string& sName, const std::string& sRemark, int nSystemID); |
| | | |
| | | std::vector<std::vector<std::string>> getSystemEventByID(int nCEID); |
| | | |
| | | std::vector<std::vector<std::string>> getAllSystemEvents(); |
| | | |
| | | int updateSystemEvent(int nCEID, int nNewCEID, const std::string& sName, const std::string& sRemark, int nSystemID); |
| | | |
| | | int deleteSystemEventByID(int nCEID); |
| | | |
| | | int deleteAllSystemEvents(); |
| | | |
| | | /** |
| | | * åå§å EqpEvent 表 |
| | | */ |
| | | void initEqpEventTable(); |
| | | |
| | | int addEqpEvent(const std::string& sName, const std::string& sRemark, int nBitNo); |
| | | |
| | | std::vector<std::vector<std::string>> getEqpEventByID(int nCEID); |
| | | |
| | | std::vector<std::vector<std::string>> getAllEqpEvents(); |
| | | |
| | | int updateEqpEvent(int nCEID, const std::string& sName, const std::string& sRemark, int nBitNo); |
| | | |
| | | int deleteEqpEventByID(int nCEID); |
| | | |
| | | int deleteAllEqpEvents(); |
| | | |
| | | /** |
| | | * åå§å EventLink 表 |
| | | */ |
| | |
| | | #include "ServoGraph.h" |
| | | #include "AlarmManager.h" |
| | | #include "SECSRuntimeManager.h" |
| | | #include "ProductionLogManager.h" |
| | | #include "VerticalLine.h" |
| | | #include "EqsGraphWnd.h" |
| | | #include "MapPosWnd.h" |
| | |
| | | AlarmManager::getInstance().insertMockData(); |
| | | |
| | | |
| | | // åå§åç产履å管çå¨ |
| | | try { |
| | | if (!ProductionLogManager::getInstance().initProductionTable()) { |
| | | AfxMessageBox("åå§åç产履å管çå¨å¤±è´¥ï¼"); |
| | | return FALSE; |
| | | } |
| | | } |
| | | catch (const std::exception& ex) { |
| | | CString errorMsg; |
| | | errorMsg.Format(_T("åå§åç产履å管çå¨å¤±è´¥ï¼%s"), CString(ex.what())); |
| | | AfxMessageBox(errorMsg, MB_ICONERROR); |
| | | return FALSE; |
| | | } |
| | | |
| | | |
| | | // åå§åSECSè¿è¡è®¾ç½®ç®¡çåº |
| | | try { |
| | | if (!SECSRuntimeManager::getInstance().initRuntimeSetting()) { |
| | |
| | | // 鿝æ¥è¦è¡¨ |
| | | AlarmManager::getInstance().termAlarmTable(); |
| | | |
| | | // 鿝ç产表 |
| | | ProductionLogManager::getInstance().termProductionTable(); |
| | | |
| | | // 鿝SECSè¿è¡è®¾ç½®ç®¡çåº |
| | | SECSRuntimeManager::getInstance().termRuntimeSetting(); |
| | | |
| | |
| | | <ClInclude Include="LogEdit.h" /> |
| | | <ClInclude Include="MapPosWnd.h" /> |
| | | <ClInclude Include="Model.h" /> |
| | | <ClInclude Include="ProductionLogDlg.h" /> |
| | | <ClInclude Include="ProductionLogManager.h" /> |
| | | <ClInclude Include="Resource.h" /> |
| | | <ClInclude Include="SECSRuntimeManager.h" /> |
| | | <ClInclude Include="SecsTestDlg.h" /> |
| | |
| | | <ClCompile Include="LogEdit.cpp" /> |
| | | <ClCompile Include="MapPosWnd.cpp" /> |
| | | <ClCompile Include="Model.cpp" /> |
| | | <ClCompile Include="ProductionLogDlg.cpp" /> |
| | | <ClCompile Include="ProductionLogManager.cpp" /> |
| | | <ClCompile Include="SECSRuntimeManager.cpp" /> |
| | | <ClCompile Include="SecsTestDlg.cpp" /> |
| | | <ClCompile Include="Servo.cpp" /> |
| | |
| | | <ClCompile Include="CRecipeList.cpp" /> |
| | | <ClCompile Include="CArm.cpp" /> |
| | | <ClCompile Include="CArmTray.cpp" /> |
| | | <ClCompile Include="ProductionLogDlg.cpp" /> |
| | | <ClCompile Include="ProductionLogManager.cpp" /> |
| | | </ItemGroup> |
| | | <ItemGroup> |
| | | <ClInclude Include="AlarmManager.h" /> |
| | |
| | | <ClInclude Include="CRecipeList.h" /> |
| | | <ClInclude Include="CArm.h" /> |
| | | <ClInclude Include="CArmTray.h" /> |
| | | <ClInclude Include="ProductionLogDlg.h" /> |
| | | <ClInclude Include="ProductionLogManager.h" /> |
| | | </ItemGroup> |
| | | <ItemGroup> |
| | | <ResourceCompile Include="Servo.rc" /> |
| | |
| | | m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); |
| | | m_crBkgnd = APPDLG_BACKGROUND_COLOR; |
| | | m_hbrBkgnd = nullptr; |
| | | m_bShowLogWnd = FALSE; |
| | | m_bShowAlarmWnd = FALSE; |
| | | m_pLogDlg = nullptr; |
| | | m_pAlarmDlg = nullptr; |
| | | m_pTerminalDisplayDlg = nullptr; |
| | | m_pObserver = nullptr; |
| | | m_pPanelMaster = nullptr; |
| | |
| | | m_pPanelAttributes = nullptr; |
| | | m_pPageGraph1 = nullptr; |
| | | m_pPageGraph2 = nullptr; |
| | | m_pPageAlarm = nullptr; |
| | | m_pPageLog = nullptr; |
| | | } |
| | | |
| | | void CServoDlg::DoDataExchange(CDataExchange* pDX) |
| | |
| | | ON_BN_CLICKED(IDCANCEL, &CServoDlg::OnBnClickedCancel) |
| | | ON_WM_CTLCOLOR() |
| | | ON_WM_DESTROY() |
| | | ON_BN_CLICKED(IDC_BUTTON_LOG, &CServoDlg::OnBnClickedButtonLog) |
| | | ON_WM_SIZE() |
| | | ON_WM_CLOSE() |
| | | ON_MESSAGE(ID_MSG_LOGDLG_HIDE, &CServoDlg::OnLogDlgHide) |
| | | ON_MESSAGE(ID_MSG_ALARMDLG_HIDE, &CServoDlg::OnAlarmDlgHide) |
| | | ON_WM_MOVING() |
| | | ON_WM_MOVE() |
| | | ON_COMMAND(ID_MENU_FILE_EXIT, &CServoDlg::OnMenuFileExit) |
| | |
| | | ON_UPDATE_COMMAND_UI(ID_MENU_FILE_SETTINGS, &CServoDlg::OnUpdateMenuFileSettings) |
| | | ON_COMMAND(ID_MENU_FILE_SECSTEST, &CServoDlg::OnMenuFileSecsTest) |
| | | ON_UPDATE_COMMAND_UI(ID_MENU_FILE_SECSTEST, &CServoDlg::OnUpdateMenuFileSecsTest) |
| | | ON_COMMAND(ID_MENU_WND_LOG, &CServoDlg::OnMenuWndLog) |
| | | ON_UPDATE_COMMAND_UI(ID_MENU_WND_LOG, &CServoDlg::OnUpdateMenuWndLog) |
| | | ON_COMMAND(ID_MENU_WND_ALARM, &CServoDlg::OnMenuWndAlarm) |
| | | ON_UPDATE_COMMAND_UI(ID_MENU_WND_ALARM, &CServoDlg::OnUpdateMenuWndAlarm) |
| | | ON_COMMAND(ID_MENU_TEST_MESSAGE_SET, &CServoDlg::OnMenuTestMessageSet) |
| | | ON_UPDATE_COMMAND_UI(ID_MENU_TEST_MESSAGE_SET, &CServoDlg::OnUpdateMenuTestMessageSet) |
| | | ON_COMMAND(ID_MENU_TEST_MESSAGE_CLEAR, &CServoDlg::OnMenuTestMessageClear) |
| | |
| | | ON_COMMAND(ID_MENU_HELP_ABOUT, &CServoDlg::OnMenuHelpAbout) |
| | | ON_WM_INITMENUPOPUP() |
| | | ON_WM_TIMER() |
| | | ON_BN_CLICKED(IDC_BUTTON_ALARM, &CServoDlg::OnBnClickedButtonAlarm) |
| | | ON_BN_CLICKED(IDC_BUTTON_ALARM, &CServoDlg::OnBnClickedButtonAlarm) |
| | | ON_MESSAGE(ID_MSG_PANEL_RESIZE, OnPanelResize) |
| | | ON_NOTIFY(BYHMTAB_SEL_CHANGED, IDC_TAB1, &CServoDlg::OnTabSelChanged) |
| | | END_MESSAGE_MAP() |
| | |
| | | SetMenu(&menu); |
| | | |
| | | |
| | | |
| | | // Tab |
| | | m_pPageGraph1 = new CPageGraph1(); |
| | | m_pPageGraph1->Create(IDD_PAGE_GRAPH1, this); |
| | | m_pPageGraph2 = new CPageGraph2(); |
| | | m_pPageGraph2->Create(IDD_PAGE_GRAPH2, this); |
| | | m_pPageAlarm = new CAlarmDlg(); |
| | | m_pPageAlarm->Create(IDD_DIALOG_ALARM, this); |
| | | m_pPageLog = new CLogDlg(); |
| | | m_pPageLog->Create(IDD_DIALOG_LOG, this); |
| | | |
| | | CHmTab* m_pTab = CHmTab::Hook(GetDlgItem(IDC_TAB1)->m_hWnd); |
| | | m_pTab->SetPaddingLeft(20); |
| | | m_pTab->SetItemMarginLeft(18); |
| | | m_pTab->AddItem("״̬ͼ", FALSE); |
| | | m_pTab->AddItem("è¿æ¥å¾", TRUE); |
| | | m_pTab->AddItem("æ¥è¦", TRUE); |
| | | m_pTab->AddItem("æ¥å¿", TRUE); |
| | | m_pTab->SetCurSel(0); |
| | | m_pTab->SetBkgndColor(RGB(222, 222, 222)); |
| | | ShowChildPage(0); |
| | |
| | | m_pPanelEquipment->Create(IDD_PANEL_EQUIPMENT, this); |
| | | m_pPanelAttributes = new CPanelAttributes(); |
| | | m_pPanelAttributes->Create(IDD_PANEL_ATTRIBUTES, this); |
| | | |
| | | |
| | | |
| | | // è°æ´åå§çªå£ä½ç½® |
| | |
| | | |
| | | SetTimer(TIMER_ID_CREATE_TERMINAL, 3000, nullptr); |
| | | InitRxWindows(); |
| | | OnBnClickedButtonLog(); |
| | | UpdateLogBtn(); |
| | | UpdateAlarmBtn(); |
| | | Resize(); |
| | | |
| | | |
| | | // ç¸å½äºå»¶æ¶è°ç¨masterçåå§å |
| | | theApp.m_model.m_master.init(); |
| | | |
| | | |
| | | // åå§åmaster以åéè¦æ§ä»¶ç»å®æ°æ® |
| | | m_pPageGraph1->BindEquipmentToGraph(); |
| | | |
| | | |
| | | return TRUE; // é¤éå°ç¦ç¹è®¾ç½®å°æ§ä»¶ï¼å¦åè¿å TRUE |
| | |
| | | pCmdUI->Enable(TRUE); |
| | | } |
| | | |
| | | void CServoDlg::OnMenuWndLog() |
| | | { |
| | | OnBnClickedButtonLog(); |
| | | } |
| | | |
| | | void CServoDlg::OnUpdateMenuWndLog(CCmdUI* pCmdUI) |
| | | { |
| | | pCmdUI->SetCheck(m_bShowLogWnd); |
| | | } |
| | | |
| | | void CServoDlg::OnMenuWndAlarm() |
| | | { |
| | | OnBnClickedButtonAlarm(); |
| | | } |
| | | |
| | | void CServoDlg::OnUpdateMenuWndAlarm(CCmdUI* pCmdUI) |
| | | { |
| | | pCmdUI->SetCheck(m_bShowAlarmWnd); |
| | | } |
| | | |
| | | void CServoDlg::OnMenuFileExit() |
| | | { |
| | | PostMessage(WM_CLOSE); |
| | |
| | | { |
| | | CDialogEx::OnDestroy(); |
| | | |
| | | if (m_pLogDlg != nullptr) { |
| | | m_pLogDlg->DestroyWindow(); |
| | | delete m_pLogDlg; |
| | | m_pLogDlg = nullptr; |
| | | } |
| | | |
| | | if (m_pAlarmDlg != nullptr) { |
| | | m_pAlarmDlg->DestroyWindow(); |
| | | delete m_pAlarmDlg; |
| | | m_pAlarmDlg = nullptr; |
| | | } |
| | | |
| | | if (m_pTerminalDisplayDlg != nullptr) { |
| | | m_pTerminalDisplayDlg->DestroyWindow(); |
| | |
| | | m_pPageGraph2 = nullptr; |
| | | } |
| | | |
| | | if (m_pPageAlarm != nullptr) { |
| | | m_pPageAlarm->DestroyWindow(); |
| | | delete m_pPageAlarm; |
| | | m_pPageAlarm = nullptr; |
| | | } |
| | | |
| | | if (m_pPageLog != nullptr) { |
| | | m_pPageLog->DestroyWindow(); |
| | | delete m_pPageLog; |
| | | m_pPageLog = nullptr; |
| | | } |
| | | |
| | | if (m_hbrBkgnd != nullptr) { |
| | | ::DeleteObject(m_hbrBkgnd); |
| | | } |
| | |
| | | |
| | | } |
| | | |
| | | void CServoDlg::OnBnClickedButtonAlarm() |
| | | { |
| | | m_bShowAlarmWnd = !m_bShowAlarmWnd; |
| | | |
| | | // å¦æè¦æ¾ç¤ºæ¥è¦çªå£ï¼åéèæ¥å¿çªå£ |
| | | if (m_bShowLogWnd) { |
| | | m_bShowLogWnd = false; |
| | | if (m_pLogDlg != nullptr) { |
| | | m_pLogDlg->ShowWindow(SW_HIDE); |
| | | UpdateLogBtn(); |
| | | } |
| | | } |
| | | |
| | | if (m_pAlarmDlg == nullptr) { |
| | | m_pAlarmDlg = new CAlarmDlg(); |
| | | m_pAlarmDlg->Create(IDD_DIALOG_ALARM, this); |
| | | |
| | | CRect rcWnd; |
| | | GetWindowRect(&rcWnd); |
| | | int nHeight = GetSystemMetrics(SM_CYSCREEN) - rcWnd.bottom - 38; |
| | | if (nHeight < 280) nHeight = 280; |
| | | m_pAlarmDlg->MoveWindow(rcWnd.left, rcWnd.bottom - 8, rcWnd.Width(), nHeight); |
| | | } |
| | | ASSERT(m_pAlarmDlg); |
| | | m_pAlarmDlg->ShowWindow(m_bShowAlarmWnd ? SW_SHOW : SW_HIDE); |
| | | |
| | | UpdateAlarmBtn(); |
| | | } |
| | | |
| | | void CServoDlg::OnBnClickedButtonLog() |
| | | { |
| | | m_bShowLogWnd = !m_bShowLogWnd; |
| | | |
| | | // å¦æè¦æ¾ç¤ºæ¥å¿çªå£ï¼åéèæ¥è¦çªå£ |
| | | if (m_bShowLogWnd) { |
| | | m_bShowAlarmWnd = false; |
| | | if (m_pAlarmDlg != nullptr) { |
| | | m_pAlarmDlg->ShowWindow(SW_HIDE); |
| | | UpdateAlarmBtn(); |
| | | } |
| | | } |
| | | |
| | | if (m_pLogDlg == nullptr) { |
| | | m_pLogDlg = new CLogDlg(); |
| | | m_pLogDlg->Create(IDD_DIALOG_LOG, this); |
| | | |
| | | CRect rcWnd; |
| | | GetWindowRect(&rcWnd); |
| | | int nHeight = GetSystemMetrics(SM_CYSCREEN) - rcWnd.bottom - 38; |
| | | if (nHeight < 280) nHeight = 280; |
| | | m_pLogDlg->MoveWindow(rcWnd.left, rcWnd.bottom - 8, rcWnd.Width(), nHeight); |
| | | } |
| | | ASSERT(m_pLogDlg); |
| | | m_pLogDlg->ShowWindow(m_bShowLogWnd ? SW_SHOW : SW_HIDE); |
| | | |
| | | UpdateLogBtn(); |
| | | } |
| | | |
| | | void CServoDlg::UpdateLogBtn() |
| | | { |
| | | m_btnLog.SetFrameColor(BS_NORMAL, BTN_LOG_FRAME_NORMAL); |
| | | m_btnLog.SetFrameColor(BS_HOVER, BTN_LOG_FRAME_HOVER); |
| | | m_btnLog.SetFrameColor(BS_PRESS, BTN_LOG_FRAME_PRESS); |
| | | m_btnLog.SetBkgndColor(BS_NORMAL, m_bShowLogWnd ? BTN_LOG_BKGND_PRESS : BTN_LOG_BKGND_NORMAL); |
| | | m_btnLog.SetBkgndColor(BS_HOVER, BTN_LOG_BKGND_HOVER); |
| | | m_btnLog.SetBkgndColor(BS_PRESS, BTN_LOG_BKGND_PRESS); |
| | | m_btnLog.Invalidate(); |
| | | } |
| | | |
| | | void CServoDlg::UpdateAlarmBtn() |
| | | { |
| | | m_btnAlarm.SetFrameColor(BS_NORMAL, BTN_ALARM_FRAME_NORMAL); |
| | | m_btnAlarm.SetFrameColor(BS_HOVER, BTN_ALARM_FRAME_HOVER); |
| | | m_btnAlarm.SetFrameColor(BS_PRESS, BTN_ALARM_FRAME_PRESS); |
| | | m_btnAlarm.SetBkgndColor(BS_NORMAL, m_bShowAlarmWnd ? BTN_ALARM_BKGND_PRESS : BTN_ALARM_BKGND_NORMAL); |
| | | m_btnAlarm.SetBkgndColor(BS_HOVER, BTN_ALARM_BKGND_HOVER); |
| | | m_btnAlarm.SetBkgndColor(BS_PRESS, BTN_ALARM_BKGND_PRESS); |
| | | m_btnAlarm.Invalidate(); |
| | | } |
| | | |
| | | void CServoDlg::OnSize(UINT nType, int cx, int cy) |
| | | { |
| | | CDialogEx::OnSize(nType, cx, cy); |
| | | if (GetDlgItem(IDC_TAB1) == nullptr) return; |
| | | if (m_pPageGraph1 == nullptr) return; |
| | | if (m_pPageGraph2 == nullptr) return; |
| | | if (m_pPageAlarm == nullptr) return; |
| | | if (m_pPageLog == nullptr) return; |
| | | |
| | | Resize(); |
| | | Invalidate(); |
| | |
| | | y += rcItem.Height(); |
| | | |
| | | |
| | | m_pPageGraph1->MoveWindow(x, y, rcClient.Width() - x, rcClient.Height()); |
| | | m_pPageGraph2->MoveWindow(x, y, rcClient.Width() - x, rcClient.Height()); |
| | | |
| | | |
| | | x = rcClient.right - 8; |
| | | pItem = GetDlgItem(IDC_BUTTON_LOG); |
| | | pItem->GetClientRect(&rcItem); |
| | | x -= rcItem.Width(); |
| | | pItem->MoveWindow(x, rcClient.bottom - 8 - rcItem.Height(), rcItem.Width(), rcItem.Height()); |
| | | x -= 8; |
| | | |
| | | pItem = GetDlgItem(IDC_BUTTON_ALARM); |
| | | pItem->GetClientRect(&rcItem); |
| | | x -= rcItem.Width(); |
| | | pItem->MoveWindow(x, rcClient.bottom - 8 - rcItem.Height(), rcItem.Width(), rcItem.Height()); |
| | | m_pPageGraph1->MoveWindow(x, y, rcClient.Width() - x, rcClient.Height() - y); |
| | | m_pPageGraph2->MoveWindow(x, y, rcClient.Width() - x, rcClient.Height() - y); |
| | | m_pPageAlarm->MoveWindow(x, y, rcClient.Width() - x, rcClient.Height() - y); |
| | | m_pPageLog->MoveWindow(x, y, rcClient.Width() - x, rcClient.Height() - y); |
| | | } |
| | | |
| | | void CServoDlg::OnClose() |
| | |
| | | CDialogEx::OnClose(); |
| | | } |
| | | |
| | | LRESULT CServoDlg::OnLogDlgHide(WPARAM wParam, LPARAM lParam) |
| | | { |
| | | m_bShowLogWnd = FALSE; |
| | | UpdateLogBtn(); |
| | | LOGE("OnLogDlgHide"); |
| | | |
| | | unsigned int DATAID, RPTID; |
| | | DATAID = 111; |
| | | RPTID = 1001; |
| | | std::vector<std::string> v; |
| | | v.push_back("abc"); |
| | | v.push_back("def"); |
| | | theApp.m_model.m_hsmsPassive.requestEventReportSend(DATAID, RPTID, v); |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | LRESULT CServoDlg::OnAlarmDlgHide(WPARAM wParam, LPARAM lParam) |
| | | { |
| | | m_bShowAlarmWnd = FALSE; |
| | | UpdateAlarmBtn(); |
| | | LOGE("OnAlarmDlgHide"); |
| | | |
| | | return 0; |
| | | } |
| | | |
| | | void CServoDlg::OnMoving(UINT fwSide, LPRECT pRect) |
| | | { |
| | | CDialogEx::OnMoving(fwSide, pRect); |
| | |
| | | |
| | | void CServoDlg::OnMove(int x, int y) |
| | | { |
| | | if (m_pLogDlg != nullptr && !m_pLogDlg->IsZoomed()) { |
| | | CRect rcWnd; |
| | | GetWindowRect(&rcWnd); |
| | | m_pLogDlg->SetWindowPos(nullptr, rcWnd.left, rcWnd.bottom - 8, 0, 0, SWP_NOSIZE); |
| | | } |
| | | |
| | | if (m_pAlarmDlg != nullptr && !m_pAlarmDlg->IsZoomed()) { |
| | | CRect rcWnd; |
| | | GetWindowRect(&rcWnd); |
| | | m_pAlarmDlg->SetWindowPos(nullptr, rcWnd.left, rcWnd.bottom - 8, 0, 0, SWP_NOSIZE); |
| | | } |
| | | |
| | | CDialogEx::OnMove(x, y); |
| | | } |
| | |
| | | |
| | | void CServoDlg::ShowChildPage(int index) |
| | | { |
| | | ASSERT(0 <= index && index < 3); |
| | | static CWnd* pPages[] = { m_pPageGraph1, m_pPageGraph2 }; |
| | | for (int i = 0; i < 2; i++) { |
| | | ASSERT(0 <= index && index < 4); |
| | | static CWnd* pPages[] = { m_pPageGraph1, m_pPageGraph2, m_pPageAlarm, m_pPageLog }; |
| | | for (int i = 0; i < 4; i++) { |
| | | pPages[i]->ShowWindow(i == index ? SW_SHOW : SW_HIDE); |
| | | } |
| | | } |
| | |
| | | private: |
| | | void InitRxWindows(); |
| | | void Resize(); |
| | | void UpdateLogBtn(); |
| | | void UpdateAlarmBtn(); |
| | | void ShowChildPage(int index); |
| | | |
| | | |
| | | private: |
| | | IObserver* m_pObserver; |
| | | BOOL m_bShowLogWnd; |
| | | BOOL m_bShowAlarmWnd; |
| | | CLogDlg* m_pLogDlg; |
| | | CAlarmDlg* m_pAlarmDlg; |
| | | CTerminalDisplayDlg* m_pTerminalDisplayDlg; |
| | | CPageGraph1* m_pPageGraph1; |
| | | CPageGraph2* m_pPageGraph2; |
| | | CAlarmDlg* m_pPageAlarm; |
| | | CLogDlg* m_pPageLog; |
| | | |
| | | |
| | | // å¯¹è¯æ¡æ°æ® |
| | |
| | | afx_msg void OnBnClickedCancel(); |
| | | afx_msg HBRUSH OnCtlColor(CDC* pDC, CWnd* pWnd, UINT nCtlColor); |
| | | afx_msg void OnDestroy(); |
| | | afx_msg void OnBnClickedButtonLog(); |
| | | afx_msg void OnSize(UINT nType, int cx, int cy); |
| | | afx_msg void OnClose(); |
| | | afx_msg LRESULT OnLogDlgHide(WPARAM wParam, LPARAM lParam); |
| | | afx_msg LRESULT OnAlarmDlgHide(WPARAM wParam, LPARAM lParam); |
| | | afx_msg void OnMoving(UINT fwSide, LPRECT pRect); |
| | | afx_msg void OnMove(int x, int y); |
| | | afx_msg void OnInitMenuPopup(CMenu* pPopupMenu, UINT nIndex, BOOL bSysMenu); |
| | |
| | | afx_msg void OnUpdateMenuFileSettings(CCmdUI* pCmdUI); |
| | | afx_msg void OnMenuFileSecsTest(); |
| | | afx_msg void OnUpdateMenuFileSecsTest(CCmdUI* pCmdUI); |
| | | afx_msg void OnMenuWndLog(); |
| | | afx_msg void OnUpdateMenuWndLog(CCmdUI* pCmdUI); |
| | | afx_msg void OnMenuWndAlarm(); |
| | | afx_msg void OnUpdateMenuWndAlarm(CCmdUI* pCmdUI); |
| | | afx_msg void OnMenuFileExit(); |
| | | afx_msg void OnUpdateMenuFileExit(CCmdUI* pCmdUI); |
| | | afx_msg void OnMenuTestMessageSet(); |
| | |
| | | afx_msg void OnUpdateMenuTestMessageClear(CCmdUI* pCmdUI); |
| | | afx_msg void OnMenuHelpAbout(); |
| | | afx_msg void OnTimer(UINT_PTR nIDEvent); |
| | | afx_msg void OnBnClickedButtonAlarm(); |
| | | afx_msg LRESULT OnPanelResize(WPARAM wParam, LPARAM lParam); |
| | | afx_msg void OnTabSelChanged(NMHDR* nmhdr, LRESULT* result); |
| | | }; |
| | |
| | | this->m_webviewController = controller; |
| | | this->m_webviewController->get_CoreWebView2(&this->m_webWiew); |
| | | } |
| | | else { |
| | | OutputDebugString(_T("WebView2 Controller å建失败ï¼\n")); |
| | | return E_FAIL; |
| | | } |
| | | // Add a few settings for the webview |
| | | // The demo step is redundant since the values are the default settings |
| | | wil::com_ptr<ICoreWebView2Settings> settings; |