Mengira Jarak Diberi Dua Titik: Latitud dan Longitud
Menentukan jarak antara titik menggunakan latitud dan longitudnya ialah tugas GIS biasa. Untuk mencari titik dalam jejari tertentu, kami boleh memanfaatkan formula matematik dan pertanyaan SQL.
Formula untuk Pengiraan Jarak
Satu pendekatan ialah menggunakan formula Haversine, yang mengira jarak antara dua titik pada sfera:
<code class="python">def get_distance(lat1, lon1, lat2, lon2, unit='Mi'): theta = lon1 - lon2 distance = (math.sin(math.radians(lat1)) * math.sin(math.radians(lat2))) + \ (math.cos(math.radians(lat1)) * math.cos(math.radians(lat2)) * \ math.cos(math.radians(theta))) distance = math.acos(distance) distance = math.degrees(distance) distance = distance * 60 * 1.1515 if unit == 'Km': distance = distance * 1.609344 return round(distance, 2)</code>
SQL Query for Radius Search
Pilihan lain ialah menggunakan pertanyaan MySQL dengan formula jarak:
<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 kaedah ini, anda boleh mengira jarak antara titik dengan cekap dan mencarinya dalam radius yang dikehendaki dari lokasi tertentu.
Atas ialah kandungan terperinci Bagaimana Mengira Jarak Antara Dua Titik Menggunakan Latitud dan Longitud?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!