我有2个坐标。坐标1是一个“人”。坐标2是目的地。
如何将坐标 1 移近 100 米以靠近坐标 2?
这将在 cron 作业中使用,因此仅包含 php 和 mysql。
例如:
此人位于:51.26667、3.45417
目的地是:51.575001、4.83889
我如何计算 Person 的新坐标以接近 100 米?
使用半正矢计算两点之间的差(以米为单位);然后按比例调整人物坐标的值。
$radius = 6378100; // radius of earth in meters
$latDist = $lat - $lat2;
$lngDist = $lng - $lng2;
$latDistRad = deg2rad($latDist);
$lngDistRad = deg2rad($lngDist);
$sinLatD = sin($latDistRad);
$sinLngD = sin($lngDistRad);
$cosLat1 = cos(deg2rad($lat));
$cosLat2 = cos(deg2rad($lat2));
$a = ($sinLatD/2)*($sinLatD/2) + $cosLat1*$cosLat2*($sinLngD/2)*($sinLngD/2);
if($a<0) $a = -1*$a;
$c = 2*atan2(sqrt($a), sqrt(1-$a));
$distance = $radius*$c;
培养您的价值观:
$lat = 51.26667; // Just South of Aardenburg in Belgium
$lng = 3.45417;
$lat2 = 51.575001; // To the East of Breda in Holland
$lng2 = 4.83889;
结果为 102059.82251083 米,102.06 公里
调整的比率为 100 / 102059.82251083 = 0.0009798174985988102859004569070625
$newLat = $lat + (($lat2 - $lat) * $ratio);
$newLng = $lng + (($lng2 - $lng) * $ratio);
给出新的纬度 51.266972108109 和经度 3.4555267728867
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)