zoukankan      html  css  js  c++  java
  • 通过计算经纬度获取附近的数据信息(未验证)

    /**
    *计算某个经纬度的周围某段距离的正方形的四个点
    *
    *@param lng float 经度
    *@param lat float 纬度
    *@param distance float 该点所在圆的半径,该圆与此正方形内切,默认值为0.5千米
    *@return array 正方形的四个点的经纬度坐标
    */
    function returnSquarePoint($lng, $lat,$distance = 0.5){
    define(EARTH_RADIUS, 6371);//地球半径,平均半径为6371km
    $dlng = 2 * asin(sin($distance / (2 * EARTH_RADIUS)) / cos(deg2rad($lat)));
    $dlng = rad2deg($dlng);
    
    $dlat = $distance/EARTH_RADIUS;
    $dlat = rad2deg($dlat);
    
    return array(
    'left-top'=>array('lat'=>$lat + $dlat,'lng'=>$lng-$dlng),
    'right-top'=>array('lat'=>$lat + $dlat, 'lng'=>$lng + $dlng),
    'left-bottom'=>array('lat'=>$lat - $dlat, 'lng'=>$lng - $dlng),
    'right-bottom'=>array('lat'=>$lat - $dlat, 'lng'=>$lng + $dlng)
    );
    }
    
    function getdistance($lng1,$lat1,$lng2,$lat2){//根据经纬度计算距离 单位为公里
    //将角度转为狐度
    $radLat1=deg2rad($lat1);
    $radLat2=deg2rad($lat2);
    $radLng1=deg2rad($lng1);
    $radLng2=deg2rad($lng2);
    $a=$radLat1-$radLat2;//两纬度之差,纬度<90
    $b=$radLng1-$radLng2;//两经度之差纬度<180
    $s=2*asin(sqrt(pow(sin($a/2),2)+cos($radLat1)*cos($radLat2)*pow(sin($b/2),2)))*6378.137;
    return $s;
    }

    函数 returnSquarePoint 是用来获取某个坐标点附近0.5KM之内的正方形的四个点,通过此办法获取附近的面积,并通过此函数组合出所需的SQL语句

    转: https://blog.csdn.net/w_yunlong/article/details/50432458

    https://my.oschina.net/jack088/blog/3012861

    https://www.cnblogs.com/xiaoyu5062/articles/7687097.html

    https://cloud.tencent.com/developer/article/1112870

  • 相关阅读:
    012.Nginx负载均衡
    011.Nginx防盗链
    010.Nginx正反代理
    009.Nginx缓存配置
    附007.Docker全系列大总结
    附024.Kubernetes全系列大总结
    008.Nginx静态资源
    007.Nginx虚拟主机
    006.Nginx访问控制
    005.Nginx配置下载站点
  • 原文地址:https://www.cnblogs.com/fps2tao/p/11598601.html
Copyright © 2011-2022 走看看