From 3d415216b8d8f101ab543dbbf22e313507a402ca Mon Sep 17 00:00:00 2001
From: 张世豪 <979909237@qq.com>
Date: 星期二, 23 十二月 2025 12:14:30 +0800
Subject: [PATCH] 优化了地块边界管理页面

---
 src/zhuye/Shouye.java |  193 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 193 insertions(+), 0 deletions(-)

diff --git a/src/zhuye/Shouye.java b/src/zhuye/Shouye.java
index 27a166d..a59e71d 100644
--- a/src/zhuye/Shouye.java
+++ b/src/zhuye/Shouye.java
@@ -131,8 +131,10 @@
 	private Runnable pathPreviewReturnAction;
 	private JButton settingsReturnButton;  // 杩斿洖绯荤粺璁剧疆椤甸潰鐨勬偓娴寜閽�
 	private JButton saveManualBoundaryButton;  // 淇濆瓨鎵嬪姩缁樺埗杈圭晫鐨勬寜閽�
+	private JButton toggleBoundaryDisplayButton;  // 鍒囨崲杈圭晫鏄剧ず鎸夐挳锛堝彧鏄剧ず鍘熷杈圭晫/鏄剧ず鍏ㄩ儴锛�
 	private String previewRestoreLandNumber;
 	private String previewRestoreLandName;
+	private Dikuai currentBoundaryPreviewDikuai;  // 褰撳墠杈圭晫棰勮鐨勫湴鍧楀紩鐢�
 	private boolean drawingPaused;
 	private ImageIcon pauseIcon;
 	private ImageIcon pauseActiveIcon;
@@ -3238,6 +3240,13 @@
 			floatingButtonColumn.add(pathPreviewReturnButton);
 			added = true;
 		}
+		if (toggleBoundaryDisplayButton != null && toggleBoundaryDisplayButton.isVisible()) {
+			if (added) {
+				floatingButtonColumn.add(Box.createRigidArea(new Dimension(0, 10)));
+			}
+			floatingButtonColumn.add(toggleBoundaryDisplayButton);
+			added = true;
+		}
 		if (saveManualBoundaryButton != null && saveManualBoundaryButton.isVisible()) {
 			if (added) {
 				floatingButtonColumn.add(Box.createRigidArea(new Dimension(0, 10)));
@@ -4296,6 +4305,190 @@
             pathPreviewReturnAction.run();
         }
     }
+    
+    /**
+     * 鏄剧ず杈圭晫棰勮锛堝師濮嬭竟鐣�-绱壊锛屼紭鍖栧悗杈圭晫-缁胯壊锛�
+     * @param dikuai 鍦板潡瀵硅薄
+     * @param optimizedBoundary 浼樺寲鍚庣殑杈圭晫鍧愭爣瀛楃涓�
+     * @param returnCallback 杩斿洖鍥炶皟
+     */
+    public static void showBoundaryPreview(dikuai.Dikuai dikuai, String optimizedBoundary, Runnable returnCallback) {
+        Shouye shouye = getInstance();
+        if (shouye == null || shouye.mapRenderer == null || dikuai == null) {
+            return;
+        }
+        
+        // 淇濆瓨褰撳墠鍦板潡寮曠敤
+        shouye.currentBoundaryPreviewDikuai = dikuai;
+        
+        // 鑾峰彇鍘熷杈圭晫XY鍧愭爣
+        String originalBoundaryXY = dikuai.getBoundaryOriginalXY();
+        
+        // 璁剧疆杈圭晫棰勮
+        shouye.mapRenderer.setBoundaryPreview(originalBoundaryXY, optimizedBoundary);
+        
+        // 璁剧疆杈圭晫棰勮鏇存柊鍥炶皟锛岀敤浜庝繚瀛樺垹闄ゅ潗鏍囩偣鍚庣殑杈圭晫
+        shouye.mapRenderer.setBoundaryPreviewUpdateCallback(updatedBoundary -> {
+            if (shouye.currentBoundaryPreviewDikuai != null && updatedBoundary != null) {
+                // 淇濆瓨鏇存柊鍚庣殑杈圭晫鍧愭爣
+                Dikuai.updateField(shouye.currentBoundaryPreviewDikuai.getLandNumber(), "boundaryCoordinates", updatedBoundary);
+                java.text.SimpleDateFormat sdf = new java.text.SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+                Dikuai.updateField(shouye.currentBoundaryPreviewDikuai.getLandNumber(), "updateTime", sdf.format(new java.util.Date()));
+                Dikuai.saveToProperties();
+                
+                // 鍚屾鏇存柊褰撳墠鍦板潡瀵硅薄鐨勫唴瀛樺�硷紙纭繚杩斿洖鏃惰兘鑾峰彇鍒版渶鏂板�硷級
+                shouye.currentBoundaryPreviewDikuai.setBoundaryCoordinates(updatedBoundary);
+                
+                // 鏇存柊棰勮杈圭晫锛堥噸鏂拌缃互鍒锋柊鏄剧ず锛�
+                shouye.mapRenderer.setBoundaryPreview(originalBoundaryXY, updatedBoundary);
+            }
+        });
+        
+        // 鍋滄缁樺埗鍓茶崏鏈哄疄鏃舵嫋灏�
+        if (shouye.mapRenderer != null) {
+            shouye.mapRenderer.setIdleTrailSuppressed(true);
+        }
+        
+        // 璁剧疆杩斿洖鍥炶皟
+        shouye.pathPreviewReturnAction = returnCallback;
+        shouye.pathPreviewActive = true;
+        
+        // 纭繚鎮诞鎸夐挳鍩虹璁炬柦宸插垱寤�
+        shouye.ensureFloatingButtonInfrastructure();
+        
+        // 鍒涘缓鎴栨樉绀鸿繑鍥炴寜閽�
+        if (shouye.pathPreviewReturnButton == null) {
+            shouye.pathPreviewReturnButton = publicway.Fanhuibutton.createReturnButton(e -> shouye.handleBoundaryPreviewReturn());
+            shouye.pathPreviewReturnButton.setToolTipText("杩斿洖杈圭晫缂栬緫椤甸潰");
+        }
+        
+        // 鍒涘缓鎴栨樉绀哄垏鎹㈣竟鐣屾樉绀烘寜閽�
+        if (shouye.toggleBoundaryDisplayButton == null) {
+            shouye.toggleBoundaryDisplayButton = shouye.createToggleBoundaryDisplayButton();
+        }
+        
+        // 閲嶇疆鍒囨崲鎸夐挳鐘舵�侊紙榛樿鏄剧ず鍏ㄩ儴杈圭晫锛�
+        if (shouye.mapRenderer != null) {
+            shouye.mapRenderer.setShowOnlyOriginalBoundary(false);
+        }
+        shouye.updateToggleBoundaryDisplayButtonText();
+        
+        // 闅愯棌鍏朵粬鎮诞鎸夐挳
+        shouye.hideFloatingDrawingControls();
+        
+        // 鏄剧ず杩斿洖鎸夐挳鍜屽垏鎹㈡寜閽�
+        shouye.pathPreviewReturnButton.setVisible(true);
+        shouye.toggleBoundaryDisplayButton.setVisible(true);
+        if (shouye.floatingButtonPanel != null) {
+            shouye.floatingButtonPanel.setVisible(true);
+            if (shouye.floatingButtonPanel.getParent() != shouye.visualizationPanel) {
+                shouye.visualizationPanel.add(shouye.floatingButtonPanel, BorderLayout.SOUTH);
+            }
+        }
+        shouye.rebuildFloatingButtonColumn();
+        
+        shouye.visualizationPanel.revalidate();
+        shouye.visualizationPanel.repaint();
+    }
+    
+    /**
+     * 澶勭悊杈圭晫棰勮杩斿洖
+     */
+    private void handleBoundaryPreviewReturn() {
+        Runnable callback = pathPreviewReturnAction;
+        exitBoundaryPreview();
+        if (callback != null) {
+            callback.run();
+        }
+    }
+    
+    /**
+     * 閫�鍑鸿竟鐣岄瑙�
+     */
+    private void exitBoundaryPreview() {
+        pathPreviewActive = false;
+        
+        // 娓呴櫎褰撳墠鍦板潡寮曠敤
+        currentBoundaryPreviewDikuai = null;
+        
+        // 鎭㈠缁樺埗鍓茶崏鏈哄疄鏃舵嫋灏�
+        if (mapRenderer != null) {
+            mapRenderer.setIdleTrailSuppressed(false);
+        }
+        
+        // 娓呴櫎杈圭晫棰勮骞堕噸缃樉绀虹姸鎬�
+        if (mapRenderer != null) {
+            mapRenderer.clearBoundaryPreview();
+            mapRenderer.setBoundaryPreviewUpdateCallback(null);
+            mapRenderer.setShowOnlyOriginalBoundary(false); // 閲嶇疆涓烘樉绀哄叏閮ㄨ竟鐣�
+        }
+        
+        // 闅愯棌杩斿洖鎸夐挳鍜屽垏鎹㈡寜閽�
+        if (pathPreviewReturnButton != null) {
+            pathPreviewReturnButton.setVisible(false);
+        }
+        if (toggleBoundaryDisplayButton != null) {
+            toggleBoundaryDisplayButton.setVisible(false);
+        }
+        
+        // 闅愯棌鎮诞闈㈡澘
+        if (floatingButtonPanel != null) {
+            floatingButtonPanel.setVisible(false);
+        }
+        
+        visualizationPanel.revalidate();
+        visualizationPanel.repaint();
+    }
+    
+    /**
+     * 鍒涘缓鍒囨崲杈圭晫鏄剧ず鎸夐挳
+     */
+    private JButton createToggleBoundaryDisplayButton() {
+        JButton button = new JButton("闅愯棌浼樺寲杈圭晫");
+        button.setFont(new Font("寰蒋闆呴粦", Font.PLAIN, 13));
+        button.setBackground(new Color(46, 139, 87));
+        button.setForeground(Color.WHITE);
+        button.setBorder(BorderFactory.createEmptyBorder(8, 16, 8, 16));
+        button.setFocusPainted(false);
+        button.setCursor(new Cursor(Cursor.HAND_CURSOR));
+        button.setToolTipText("鍒囨崲鏄剧ず锛氬彧鏄剧ず鍘熷杈圭晫/鏄剧ず鍏ㄩ儴杈圭晫");
+        
+        button.addActionListener(e -> {
+            if (mapRenderer == null) {
+                return;
+            }
+            // 鍒囨崲鏄剧ず鐘舵��
+            boolean currentState = mapRenderer.isShowOnlyOriginalBoundary();
+            mapRenderer.setShowOnlyOriginalBoundary(!currentState);
+            updateToggleBoundaryDisplayButtonText();
+        });
+        
+        button.addMouseListener(new java.awt.event.MouseAdapter() {
+            public void mouseEntered(java.awt.event.MouseEvent e) {
+                button.setBackground(new Color(30, 107, 69));
+            }
+            
+            public void mouseExited(java.awt.event.MouseEvent e) {
+                button.setBackground(new Color(46, 139, 87));
+            }
+        });
+        
+        return button;
+    }
+    
+    /**
+     * 鏇存柊鍒囨崲杈圭晫鏄剧ず鎸夐挳鐨勬枃鏈�
+     */
+    private void updateToggleBoundaryDisplayButtonText() {
+        if (toggleBoundaryDisplayButton == null || mapRenderer == null) {
+            return;
+        }
+        if (mapRenderer.isShowOnlyOriginalBoundary()) {
+            toggleBoundaryDisplayButton.setText("鏄剧ず鍏ㄩ儴杈圭晫");
+        } else {
+            toggleBoundaryDisplayButton.setText("闅愯棌浼樺寲杈圭晫");
+        }
+    }
 
 	// 娴嬭瘯鏂规硶
     public static void main(String[] args) {

--
Gitblit v1.10.0