Rumah > Artikel > pangkalan data > Bagaimanakah Saya Boleh Mengira Jarak Antara Dua Titik Menggunakan Latitud dan Longitud?
Mengira Jarak Antara Titik Menggunakan Latitud dan Longitud
Dalam pelbagai senario, ia menjadi perlu untuk menentukan jarak antara dua titik yang diberikan masing-masing koordinat latitud dan longitud. Contoh biasa melibatkan pengesanan titik dalam jejari tertentu dari lokasi tertentu.
Untuk mencapai matlamat ini, anda boleh memanfaatkan formula matematik untuk mengira jarak. Pertimbangkan fungsi ilustrasi berikut:
<code class="php">function get_distance($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'Mi') { $theta = $longitude1 - $longitude2; $distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta))); $distance = acos($distance); $distance = rad2deg($distance); $distance = $distance * 60 * 1.1515; switch($unit) { case 'Mi': break; case 'Km': $distance = $distance * 1.609344; } return (round($distance, 2)); }</code>
Sebagai alternatif, anda boleh menggunakan pertanyaan SQL untuk mengira jarak dalam jejari menggunakan formula seperti:
<code class="sql">SELECT *,(((acos(sin((".$latitude."*pi()/180)) * sin((`Latitude`*pi()/180))+cos((".$latitude."*pi()/180)) * cos((`Latitude`*pi()/180)) * cos(((".$longitude."- `Longitude`)* pi()/180))))*180/pi())*60*1.1515 ) as distance FROM `MyTable` HAVING distance >= ".$distance.";</code>
Dengan menggunakan pendekatan ini, anda boleh dengan berkesan cari titik dalam radius tertentu berdasarkan koordinat latitud dan longitudnya.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengira Jarak Antara Dua Titik Menggunakan Latitud dan Longitud?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!