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);
這個結果我對照高德地圖看過,基本差不多,可以使用,但其他地圖要看情況