From 4e5df2e71445ca3c0cc412e24510234e671b6072 Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期四, 19 六月 2025 16:18:33 +0800
Subject: [PATCH] Merge branch 'clh' into liuyang

---
 SourceCode/Bond/Servo/ServoGraph.h |   14 ++++++++++++++
 1 files changed, 14 insertions(+), 0 deletions(-)

diff --git a/SourceCode/Bond/Servo/ServoGraph.h b/SourceCode/Bond/Servo/ServoGraph.h
index a5ca74f..0440181 100644
--- a/SourceCode/Bond/Servo/ServoGraph.h
+++ b/SourceCode/Bond/Servo/ServoGraph.h
@@ -75,6 +75,7 @@
 		HBITMAP hBitmap;
 		int bmWidth;
 		int bmHeight;
+		float angle;
 	} IMAGE;
 
 
@@ -93,6 +94,7 @@
 			this->box2BackgroundColor = RGB(0, 255, 255);;
 			this->box2FrameColor = RGB(255, 255, 0);;
 			this->bBox2Visible = FALSE;
+			this->m_pData = nullptr;
 		};
 		~INDICATEBOX() {};
 
@@ -109,6 +111,7 @@
 		COLORREF box2FrameColor;
 		BOOL bBox2Visible;
 		std::vector<void*> m_contexts;
+		void* m_pData;
 	};
 
 	class INDICATEBKGND
@@ -141,6 +144,7 @@
 	LRESULT OnTimer(WPARAM wParam, LPARAM lParam);
 	LRESULT OnPaint(WPARAM wParam, LPARAM lParam);
 	LRESULT OnMouseMove(WPARAM wParam, LPARAM lParam);
+	LRESULT OnSize(WPARAM wParam, LPARAM lParam);
 	LRESULT OnLButtonDown(WPARAM wParam, LPARAM lParam);
 
 public:
@@ -153,6 +157,8 @@
 	BOOL RemoveIndicateBoxAllContext(int id);
 	const std::vector<void*>& GetIndicateBoxContexts(int id);
 	bool IsIndicateBoxContextsEmpty(int id);
+	void SetIndicateBoxData(int id, void* pData);
+	void* GetIndicateBoxData(int id);
 	void ShowIndicateBoxInterior(int id, COLORREF color);
 	void HideIndicateBoxInterior(int id);
 	CServoGraph::INDICATEBOX* GetIndicateBox(int id);
@@ -166,6 +172,14 @@
 	BOOL GetIndicateBoxRect(int id, LPRECT lprcBox);
 	void SetBoxText(int id, const char* pszText, const char* pszTooltip);
 	HWND GetSafeWnd();
+	void UpdateImageCoordinates(int id, int newX, int newY);
+	void UpdateIndicateBoxCoordinates(int id, int newX, int newY);
+	void UpdateImageAngle(int id, float angle);
+	void UpdateIndicateBox1Colors(int id, COLORREF newBackgroundColor, COLORREF newFrameColor1, COLORREF newFrameColor2);
+	void UpdateIndicateBox2Colors(int id, COLORREF newBackgroundColor, COLORREF newFrameColor);
+
+private:
+	void DrawImage(HDC hMemDC, IMAGE& item);
 
 private:
 	HWND		m_hWnd;

--
Gitblit v1.9.3