比如我现在知道一个点的经度和纬度了,然后我想算出以这个点为圆心,1000米为半径,最大的经度和纬度,最小的经度和纬度,请问怎么算呢?

PHP代码我网上找了一个算出来好像不对呀

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
获取当前位置三公里内最大、最小经纬度
    /**
     * 查找一定范围内的经纬度值
     * 传入值:纬度  经度  查找半径(m)
     * 返回值:最小纬度、经度,最大纬度、经度
     */
    public function getAround($lat,$lon,$raidus)
    
        $PI = 3.14159265;               // 圆周率
     $EARTH_RADIUS = 6378137;     // 地球半径
    $RAD = Math.PI / 180.0;         // 弧度
         
        $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;
        $result['minwei']=$minLat;
        $result['minjing']=$minLng;
        $result['maxwei']=$maxLat;
        $result['maxjing']=$maxLng;
        return $result;
    }

lat=116.575831
lng=39.788623
Array
([minwei] => 116.56684576[minjing] => 39.8087070499[maxwei] => 116.58481624[maxjing] => 39.7685389501
)

微信 根据当前地理位置经纬度计算1000米以内的经纬度范围 php版

核心PHP代码如下!

[php] view plaincopy
  1. $myLat = $postObj->Location_X;//接收到的当前位置的纬度
  2. $myLng = $postObj->Location_Y;//接收到的当前位置的经度
  3. $Label = $postObj->Label;//接收到的当前地理位置信息
  4. $Label = iconv("UTF-8","GBK",$Label);
  5. $find = stripos($Label,' ');//过滤掉邮政编码 纯属为了整洁性
  6. if($find!==false)
  7. {
  8. $Label = substr($Label,0,$find);
  9. }
  10. //以下为核心代码
  11. $range = 180 / pi() * 1 / 6372.797;     //里面的 1 就代表搜索 1km 之内,单位km
  12. $lngR = $range / cos($myLat * pi() / 180);
  13. $maxLat = $myLat + $range;//最大纬度
  14. $minLat = $myLat - $range;//最小纬度
  15. $maxLng = $myLng + $lngR;//最大经度
  16. $minLng = $myLng - $lngR;//最小经度
  17. //得出这四个值以后,就可以根据你数据库里存的经纬度信息查找记录了~

LBS中从数据库查询某经纬度2KM范围内的数据 - 针对大数据量的性能优化

[-]

  1. 之前很啥很天真地以为无非就是逐个计算距离然后比较出来就行了然后当碰到访问用户很多而且数据库中经纬度信息很多的时候计算量的迅速增长能让服务器完全傻逼掉还是老前辈的经验比我们丰富给了我很大的启示
  2. MySQL性能调优 使用更为快速的算法进行距离计算

之前很啥很天真地以为无非就是逐个计算距离,然后比较出来就行了,然后当碰到访问用户很多,而且数据库中经纬度信息很多的时候,计算量的迅速增长,能让服务器完全傻逼掉,还是老前辈的经验比我们丰富,给了我很大的启示。

MySQL性能调优 – 使用更为快速的算法进行距离计算

最近遇到了一个问题,通过不断的尝试最终将某句原本占据近1秒的查询优化到了0.01秒,效率提高了100倍.

问题是这样的,有一张存放用户居住地点经纬度信息的MySQL数据表,表结构可以简化 为:id(int),longitude(long),latitude()long. 而业务系统中有一个功能是查找离某个用户最近的其余数个用户,通过代码分析,可以确定原先的做法基本是这样的:

//需要查询的用户的坐标

$lat=20;
$lon=20;//执行查询,算出该用户与所有其他用户的距离,取出最近的10个
$sql='select * from users_location order by ACOS(SIN(('.$lat.' * 3.1415) / 180 ) *SIN((latitude * 3.1415) / 180 ) +COS(('.$lat.' * 3.1415) / 180 ) * COS((latitude * 3.1415) / 180 ) *COS(('.$lon.' * 3.1415) / 180 - (longitude * 3.1415) / 180 ) ) * 6380 asc limit 10';

而这条sql执行的速度却非常缓慢,用了近1秒的时间才返回结果,应该是因为order里的子语句用了太多的数学计算公式,导致整体的运算速度下降.

而在实际的使用中,不太可能会发生需要计算该用户与所有其他用户的距离,然后再排序的情况,当用户数量达到一个级别时,就可以在一个较小的范围里进行搜索,而非在所有用户中进行搜索.

所以对于这个例子,我增加了4个where条件,只对于经度和纬度大于或小于该用户1度(111公里)范围内的用户进行距离计算,同时对数据表中的经度和纬度两个列增加了索引来优化where语句执行时的速度.

最终的sql语句如下

$sql='select * from users_location where
latitude > '.$lat.'-1 and
latitude < '.$lat.'+1 and
longitude > '.$lon.'-1 and
longitude < '.$lon.'+1
order by ACOS(SIN(('.$lat.' * 3.1415) / 180 ) *SIN((latitude * 3.1415) / 180 ) +COS(('.$lat.' * 3.1415) / 180 ) * COS((latitude * 3.1415) / 180 ) *COS(('.$lon.'* 3.1415) / 180 - (longitude * 3.1415) / 180 ) ) * 6380 asc limit 10';

经过优化的sql大大提高了运行速度,在某些情况下甚至有100倍的提升.这种从业务角度出发,缩小sql查询范围的方法也可以适用在其他地方.

一个点的经度和纬度,以这个点为圆心,1000米为半径,最大的经度和纬度,最小的经度和纬度相关推荐

  1. 一个点的经度和纬度,以这个点为圆心,1000米为半径,最大的经度和纬度,最小的经度和纬度...

    比方我如今知道一个点的经度和纬度了,然后我想算出以这个点为圆心,1000米为半径.最大的经度和纬度,最小的经度和纬度.请问怎么算呢? PHP代码我网上找了一个算出来好像不正确呀 ? 1 2 3 4 5 ...

  2. C语言试题二十三之编写一个函数void function(int tt[m][n],int pp[n]),tt指向一个m行n列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维数组中

    1. 题目 请编写一个函数void function(int tt[m][n],int pp[n]),tt指向一个m行n列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维数组中.二 ...

  3. Google Maps API 以某一经纬度为中心,以某一长度位半径画圆 Draw the radius of a circle...

    直接看代码: <!DOCTYPE html> <html> <head> <meta http-equiv="content-type" ...

  4. 一个N*M的矩阵,找出这个矩阵中所有元素的和不小于K的面积最小的子矩阵

    题目描述: 一个N*M的矩阵,找出这个矩阵中所有元素的和不小于K的面积最小的子矩阵(矩阵中元素个数为矩阵面积) 输入: 每个案例第一行三个正整数N,M<=100,表示矩阵大小,和一个整数K 接下 ...

  5. java类求圆的面积周长_java编程 1. 设计一个求圆的面积和周长的类,要求:1计算当半径r,JAVA编程题。编写一个应用程序计算圆的周长和面积,设圆的半...

    问题标题 java编程 1. 设计一个求圆的面积和周长的类,要求:1计算当半径r,JAVA编程题.编写一个应用程序计算圆的周长和面积,设圆的半 2019-5-23来自ip:15.196.194.53的 ...

  6. java设计求圆的面积周长的代码_java编程 1.设计一个求圆的面积和周长的类,要求:1计算当半径r=10和20时,圆的面积,并显示出来 、...

    导航:网站首页 > java编程 1.设计一个求圆的面积和周长的类,要求:1计算当半径r=10和20时,圆的面积,并显示出来 . 时间:2018-11-8 java编程 1.设计一个求圆的面积和 ...

  7. Java编程入门与应用 P80——例3-24(小明参加一个1000米的长跑比赛每跑完一圈,教练就会问他是否要坚持下去,如果回答yes,则继续跑,否则表示放弃。)

    Java编程入门与应用 P80--例3-24 小明参加一个1000米的长跑比赛,在100米的跑道上,他循环地跑着,每跑一圈,剩余的路程就会减去100米,要跑的圈数就是循环的次数.但是,在每跑完一圈, ...

  8. C语言:一个小猴子边上有100根香蕉,他要走过50米才能到家,每次他最多搬50根香蕉搬到家里,请问它最多能把多少根香蕉搬到家里?

    代码如下: /********************************************************功能:求以下问题*一个小猴子边上有100根香蕉,他要走过50米才能到家,每 ...

  9. Java---定义一个圆(Circle)类表示三维空间中的圆(两个成员变量:圆心Point类、半径)

    要求如下: 可以生成具有特定圆心.半径的圆对象 提供可以设置成员变量的方法 计算一个点(Point)对象是否在圆(Circle)对象内 源代码如下: import java.util.Scanner; ...

  10. 1、已知:1公里=2里=1000米,请编写一个程序,输入公里数,将其转换成里和米。要求程序的输入输出如下: 请输入公里数: 3.3 3.30公里=6.60里=3300米

    #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> int main() {     float a, b, c;//定义公里,里,米的 ...

最新文章

  1. 斯坦福Google | 面向机器人的机器学习(附63页PPT下载)
  2. 解决ubuntu的chkconfig[/sbin/insserv 无法找到路径问题]
  3. 2.5万美元奖金!滴滴算法工程师详解专业赛事:2021 SIGSPATIAL GISCUP
  4. Nginx安装环境配置
  5. Apache+Tomcat动静分离
  6. 腾讯云启动 tomcat 很慢的问题
  7. php-cs-fixer不起作用,使用 PHP-CS-Fixer 规范PHP代码
  8. 伺服驱动器cn1引脚定义_关于三菱驱动器CN1端口的接线-专业自动化论坛-中国工控网论坛...
  9. nssa和stub_ospf协议stub和nssa区域说明
  10. 数据标准化/归一化normalization
  11. 安全测试(五)Android APK软件安全 APP应用安全 手机软件安全 apk安全 apk反编译 应用日志窃取 apk漏洞 应用软件本身功能漏洞 高危权限泄密风险等 移动应用常规安全讲解
  12. signature=d392c0d1876b3909bd8f7e1f3c0bef22,【技术分享】NSA武器库:CVE-2017-9073 EsteemAudit分析...
  13. win10使用的c语言程序开发,Win10是什么编程语言写的?源代码文件多到你无法想象...
  14. 写一个商品类Goods,属性有商品编号,商品名称,商品价格和上架时间。
  15. matlab中的箭头符号怎么打开,MATLAB中上下标、斜体、箭头等符号的使用方法
  16. idea 配置文件中的中文与ASCII码互转
  17. 机器人运动估计——IMU运动方程与ESKF原理介绍(下)
  18. 机构不会教的python入门学习路线
  19. 【第一次完成的需求测试流程总结】
  20. springboot -- 实现qq登录功能

热门文章

  1. simulink中不能改名_王者荣耀:万格改名教学,空白名、重复名、个性符号名改法技巧!...
  2. html特殊符号怎么输入法,教您特殊符号怎么打出来
  3. 写教案时,PDF怎么转换成PPT?用迅读PDF大师,超简单
  4. 五月份适合去哪旅游 国内15个旅游胜地
  5. imazing iOS设备管理软件
  6. pentaho mysql_pentaho5.0.1将数据库移植成mysql
  7. java 先入先出_一道java的基础题:一个线程安全的后进先出队列
  8. 时钟芯片DS1302异常
  9. python爬取每日腾讯新闻数据
  10. 五款实用的微信小程序(免费证件照)