From 8d55ed4a167d9b09d65e4a26ece287c6e37a9c84 Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期五, 12 九月 2025 10:58:58 +0800
Subject: [PATCH] 1. 修复SG精度检编辑框修改覆盖问题(界面频繁刷新导致)

---
 SourceCode/Bond/Servo/CEquipment.cpp |   51 +++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 39 insertions(+), 12 deletions(-)

diff --git a/SourceCode/Bond/Servo/CEquipment.cpp b/SourceCode/Bond/Servo/CEquipment.cpp
index e390343..f89dcf9 100644
--- a/SourceCode/Bond/Servo/CEquipment.cpp
+++ b/SourceCode/Bond/Servo/CEquipment.cpp
@@ -5,6 +5,7 @@
 #include "CArm.h"
 #include "CGlassPool.h"
 #include "Servo.h"
+#include "GlassJson.h"
 
 
 namespace SERVO {
@@ -335,11 +336,16 @@
 			for (int i = 0; i < SLOT_MAX; i++) {
 				m_slot[i].serialize(ar);
 				CGlass* pGlass = (CGlass *)m_slot[i].getContext();
-				if (pGlass != nullptr) {					
-					pGlass->serialize(ar);
+				if (pGlass != nullptr) {
+					const std::string pretty = GlassJson::ToPrettyString(*pGlass);
+					CString strPretty = CString(pretty.c_str());
+					ar << strPretty;
+
 					CGlass* pBuddy = pGlass->getBuddy();
 					if (pBuddy != nullptr) {
-						pBuddy->serialize(ar);
+						const std::string prettyBuddy = GlassJson::ToPrettyString(*pBuddy);
+						CString strPrettyBuddy = CString(prettyBuddy.c_str());
+						ar << strPrettyBuddy;
 					}
 				}
 			}
@@ -349,17 +355,29 @@
 			for (int i = 0; i < SLOT_MAX; i++) {
 				m_slot[i].serialize(ar);
 				if (m_slot[i].getTempContext() != nullptr) {
-					CGlass* pGlass = theApp.m_model.m_glassPool.allocaGlass();
-					pGlass->serialize(ar);
-					m_slot[i].setContext(pGlass);
-					if (pGlass->getBuddy() != nullptr) {
-						CGlass* pBuddy = theApp.m_model.m_glassPool.allocaGlass();
-						pBuddy->serialize(ar);
-						pGlass->forceSetBuddy(pBuddy);
+					CString strPretty;
+					std::string pretty;
+					ar >> strPretty;
+					pretty = (LPTSTR)(LPCTSTR)strPretty;
+					if (!pretty.empty()) {
+						CGlass* pGlass = theApp.m_model.m_glassPool.allocaGlass();
+						GlassJson::FromString(pretty, *pGlass);
+						m_slot[i].setContext(pGlass);
+
+						if (!pGlass->getBuddyId().empty()) {
+							CGlass* pBuddy = theApp.m_model.m_glassPool.allocaGlass();
+							CString strPrettyBuddy;
+							std::string prettyBuddy;
+							ar >> strPrettyBuddy;
+							prettyBuddy = (LPTSTR)(LPCTSTR)strPrettyBuddy;
+							GlassJson::FromString(prettyBuddy, *pBuddy);
+							pGlass->forceSetBuddy(pBuddy);
+						}
 					}
+
 				}
 			}
-			
+
 			// 梳理各玻璃之间的绑定关系
 			/*
 			Lock();
@@ -917,6 +935,8 @@
 		ASSERT(pGlass);
 		Lock();
 		pGlass->addPath(m_nID, getSlotUnit(putSlot), putSlot);
+		CGlass* pBuddy = pGlass->getBuddy();
+		if (pBuddy != nullptr) pBuddy->addPath(m_nID, getSlotUnit(putSlot), putSlot);
 		m_slot[putSlot - 1].setContext(pGlass);
 		pGlass->release();				// tempFetchOut需要调用一次release
 		Unlock();
@@ -1563,7 +1583,14 @@
 		std::vector<CParam> params;
 		this->parsingParams((const char*)rawData.data(), rawData.size(), params);
 		pGlass->addParams(params);
-
+		
+		// 关联的Glass也要更新
+		CGlass* pBuddy = pGlass->getBuddy();
+		LOGI("<Equipment-%s>decodeProcessDataReport pBuddy=%x %s", getName().c_str(), pBuddy, pGlass->getID().c_str());
+		if (pBuddy != nullptr) {
+			LOGI("<Equipment-%s>decodeProcessDataReport addParams pBuddy=%x %s", getName().c_str(), pBuddy, pGlass->getID().c_str());
+			pBuddy->addParams(params);
+		}
 
 		return nRet;
 	}

--
Gitblit v1.9.3