第一步:先搞一个计算距离的工具类
package com.gly.lvyouju.utils;
public class CountDistanceUtil {
/**
* 计算地球上任意两点(经纬度)距离
*
* @param long1 第一点经度
* @param lat1 第一点纬度
* @param long2 第二点经度
* @param lat2 第二点纬度
* @return 返回距离 单位:米
*/
public static double Distance(double long1, double lat1, double long2,
double lat2) {
double a, b, R;
R = 6378137; // 地球半径
lat1 = lat1 * Math.PI / 180.0;
lat2 = lat2 * Math.PI / 180.0;
a = lat1 - lat2;
b = (long1 - long2) * Math.PI / 180.0;
double d;
double sa2, sb2;
sa2 = Math.sin(a / 2.0);
sb2 = Math.sin(b / 2.0);
d = 2
* R
* Math.asin(Math.sqrt(sa2 * sa2 + Math.cos(lat1)
* Math.cos(lat2) * sb2 * sb2));
return d;
}
}
第二步:在需要计算的地方调用工具类,并且可以根据距离显示m或者km
/**
* 计算距离
*/
// 当前位置的经度纬度
double locationLong = MyApplication.getLongitude();// 当前位置的经度
double locationLa = MyApplication.getLatitude();// 当前位置的纬度
double actionLong = infos.getActionLocation().getLongitude();// 活动的经度
double actionLa = infos.getActionLocation().getLatitude();// 活动的纬度
double distance = CountDistanceUtil.Distance(locationLong, locationLa,
actionLong, actionLa);
if (distance < 1000) {
holder.distanceTv.setText("距离我" + distance + "m");
} else {
// 保留两位小数
DecimalFormat df = new DecimalFormat("#.00");
String distancekm = df.format(distance / 1000.0);
holder.distanceTv.setText("距离我" + distancekm + "km");
}