我想通过latlng获得从A到B的距离.当我使用以下代码运行我的应用程序时,它返回错误的结果.Fx我尝试了A(31.172740,115.0081630),然后是B(30.6055980,114.3603140),结果是大约3111km.但是正确的距离是大约134km.我的代码是:
class btnListener implements OnClickListener{
public void onClick(View v) {
lat_a=lat_A.getText().toString();
lng_a=lng_A.getText().toString();
lat_b=lat_B.getText().toString();
lng_b=lng_B.getText().toString();
double a1,n1,a2,n2;
a1=30.6055980;
a2=Double.parseDouble(lat_b);
n2=Double.parseDouble(lng_b);
double R=6371;
double D=Math.acos(Math.sin(a1)*Math.sin(a2)+Math.cos(a1)*Math.cos(a2)*Math.cos(n2-n1));
Toast.makeText(getApplication(), "the distance is"+String.valueOf(D*R)+"km from A to B", Toast.LENGTH_SHORT).show();
}
}
Run Code Online (Sandbox Code Playgroud)
jee*_*eet 66
android本身提供了一个api来获取两点之间的距离.使用:
Location.distanceBetween(
startLatitude,
startLongitude,
endLatitude,
endLongitude,
results);
Run Code Online (Sandbox Code Playgroud)
以米为单位返回距离.
Yug*_*abu 12
试试下面的代码.
public float distance (float lat_a, float lng_a, float lat_b, float lng_b )
{
double earthRadius = 3958.75;
double latDiff = Math.toRadians(lat_b-lat_a);
double lngDiff = Math.toRadians(lng_b-lng_a);
double a = Math.sin(latDiff /2) * Math.sin(latDiff /2) +
Math.cos(Math.toRadians(lat_a)) * Math.cos(Math.toRadians(lat_b)) *
Math.sin(lngDiff /2) * Math.sin(lngDiff /2);
double c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
double distance = earthRadius * c;
int meterConversion = 1609;
return new Float(distance * meterConversion).floatValue();
}
Run Code Online (Sandbox Code Playgroud)
如果您不理解,请查看此链接,此处提供相同的代码.
dil*_*nte 10
LatLng startLatLng = new LatLng(startLatitude, startLongitude);
LatLng endLatLng = new LatLng(endLatitude, endLongitude)
double distance = SphericalUtil.computeDistanceBetween(startLatLng, endLatLng);
Run Code Online (Sandbox Code Playgroud)
还添加
compile 'com.google.android.gms:play-services-maps:15.0.1'
compile 'com.google.maps.android:android-maps-utils:0.5+'
Run Code Online (Sandbox Code Playgroud)
你的gradle依赖
距离(米)
| 归档时间: |
|
| 查看次数: |
26234 次 |
| 最近记录: |