826220679@qq.com
5 小时以前 69b40096cb0ae965f2a3e92672b880edfe7d04d2
src/zhuye/MapRenderer.java
@@ -18,6 +18,7 @@
import java.util.List;
import java.util.Locale;
import java.util.Set;
import java.util.function.Consumer;
import java.io.File;
import set.Setsys;
import gecaoji.Device;
@@ -632,7 +633,7 @@
     * 添加导航预览轨迹点
     */
    public void addNavigationPreviewTrackPoint(Point2D.Double point) {
        if (point != null && Double.isFinite(point.x) && Double.isFinite(point.y)) {
        if (point != null && isFinite(point.x) && isFinite(point.y)) {
            navigationPreviewTrack.add(new Point2D.Double(point.x, point.y));
            if (visualizationPanel != null) {
                visualizationPanel.repaint();
@@ -750,7 +751,7 @@
            return;
        }
        Point2D.Double position = mower.getPosition();
        if (position == null || !Double.isFinite(position.x) || !Double.isFinite(position.y)) {
        if (position == null || !isFinite(position.x) || !isFinite(position.y)) {
            pendingTrackBreak = true;
            return;
        }
@@ -776,7 +777,7 @@
        }
        realtimeMowingTrack.add(candidate);
        if (!pendingTrackBreak && lastPoint != null && Double.isFinite(distance)) {
        if (!pendingTrackBreak && lastPoint != null && isFinite(distance)) {
            trackLengthMeters += distance;
        }
@@ -807,7 +808,7 @@
        }
        Point2D.Double position = mower.getPosition();
        if (position == null || !Double.isFinite(position.x) || !Double.isFinite(position.y)) {
        if (position == null || !isFinite(position.x) || !isFinite(position.y)) {
            return;
        }
@@ -852,7 +853,7 @@
        // 刷新mower位置,使用最新的Device数据
        mower.refreshFromDevice();
        Point2D.Double position = mower.getPosition();
        if (position == null || !Double.isFinite(position.x) || !Double.isFinite(position.y)) {
        if (position == null || !isFinite(position.x) || !isFinite(position.y)) {
            return;
        }
@@ -963,7 +964,7 @@
    }
    private String formatTrackCoordinate(double value) {
        if (!Double.isFinite(value)) {
        if (!isFinite(value)) {
            return "0";
        }
        return String.format(Locale.US, "%.3f", value);
@@ -1154,7 +1155,7 @@
            try {
                double x = Double.parseDouble(parts[0].trim());
                double y = Double.parseDouble(parts[1].trim());
                if (!Double.isFinite(x) || !Double.isFinite(y)) {
                if (!isFinite(x) || !isFinite(y)) {
                    continue;
                }
                Point2D.Double current = new Point2D.Double(x, y);
@@ -1459,6 +1460,7 @@
        String safetyDistance = null;
        String obstaclesCoords = null;
        String mowingPattern = null;
        String plannedPathStr = null;
        
        // 从当前地块编号获取地块信息
        if (currentBoundaryLandNumber != null) {
@@ -1468,6 +1470,8 @@
                mowingWidth = landData.getMowingWidth();
                safetyDistance = landData.getMowingSafetyDistance();
                mowingPattern = landData.getMowingPattern();
                // 从地块获取plannedPath属性值作为路径
                plannedPathStr = landData.getPlannedPath();
                
                // 获取障碍物坐标
                try {
@@ -1525,10 +1529,19 @@
            }
        }
        
        // 如果从地块获取到了路径,使用地块的路径;否则使用currentPlannedPath
        List<Point2D.Double> pathToDraw = currentPlannedPath;
        if (plannedPathStr != null && !plannedPathStr.trim().isEmpty() && !"-1".equals(plannedPathStr.trim())) {
            // 从地块获取的路径
            pathToDraw = lujingdraw.parsePlannedPath(plannedPathStr);
        }
        // 调用带地块信息的绘制方法
        lujingdraw.drawPlannedPath(g2d, currentPlannedPath, scale, arrowScale,
        if (pathToDraw != null && pathToDraw.size() >= 2) {
            lujingdraw.drawPlannedPath(g2d, pathToDraw, scale, arrowScale,
                                   boundaryCoords, mowingWidth, safetyDistance, obstaclesCoords, mowingPattern);
    }
    }
    private void drawCircleSampleMarkers(Graphics2D g2d, List<double[]> markers, double scale) {
        if (markers == null || markers.isEmpty()) {
@@ -1549,7 +1562,7 @@
        FontMetrics metrics = g2d.getFontMetrics(labelFont);
        
        for (double[] pt : markers) {
            if (pt == null || pt.length < 2 || !Double.isFinite(pt[0]) || !Double.isFinite(pt[1])) {
            if (pt == null || pt.length < 2 || !isFinite(pt[0]) || !isFinite(pt[1])) {
                continue;
            }
            double x = pt[0];
@@ -1647,7 +1660,7 @@
                }
                double x = pt[0];
                double y = pt[1];
                if (!Double.isFinite(x) || !Double.isFinite(y)) {
                if (!isFinite(x) || !isFinite(y)) {
                    continue;
                }
                circleSampleMarkers.add(new double[]{x, y});
@@ -1870,7 +1883,7 @@
    private double computeSelectionThresholdPixels() {
        double scaleFactor = Math.max(0.5, scale);
        double diameterScale = boundaryPointSizeScale * (previewSizingEnabled ? PREVIEW_BOUNDARY_MARKER_SCALE : 1.0d);
        if (!Double.isFinite(diameterScale) || diameterScale <= 0.0d) {
        if (!isFinite(diameterScale) || diameterScale <= 0.0d) {
            diameterScale = 1.0d;
        }
        double markerDiameterWorld = Math.max(1.0, (10.0 / scaleFactor) * 0.2 * diameterScale);
@@ -2035,7 +2048,7 @@
    }
    private boolean isPointInsideActiveBoundary(Point2D.Double point) {
        if (point == null || !Double.isFinite(point.x) || !Double.isFinite(point.y)) {
        if (point == null || !isFinite(point.x) || !isFinite(point.y)) {
            return false;
        }
        if (realtimeTrackLandNumber == null) {
@@ -2046,7 +2059,7 @@
    }
    private boolean isPointInsideBoundary(Point2D.Double point, Path2D.Double path) {
        if (point == null || path == null || !Double.isFinite(point.x) || !Double.isFinite(point.y)) {
        if (point == null || path == null || !isFinite(point.x) || !isFinite(point.y)) {
            return false;
        }
        if (path.contains(point.x, point.y)) {
@@ -2067,7 +2080,7 @@
        Path2D.Double path = new Path2D.Double();
        boolean started = false;
        for (Point2D.Double point : boundary) {
            if (point == null || !Double.isFinite(point.x) || !Double.isFinite(point.y)) {
            if (point == null || !isFinite(point.x) || !isFinite(point.y)) {
                continue;
            }
            if (!started) {
@@ -2103,7 +2116,7 @@
        // 设置点的大小(随缩放变化)
        double scaleFactor = Math.max(0.5, scale);
        double clampedScale = boundaryPointSizeScale * (previewSizingEnabled ? PREVIEW_BOUNDARY_MARKER_SCALE : 1.0d);
        if (!Double.isFinite(clampedScale) || clampedScale <= 0.0d) {
        if (!isFinite(clampedScale) || clampedScale <= 0.0d) {
            clampedScale = 1.0d;
        }
        double minimumDiameter = clampedScale < 1.0 ? 0.5 : 1.0;
@@ -2552,7 +2565,7 @@
            }
            double x = coord.getX();
            double y = coord.getY();
            if (!Double.isFinite(x) || !Double.isFinite(y)) {
            if (!isFinite(x) || !isFinite(y)) {
                continue;
            }
            copy.add(new Obstacledge.XYCoordinate(x, y));
@@ -2890,7 +2903,7 @@
    }
    public void setBoundaryPointSizeScale(double sizeScale) {
        double normalized = (Double.isFinite(sizeScale) && sizeScale > 0.0d) ? sizeScale : 1.0d;
        double normalized = (isFinite(sizeScale) && sizeScale > 0.0d) ? sizeScale : 1.0d;
        if (Math.abs(boundaryPointSizeScale - normalized) < 1e-6) {
            return;
        }
@@ -2918,7 +2931,7 @@
    }
    public void setBoundaryPreviewMarkerScale(double markerScale) {
        double normalized = Double.isFinite(markerScale) && markerScale > 0.0d ? markerScale : 1.0d;
        double normalized = isFinite(markerScale) && markerScale > 0.0d ? markerScale : 1.0d;
        if (Math.abs(boundaryPreviewMarkerScale - normalized) < 1e-6) {
            return;
        }
@@ -2955,7 +2968,7 @@
    }
    public void addHandheldBoundaryPoint(double x, double y) {
        if (!Double.isFinite(x) || !Double.isFinite(y)) {
        if (!isFinite(x) || !isFinite(y)) {
            return;
        }
        if (!handheldBoundaryPreviewActive) {
@@ -3067,8 +3080,8 @@
        Point2D.Double mowerPosition = mower.getPosition();
        if (mowerPosition == null
            || !Double.isFinite(mowerPosition.x)
            || !Double.isFinite(mowerPosition.y)) {
            || !isFinite(mowerPosition.x)
            || !isFinite(mowerPosition.y)) {
            return expanded;
        }
@@ -3512,9 +3525,9 @@
    /**
     * 设置边界预览更新回调
     */
    private java.util.function.Consumer<String> boundaryPreviewUpdateCallback;
    private Consumer<String> boundaryPreviewUpdateCallback;
    
    public void setBoundaryPreviewUpdateCallback(java.util.function.Consumer<String> callback) {
    public void setBoundaryPreviewUpdateCallback(Consumer<String> callback) {
        this.boundaryPreviewUpdateCallback = callback;
    }
@@ -3531,4 +3544,12 @@
            fitBoundsToView(bounds);
        }
    }
    /**
     * 检查double值是否有限(不是NaN或无穷大)
     * 兼容低版本Java
     */
    private static boolean isFinite(double value) {
        return !Double.isNaN(value) && !Double.isInfinite(value);
    }
}