欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2022-05-27 11:21:48
...
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 $$;

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