두지점의 위도,경도간 거리계산 정보
PHP 두지점의 위도,경도간 거리계산본문
간단한거지만 찾을려면 힘들것 같아서 10원짜리 팁으로 올립니다.
금일 쓸일이 있어서 찾다가 남깁니다.
[출처] phpschool
<?php
function _deg2rad($deg)
{
$radians = 0.0;
$radians = $deg * M_PI/180.0;
return($radians);
}
function geoDistance($lat1, $lon1, $lat2, $lon2, $unit="k")
{
$theta = $lon1 - $lon2;
$dist = sin(_deg2rad($lat1)) * sin(_deg2rad($lat2)) + cos(_deg2rad($lat1)) * cos(_deg2rad($lat2)) * cos(_deg2rad($theta));
$dist = acos($dist);
$dist = rad2deg($dist);
$miles = $dist * 60 * 1.1515;
$unit = strtolower($unit);
if ($unit == "k") {
return ($miles * 1.609344);
} else {
return $miles;
}
}
// 양재
$a1 = 37.47163412599279;
$a2 = 127.02677155082887;
// 우만동
$b1 = 37.284357977075565;
$b2 = 127.03281619405365;
// 수서
$c1 = 37.4889123433992;
$c2 = 127.10502769792124;
echo geoDistance($a1,$a2,$c1,$c2);
?>
function _deg2rad($deg)
{
$radians = 0.0;
$radians = $deg * M_PI/180.0;
return($radians);
}
function geoDistance($lat1, $lon1, $lat2, $lon2, $unit="k")
{
$theta = $lon1 - $lon2;
$dist = sin(_deg2rad($lat1)) * sin(_deg2rad($lat2)) + cos(_deg2rad($lat1)) * cos(_deg2rad($lat2)) * cos(_deg2rad($theta));
$dist = acos($dist);
$dist = rad2deg($dist);
$miles = $dist * 60 * 1.1515;
$unit = strtolower($unit);
if ($unit == "k") {
return ($miles * 1.609344);
} else {
return $miles;
}
}
// 양재
$a1 = 37.47163412599279;
$a2 = 127.02677155082887;
// 우만동
$b1 = 37.284357977075565;
$b2 = 127.03281619405365;
// 수서
$c1 = 37.4889123433992;
$c2 = 127.10502769792124;
echo geoDistance($a1,$a2,$c1,$c2);
?>
추천
0
0
댓글 0개