Problem:
Das bereitgestellte Java-Code-Snippet berechnet den Abstand zwischen zwei Punkte basierend auf ihrem Breiten- und Längengrad. Es besteht die Sorge, dass die verwendete Formel möglicherweise etwas ungenaue Ergebnisse liefert, insbesondere wenn es mehrere Punkte über eine beträchtliche Entfernung gibt.
Lösung:
Um dieses Problem zu beheben, finden Sie hier Folgendes eine Java-Implementierung der Haversine-Methode, die auch Höhenunterschiede berücksichtigt:
<code class="java">/** * Calculate distance between two points in latitude and longitude taking * into account height difference. If you are not interested in height * difference pass 0.0. Uses Haversine method as its base. * * lat1, lon1 Start point lat2, lon2 End point el1 Start altitude in meters * el2 End altitude in meters * @returns Distance in Meters */ public static double distance(double lat1, double lat2, double lon1, double lon2, double el1, double el2) { final int R = 6371; // Radius of the earth double latDistance = Math.toRadians(lat2 - lat1); double lonDistance = Math.toRadians(lon2 - lon1); double a = Math.sin(latDistance / 2) * Math.sin(latDistance / 2) + Math.cos(Math.toRadians(lat1)) * Math.cos(Math.toRadians(lat2)) * Math.sin(lonDistance / 2) * Math.sin(lonDistance / 2); double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)); double distance = R * c * 1000; // convert to meters double height = el1 - el2; distance = Math.pow(distance, 2) + Math.pow(height, 2); return Math.sqrt(distance); }</code>
Diese Implementierung berechnet die Entfernung genau und berücksichtigt dabei auch Höhenunterschiede. Es verwendet die Haversine-Methode als Grundlage und berücksichtigt dabei den Höhenunterschied zwischen den beiden Punkten.
Das obige ist der detaillierte Inhalt vonWie berechnet man den Abstand zwischen zwei Punkten anhand von Breitengrad, Längengrad und Höhe genau?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!