ホームページ > データベース > mysql チュートリアル > PHP で緯度と経度を使用して半径内の距離を計算するにはどうすればよいですか?

PHP で緯度と経度を使用して半径内の距離を計算するにはどうすればよいですか?

Barbara Streisand
リリース: 2024-10-30 18:40:03
オリジナル
565 人が閲覧しました

How to Calculate Distances within a Radius Using Latitude and Longitude in PHP?

緯度と経度からの距離の計算

このシナリオでは、半径 15 マイル以内のポイントを決定しようとしています。ユーザーが入力した座標。これを実現するには、数式を利用して距離を計算します。

次の PHP 関数を検討してください:

<code class="php">function get_distance($latitude1, $longitude1, $latitude2, $longitude2, $unit = 'Mi') { 

    // Calculate the angle difference
    $theta = $longitude1 - $longitude2; 

    // Calculate the distance
    $distance = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + 
                (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * 
                cos(deg2rad($theta))); 

    // Convert to degrees
    $distance = acos($distance); 
    $distance = rad2deg($distance); 

    // Convert to miles or kilometers
    $distance = $distance * 60 * 1.1515; 

    // Round the distance
    return (round($distance,2));
}</code>
ログイン後にコピー

あるいは、データベース クエリを利用してこれを実現できます:

<code class="sql">$query = "SELECT *,(((acos(sin((".$latitude."*pi()/180)) * 
            sin((`Latitude`*pi()/180))+cos((".$latitude."*pi()/180)) * 
            cos((`Latitude`*pi()/180)) * cos(((".$longitude."- `Longitude`)* 
            pi()/180))))*180/pi())*60*1.1515
        ) as distance 
        FROM `MyTable` 
        HAVING distance > ".$distance.";</code>
ログイン後にコピー

以上がPHP で緯度と経度を使用して半径内の距離を計算するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート