java使用geocoder,获取经纬度并计算没两点间距离

时间:2021-01-18 19:52:44

1、首先下载所需要的jar包 http://download.csdn.net/detail/kof0101/6603595

2、将jar包添加到Eclipse工程中(右键->属性->Java Build->Libraries)

3、使用geocoder,获取经纬度只需要几行的代码

private void getLatlng_Geo(String address){
if (address==null || address.equals(""))
return null;
List<GeocoderResult> result;
Geocoder geocoder = new Geocoder();
//向google发送获取地址详细请求
GeocoderRequest geocoderRequest = new GeocoderRequestBuilder().setAddress(address).setLanguage("en").getGeocoderRequest();
//获得google的反馈
GeocodeResponse geocoderResponse = geocoder.geocode(geocoderRequest);
do{
System.out.println(geocoderResponse.getStatus());
//获取反馈结果
result = geocoderResponse.getResults();
}while(result.size()==0);

//获取地址经纬度信息
float lat = result.get(0).getGeometry().getLocation().getLat().floatValue();
float lng = result.get(0).getGeometry().getLocation().getLng().floatValue();

System.out.println(result.get(0).getFormattedAddress());
System.out.println("lat/lng=" + lat + "," + lng);


}


4、计算两点间距离,参照网上提供的google方法,实现如下

/** 
* 转化为弧度(rad)
* */
private double rad(double d)
{
return d * Math.PI / 180.0;
}


/**
* 基于googleMap中的算法得到两经纬度之间的距离,计算精度与谷歌地图的距离精度差不多,相差范围在0.2米以下
* @param lon1 第一点的精度
* @param lat1 第一点的纬度
* @param lon2 第二点的精度
* @param lat3 第二点的纬度
* @return 返回的距离,单位km
* */
public double getDistance(double lon1,double lat1,double lon2, double lat2)
{
double radLat1 = rad(lat1);
double radLat2 = rad(lat2);
double a = radLat1 - radLat2;
double b = rad(lon1) - rad(lon2);
double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a/2),2)+Math.cos(radLat1)*Math.cos(radLat2)*Math.pow(Math.sin(b/2),2)));
s = s * EARTH_RADIUS;
s = s / 1000;
return s;
}
private static final double EARTH_RADIUS = 6378137;//赤道半径(单位m)


5、将得到的距离float类型保留一位小数

DecimalFormat df=new DecimalFormat(".#");//保留一位小数
String temp = df.format(distance); //保留一位小数