ホームページ  >  記事  >  バックエンド開発  >  百度地図座標間の距離を計算する PHP メソッド 百度地図バス クエリ 百度地図 API 百度地図ルート クエリ

百度地図座標間の距離を計算する PHP メソッド 百度地図バス クエリ 百度地図 API 百度地図ルート クエリ

WBOY
WBOYオリジナル
2016-07-29 08:50:331508ブラウズ

この記事の例では、PHP で Baidu マップ座標間の距離を計算する方法を説明します。参考のためにみんなと共有してください。詳細は次のとおりです:

以下はインターネット上のコードです。使用する場合はいくつかの変更を加える必要があります

最初の関数は範囲を取得することであり、パラメータは緯度、経度と半径

2 番目の関数は、座標距離を計算することです

<&#63;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 チュートリアルに興味のある友人に役立つことを願っています。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。