From 68b1f4e85c29164d5de189262282454f9a0b1cc0 Mon Sep 17 00:00:00 2001
From: 张世豪 <979909237@qq.com>
Date: 星期二, 16 十二月 2025 16:27:41 +0800
Subject: [PATCH] 以割草机视图为中心显示功能

---
 src/set/Sets.java |   43 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 43 insertions(+), 0 deletions(-)

diff --git a/src/set/Sets.java b/src/set/Sets.java
index 39db2d6..1529e53 100644
--- a/src/set/Sets.java
+++ b/src/set/Sets.java
@@ -5,6 +5,7 @@
 import zhuye.MapRenderer;
 import zhuye.Shouye;
 import zhuye.buttonset;
+import set.Setsys;
 
 import javax.swing.*;
 import javax.swing.filechooser.FileNameExtensionFilter;
@@ -333,6 +334,48 @@
         setData.initializeFromProperties();
         baseStation.load();
         updateDisplay();
+        // 鍔犺浇骞跺簲鐢ㄤ笂娆′繚瀛樼殑瑙嗗浘涓績鍧愭爣
+        loadViewCenterFromProperties();
+    }
+    
+    /**
+     * 浠庨厤缃枃浠跺姞杞借鍥句腑蹇冨潗鏍囧苟搴旂敤鍒癕apRenderer
+     */
+    private void loadViewCenterFromProperties() {
+        Shouye shouye = Shouye.getInstance();
+        if (shouye == null) {
+            return;
+        }
+        MapRenderer renderer = shouye.getMapRenderer();
+        if (renderer == null) {
+            return;
+        }
+        
+        // 浠庨厤缃枃浠惰鍙栬鍥句腑蹇冨潗鏍�
+        String viewCenterXValue = Setsys.getPropertyValue("viewCenterX");
+        String viewCenterYValue = Setsys.getPropertyValue("viewCenterY");
+        
+        double savedTranslateX = 0.0;
+        double savedTranslateY = 0.0;
+        
+        if (viewCenterXValue != null && !viewCenterXValue.trim().isEmpty()) {
+            try {
+                savedTranslateX = Double.parseDouble(viewCenterXValue.trim());
+            } catch (NumberFormatException e) {
+                savedTranslateX = 0.0;
+            }
+        }
+        if (viewCenterYValue != null && !viewCenterYValue.trim().isEmpty()) {
+            try {
+                savedTranslateY = Double.parseDouble(viewCenterYValue.trim());
+            } catch (NumberFormatException e) {
+                savedTranslateY = 0.0;
+            }
+        }
+        
+        // 搴旂敤瑙嗗浘涓績鍧愭爣锛堜繚鎸佸綋鍓嶇缉鏀炬瘮渚嬶級
+        double currentScale = renderer.getScale();
+        renderer.setViewTransform(currentScale, savedTranslateX, savedTranslateY);
     }
     
     private void updateDisplay() {

--
Gitblit v1.10.0