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/BoounionPLC/PagePlcList.cpp |   16 ++++++++++++++++
 1 files changed, 16 insertions(+), 0 deletions(-)

diff --git a/SourceCode/Bond/BoounionPLC/PagePlcList.cpp b/SourceCode/Bond/BoounionPLC/PagePlcList.cpp
index 56b9ff5..fd94ec0 100644
--- a/SourceCode/Bond/BoounionPLC/PagePlcList.cpp
+++ b/SourceCode/Bond/BoounionPLC/PagePlcList.cpp
@@ -85,6 +85,18 @@
 					theApp.m_model.notifyPtr(RX_CODE_SELECT_PLC, pSelectedPlc);
 				}
 			}
+			else if (RX_PLC_STATE_CHANGED == code) {
+				CPLC* pPlc;
+				if (pAny->getPtrValue("ptr", (void*&)pPlc)) {
+					HTREEITEM hItem = FindItem(pPlc);
+					if (hItem != nullptr && pPlc->isConnected()) {
+						m_treeCtrl.ShowItemBadgeDotMode(hItem);
+					}
+					else {
+						m_treeCtrl.HideItemBadge(hItem);
+					}
+				}
+			}
 
 			pAny->release();
 		}, [&]() -> void {
@@ -191,6 +203,10 @@
 	for (auto item : plcs) {
 		HTREEITEM hItem = m_treeCtrl.InsertItem(item.second->getName().c_str(), nullptr, nullptr);
 		m_treeCtrl.SetItemData(hItem, (DWORD_PTR)item.second);
+		m_treeCtrl.SetItemBadge(hItem, TREE_BADGE_BACKGROUND, TREE_BADGE_FOREGROUND);
+		if (item.second->isConnected()) {
+			m_treeCtrl.ShowItemBadgeDotMode(hItem);
+		}
 		if (hItemFirst == nullptr) {
 			hItemFirst = hItem;
 		}

--
Gitblit v1.9.3