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

  • 相关阅读:
    SQLite数据库
    如何将大文件写入到数据库中
    Visual Studio 2008 附加进程调试
    VS2010MFC编程入门
    关于exe文件传递参数方法
    监视剪贴板数据
    Delphi快捷键
    判断一个对象是否存在, 谁更快
    全局探色器
    用DELPHI中实现RAR文件解压到指定一目录
  • 原文地址:https://www.cnblogs.com/fps2tao/p/11598601.html
Copyright © 2011-2022 走看看