计算距离的逻辑是从Android的提供的接口(Location.distanceBetween)中拔来的,应该是最精确的方法了
php代码
<?php function computeDistance($lat1, $lon1, $lat2, $lon2) { // using the "Inverse Formula" (section 4) $MAXITERS = 20; // Convert lat/long to radians $lat1 *= pi() / 180.0; $lat2 *= pi() / 180.0; $lon1 *= pi() / 180.0; $lon2 *= pi() / 180.0; $a = 6378137.0; // WGS84 major axis $b = 6356752.3142; // WGS84 semi-major axis $f = ($a - $b) / $a; $aSqMinusBSqOverBSq = ($a * $a - $b * $b) / ($b * $b); $L = $lon2 - $lon1; $A = 0.0; $U1 = atan((1.0 - $f) * tan($lat1)); $U2 = atan((1.0 - $f) * tan($lat2)); $cosU1 = cos($U1); $cosU2 = cos($U2); $sinU1 = sin($U1); $sinU2 = sin($U2); $cosU1cosU2 = $cosU1 * $cosU2; $sinU1sinU2 = $sinU1 * $sinU2; $sigma = 0.0; $deltaSigma = 0.0; $cosSqAlpha = 0.0; $cos2SM = 0.0; $cosSigma = 0.0; $sinSigma = 0.0; $cosLambda = 0.0; $sinLambda = 0.0; $lambda = $L; // initial guess for ($iter = 0; $iter < $MAXITERS; $iter++) { $lambdaOrig = $lambda; $cosLambda = cos($lambda); $sinLambda = sin($lambda); $t1 = $cosU2 * $sinLambda; $t2 = $cosU1 * $sinU2 - $sinU1 * $cosU2 * $cosLambda; $sinSqSigma = $t1 * $t1 + $t2 * $t2; // (14) $sinSigma = sqrt($sinSqSigma); $cosSigma = $sinU1sinU2 + $cosU1cosU2 * $cosLambda; // (15) $sigma = atan2($sinSigma, $cosSigma); // (16) $sinAlpha = ($sinSigma == 0) ? 0.0 : $cosU1cosU2 * $sinLambda / $sinSigma; // (17) $cosSqAlpha = 1.0 - $sinAlpha * $sinAlpha; $cos2SM = ($cosSqAlpha == 0) ? 0.0 : $cosSigma - 2.0 * $sinU1sinU2 / $cosSqAlpha; // (18) $uSquared = $cosSqAlpha * $aSqMinusBSqOverBSq; // defn $A = 1 + ($uSquared / 16384.0) * // (3) (4096.0 + $uSquared * (-768 + $uSquared * (320.0 - 175.0 * $uSquared))); $B = ($uSquared / 1024.0) * // (4) (256.0 + $uSquared * (-128.0 + $uSquared * (74.0 - 47.0 * $uSquared))); $C = ($f / 16.0) * $cosSqAlpha * (4.0 + $f * (4.0 - 3.0 * $cosSqAlpha)); // (10) $cos2SMSq = $cos2SM * $cos2SM; $deltaSigma = $B * $sinSigma * // (6) ($cos2SM + ($B / 4.0) * ($cosSigma * (-1.0 + 2.0 * $cos2SMSq) - ($B / 6.0) * $cos2SM * (-3.0 + 4.0 * $sinSigma * $sinSigma) * (-3.0 + 4.0 * $cos2SMSq))); $lambda = $L + (1.0 - $C) * $f * $sinAlpha * ($sigma + $C * $sinSigma * ($cos2SM + $C * $cosSigma * (-1.0 + 2.0 * $cos2SM * $cos2SM))); // (11) $delta = ($lambda - $lambdaOrig) / $lambda; if (abs($delta) < 1.0e-12) { break; } } return $b * $A * ($sigma - $deltaSigma); } echo computeDistance(34.8082342, 113.6125439, 34.8002478, 113.659779); ?>
로그인 후 복사
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사
<garden> : 정원 재배 - 완전한 돌연변이 가이드
3 몇 주 전
By DDD
<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
KB5055612 수정 방법 Windows 10에 설치되지 않습니까?
3 몇 주 전
By DDD
Nordhold : Fusion System, 설명
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
3 몇 주 전
By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)