Rumah  >  Artikel  >  pangkalan data  >  Bagaimana untuk Mengira Jarak dalam Jejari Menggunakan Latitud dan Longitud dalam PHP?

Bagaimana untuk Mengira Jarak dalam Jejari Menggunakan Latitud dan Longitud dalam PHP?

Barbara Streisand
Barbara Streisandasal
2024-10-30 18:40:03474semak imbas

How to Calculate Distances within a Radius Using Latitude and Longitude in PHP?

Mengira Jarak dari Latitud dan Longitud

Dalam senario ini, anda sedang mencari untuk menentukan titik dalam radius 15 batu dari koordinat yang dimasukkan pengguna. Untuk mencapai matlamat ini, anda boleh memanfaatkan formula matematik untuk mengira jarak.

Pertimbangkan fungsi PHP berikut:

<code class="php">function get_distance($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'Mi') { 

    // Calculate the angle difference
    $theta = $longitude1 - $longitude2; 

    // Calculate the distance
    $distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + 
                (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * 
                cos(deg2rad($theta))); 

    // Convert to degrees
    $distance = acos($distance); 
    $distance = rad2deg($distance); 

    // Convert to miles or kilometers
    $distance = $distance * 60 * 1.1515; 

    // Round the distance
    return (round($distance,2));
}</code>

Sebagai alternatif, anda boleh menggunakan pertanyaan pangkalan data untuk mencapai ini:

<code class="sql">$query = "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>

Atas ialah kandungan terperinci Bagaimana untuk Mengira Jarak dalam Jejari Menggunakan Latitud dan Longitud dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn