最近用到了geohash(参考
《geohash:用字符串实现附近地点搜索》)来实现附近搜索的功能,在
《微信、陌陌架构方案分析》文中提供了一个php的geohash类直接能对经纬地址编码成字符串, 而其中包含一个getDistance方法获取两点间的距离,但在sphinx中使用过滤附近地标的方法SetGeoAnchor发现返回的距离值有误,遂google出以下方法,经测试可用。。
/**
* @desc 根据两点间的经纬度计算距离
* @param float $lat 纬度值
* @param float $lng 经度值
*/
function getDistance($lat1, $lng1, $lat2, $lng2)
{
$earthRadius = 6367000; //approximate radius of earth in meters
/*
Convert these degrees to radians
to work with the formula
*/
$lat1 = ($lat1 * pi() ) / 180;
$lng1 = ($lng1 * pi() ) / 180;
$lat2 = ($lat2 * pi() ) / 180;
$lng2 = ($lng2 * pi() ) / 180;
/*
Using the
Haversine formula
http://en.wikipedia.org/wiki/Haversine_formula
calculate the distance
*/
$calcLongitude = $lng2 - $lng1;
$calcLatitude = $lat2 - $lat1;
$stepOne = pow(sin($calcLatitude / 2), 2) + cos($lat1) * cos($lat2) * pow(sin($calcLongitude / 2), 2); $stepTwo = 2 * asin(min(1, sqrt($stepOne)));
$calculatedDistance = $earthRadius * $stepTwo;
return round($calculate);
}
附一个在线计算两点距离的地址:
http://www.nhc.noaa.gov/gccalc.shtml
分享到:
相关推荐
WGS84坐标下根据经纬度计算两点之间的距离 Xian80的需要先转化
PHP根据两点间的经纬度计算距离 一、 开发环境 1、环境搭建:Windows 7+Apache 2.4.18+MySQL 5.7.11+PHP 7.1.0。 2、文本编辑器:Sublime 3。 二、主要技术 本案例主要使用PHP中的数学函数,通过两点间的经纬度来...
二、主要技术本案例主要使用PHP中的数学函数,通过两点间的经纬度来计算两点之间的距离 三、效果图展示实现效果图,如图1所示 五、网页测试①开启Apache服务器
现在计算距离一般是同步百度和其他地图接口调用,可以直接通过公式计算获取两点经纬度距离
geohash解决计算附近距离,搜索附近的商业点,两个经纬度距离,地理位置应用处理
主要为大家详细介绍了php两点地理坐标距离的计算方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
geohash解决计算附近距离,搜索附近的商业点,两个经纬度距离,地理位置应用处理
计算两个地理坐标之间距离的简单方法。 有用于计算的文。 由 Composer 安装 require: "ayeo/geo": "1.0.*" 示例使用 use Ayeo \ Geo \ Coordinate ; use Ayeo \ Geo \ DistanceCalculator ; //London: 51°30′N 0...
LBS,存储每个地点的经纬度坐标,搜寻附近的地点,建立地理位置索引可提高查询效率。 mongodb地理位置索引,2d和2dsphere,对应平面和球面。 1.创建lbs集合存放地点坐标 use lbs; db.lbs.insert( { loc:{ type:...
邮政编码数据库使用此包将邮政编码转换为地理坐标,计算两个邮政编码之间的距离,找到最接近经纬度点的邮政编码,并返回邮政编码半径内的邮政编码列表。安装通过 composer 安装、发布配置文件、使用新的 artisan ...