最近在做与地图相关的应用,使用了高德地图,研究了下高德地图计算两坐标距离的方法,官网上提供的开发包中有相关的方法,但是我的产品中比较特殊,无法直接使用提供的方法,所以就自己封装了相关计算方法,供大家参考。

Java实现

首先定义一个用于存储经纬度的类,这里起个名字叫:LngLat

package amap;

import java.text.DecimalFormat;

import java.text.DecimalFormatSymbols;

import java.util.Locale;

/**

* 存储经纬度坐标值的类,单位角度

*

*@author jianggujin

*

*/

public final class LngLat implements Cloneable

{

/**

* 纬度 (垂直方向)

*/

public final double latitude;

/**

* 经度 (水平方向)

*/

public final double longitude;

/**

* 格式化

*/

private static DecimalFormat format = new DecimalFormat("0.000000", new DecimalFormatSymbols(Locale.US));

/**

* 使用传入的经纬度构造LatLng 对象,一对经纬度值代表地球上一个地点。

*

*@param longitude

* 地点的经度,在-180 与180 之间的double 型数值。

*@param latitude

* 地点的纬度,在-90 与90 之间的double 型数值。

*/

public LngLat(double longitude, double latitude)

{

this(longitude, latitude, true);

}

/**

* 使用传入的经纬度构造LatLng 对象,一对经纬度值代表地球上一个地点

*

*@param longitude

* 地点的经度,在-180 与180 之间的double 型数值。

*

*@param latitude

* 地点的纬度,在-90 与90 之间的double 型数值。

*@param isCheck

* 是否需要检查经纬度的合理性,建议填写true

*/

public LngLat(double longitude, double latitude, boolean isCheck)

{

if (isCheck)

{

if ((-180.0D <= longitude) && (longitude < 180.0D))

this.longitude = parse(longitude);

else

{

throw new IllegalArgumentException("the longitude range [-180, 180].");

// this.longitude = parse(((longitude - 180.0D) % 360.0D + 360.0D) %

// 360.0D - 180.0D);

}

if ((latitude < -90.0D) || (latitude > 90.0D))

{

throw new IllegalArgumentException("the latitude range [-90, 90].");

}

this.latitude = latitude;

// this.latitude = parse(Math.max(-90.0D, Math.min(90.0D, latitude)));

}

else

{

this.latitude = latitude;

this.longitude = longitude;

}

}

/**

* 解析

*

*@param d

*@return

*/

private static double parse(double d)

{

return Double.parseDouble(format.format(d));

}

public LngLat clone()

{

return new LngLat(this.latitude, this.longitude);

}

@Override

public int hashCode()

{

final int prime = 31;

int result = 1;

long temp;

temp = Double.doubleToLongBits(latitude);

result = prime * result + (int) (temp ^ (temp >>> 32));

temp = Double.doubleToLongBits(longitude);

result = prime * result + (int) (temp ^ (temp >>> 32));

return result;

}

@Override

public boolean equals(Object obj)

{

if (this == obj)

return true;

if (obj == null)

return false;

if (getClass() != obj.getClass())

return false;

LngLat other = (LngLat) obj;

if (Double.doubleToLongBits(latitude) != Double.doubleToLongBits(other.latitude))

return false;

if (Double.doubleToLongBits(longitude) != Double.doubleToLongBits(other.longitude))

return false;

return true;

}

public String toString()

{

return "lat/lng: (" + this.latitude + "," + this.longitude + ")";

}

}

计算工具类如下:

package amap;

/**

* 高德地图工具

*

*@author jianggujin

*

*/

public class AMapUtils

{

/**

* 根据用户的起点和终点经纬度计算两点间距离,此距离为相对较短的距离,单位米。

*

*@param start

* 起点的坐标

*@param end

* 终点的坐标

*@return

*/

public static double calculateLineDistance(LngLat start, LngLat end)

{

if ((start == null) || (end == null))

{

throw new IllegalArgumentException("非法坐标值,不能为null");

}

double d1 = 0.01745329251994329D;

double d2 = start.longitude;

double d3 = start.latitude;

double d4 = end.longitude;

double d5 = end.latitude;

d2 *= d1;

d3 *= d1;

d4 *= d1;

d5 *= d1;

double d6 = Math.sin(d2);

double d7 = Math.sin(d3);

double d8 = Math.cos(d2);

double d9 = Math.cos(d3);

double d10 = Math.sin(d4);

double d11 = Math.sin(d5);

double d12 = Math.cos(d4);

double d13 = Math.cos(d5);

double[] arrayOfDouble1 = new double[3];

double[] arrayOfDouble2 = new double[3];

arrayOfDouble1[0] = (d9 * d8);

arrayOfDouble1[1] = (d9 * d6);

arrayOfDouble1[2] = d7;

arrayOfDouble2[0] = (d13 * d12);

arrayOfDouble2[1] = (d13 * d10);

arrayOfDouble2[2] = d11;

double d14 = Math.sqrt((arrayOfDouble1[0] - arrayOfDouble2[0]) * (arrayOfDouble1[0] - arrayOfDouble2[0])

+ (arrayOfDouble1[1] - arrayOfDouble2[1]) * (arrayOfDouble1[1] - arrayOfDouble2[1])

+ (arrayOfDouble1[2] - arrayOfDouble2[2]) * (arrayOfDouble1[2] - arrayOfDouble2[2]));

return (Math.asin(d14 / 2.0D) * 12742001.579854401D);

}

}

最后边写一段测试代码测试一下:

package test;

import org.junit.Test;

import amap.AMapUtils;

import amap.LngLat;

public class AMapTest

{

@Test

public void Test()

{

LngLat start = new LngLat(116.368904, 39.923423);

LngLat end = new LngLat(116.387271, 39.922501);

System.err.println(AMapUtils.calculateLineDistance(start, end));

}

}

运行结果为:1569.6213922679392,官网的javascript API示例结果如图:

结果虽然有一点误差,但是这hi在可接受范围内的。

Javascript实现

同样的算法,将其转换成JS的写法,完整的代码如下:

* 存储经纬度

* @param {Object} longitude

* @param {Object} latitude

*/

function LngLat(longitude, latitude) {

this.longitude = longitude;

this.latitude = latitude;

}

function calculateLineDistance(start, end) {

var d1 = 0.01745329251994329;

var d2 = start.longitude;

var d3 = start.latitude;

var d4 = end.longitude;

var d5 = end.latitude;

d2 *= d1;

d3 *= d1;

d4 *= d1;

d5 *= d1;

var d6 = Math.sin(d2);

var d7 = Math.sin(d3);

var d8 = Math.cos(d2);

var d9 = Math.cos(d3);

var d10 = Math.sin(d4);

var d11 = Math.sin(d5);

var d12 = Math.cos(d4);

var d13 = Math.cos(d5);

var arrayOfDouble1 = [];

var arrayOfDouble2 = [];

arrayOfDouble1.push(d9 * d8);

arrayOfDouble1.push(d9 * d6);

arrayOfDouble1.push(d7);

arrayOfDouble2.push(d13 * d12);

arrayOfDouble2.push(d13 * d10);

arrayOfDouble2.push(d11);

var d14 = Math.sqrt((arrayOfDouble1[0] - arrayOfDouble2[0]) * (arrayOfDouble1[0] - arrayOfDouble2[0]) +

(arrayOfDouble1[1] - arrayOfDouble2[1]) * (arrayOfDouble1[1] - arrayOfDouble2[1]) +

(arrayOfDouble1[2] - arrayOfDouble2[2]) * (arrayOfDouble1[2] - arrayOfDouble2[2]));

return(Math.asin(d14 / 2.0) * 12742001.579854401);

}

var start = new LngLat(116.368904, 39.923423);

var end = new LngLat(116.387271, 39.922501);

MySQL实现

DELIMITER $$

CREATE FUNCTION `calculateLineDistance`(startLng double, startLat double, endLng double, endLat double) RETURNS double

BEGIN

declare d2 DOUBLE;

declare d3 DOUBLE;

declare d4 DOUBLE;

declare d5 DOUBLE;

declare d6 DOUBLE;

declare d7 DOUBLE;

declare d8 DOUBLE;

declare d9 DOUBLE;

declare d10 DOUBLE;

declare d11 DOUBLE;

declare d12 DOUBLE;

declare d13 DOUBLE;

declare d14 DOUBLE;

declare arrayOfDouble10 DOUBLE;

declare arrayOfDouble11 DOUBLE;

declare arrayOfDouble12 DOUBLe;

declare arrayOfDouble20 DOUBLE;

declare arrayOfDouble21 DOUBLE;

declare arrayOfDouble22 DOUBLE;

set d2 = startLng * 0.01745329251994329;

set d3 = startLat * 0.01745329251994329;

set d4 = endLng * 0.01745329251994329;

set d5 = endLat * 0.01745329251994329;

set d6 = sin(d2);

set d7 = sin(d3);

set d8 = cos(d2);

set d9 = cos(d3);

set d10 = sin(d4);

set d11 = sin(d5);

set d12 = cos(d4);

set d13 = cos(d5);

set arrayOfDouble10 = (d9 * d8);

set arrayOfDouble11 = (d9 * d6);

set arrayOfDouble12 = d7;

set arrayOfDouble20 = (d13 * d12);

set arrayOfDouble21 = (d13 * d10);

set arrayOfDouble22 = d11;

set d14 = sqrt((arrayOfDouble10 - arrayOfDouble20) * (arrayOfDouble10 - arrayOfDouble20)

+ (arrayOfDouble11 - arrayOfDouble21) * (arrayOfDouble11 - arrayOfDouble21)

+ (arrayOfDouble12 - arrayOfDouble22) * (arrayOfDouble12 - arrayOfDouble22));

return (asin(d14 / 2.0) * 12742001.579854401);

END $$

DELIMITER ;

--------------------- 本文来自 蒋固金 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/jianggujin/article/details/72833711?utm_source=copy

高德地图获取坐标距离_高德地图计算两坐标之间距离相关推荐

  1. 高德地图计算两坐标之间距离

    转载自:http://blog.csdn.net/jianggujin/article/details/72833711 如要转载请写明原创地址 Java实现 Javascript实现 MySQL实现 ...

  2. php高德地图计算距离接口,高德地图计算两坐标之间距离

    最近在做与地图相关的应用,使用了高德地图,研究了下高德地图计算两坐标距离的方法,官网上提供的开发包中有相关的方法,但是我的产品中比较特殊,无法直接使用提供的方法,所以就自己封装了相关计算方法,供大家参 ...

  3. android地图获取坐标位置,android 百度地图 根据得到的经纬度 获取位置信息

    满意答案 回复了sfdzyy 2015.07.03 采纳率:57%    等级:7 已帮助:658人 private GeoCoder mSearch = null; // 搜索模块 // 初始化搜索 ...

  4. Java对接高德地图计算距离_高德地图计算两点之间的距离java+html

    高德地图现在使用比较多了,但是高德地图计算两点之间的距离有些问题.下面提供一个很好的解决方案. 代码如下: /** * 两点的经纬度获取两点距离米 * @param (121.293986,37.27 ...

  5. Java-高德地图根据经纬度计算两坐标之间的直线距离

    Java-高德地图根据经纬度计算两坐标之间的直线距离 最近在做毕设项目,项目打卡需要用到高德地图,看了下高德地图计算两坐标距离的方法,官网上提供的开发包中也有相关的方法. /**** @author ...

  6. 小程序计算两点之间距离

    计算两点之间距离 一. 在小程序中获取两点之间的距离 要首先明确哪俩点的位置 在页面的js中先写出 经纬度 以此来计算 这里是计算当前位置和目的地的位置 二 .通过函数来计算俩点之间的距离 需要写在j ...

  7. 高德地图获取坐标距离_计算两个坐标点之间的距离(高德地图)

    /** * 计算两点的距离 * * @param fromPoint * @param toPoint * @return 返回String类型带距离单位 */ public static Strin ...

  8. 高德地图获取坐标距离_利用java、js或mysql计算高德地图中两坐标之间的距离

    前言 因为工作的原因,最近在做与地图相关的应用,使用了高德地图,研究了下高德地图计算两坐标距离的方法,官网上提供的开发包中有相关的方法,但是我的产品中比较特殊,无法直接使用提供的方法,所以就自己封装了 ...

  9. 高德地图获取坐标距离_高德地图获取两个经纬度点间直线距离JS/PHP/SQL代码

    最近做了几个小站,要求要定位到当前地址并且显示附近多少公里内的商家和产品. 定位好办,直接用高德地图搞定.有不需要显示地图又需要定位的页面把地图直接隐藏掉都可以.或者可以直接调用高德的定位组件. 但是 ...

  10. 在vue中使用高德地图获取坐标与地址信息(包含点击+搜索)

    首先 注册登陆高德地图 https://lbs.amap.com/ 划过头像里面有个应用管理点开 进入到应用管理打开我的应用 选择创建应用 然后按照要求填写内容,切记一定要选择web端(JS API) ...

最新文章

  1. 223.主成分分析PCA
  2. 八年磨一剑,重新定义HBase——HBase 2.0阿里云HBase解读
  3. C#事件(event)解析
  4. 1至m为PQ节点,m+1至n-1为PV节点,n为平衡节点
  5. 配置管理 ACM 在高可用服务 AHAS 流控降级组件中的应用场景
  6. python网格搜索核函数_(转载)Python机器学习笔记GridSearchCV(网格搜索)
  7. linux配置vscodec运行环境,Linux 下 VSCode c/c++环境配置
  8. SLAM研究内容框架分析
  9. 目标检测论文阅读:Cascade R-CNN: Delving into High Quality Object Detection(CVPR2018)
  10. 【tool】将虚拟机从 VMware workstation 转到 vsphere
  11. (28)状态机概述(第6天)
  12. mui.ajax php,求助!!!关于mui ajax获取不到后台数据
  13. TokenInsight:反映区块链行业整体表现的TI指数较昨日同期上涨2.62%
  14. windows 下杀手tomcat 进程
  15. dw中html网页如何加音乐播放器,在dreamweaver网页制作中插入音乐播放器详细参考...
  16. getinfo怎么用php,PHP SplObjectStorage getinfo()用法及代码示例
  17. 2021年田野的风响彻了整个冰岛
  18. 杜撰——深圳市贝力公司电子商务方案
  19. dubbo(5) Dubbo源码解析之服务调用过程
  20. 数学分析教程(科大)——4.1笔记+习题

热门文章

  1. Java对象内存分配流程
  2. _ZN10tensorflow8internal21CheckOpMessageBuilder9NewStringB5cxx11Ev
  3. html中加入emjio表情,jqueryemoji表情插件
  4. 微信html5线上卡券,16.7.1HTML5网页领取卡券
  5. 新鲜的字节跳动实习面经(Android开发岗),字节跳动面试分享
  6. 【02.06-02.13】长赢计划主理人“ETF拯救世界”微博精选
  7. 通信线路工程验收规范_老杨一建通信学堂通信线路工程施工技术
  8. 合作式智能运输系统通信架构
  9. matlab 计算一元函数解,遗传算法简单一元函数优化实例
  10. 尘埃4 for Mac(DiRT4赛车竞速游戏)原生版