From e8a27bb203fe2aff70390a5eca002d7438da9b0f Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期三, 22 十月 2025 14:24:34 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 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