当前位置:Gxlcms > PHP教程 > PHP根据自己经度x与y与数据库里的信息x和y,计算出距离,后输出5000米以内的数据

PHP根据自己经度x与y与数据库里的信息x和y,计算出距离,后输出5000米以内的数据

时间:2021-07-01 10:21:17 帮助过:29人阅读

PHP根据自己经度x与y与数据库里的信息x和y,计算出距离,后输出5000米以内的数据

当前使用JS获得自己的位置了。
window.onload=function(){
var options={
enableHighAccuracy:true,
maximunAge:1000,
timeout:5000
};
if(window.navigator.geolocation){
navigator.geolocation.getCurrentPosition(successCallback,errorCallback,options);
}else{
alert("你的浏览器不支持定位!");
}
}
function successCallback(position){
var output="";
output +="Your position has bean located . \r\n";
output+=" Latitude:"+position.coords.latitude+" ";
output+=" Longitude:"+position.coords.longitude+" ";
output+=" Accuracy :"+position.coords.accuracy +" meters";
if(position.coords.latitude){
output+=" Accuracy :"+position.coords.altitudeAccuracy +" meters";
}
if(position.coords.heading){
output+=" Heading :"+position.coords.Heading +" meters";
}
if(position.coords.speed){
output+=" Speed :"+position.coords.Speed +" m/s";
}
output+=" Time of Position "+position.timestamp +" m/s";
alert(output);
}

数据表table_map记录着很多位置,字段为Latitude和Longitude

我现在需要输出与自己5000米以内的信息,给点思路!!


回复讨论(解决方案)

计算两点距离的如下公式:
C = sin(MLatA)*sin(MLatB)*cos(MLonA-MLonB) + cos(MLatA)*cos(MLatB)
Distance = R*Arccos(C)*Pi/180
这里,R和Distance单位是相同,如果是采用6371.004千米作为半径,那么Distance就是千米为单位


计算两点距离的如下公式:
C = sin(MLatA)*sin(MLatB)*cos(MLonA-MLonB) + cos(MLatA)*cos(MLatB)
Distance = R*Arccos(C)*Pi/180
这里,R和Distance单位是相同,如果是采用6371.004千米作为半径,那么Distance就是千米为单位



看不懂。。。这是PHP吗

这是数学公式
看不懂就去问你们的数学老师


计算两点距离的如下公式:
C = sin(MLatA)*sin(MLatB)*cos(MLonA-MLonB) + cos(MLatA)*cos(MLatB)
Distance = R*Arccos(C)*Pi/180
这里,R和Distance单位是相同,如果是采用6371.004千米作为半径,那么Distance就是千米为单位



看不懂。。。这是PHP吗

正弦、余弦看不懂吗?

之前做过类似商家APP,功能就是计算用户距离具体商家位置。我用的是js来实现的 ,没有用后端。

/进行经纬度转换为距离的计算     function Rad(d){       return d * Math.PI / 180.0;//经纬度转换成三角函数中度分表形式。    }    //计算距离,参数分别为第一点的纬度,经度;第二点的纬度,经度    function GetDistance(lat1,lng1,lat2,lng2){         var radLat1 = Rad(lat1);        var radLat2 = Rad(lat2);        var a = radLat1 - radLat2;        var  b = Rad(lng1) - Rad(lng2);        var s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2) +        Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));        s = s *6378.137 ;// EARTH_RADIUS;        s = Math.round(s * 10000) / 10000; //
输出为公里 //s=s.toFixed(4); return s; }
这是相关函数


我目前的办法是:
在数据库中实现计算两点之间距离的存储过程(在添加此存储过程前先执行
set global log_bin_trust_function_creators=1;

然后直接在查询中调用此函数

/*
* 计算poi点距离(单位为km)
*
*/
DELIMITER $$
CREATE DEFINER = CURRENT_USER FUNCTION `getDistance`(`lon1` float,`lat1` float,`lon2` float,`lat2` float)
RETURNS double
begin
declare d double;
declare radius int;
if lon1=0 or lat1=0 or lon2=0 or lat2=0 then
return 99999999;
end if;
set radius = 6378140; #假设地球为正球形,直径为6378140米
set d = (2*ATAN2(SQRT(SIN((lat1-lat2)*PI()/180/2)
*SIN((lat1-lat2)*PI()/180/2)+
COS(lat2*PI()/180)*COS(lat1*PI()/180)
*SIN((lon1-lon2)*PI()/180/2)
*SIN((lon1-lon2)*PI()/180/2)),
SQRT(1-SIN((lat1-lat2)*PI()/180/2)
*SIN((lat1-lat2)*PI()/180/2)
+COS(lat2*PI()/180)*COS(lat1*PI()/180)
*SIN((lon1-lon2)*PI()/180/2)
*SIN((lon1-lon2)*PI()/180/2))))*radius;
return round(d/1000, 2);
END $$
DELIMITER $$;

当然,前提是每个用户都有经纬度属性

人气教程排行