Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Jak przesunąć znacznik o 100 metrów ze współrzędnymi

Użyj Haversine, aby obliczyć różnicę między dwoma punktami w metrach; następnie proporcjonalnie dostosuj wartość współrzędnych osoby.

$radius = 6378100; // radius of earth in meters
$latDist = $lat - $lat2;
$lngDist = $lng - $lng2;
$latDistRad = deg2rad($latDist);
$lngDistRad = deg2rad($lngDist);
$sinLatD = sin($latDistRad);
$sinLngD = sin($lngDistRad);
$cosLat1 = cos(deg2rad($lat));
$cosLat2 = cos(deg2rad($lat2));
$a = ($sinLatD/2)*($sinLatD/2) + $cosLat1*$cosLat2*($sinLngD/2)*($sinLngD/2);
if($a<0) $a = -1*$a;
$c = 2*atan2(sqrt($a), sqrt(1-$a));
$distance = $radius*$c;

Karmienie swoimi wartościami:

$lat = 51.26667;        //  Just South of Aardenburg in Belgium
$lng = 3.45417;
$lat2 = 51.575001;      //  To the East of Breda in Holland
$lng2 = 4.83889;

daje wynik 102059.82251083 metrów, 102,06 kilometrów

Stosunek do korekty wynosi 100 / 102059.82251083 =0.0009798174985988102859004569070625

$newLat = $lat + (($lat2 - $lat) * $ratio);
$newLng = $lng + (($lng2 - $lng) * $ratio);

Daje nową szerokość geograficzną 51.266972108109 i długość geograficzną 3.4555267728867



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Korzystanie z tablicy w zapytaniu SQL

  2. Kolumna autoinkrementacji:różnice w składni SQL między Oracle i MySQL

  3. Jak znaleźć deltę czasu wiersza datatime w mysql?

  4. Jak ustawić globalne event_scheduler=ON, nawet jeśli MySQL jest restartowany?

  5. wyświetlanie zmiennej obrazu