1.官方推荐的方法是这样子的(有的准确,但大部分还是不准确的,有负数和超大值)
float distance = AMapUtils.calculateLineDistance(latLng1,latLng2);
2.正确的距离计算是这样子的(返回的单位可以是KM或M,但有自有方法可以自动判断,请看3)
public double getDistance(LatLng start, LatLng end) {
double lon1 = (Math.PI / 180) * start.longitude;
double lon2 = (Math.PI / 180) * end.longitude;
double lat1 = (Math.PI / 180) * start.latitude;
double lat2 = (Math.PI / 180) * end.latitude;
// 地球半径
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;
return d * 1000;
}
- 在获取到距离之后,需要对数据进行小数点,单位的处理,最后显示的如果小于一千米,单位会以M,其余的会以KM为单位。
double aaaa = getDistance(latlng1, latlng);
float distance1 = (float) Math.abs(aaaa);
distance1 = Math.round(distance1);
if (distance1 > 0) {
holder.distance.setText(Utils.getDisDsrc(distance1));
} else {
holder.distance.setText("");
}