Maison >développement back-end >tutoriel php >PHP根据自己经度x与y与数据库里的信息x和y,计算出距离,后输出5000米以内的数据
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就是千米为单位
这是数学公式
看不懂就去问你们的数学老师
计算两点距离的如下公式:
C = sin(MLatA)*sin(MLatB)*cos(MLonA-MLonB) + cos(MLatA)*cos(MLatB)
Distance = R*Arccos(C)*Pi/180
这里,R和Distance单位是相同,如果是采用6371.004千米作为半径,那么Distance就是千米为单位
之前做过类似商家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 $$;
当然,前提是每个用户都有经纬度属性