From c498385fb7e372d13e2ee76d7b54ae2381728082 Mon Sep 17 00:00:00 2001
From: 张世豪 <979909237@qq.com>
Date: 星期三, 17 十二月 2025 19:35:57 +0800
Subject: [PATCH] 新增了测量模式

---
 src/set/Sets.java |  556 ++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 400 insertions(+), 156 deletions(-)

diff --git a/src/set/Sets.java b/src/set/Sets.java
index deaacd8..9a4d8c2 100644
--- a/src/set/Sets.java
+++ b/src/set/Sets.java
@@ -4,7 +4,8 @@
 
 import zhuye.MapRenderer;
 import zhuye.Shouye;
-
+import zhuye.buttonset;
+import zhuye.celiangmoshi;
 import javax.swing.*;
 import javax.swing.filechooser.FileNameExtensionFilter;
 
@@ -19,14 +20,15 @@
  */
 public class Sets extends JDialog {
     private static final long serialVersionUID = 1L;
-    private static final int ROW_HEIGHT = 40;
-    private static final int ROW_SPACING = 25;
+    private static final int ROW_HEIGHT = 50;  // 澧炲姞琛岄珮浠ラ�傚簲鍒嗗壊绾�
+    private static final int ITEM_PADDING = 16;  // 鍒楄〃椤瑰唴杈硅窛
     
     // 涓婚棰滆壊
     private final Color THEME_COLOR;
-    private final Color BACKGROUND_COLOR = new Color(250, 250, 250);
-    private final Color PANEL_BACKGROUND = new Color(255, 255, 255);
-    private final Color BORDER_COLOR = new Color(220, 220, 220);
+    private final Color BACKGROUND_COLOR = new Color(245, 247, 250);  // 鏇存煍鍜岀殑娴呯伆鑹茶儗鏅�
+    private final Color PANEL_BACKGROUND = new Color(255, 255, 255);  // 鐧借壊闈㈡澘
+    private final Color BORDER_COLOR = new Color(233, 236, 239);  // 娴呰竟妗嗚壊
+    private final Color DIVIDER_COLOR = new Color(233, 236, 239);  // 鍒嗗壊绾块鑹�
     
     // 璁剧疆椤圭粍浠�
     private JLabel mowerIdLabel;
@@ -37,12 +39,13 @@
     private JLabel firmwareVersionLabel;
     private JLabel appVersionLabel;
     private JLabel idleTrailDurationLabel;
+    private JLabel boundaryLengthVisibleLabel;
+    private JLabel measurementModeEnabledLabel;
     
     private JButton mowerIdEditBtn;
     private JButton baseStationIdEditBtn;
     private JButton handheldEditBtn;
     private JButton checkUpdateBtn;
-    private JButton systemDebugButton;
     private JButton feedbackButton;
     private JButton idleTrailEditBtn;
     
@@ -77,30 +80,42 @@
         setLocationRelativeTo(getParent());
         setResizable(false);
         
-        // 鍒涘缓涓诲唴瀹归潰鏉�
+        // 鍒涘缓涓诲唴瀹归潰鏉匡紙浣跨敤鏇存煍鍜岀殑娴呯伆鑹茶儗鏅級
         JPanel mainPanel = new JPanel();
-        mainPanel.setLayout(new BoxLayout(mainPanel, BoxLayout.Y_AXIS));
+        mainPanel.setLayout(new BorderLayout());
         mainPanel.setBackground(BACKGROUND_COLOR);
         mainPanel.setBorder(BorderFactory.createEmptyBorder(20, 20, 20, 20));
         
-        // 鍒涘缓璁剧疆椤归潰鏉�
+        // 鍒涘缓璁剧疆椤归潰鏉匡紙鍦嗚鐧借壊闈㈡澘锛�
         JPanel settingsPanel = createSettingsPanel();
         
         // 娣诲姞缁勪欢鍒颁富闈㈡澘
-        mainPanel.add(settingsPanel);
-        mainPanel.add(Box.createVerticalGlue());
+        mainPanel.add(settingsPanel, BorderLayout.CENTER);
         
         add(mainPanel, BorderLayout.CENTER);
     }
     
     private JPanel createSettingsPanel() {
+        // 鍒涘缓鍦嗚鐧借壊闈㈡澘瀹瑰櫒
+        JPanel container = new JPanel() {
+            @Override
+            protected void paintComponent(Graphics g) {
+                Graphics2D g2d = (Graphics2D) g.create();
+                g2d.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON);
+                g2d.setColor(PANEL_BACKGROUND);
+                // 缁樺埗鍦嗚鐭╁舰鑳屾櫙
+                g2d.fillRoundRect(0, 0, getWidth(), getHeight(), 16, 16);
+                g2d.dispose();
+            }
+        };
+        container.setLayout(new BorderLayout());
+        container.setOpaque(false);
+        
+        // 鍐呭闈㈡澘
         JPanel panel = new JPanel();
         panel.setLayout(new BoxLayout(panel, BoxLayout.Y_AXIS));
-        panel.setBackground(PANEL_BACKGROUND);
-        panel.setBorder(BorderFactory.createCompoundBorder(
-            BorderFactory.createLineBorder(BORDER_COLOR),
-            BorderFactory.createEmptyBorder(20, 20, 20, 20)
-        ));
+        panel.setOpaque(false);
+        panel.setBorder(BorderFactory.createEmptyBorder(8, 0, 8, 0));
         
         // 鍓茶崏鏈虹紪鍙�
         JPanel mowerIdPanel = createSettingItemPanel("鍓茶崏鏈虹紪鍙�", 
@@ -136,24 +151,50 @@
             formatIdleTrailDurationValue(), true);
         idleTrailDurationLabel = (JLabel) idleTrailPanel.getClientProperty("valueLabel");
         idleTrailEditBtn = (JButton) idleTrailPanel.getClientProperty("editButton");
+        
+        // 鏄剧ず杈圭晫璺濈璁剧疆椤�
+        JPanel boundaryLengthPanel = createBoundaryLengthPanel();
+        boundaryLengthVisibleLabel = (JLabel) boundaryLengthPanel.getClientProperty("valueLabel");
+        
+        // 寮�鍚祴閲忔ā寮忚缃」
+        JPanel measurementModePanel = createMeasurementModePanel();
+        measurementModeEnabledLabel = (JLabel) measurementModePanel.getClientProperty("valueLabel");
 
         JPanel feedbackPanel = createFeedbackPanel();
         
         // APP鐗堟湰
         JPanel appVersionPanel = createAppVersionPanel();
         
-    addRowWithSpacing(panel, mowerIdPanel);
-    addRowWithSpacing(panel, baseStationIdPanel);
-        addRowWithSpacing(panel, handheldPanel);
-    addRowWithSpacing(panel, simCardPanel);
-    addRowWithSpacing(panel, baseStationSimPanel);
-    addRowWithSpacing(panel, firmwarePanel);
-    addRowWithSpacing(panel, idleTrailPanel);
-    addRowWithSpacing(panel, feedbackPanel);
-    addRowWithSpacing(panel, appVersionPanel);
-    panel.add(createDebugPanel());
+        // 娣诲姞璁剧疆椤癸紝浣跨敤鍒嗗壊绾垮垎闅�
+        addSettingItem(panel, mowerIdPanel, true);
+        addSettingItem(panel, baseStationIdPanel, true);
+        addSettingItem(panel, handheldPanel, true);
+        addSettingItem(panel, simCardPanel, true);
+        addSettingItem(panel, baseStationSimPanel, true);
+        addSettingItem(panel, firmwarePanel, true);
+        addSettingItem(panel, idleTrailPanel, true);
+        addSettingItem(panel, boundaryLengthPanel, true);
+        addSettingItem(panel, measurementModePanel, true);
+        addSettingItem(panel, feedbackPanel, true);
+        addSettingItem(panel, appVersionPanel, false);  // 鏈�鍚庝竴椤逛笉鍔犲垎鍓茬嚎
         
-        return panel;
+        container.add(panel, BorderLayout.CENTER);
+        return container;
+    }
+    
+    /**
+     * 娣诲姞璁剧疆椤癸紙甯﹀垎鍓茬嚎锛�
+     */
+    private void addSettingItem(JPanel container, JPanel itemPanel, boolean showDivider) {
+        container.add(itemPanel);
+        if (showDivider) {
+            // 娣诲姞鍒嗗壊绾�
+            JSeparator divider = new JSeparator();
+            divider.setForeground(DIVIDER_COLOR);
+            divider.setMaximumSize(new Dimension(Integer.MAX_VALUE, 1));
+            divider.setAlignmentX(Component.LEFT_ALIGNMENT);
+            container.add(divider);
+        }
     }
 
     private String formatIdleTrailDurationValue() {
@@ -164,18 +205,15 @@
         return seconds + "绉�";
     }
 
-    private void addRowWithSpacing(JPanel container, JPanel row) {
-        container.add(row);
-        container.add(Box.createRigidArea(new Dimension(0, ROW_SPACING)));
-    }
     
     private JPanel createSettingItemPanel(String title, String value, boolean editable) {
         JPanel panel = new JPanel(new GridBagLayout());
-        panel.setBackground(PANEL_BACKGROUND);
+        panel.setOpaque(false);  // 閫忔槑鑳屾櫙锛岀敱瀹瑰櫒缁樺埗
         panel.setAlignmentX(Component.LEFT_ALIGNMENT);
         panel.setMaximumSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
         panel.setPreferredSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
         panel.setMinimumSize(new Dimension(0, ROW_HEIGHT));
+        panel.setBorder(BorderFactory.createEmptyBorder(ITEM_PADDING, ITEM_PADDING, ITEM_PADDING, ITEM_PADDING));
 
         GridBagConstraints gbc = new GridBagConstraints();
 
@@ -221,11 +259,12 @@
     
     private JPanel createAppVersionPanel() {
         JPanel panel = new JPanel(new GridBagLayout());
-        panel.setBackground(PANEL_BACKGROUND);
+        panel.setOpaque(false);  // 閫忔槑鑳屾櫙
         panel.setAlignmentX(Component.LEFT_ALIGNMENT);
         panel.setMaximumSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
         panel.setPreferredSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
         panel.setMinimumSize(new Dimension(0, ROW_HEIGHT));
+        panel.setBorder(BorderFactory.createEmptyBorder(ITEM_PADDING, ITEM_PADDING, ITEM_PADDING, ITEM_PADDING));
 
         GridBagConstraints gbc = new GridBagConstraints();
 
@@ -250,28 +289,8 @@
         gbc.anchor = GridBagConstraints.EAST;
         panel.add(appVersionLabel, gbc);
 
-    checkUpdateBtn = new JButton("妫�鏌ユ洿鏂�");
-    checkUpdateBtn.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
-    checkUpdateBtn.setBackground(THEME_COLOR);
-    checkUpdateBtn.setForeground(Color.WHITE);
-    checkUpdateBtn.setBorder(BorderFactory.createEmptyBorder(0, 20, 0, 20));
-    checkUpdateBtn.setPreferredSize(new Dimension(100, 28));
-    checkUpdateBtn.setMinimumSize(new Dimension(100, 28));
-    checkUpdateBtn.setMaximumSize(new Dimension(100, 28));
-        checkUpdateBtn.setFocusPainted(false);
-
-        checkUpdateBtn.addMouseListener(new MouseAdapter() {
-            public void mouseEntered(MouseEvent e) {
-                checkUpdateBtn.setBackground(new Color(
-                    Math.max(THEME_COLOR.getRed() - 20, 0),
-                    Math.max(THEME_COLOR.getGreen() - 20, 0),
-                    Math.max(THEME_COLOR.getBlue() - 20, 0)
-                ));
-            }
-            public void mouseExited(MouseEvent e) {
-                checkUpdateBtn.setBackground(THEME_COLOR);
-            }
-        });
+        checkUpdateBtn = buttonset.createStyledButton("妫�鏌ユ洿鏂�", THEME_COLOR);
+        checkUpdateBtn.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
 
         gbc = new GridBagConstraints();
         gbc.gridx = 2;
@@ -283,69 +302,14 @@
         return panel;
     }
 
-    private JPanel createDebugPanel() {
-        JPanel panel = new JPanel(new GridBagLayout());
-        panel.setBackground(PANEL_BACKGROUND);
-        panel.setAlignmentX(Component.LEFT_ALIGNMENT);
-        panel.setMaximumSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
-        panel.setPreferredSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
-        panel.setMinimumSize(new Dimension(0, ROW_HEIGHT));
-
-        GridBagConstraints gbc = new GridBagConstraints();
-
-        JLabel titleLabel = new JLabel("绯荤粺璋冭瘯");
-        titleLabel.setFont(new Font("寰蒋闆呴粦", Font.BOLD, 14));
-        titleLabel.setForeground(Color.BLACK);
-        titleLabel.setHorizontalAlignment(SwingConstants.RIGHT);
-        gbc.gridx = 0;
-        gbc.gridy = 0;
-        gbc.weightx = 0;
-        gbc.anchor = GridBagConstraints.EAST;
-        gbc.insets = new Insets(0, 0, 0, 12);
-        panel.add(titleLabel, gbc);
-
-        systemDebugButton = new JButton("绯荤粺璋冭瘯");
-        systemDebugButton.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
-        systemDebugButton.setBackground(new Color(
-            Math.max(THEME_COLOR.getRed() - 20, 0),
-            Math.max(THEME_COLOR.getGreen() - 20, 0),
-            Math.max(THEME_COLOR.getBlue() - 20, 0)));
-        systemDebugButton.setForeground(Color.WHITE);
-        systemDebugButton.setBorder(BorderFactory.createEmptyBorder(0, 20, 0, 20));
-        systemDebugButton.setPreferredSize(new Dimension(100, 28));
-        systemDebugButton.setMinimumSize(new Dimension(100, 28));
-        systemDebugButton.setMaximumSize(new Dimension(100, 28));
-        systemDebugButton.setFocusPainted(false);
-
-        systemDebugButton.addMouseListener(new MouseAdapter() {
-            public void mouseEntered(MouseEvent e) {
-                systemDebugButton.setBackground(THEME_COLOR);
-            }
-            public void mouseExited(MouseEvent e) {
-                systemDebugButton.setBackground(new Color(
-                    Math.max(THEME_COLOR.getRed() - 20, 0),
-                    Math.max(THEME_COLOR.getGreen() - 20, 0),
-                    Math.max(THEME_COLOR.getBlue() - 20, 0)));
-            }
-        });
-
-        gbc = new GridBagConstraints();
-        gbc.gridx = 1;
-        gbc.gridy = 0;
-        gbc.weightx = 1.0;
-        gbc.anchor = GridBagConstraints.EAST;
-        panel.add(systemDebugButton, gbc);
-
-        return panel;
-    }
-
     private JPanel createFeedbackPanel() {
         JPanel panel = new JPanel(new GridBagLayout());
-        panel.setBackground(PANEL_BACKGROUND);
+        panel.setOpaque(false);  // 閫忔槑鑳屾櫙
         panel.setAlignmentX(Component.LEFT_ALIGNMENT);
         panel.setMaximumSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
         panel.setPreferredSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
         panel.setMinimumSize(new Dimension(0, ROW_HEIGHT));
+        panel.setBorder(BorderFactory.createEmptyBorder(ITEM_PADDING, ITEM_PADDING, ITEM_PADDING, ITEM_PADDING));
 
         GridBagConstraints gbc = new GridBagConstraints();
 
@@ -360,30 +324,8 @@
         gbc.insets = new Insets(0, 0, 0, 12);
         panel.add(titleLabel, gbc);
 
-        feedbackButton = new JButton("鍙嶉");
+        feedbackButton = buttonset.createStyledButton("鍙嶉", THEME_COLOR);
         feedbackButton.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
-        feedbackButton.setBackground(THEME_COLOR);
-        feedbackButton.setForeground(Color.WHITE);
-        feedbackButton.setBorder(BorderFactory.createEmptyBorder(0, 20, 0, 20));
-        feedbackButton.setPreferredSize(new Dimension(100, 28));
-        feedbackButton.setMinimumSize(new Dimension(100, 28));
-        feedbackButton.setMaximumSize(new Dimension(100, 28));
-        feedbackButton.setFocusPainted(false);
-
-        feedbackButton.addMouseListener(new MouseAdapter() {
-            @Override
-            public void mouseEntered(MouseEvent e) {
-                feedbackButton.setBackground(new Color(
-                        Math.max(THEME_COLOR.getRed() - 20, 0),
-                        Math.max(THEME_COLOR.getGreen() - 20, 0),
-                        Math.max(THEME_COLOR.getBlue() - 20, 0)));
-            }
-
-            @Override
-            public void mouseExited(MouseEvent e) {
-                feedbackButton.setBackground(THEME_COLOR);
-            }
-        });
 
         gbc = new GridBagConstraints();
         gbc.gridx = 1;
@@ -395,6 +337,253 @@
         return panel;
     }
     
+    /**
+     * 鍒涘缓鏄剧ず杈圭晫璺濈璁剧疆闈㈡澘
+     */
+    private JPanel createBoundaryLengthPanel() {
+        JPanel panel = new JPanel(new GridBagLayout());
+        panel.setOpaque(false);  // 閫忔槑鑳屾櫙
+        panel.setAlignmentX(Component.LEFT_ALIGNMENT);
+        panel.setMaximumSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
+        panel.setPreferredSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
+        panel.setMinimumSize(new Dimension(0, ROW_HEIGHT));
+        panel.setBorder(BorderFactory.createEmptyBorder(ITEM_PADDING, ITEM_PADDING, ITEM_PADDING, ITEM_PADDING));
+
+        GridBagConstraints gbc = new GridBagConstraints();
+
+        JLabel titleLabel = new JLabel("鏄剧ず杈圭晫璺濈");
+        titleLabel.setFont(new Font("寰蒋闆呴粦", Font.BOLD, 14));
+        titleLabel.setForeground(Color.BLACK);
+        titleLabel.setHorizontalAlignment(SwingConstants.RIGHT);
+        gbc.gridx = 0;
+        gbc.gridy = 0;
+        gbc.weightx = 0;
+        gbc.anchor = GridBagConstraints.EAST;
+        gbc.insets = new Insets(0, 0, 0, 12);
+        panel.add(titleLabel, gbc);
+
+        boundaryLengthVisibleLabel = new JLabel(setData.isBoundaryLengthVisible() ? "宸插紑鍚�" : "宸插叧闂�");
+        boundaryLengthVisibleLabel.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 14));
+        boundaryLengthVisibleLabel.setForeground(Color.DARK_GRAY);
+        gbc = new GridBagConstraints();
+        gbc.gridx = 1;
+        gbc.gridy = 0;
+        gbc.weightx = 1.0;
+        gbc.anchor = GridBagConstraints.EAST;
+        panel.add(boundaryLengthVisibleLabel, gbc);
+
+        panel.putClientProperty("valueLabel", boundaryLengthVisibleLabel);
+
+        // 鍒涘缓鍒囨崲鎸夐挳锛堜娇鐢ㄥ浘鏍囷級
+        JButton toggleBtn = createBoundaryLengthToggleButton();
+        gbc = new GridBagConstraints();
+        gbc.gridx = 2;
+        gbc.gridy = 0;
+        gbc.weightx = 0;
+        gbc.anchor = GridBagConstraints.EAST;
+        panel.add(toggleBtn, gbc);
+        panel.putClientProperty("toggleButton", toggleBtn);
+
+        return panel;
+    }
+    
+    /**
+     * 鍒涘缓寮�鍚祴閲忔ā寮忚缃潰鏉�
+     */
+    private JPanel createMeasurementModePanel() {
+        JPanel panel = new JPanel(new GridBagLayout());
+        panel.setOpaque(false);  // 閫忔槑鑳屾櫙
+        panel.setAlignmentX(Component.LEFT_ALIGNMENT);
+        panel.setMaximumSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
+        panel.setPreferredSize(new Dimension(Integer.MAX_VALUE, ROW_HEIGHT));
+        panel.setMinimumSize(new Dimension(0, ROW_HEIGHT));
+        panel.setBorder(BorderFactory.createEmptyBorder(ITEM_PADDING, ITEM_PADDING, ITEM_PADDING, ITEM_PADDING));
+
+        GridBagConstraints gbc = new GridBagConstraints();
+
+        JLabel titleLabel = new JLabel("寮�鍚祴閲忔ā寮�");
+        titleLabel.setFont(new Font("寰蒋闆呴粦", Font.BOLD, 14));
+        titleLabel.setForeground(Color.BLACK);
+        titleLabel.setHorizontalAlignment(SwingConstants.RIGHT);
+        gbc.gridx = 0;
+        gbc.gridy = 0;
+        gbc.weightx = 0;
+        gbc.anchor = GridBagConstraints.EAST;
+        gbc.insets = new Insets(0, 0, 0, 12);
+        panel.add(titleLabel, gbc);
+
+        measurementModeEnabledLabel = new JLabel(setData.isMeasurementModeEnabled() ? "宸插紑鍚�" : "宸插叧闂�");
+        measurementModeEnabledLabel.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 14));
+        measurementModeEnabledLabel.setForeground(Color.DARK_GRAY);
+        gbc = new GridBagConstraints();
+        gbc.gridx = 1;
+        gbc.gridy = 0;
+        gbc.weightx = 1.0;
+        gbc.anchor = GridBagConstraints.EAST;
+        panel.add(measurementModeEnabledLabel, gbc);
+
+        panel.putClientProperty("valueLabel", measurementModeEnabledLabel);
+
+        // 鍒涘缓鍒囨崲鎸夐挳锛堜娇鐢ㄥ浘鏍囷級
+        JButton toggleBtn = createMeasurementModeToggleButton();
+        gbc = new GridBagConstraints();
+        gbc.gridx = 2;
+        gbc.gridy = 0;
+        gbc.weightx = 0;
+        gbc.anchor = GridBagConstraints.EAST;
+        panel.add(toggleBtn, gbc);
+        panel.putClientProperty("toggleButton", toggleBtn);
+
+        return panel;
+    }
+    
+    /**
+     * 鍒涘缓娴嬮噺妯″紡鍒囨崲鎸夐挳
+     */
+    private JButton createMeasurementModeToggleButton() {
+        JButton button = new JButton();
+        button.setContentAreaFilled(false);
+        button.setBorder(null);
+        button.setFocusPainted(false);
+        button.setCursor(new Cursor(Cursor.HAND_CURSOR));
+        button.setPreferredSize(new Dimension(32, 32));
+        button.setMinimumSize(new Dimension(32, 32));
+        button.setMaximumSize(new Dimension(32, 32));
+        
+        updateMeasurementModeToggleButton(button);
+        
+        button.addActionListener(e -> toggleMeasurementMode(button));
+        
+        return button;
+    }
+    
+    /**
+     * 鏇存柊娴嬮噺妯″紡鍒囨崲鎸夐挳鍥炬爣
+     */
+    private void updateMeasurementModeToggleButton(JButton button) {
+        boolean isEnabled = setData.isMeasurementModeEnabled();
+        try {
+            String iconPath = isEnabled ? "image/open.png" : "image/close.png";
+            ImageIcon icon = new ImageIcon(iconPath);
+            if (icon.getIconWidth() > 0) {
+                Image scaledImage = icon.getImage().getScaledInstance(32, 32, Image.SCALE_SMOOTH);
+                button.setIcon(new ImageIcon(scaledImage));
+                button.setText(null);
+            } else {
+                button.setIcon(null);
+                button.setText(isEnabled ? "寮�" : "鍏�");
+            }
+        } catch (Exception e) {
+            button.setIcon(null);
+            button.setText(isEnabled ? "寮�" : "鍏�");
+            System.err.println("鏃犳硶鍔犺浇娴嬮噺妯″紡鍥炬爣: " + e.getMessage());
+        }
+    }
+    
+    /**
+     * 鍒囨崲娴嬮噺妯″紡鐘舵��
+     */
+    private void toggleMeasurementMode(JButton button) {
+        boolean newValue = !setData.isMeasurementModeEnabled();
+        setData.setMeasurementModeEnabled(newValue);
+        
+        // 淇濆瓨鍒伴厤缃枃浠�
+        setData.updateProperty("measurementModeEnabled", String.valueOf(newValue));
+        
+        // 鏇存柊UI
+        if (measurementModeEnabledLabel != null) {
+            measurementModeEnabledLabel.setText(newValue ? "宸插紑鍚�" : "宸插叧闂�");
+        }
+        updateMeasurementModeToggleButton(button);
+        
+        // 閫氱煡MapRenderer鏇存柊
+        Shouye shouye = Shouye.getInstance();
+        if (shouye != null) {
+            MapRenderer renderer = shouye.getMapRenderer();
+            if (renderer != null) {
+                renderer.setMeasurementMode(newValue);
+            }
+            if (newValue) {
+                celiangmoshi.start();
+            } else {
+                celiangmoshi.stop();
+            }
+            // 鍒锋柊鍦板浘鏄剧ず锛堥�氳繃MapRenderer瑙﹀彂閲嶇粯锛�
+            if (renderer != null) {
+                renderer.repaint();
+            }
+        }
+    }
+    
+    /**
+     * 鍒涘缓杈圭晫璺濈鏄剧ず鍒囨崲鎸夐挳
+     */
+    private JButton createBoundaryLengthToggleButton() {
+        JButton button = new JButton();
+        button.setContentAreaFilled(false);
+        button.setBorder(null);
+        button.setFocusPainted(false);
+        button.setCursor(new Cursor(Cursor.HAND_CURSOR));
+        button.setPreferredSize(new Dimension(32, 32));
+        button.setMinimumSize(new Dimension(32, 32));
+        button.setMaximumSize(new Dimension(32, 32));
+        
+        updateBoundaryLengthToggleButton(button);
+        
+        button.addActionListener(e -> toggleBoundaryLengthVisible(button));
+        
+        return button;
+    }
+    
+    /**
+     * 鏇存柊杈圭晫璺濈鍒囨崲鎸夐挳鍥炬爣
+     */
+    private void updateBoundaryLengthToggleButton(JButton button) {
+        boolean isVisible = setData.isBoundaryLengthVisible();
+        try {
+            String iconPath = isVisible ? "image/open.png" : "image/close.png";
+            ImageIcon icon = new ImageIcon(iconPath);
+            if (icon.getIconWidth() > 0) {
+                Image scaledImage = icon.getImage().getScaledInstance(32, 32, Image.SCALE_SMOOTH);
+                button.setIcon(new ImageIcon(scaledImage));
+                button.setText(null);
+            } else {
+                button.setIcon(null);
+                button.setText(isVisible ? "寮�" : "鍏�");
+            }
+        } catch (Exception e) {
+            button.setIcon(null);
+            button.setText(isVisible ? "寮�" : "鍏�");
+            System.err.println("鏃犳硶鍔犺浇杈圭晫璺濈鍥炬爣: " + e.getMessage());
+        }
+    }
+    
+    /**
+     * 鍒囨崲杈圭晫璺濈鏄剧ず鐘舵��
+     */
+    private void toggleBoundaryLengthVisible(JButton button) {
+        boolean newValue = !setData.isBoundaryLengthVisible();
+        setData.setBoundaryLengthVisible(newValue);
+        
+        // 淇濆瓨鍒伴厤缃枃浠�
+        setData.updateProperty("boundaryLengthVisible", String.valueOf(newValue));
+        
+        // 鏇存柊UI
+        if (boundaryLengthVisibleLabel != null) {
+            boundaryLengthVisibleLabel.setText(newValue ? "宸插紑鍚�" : "宸插叧闂�");
+        }
+        updateBoundaryLengthToggleButton(button);
+        
+        // 閫氱煡MapRenderer鏇存柊
+        Shouye shouye = Shouye.getInstance();
+        if (shouye != null) {
+            MapRenderer renderer = shouye.getMapRenderer();
+            if (renderer != null) {
+                renderer.setBoundaryLengthVisible(newValue);
+            }
+        }
+    }
+    
     private JButton createEditButton() {
         JButton button = new JButton();
         try {
@@ -432,6 +621,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() {
@@ -468,6 +699,32 @@
             idleTrailDurationLabel.setText(formatIdleTrailDurationValue());
         }
         
+        // 鏇存柊鏄剧ず杈圭晫璺濈鐘舵��
+        if (boundaryLengthVisibleLabel != null) {
+            boundaryLengthVisibleLabel.setText(setData.isBoundaryLengthVisible() ? "宸插紑鍚�" : "宸插叧闂�");
+        }
+        // 鏇存柊鍒囨崲鎸夐挳鍥炬爣
+        JPanel boundaryLengthPanel = (JPanel) boundaryLengthVisibleLabel.getParent();
+        if (boundaryLengthPanel != null) {
+            JButton toggleBtn = (JButton) boundaryLengthPanel.getClientProperty("toggleButton");
+            if (toggleBtn != null) {
+                updateBoundaryLengthToggleButton(toggleBtn);
+            }
+        }
+        
+        // 鏇存柊娴嬮噺妯″紡鐘舵��
+        if (measurementModeEnabledLabel != null) {
+            measurementModeEnabledLabel.setText(setData.isMeasurementModeEnabled() ? "宸插紑鍚�" : "宸插叧闂�");
+        }
+        // 鏇存柊娴嬮噺妯″紡鍒囨崲鎸夐挳鍥炬爣
+        JPanel measurementModePanel = (JPanel) measurementModeEnabledLabel.getParent();
+        if (measurementModePanel != null) {
+            JButton toggleBtn = (JButton) measurementModePanel.getClientProperty("toggleButton");
+            if (toggleBtn != null) {
+                updateMeasurementModeToggleButton(toggleBtn);
+            }
+        }
+        
         // 鏇存柊APP鐗堟湰鏄剧ず
         if (appVersionLabel != null) {
             appVersionLabel.setText(setData.getAppVersion() != null ? 
@@ -528,10 +785,6 @@
             feedbackButton.addActionListener(e -> showFeedbackDialog());
         }
 
-        if (systemDebugButton != null) {
-            systemDebugButton.addActionListener(e -> openSystemDebugDialog());
-        }
-
         if (idleTrailEditBtn != null) {
             idleTrailEditBtn.addActionListener(e -> editIdleTrailDuration());
         }
@@ -715,9 +968,8 @@
         photoControls.setAlignmentX(Component.LEFT_ALIGNMENT);
         JLabel photoLabel = new JLabel("閫夋嫨鐓х墖锛堟渶澶�6寮狅級锛�");
         photoLabel.setFont(new Font("寰蒋闆呴粦", Font.BOLD, 13));
-        JButton selectPhotosButton = new JButton("閫夋嫨鐓х墖");
-        selectPhotosButton.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
-        selectPhotosButton.setFocusPainted(false);
+    JButton selectPhotosButton = buttonset.createStyledButton("閫夋嫨鐓х墖", THEME_COLOR);
+    selectPhotosButton.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
         photoControls.add(photoLabel);
         photoControls.add(selectPhotosButton);
     content.add(photoControls);
@@ -737,13 +989,11 @@
 
         content.add(Box.createRigidArea(new Dimension(0, 20)));
 
-        JPanel buttonPanel = new JPanel(new FlowLayout(FlowLayout.RIGHT));
-        JButton cancelButton = new JButton("鏀惧純");
-        JButton submitButton = new JButton("鎻愪氦");
-        submitButton.setBackground(THEME_COLOR);
-        submitButton.setForeground(Color.WHITE);
-        submitButton.setFocusPainted(false);
-        cancelButton.setFocusPainted(false);
+    JPanel buttonPanel = new JPanel(new FlowLayout(FlowLayout.RIGHT));
+    JButton cancelButton = buttonset.createStyledButton("鏀惧純", new Color(128, 128, 128));
+    cancelButton.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
+    JButton submitButton = buttonset.createStyledButton("鎻愪氦", THEME_COLOR);
+    submitButton.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 12));
 
         buttonPanel.add(cancelButton);
         buttonPanel.add(submitButton);
@@ -852,12 +1102,6 @@
         timer.setRepeats(false);
         timer.start();
     }
-
-    private void openSystemDebugDialog() {
-        debug dialog = new debug(this, THEME_COLOR);
-        dialog.setLocationRelativeTo(this);
-        dialog.setVisible(true);
-    }
     
     @Override
     public void setVisible(boolean visible) {

--
Gitblit v1.10.0