Posted By

nikhilkumar80 on 10/10/10


Tagged

geolocation


Versions (?)

Who likes this?

2 people have marked this snippet as a favorite

bobbym245
MaxLazar


Calculate Distance


 / Published in: PHP
 

  1. function distance($lat1, $lon1, $lat2, $lon2, $unit) {
  2.  
  3. $theta = $lon1 - $lon2;
  4. $dist = sin(deg2rad($lat1)) * sin(deg2rad($lat2)) + cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * cos(deg2rad($theta));
  5. $dist = acos($dist);
  6. $dist = rad2deg($dist);
  7. $miles = $dist * 60 * 1.1515;
  8. $unit = strtoupper($unit);
  9.  
  10. if ($unit == "K") {
  11. return ($miles * 1.609344);
  12. } else if ($unit == "N") {
  13. return ($miles * 0.8684);
  14. } else {
  15. return $miles;
  16. }
  17. }

Report this snippet  

Comments

RSS Icon Subscribe to comments
Posted By: nikhilkumar80 on October 10, 2010

USAGE

//Miles echo distance(32.9697, -96.80322, 29.46786, -98.53506, "m") . " miles";

//Kilometers echo distance(32.9697, -96.80322, 29.46786, -98.53506, "k") . " kilometers";

//Nautical miles echo distance(32.9697, -96.80322, 29.46786, -98.53506, "n") . " nautical miles";

You need to login to post a comment.