php mysql 经纬度_mysql,php和js根据经纬度计算距离

php mysql 经纬度_mysql,php和js根据经纬度计算距离根据经纬度计算距离公式图片来自互联网对上面的公式解释如下:Lung1Lat1表示A点经纬度,Lung2Lat2表示B点经纬度;a=Lat1–Lat2为两点纬度之差b=Lung1-Lung2为两点经度之差;6378.137为地球半径,单位为千米;计算出来的结果单位为千米,若将半径改为米为单位则计算的结果单位为米。计算精度与谷歌地图的距离精度差不多,相差范围在0.2米以下。参数说明…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

根据经纬度计算距离公式

259ab2f76dfe1a4841da9ded2e7fae5f.png

图片来自互联网

对上面的公式解释如下:

Lung1 Lat1表示A点经纬度, Lung2 Lat2表示B点经纬度;

a=Lat1 – Lat2 为两点纬度之差 b=Lung1 -Lung2 为两点经度之差;

6378.137为地球半径,单位为千米;

计算出来的结果单位为千米,若将半径改为米为单位则计算的结果单位为米。

计算精度与谷歌地图的距离精度差不多,相差范围在0.2米以下。

参数说明

lng:经度

lat:纬度

地球半径:6378.137(千米)

一般地图上显示的坐标顺序为,纬度在前(范围-90 ~ 90),经度在后(范围-180 ~ 180)

各种语言计算距离的代码

这种计算方式一般都是直线距离

sql语句

SELECT

*,

6378.138 * 2 * ASIN(

SQRT(

POW(

SIN(

(

‘.$lat.’ * PI() / 180 – lat * PI() / 180

) / 2

), 2

) + COS(‘.$lat.’ * PI() / 180) * COS(lat * PI() / 180) * POW(

SIN(

(

‘.$lng.’ * PI() / 180 – lng * PI() / 180

) / 2

), 2

)

)

) *1000 AS distance

FROM

distance

ORDER BY

distance ASC

php计算距离

/**

* 根据两点间的经纬度计算距离

* @param $lng1

* @param $lat1

* @param $lng2

* @param $lat2

* @return int

*/

public static function getDistance($lng1, $lat1, $lng2, $lat2)

{

//将角度转为狐度

$radLat1 = deg2rad($lat1);//deg2rad()函数将角度转换为弧度

$radLat2 = deg2rad($lat2);

$radLng1 = deg2rad($lng1);

$radLng2 = deg2rad($lng2);

$a = $radLat1 – $radLat2;

$b = $radLng1 – $radLng2;

$s = 2 * asin(sqrt(pow(sin($a / 2), 2) + cos($radLat1) * cos($radLat2) * pow(sin($b / 2), 2))) * 6378.137 * 1000;

return $s;

}

js求距离的方法

/**

* 转换弧度

* @param d

* @returns {number}

*/

function getRad(d){

var PI = Math.PI;

return d*PI/180.0;

}

/**

* 根据经纬度计算两点间距离

* @param lng1

* @param lat1

* @param lng2

* @param lat2

* @returns {number|*}

* @constructor

*/

function CoolWPDistance(lng1,lat1,lng2,lat2){

var f = getRad((lat1 + lat2)/2);

var g = getRad((lat1 – lat2)/2);

var l = getRad((lng1 – lng2)/2);

var sg = Math.sin(g);

var sl = Math.sin(l);

var sf = Math.sin(f);

var s,c,w,r,d,h1,h2;

var a = 6378137.0;//The Radius of eath in meter.

var fl = 1/298.257;

sg = sg*sg;

sl = sl*sl;

sf = sf*sf;

s = sg*(1-sl) + (1-sf)*sl;

c = (1-sg)*(1-sl) + sf*sl;

w = Math.atan(Math.sqrt(s/c));

r = Math.sqrt(s*c)/w;

d = 2*w*a;

h1 = (3*r -1)/2/c;

h2 = (3*r +1)/2/s;

s = d*(1 + fl*(h1*sf*(1-sg) – h2*(1-sf)*sg));

if(s >= 1000 && s <= 99000){

var kilometer = s/1000;

s = kilometer.toFixed(1) + ‘km’;

}else if(s > 99000){

s = ‘>99km’;

}else{

s = Math.round(s) + ‘m’;

}

// s = s/1000;

// s = s.toFixed(2);//指定小数点后的位数。

return s;

}

以上代码大部分来自网上收集,经过验证过的,可以使用

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/190354.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • C#数组–(一维数组,二维数组的声明,使用及遍历)

    C#数组–(一维数组,二维数组的声明,使用及遍历)数组:是具有相同数据类型的一组数据的集合。数组的每一个的变量称为数组的元素,数组能够容纳元素的数称为数组的长度。一维数组:以线性方式存储固定数目的数组元素,它只需要1个索引值即可标识任意1个数组元素

    2022年7月2日
    23
  • 光纤通信视频_光纤传输的信号属于什么

    光纤通信视频_光纤传输的信号属于什么目前,光纤在生产和施工方面较于以前有了很大的提升,价格也降低了很多。再加上光纤的传输质量,光纤无疑将成为发展较快的传输模式。马上为您全面剖析光纤传输技术。  光纤通信的原理:在发送端首先要把传送的信息(如视频)变成电信号,然后调制到激光器发出的激光束上,使光的强度随电信号的幅度(频率)变化而变化,并通过光纤发送出去;在接收端,检测器收到光信号后把它变换成电信号,经解调后恢复原信息。  光纤监…

    2022年10月3日
    2
  • 彻底理解接口幂等性

    彻底理解接口幂等性目录背景 1 幂等性的概念 2 什么情况需要处理接口幂等性问题 2 1select 天然自带幂等性 2 2insert 当我们重复插入数据的时候 会出现什么情况 2 3delete 是否具有幂等性 2 4update 猜一猜是否具有天热幂等性 3 接口幂等性解决方案 3 1 唯一索引 防止新增脏数据 3 2token redis 机制 3 3CAS 保证接口幂等性 3 4 悲观锁 3 5 乐观锁实现幂等 3 6 分布式锁 3 7 防重表 3 8 缓

    2025年8月22日
    4
  • String转成Json数组 JsonArray 保持有序

    String转成Json数组 JsonArray 保持有序接收上传的数据转成Json,希望数据保持原来的顺序,fastjson处理JsonArray会把顺序hash,可以使用Gson来转成Json,避免顺序改变。importcom.google.gson.JsonArray;importcom.google.gson.JsonParser;/***createbyLiuJinHe2019/9/20*/pu…

    2022年6月20日
    75
  • pycahrm激活码【注册码】

    pycahrm激活码【注册码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月19日
    45
  • IntelliJ IDEA创建Servlet最新方法 Idea版本2020.2.2以及IntelliJ IDEA创建Servlet 404问题(超详细)

    IntelliJ IDEA创建Servlet最新方法 Idea版本2020.2.2以及IntelliJ IDEA创建Servlet 404问题(超详细)第一次用IntelliJIDEA写java代码,之前都是用eclipse,但eclipse太老了。下面为兄弟们奉上IntelliJIDEA创建Servlet方法,写这个的目的也是因为在网上找了很多资料但都过时了,所以把我走过的坑和弯路直接告诉兄弟们,为大家节省点宝贵的时间。说一下现在创建Servlet或者是web和之前的主要区别,之前是直接创建,现在是先要创建java项目然后通过添加支持框架变成Servlet或者web项目下面这些截图最好都看完,因为有的地方有坑,都在后面的截图里。我用

    2022年6月17日
    55

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号