この記事の例では、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 配列 (array) 操作スキル」を参照してください。 ", "php の数学的演算スキルのまとめ", "php 正規表現の使用法の概要"、"php ajax スキルとアプリケーションの概要"、"php の操作と演算子の使用法の概要"、"概要php ネットワーク プログラミング スキルの習得 "、"php 基本構文入門チュートリアル"、"php の日付と時刻の使用法の概要"、"php オブジェクト指向プログラミング入門チュートリアル a>", "php 文字列 (文字列) の使用法の概要", "php mysql データベース操作入門チュートリアル" および "php 一般的なデータベース操作スキルの概要"
この記事が php プログラミングのすべての人に役立つことを願っています。