我正在尝试创建一个函数,以便根据我所在的位置和其余点返回地图上各个点之间的距离。
但是这样可以得到在数据库的第一个点得到的距离。
你可以帮帮我吗?
if (cursor.getCount() > 0) {
if (cursor != null && cursor.moveToFirst()) {
lat_s = >cursor.getString(cursor.getColumnIndex("latitude"));
lng_s = >cursor.getString(cursor.getColumnIndex("longitude"));
lat_p = Double.parseDouble(lat_s);
lng_p = Double.parseDouble(lng_s);
double dist = getDistancia(lat, lng, lat_p, lng_p);
}
@SuppressWarnings("deprecation")
SimpleCursorAdapter mAdapter = new SimpleCursorAdapter(this,
R.layout.list_row, cursor, from, to);
listView.setAdapter(mAdapter);
}
并且返回我距离的功能是:
public double getDistancia(double latitude, double longitude,
double latitudePto, double longitudePto){
double dlon, dlat, a, distancia;
dlon = longitudePto - longitude;
dlat = latitudePto - latitude;
a = Math.pow(Math.sin(dlat/2),2) + Math.cos(latitude) *
Math.cos(latitudePto) * Math.pow(Math.sin(dlon/2),2);
distancia = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
return 6378140 * distancia; /* 6378140 is the radius of the Earth in meters*/
}