From cf1497e3bba45ddc3b31cf9768954248bedc0bc1 Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期三, 14 一月 2026 16:03:21 +0800
Subject: [PATCH] 1.修复以下问题:Only-1 Job 支持:isProcessJobsEmpty()/validate 决定了当前实现只支持单个 PJ/CJ。Host 如果按标准一次下多 PJ 或在运行中追加 PJ,会被拒绝但无明确回应,容易引起 Host/设备状态脱节。

---
 SourceCode/Bond/Servo/ServoDlg.cpp |   59 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 58 insertions(+), 1 deletions(-)

diff --git a/SourceCode/Bond/Servo/ServoDlg.cpp b/SourceCode/Bond/Servo/ServoDlg.cpp
index 34c48f1..cdc423f 100644
--- a/SourceCode/Bond/Servo/ServoDlg.cpp
+++ b/SourceCode/Bond/Servo/ServoDlg.cpp
@@ -93,6 +93,7 @@
 	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
 	m_crBkgnd = APPDLG_BACKGROUND_COLOR;
 	m_hbrBkgnd = nullptr;
+	m_nLeftPanelType = 2;
 	m_pTerminalDisplayDlg = nullptr;
 	m_pObserver = nullptr;
 	m_pPanelMaster = nullptr;
@@ -142,6 +143,10 @@
 	ON_UPDATE_COMMAND_UI(ID_MENU_TEST_MESSAGE_CLEAR, &CServoDlg::OnUpdateMenuTestMessageClear)
 	ON_COMMAND(ID_MENU_TOOLS_CLIENT_LIST, &CServoDlg::OnMenuToolsClientList)
 	ON_UPDATE_COMMAND_UI(ID_MENU_TOOLS_CLIENT_LIST, &CServoDlg::OnUpdateMenuToolsClientList)
+	ON_COMMAND(ID_MENU_WND_TEST_PANEL, &CServoDlg::OnMenuWndTestPanel)
+	ON_UPDATE_COMMAND_UI(ID_MENU_WND_TEST_PANEL, &CServoDlg::OnUpdateMenuWndTestPanel)
+	ON_COMMAND(ID_MENU_WND_PRO_PANEL, &CServoDlg::OnMenuWndProPanel)
+	ON_UPDATE_COMMAND_UI(ID_MENU_WND_PRO_PANEL, &CServoDlg::OnUpdateMenuWndProPanel)
 	ON_COMMAND(ID_MENU_HELP_ABOUT, &CServoDlg::OnMenuHelpAbout)
 	ON_WM_INITMENUPOPUP()
 	ON_WM_TIMER()
@@ -435,7 +440,7 @@
 	m_pPanelProduction = new CPanelProduction();
 	m_pPanelProduction->setPanelWidth(nPanelWidth);
 	m_pPanelProduction->Create(IDD_PANEL_PRODUCTION, this);
-	m_pPanelProduction->ShowWindow(SW_SHOW);
+	SetLeftPanelType(m_nLeftPanelType, false);
 	m_pPanelEquipment = new CPanelEquipment();
 	m_pPanelEquipment->Create(IDD_PANEL_EQUIPMENT, this);
 	m_pPanelAttributes = new CPanelAttributes();
@@ -648,6 +653,10 @@
 	pPage3->Create(IDD_PAGE_VARIABLE);
 	dlg.addPage(pPage3, "Variable");
 
+	CPageDataVarialbles* pPage4 = new CPageDataVarialbles();
+	pPage4->Create(IDD_PAGE_VARIABLE);
+	dlg.addPage(pPage4, "DataVariable");
+
 	dlg.DoModal();
 }
 
@@ -693,6 +702,28 @@
 void CServoDlg::OnUpdateMenuToolsClientList(CCmdUI* pCmdUI)
 {
 	pCmdUI->Enable(TRUE);
+}
+
+void CServoDlg::OnMenuWndTestPanel()
+{
+	SetLeftPanelType(1);
+}
+
+void CServoDlg::OnUpdateMenuWndTestPanel(CCmdUI* pCmdUI)
+{
+	pCmdUI->Enable(TRUE);
+	pCmdUI->SetCheck(m_nLeftPanelType == 1);
+}
+
+void CServoDlg::OnMenuWndProPanel()
+{
+	SetLeftPanelType(2);
+}
+
+void CServoDlg::OnUpdateMenuWndProPanel(CCmdUI* pCmdUI)
+{
+	pCmdUI->Enable(TRUE);
+	pCmdUI->SetCheck(m_nLeftPanelType == 2);
 }
 
 void CServoDlg::OnMenuHelpAbout()
@@ -916,6 +947,32 @@
 	m_pMyStatusbar->MoveWindow(0, y2, rcClient.Width(), STATUSBAR_HEIGHT);
 }
 
+void CServoDlg::SetLeftPanelType(int type, bool resize)
+{
+	if (type != 1 && type != 2) {
+		type = 1;
+	}
+
+	m_nLeftPanelType = type;
+	if (m_pPanelMaster != nullptr) {
+		m_pPanelMaster->ShowWindow(SW_HIDE);
+	}
+	if (m_pPanelProduction != nullptr) {
+		m_pPanelProduction->ShowWindow(SW_HIDE);
+	}
+	if (type == 1 && m_pPanelMaster != nullptr) {
+		m_pPanelMaster->ShowWindow(SW_SHOW);
+	}
+	else if (type == 2 && m_pPanelProduction != nullptr) {
+		m_pPanelProduction->ShowWindow(SW_SHOW);
+	}
+
+	if (resize && ::IsWindow(m_hWnd)) {
+		Resize();
+		DrawMenuBar();
+	}
+}
+
 void CServoDlg::OnClose()
 {
 	// TODO: 鍦ㄦ娣诲姞娑堟伅澶勭悊绋嬪簭浠g爜鍜�/鎴栬皟鐢ㄩ粯璁ゅ��

--
Gitblit v1.9.3