高德地图计算两个坐标经纬度之间的直线距离

double lon1 = (Math.PI / 180) * 116.368904;//开始经度
double lon2 = (Math.PI / 180) * 116.387271;//结束经度
double lat1 = (Math.PI / 180) * 39.923423;//开始纬度
double lat2 = (Math.PI / 180) * 39.922501;//结束纬度

// 地球半径
double R = 6371;

// 两点间距离 km,如果想要米的话,结果*1000就可以了
double d = Math.acos(Math.sin(lat1) * Math.sin(lat2) + Math.cos(lat1) * Math.cos(lat2) * Math.cos(lon2 - lon1)) * R;

System.out.println(d * 1000);

 

这个结果我对照高德地图看过,基本差不多,可以使用,但其他地图要看情况

上一篇:【Mysql 学习】算术运算及字符串,数值函数


下一篇:展望CES 2015:智能硬件唱主角 上演个人云时代大片