From ed6936545d20cc490145d2936cee4387be2afd53 Mon Sep 17 00:00:00 2001
From: 张世豪 <979909237@qq.com>
Date: 星期一, 22 十二月 2025 19:04:34 +0800
Subject: [PATCH] 优化了导航预览模式

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

diff --git a/src/zhuye/MapRenderer.java b/src/zhuye/MapRenderer.java
index 790f3b9..1eb0bd2 100644
--- a/src/zhuye/MapRenderer.java
+++ b/src/zhuye/MapRenderer.java
@@ -107,6 +107,12 @@
     private boolean idleTrailSuppressed;
     private Path2D.Double realtimeBoundaryPathCache;
     private String realtimeBoundaryPathLand;
+    private WangfanDraw returnPathDrawer;  // 寰�杩旇矾寰勭粯鍒剁鐞嗗櫒
+    private List<Point2D.Double> currentReturnPath; // 褰撳墠鍦板潡鐨勫線杩旇矾寰勶紙鐢ㄤ簬鏄剧ず锛�
+    private List<Point2D.Double> previewReturnPath; // 棰勮鐨勫線杩旇矾寰�
+    private List<Point2D.Double> previewOriginalBoundary; // 棰勮鐨勫師濮嬭竟鐣岋紙绱壊锛�
+    private List<Point2D.Double> previewOptimizedBoundary; // 棰勮鐨勪紭鍖栧悗杈圭晫
+    private boolean boundaryPreviewActive; // 鏄惁澶勪簬杈圭晫棰勮妯″紡
 
     private static final double TRACK_SAMPLE_MIN_DISTANCE_METERS = 0.2d;
     private static final double TRACK_DUPLICATE_TOLERANCE_METERS = 1e-3d;
@@ -394,6 +400,11 @@
         if (hasBoundary) {
             drawCurrentBoundary(g2d);
         }
+        
+        // 缁樺埗杈圭晫棰勮锛堝師濮嬭竟鐣�-绱壊锛屼紭鍖栧悗杈圭晫锛�
+        if (boundaryPreviewActive) {
+            drawBoundaryPreview(g2d);
+        }
 
         yulanzhangaiwu.renderPreview(g2d, scale);
 
@@ -459,6 +470,17 @@
             drawNavigationPreviewCoverage(g2d);
         }
 
+        // 鍏堢敾寰�杩旇矾寰勶紙绾�+鐐癸級锛屼繚璇佸壊鑽夋満鍥炬爣鍦ㄥ叾涓婃柟
+        if (returnPathDrawer != null && returnPathDrawer.isActive()) {
+            returnPathDrawer.draw(g2d, scale);
+        } else if (previewReturnPath != null && !previewReturnPath.isEmpty()) {
+            // 缁樺埗棰勮鐨勫線杩旇矾寰勶紙閾佺嚎璺浘椋庢牸锛�
+            WangfanDraw.drawRailwayPath(g2d, previewReturnPath, scale);
+        } else if (currentReturnPath != null && !currentReturnPath.isEmpty()) {
+            // 缁樺埗淇濆瓨鐨勫線杩旇矾寰勶紙閾佺嚎璺浘椋庢牸锛�
+            WangfanDraw.drawRailwayPath(g2d, currentReturnPath, scale);
+        }
+
         drawMower(g2d);
         
         // 缁樺埗瀵艰埅棰勮閫熷害锛堝鏋滄鍦ㄥ鑸瑙堬級
@@ -962,6 +984,14 @@
             mowerEffectiveWidthMeters = defaultMowerWidthMeters;
         }
 
+        // 鍔犺浇寰�杩旇矾寰�
+        String returnPathStr = dikuai != null ? dikuai.getReturnPathCoordinates() : null;
+        if (returnPathStr != null && !returnPathStr.isEmpty() && !"-1".equals(returnPathStr)) {
+            currentReturnPath = lujingdraw.parsePlannedPath(returnPathStr);
+        } else {
+            currentReturnPath = null;
+        }
+
         loadRealtimeTrack(landNumber, dikuai != null ? dikuai.getMowingTrack() : null);
         visualizationPanel.repaint();
     }
@@ -2993,5 +3023,140 @@
     public Gecaoji getMower() {
         return mower;
     }
+    
+    /**
+     * 璁剧疆寰�杩旇矾寰勭粯鍒剁鐞嗗櫒
+     */
+    public void setReturnPathDrawer(WangfanDraw drawer) {
+        this.returnPathDrawer = drawer;
+    }
+
+    /**
+     * 璁剧疆棰勮鐨勫線杩旇矾寰�
+     */
+    public void setPreviewReturnPath(List<Point2D.Double> path) {
+        this.previewReturnPath = path;
+        if (visualizationPanel != null) {
+            visualizationPanel.repaint();
+        }
+    }
+    
+    /**
+     * 寮�濮嬪線杩旇矾寰勭粯鍒�
+     */
+    public void startReturnPathDrawing() {
+        if (returnPathDrawer != null) {
+            // 绂佺敤鎷栧熬鏁堟灉锛堝湪寰�杩旇矾寰勭粯鍒舵ā寮忎笅涓嶆樉绀哄疄鏃惰建杩规嫋灏撅級
+            idleTrailSuppressed = true;
+            clearIdleMowerTrail();
+            // 娓呯┖涔嬪墠鐨勮矾寰勭偣锛堥�氳繃 WangfanDraw 绠$悊锛�
+            repaint();
+        }
+    }
+    
+    /**
+     * 鍋滄寰�杩旇矾寰勭粯鍒�
+     */
+    public void stopReturnPathDrawing() {
+        // 鎭㈠鎷栧熬鏁堟灉
+        idleTrailSuppressed = false;
+        repaint();
+    }
+    
+    /**
+     * 璁剧疆鎷栧熬鎶戝埗鐘舵��
+     * @param suppressed true琛ㄧず鎶戝埗鎷栧熬缁樺埗锛宖alse琛ㄧず鍏佽鎷栧熬缁樺埗
+     */
+    public void setIdleTrailSuppressed(boolean suppressed) {
+        idleTrailSuppressed = suppressed;
+        if (suppressed && !idleMowerTrail.isEmpty()) {
+            clearIdleMowerTrail();
+        }
+        if (visualizationPanel != null) {
+            visualizationPanel.repaint();
+        }
+    }
+    
+    /**
+     * 娣诲姞寰�杩旇矾寰勭偣锛堝凡搴熷純锛岃矾寰勭偣鐢� WangfanDraw 鐩存帴绠$悊锛�
+     */
+    @Deprecated
+    public void addReturnPathPoint(double x, double y) {
+        // 璺緞鐐圭敱 WangfanDraw 鐩存帴绠$悊锛岃繖閲屽彧闇�瑕侀噸缁�
+        repaint();
+    }
+    
+    /**
+     * 鑾峰彇寰�杩旇矾寰勭偣鍒楄〃鐨勫揩鐓�
+     */
+    public List<Point2D.Double> getReturnPathPointsSnapshot() {
+        if (returnPathDrawer != null) {
+            return returnPathDrawer.getPointsSnapshot();
+        }
+        return new ArrayList<>();
+    }
+    
+    /**
+     * 璁剧疆杈圭晫棰勮鏁版嵁锛堝師濮嬭竟鐣屽拰浼樺寲鍚庤竟鐣岋級
+     */
+    public void setBoundaryPreview(String originalBoundaryXY, String optimizedBoundary) {
+        if (originalBoundaryXY != null && !originalBoundaryXY.trim().isEmpty() && !"-1".equals(originalBoundaryXY.trim())) {
+            previewOriginalBoundary = parseBoundary(originalBoundaryXY.trim());
+        } else {
+            previewOriginalBoundary = null;
+        }
+        
+        if (optimizedBoundary != null && !optimizedBoundary.trim().isEmpty() && !"-1".equals(optimizedBoundary.trim())) {
+            previewOptimizedBoundary = parseBoundary(optimizedBoundary.trim());
+        } else {
+            previewOptimizedBoundary = null;
+        }
+        
+        boundaryPreviewActive = (previewOriginalBoundary != null && previewOriginalBoundary.size() >= 2) ||
+                               (previewOptimizedBoundary != null && previewOptimizedBoundary.size() >= 2);
+        
+        if (boundaryPreviewActive) {
+            // 璁$畻棰勮杈圭晫鐨勮竟鐣屾骞惰皟鏁磋鍥�
+            List<Point2D.Double> allPoints = new ArrayList<>();
+            if (previewOriginalBoundary != null) allPoints.addAll(previewOriginalBoundary);
+            if (previewOptimizedBoundary != null) allPoints.addAll(previewOptimizedBoundary);
+            if (!allPoints.isEmpty()) {
+                Rectangle2D.Double bounds = computeBounds(allPoints);
+                SwingUtilities.invokeLater(() -> {
+                    fitBoundsToView(bounds);
+                    visualizationPanel.repaint();
+                });
+            }
+        } else {
+            visualizationPanel.repaint();
+        }
+    }
+    
+    /**
+     * 娓呴櫎杈圭晫棰勮
+     */
+    public void clearBoundaryPreview() {
+        previewOriginalBoundary = null;
+        previewOptimizedBoundary = null;
+        boundaryPreviewActive = false;
+        visualizationPanel.repaint();
+    }
+    
+    /**
+     * 缁樺埗杈圭晫棰勮锛堝師濮嬭竟鐣�-绱壊锛屼紭鍖栧悗杈圭晫-缁胯壊锛�
+     */
+    private void drawBoundaryPreview(Graphics2D g2d) {
+        // 缁樺埗鍘熷杈圭晫锛堢传鑹诧級
+        if (previewOriginalBoundary != null && previewOriginalBoundary.size() >= 2) {
+            Color purpleFill = new Color(128, 0, 128, 80); // 绱壊鍗婇�忔槑濉厖
+            Color purpleBorder = new Color(128, 0, 128, 255); // 绱壊杈规
+            bianjiedrwa.drawBoundary(g2d, previewOriginalBoundary, scale, purpleFill, purpleBorder);
+        }
+        
+        // 缁樺埗浼樺寲鍚庤竟鐣岋紙缁胯壊锛屼笌姝e父杈圭晫棰滆壊涓�鑷达級
+        if (previewOptimizedBoundary != null && previewOptimizedBoundary.size() >= 2) {
+            bianjiedrwa.drawBoundary(g2d, previewOptimizedBoundary, scale, GRASS_FILL_COLOR, GRASS_BORDER_COLOR);
+        }
+    }
 
 }
\ No newline at end of file

--
Gitblit v1.10.0