From 4597db5a8e60149028e87d57692d61b97c456350 Mon Sep 17 00:00:00 2001
From: mrDarker <mr.darker@163.com>
Date: 星期五, 06 六月 2025 14:22:24 +0800
Subject: [PATCH] 1. 添加Link Signal显示 2. 优化CJobSlotGrid::DrawGrid,支持文本换行

---
 SourceCode/Bond/Servo/JobSlotGrid.cpp |   59 +++++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 41 insertions(+), 18 deletions(-)

diff --git a/SourceCode/Bond/Servo/JobSlotGrid.cpp b/SourceCode/Bond/Servo/JobSlotGrid.cpp
index 12a4c2f..46551e6 100644
--- a/SourceCode/Bond/Servo/JobSlotGrid.cpp
+++ b/SourceCode/Bond/Servo/JobSlotGrid.cpp
@@ -229,9 +229,22 @@
     CRect rect;
     GetClientRect(&rect);
 
+    if (m_nCols == 0 || m_nRows == 0) {
+        return;
+    }
+
+    // 璁$畻鏍煎瓙灏哄
     int nCellWidth = rect.Width() / m_nCols;
     int nCellHeight = rect.Height() / m_nRows;
+
+    // 瀛椾綋璁剧疆
     CFont* pOldFont = pDC->SelectObject(&m_fontText);
+    pDC->SetBkMode(TRANSPARENT);
+    pDC->SetTextColor(RGB(0, 0, 0));
+
+    // 瀹氫箟棰滆壊甯搁噺
+    constexpr COLORREF COLOR_HOVER = RGB(200, 230, 255);
+    constexpr COLORREF COLOR_CLICK = RGB(0, 120, 215);
 
     for (int i = 0; i < m_nRows; ++i) {
         for (int j = 0; j < m_nCols; ++j) {
@@ -241,29 +254,39 @@
             bool bIsHover = (m_ptHover.x == j && m_ptHover.y == i);
             bool bIsClicking = bIsHover && m_bLButtonDown;
 
-            // 閫夋嫨棰滆壊
-            COLORREF fillColor;
-            if (bIsClicking) {
-                fillColor = RGB(0, 120, 215);   // 榧犳爣鎸変笅鑹�
-            }
-            else if (bIsHover) {
-                fillColor = RGB(200, 230, 255); // 鎮仠楂樹寒
-            }
-            else {
-                fillColor = m_vSlotStatus[i][j] ? m_colorHasJob : m_colorNoJob;
+            // 閫夋嫨濉厖棰滆壊
+            COLORREF fillColor = m_vSlotStatus[i][j] ? m_colorHasJob : m_colorNoJob;
+            if (IsSlotClickable(i, j)) {
+                if (bIsClicking)
+                    fillColor = COLOR_CLICK;
+                else if (bIsHover)
+                    fillColor = COLOR_HOVER;
             }
 
-            // 鐢昏儗鏅�
-            CBrush brush(fillColor);
-            pDC->FillRect(&cellRect, &brush);
+            // 缁樺埗鑳屾櫙锛堥珮鏁堟浛浠� CBrush锛�
+            pDC->FillSolidRect(&cellRect, fillColor);
 
-            // 杈规
+            // 缁樺埗杈规
             pDC->DrawEdge(&cellRect, EDGE_SUNKEN, BF_RECT);
 
-            // 鏂囨湰
-            pDC->SetBkMode(TRANSPARENT);
-            pDC->SetTextColor(RGB(0, 0, 0));
-            pDC->DrawText(m_vSlotText[i][j], &cellRect, DT_CENTER | DT_VCENTER | DT_SINGLELINE);
+            // 鑾峰彇鏂囧瓧锛堝畨鍏級
+            CString strText;
+            if (i < m_vSlotText.size() && j < m_vSlotText[i].size()) {
+                strText = m_vSlotText[i][j];
+            }
+
+            if (!strText.IsEmpty()) {
+                // 鍏堣绠楁枃瀛楅珮搴︼紙鏀寔鎹㈣锛�
+                CRect calcRect = cellRect;
+                pDC->DrawText(strText, &calcRect, DT_CENTER | DT_WORDBREAK | DT_NOPREFIX | DT_CALCRECT);
+
+                // 閲嶆柊璁惧畾灞呬腑缁樺埗鍖哄煙
+                CRect textRect = cellRect;
+                textRect.top += (cellRect.Height() - calcRect.Height()) / 2;
+
+                // 瀹為檯缁樺埗鏂囧瓧
+                pDC->DrawText(strText, &textRect, DT_CENTER | DT_WORDBREAK | DT_NOPREFIX);
+            }
         }
     }
 

--
Gitblit v1.9.3