この記事の例では、PHP で Baidu マップ座標間の距離を計算する方法を説明します。参考のためにみんなと共有してください。詳細は次のとおりです:
以下はインターネット上のコードです。使用する場合はいくつかの変更を加える必要があります
最初の関数は範囲を取得することであり、パラメータは緯度、経度と半径
2 番目の関数は、座標距離を計算することです
<?php define('PI',3.1415926535898); define('EARTH_RADIUS',6378.137); //计算范围,可以做搜索用户 function GetRange($lat,$lon,$raidus){ //计算纬度 $degree = (24901 * 1609) / 360.0; $dpmLat = 1 / $degree; $radiusLat = $dpmLat * $raidus; $minLat = $lat - $radiusLat; //得到最小纬度 $maxLat = $lat + $radiusLat; //得到最大纬度 //计算经度 $mpdLng = $degree * cos($lat * (PI / 180)); $dpmLng = 1 / $mpdLng; $radiusLng = $dpmLng * $raidus; $minLng = $lon - $radiusLng; //得到最小经度 $maxLng = $lon + $radiusLng; //得到最大经度 //范围 $range = array( 'minLat' => $minLat, 'maxLat' => $maxLat, 'minLon' => $minLng, 'maxLon' => $maxLng ); return $range; } //获取2点之间的距离 function GetDistance($lat1, $lng1, $lat2, $lng2){ $radLat1 = $lat1 * (PI / 180); $radLat2 = $lat2 * (PI / 180); $a = $radLat1 - $radLat2; $b = ($lng1 * (PI / 180)) - ($lng2 * (PI / 180)); $s = 2 * asin(sqrt(pow(sin($a/2),2) + cos($radLat1)*cos($radLat2)*pow(sin($b/2),2))); $s = $s * EARTH_RADIUS; $s = round($s * 10000) / 10000; return $s; }
さらに PHP 関連のコンテンツに興味のある読者は、このサイトの特別トピック「完全な PHP 配列 (配列) 操作スキル」をチェックしてください。 「PHP 数学的演算スキルの概要」、「PHP 正規表現の使用法の概要」、「PHP+ajax スキルとアプリケーションの概要」、「PHP 操作と演算子の使用法の概要」、「PHP ネットワーク プログラミング スキルの概要」、「はじめに」 「PHP 基本構文チュートリアル」、「PHP 日付と時刻の使い方のまとめ」、「php オブジェクト指向プログラミング「入門チュートリアル」、「PHP 文字列の使い方のまとめ」、「PHP+MySQL データベース操作の入門チュートリアル」、「PHP の使い方のまとめ」一般的な PHP データベース操作スキル」
この記事が PHP プログラミングの皆様のお役に立てれば幸いです。
上記では、Baidu Map の方法を含め、PHP で Baidu マップの座標間の距離を計算する方法を紹介しました。PHP チュートリアルに興味のある友人に役立つことを願っています。