码迷,mamicode.com
首页 > 其他好文 > 详细

地图上半径内的经纬度

时间:2015-01-10 18:03:23      阅读:218      评论:0      收藏:0      [点我收藏+]

标签:

    /*
     * 地图上半径内的经纬度
     * @param lat 纬度 lon 经度 raidus 单位米
     */
    function getAround($lat,$lon,$raidus){
        $raidus = empty($raidus)?3000:$raidus;
        $PI = 3.14159265;
        $latitude = $lat;
        $longitude = $lon;
        $degree = (24901*1609)/360.0;
        $raidusMile = $raidus;
        $dpmLat = 1/$degree;
        $radiusLat = $dpmLat*$raidusMile;
        $minLat = $latitude-$radiusLat;
        $maxLat = $latitude + $radiusLat;
        $mpdLng = $degree*cos($latitude * ($PI/180));
        $dpmLng = 1 / $mpdLng;
        $radiusLng = $dpmLng*$raidusMile;
        $minLng = $longitude - $radiusLng;
        $maxLng = $longitude + $radiusLng;
        $data[‘minLat‘] = $minLat;
        $data[‘maxLat‘] = $maxLat;
        $data[‘minLng‘] = $minLng;
        $data[‘maxLng‘] = $maxLng;
        return $data;
    }

根据距离远近来排序,大概思路,没去写,到时候用到再改 order by  ( |Latitude-当前纬度|+|Longitude-当前经度|) asc

地图上半径内的经纬度

标签:

原文地址:http://www.cnblogs.com/steptoupper/p/4215273.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!