Baidu マップ座標間の距離を計算する PHP メソッド_php スキル

WBOY
リリース: 2016-05-16 09:00:21
オリジナル
2325 人が閲覧しました

この記事の例では、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 プログラミングのすべての人に役立つことを願っています。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!